亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? sei.c

?? h264標準的VC實現(xiàn)
?? C
?? 第 1 頁 / 共 4 頁
字號:

/*!
 ************************************************************************
 *  \file
 *     sei.c
 *  \brief
 *     implementation of SEI related functions
 *  \author(s)
 *      - Dong Tian                             <tian@cs.tut.fi>
 *
 ************************************************************************
 */

#include <stdlib.h>
#include <assert.h>
#include <memory.h>

#include "global.h"

#include "memalloc.h"
#include "rtp.h"
#include "mbuffer.h"
#include "sei.h"
#include "vlc.h"

Boolean seiHasTemporal_reference=FALSE;
Boolean seiHasClock_timestamp=FALSE;
Boolean seiHasPanscan_rect=FALSE;
Boolean seiHasBuffering_period=FALSE;
Boolean seiHasHrd_picture=FALSE;
Boolean seiHasFiller_payload=FALSE;
Boolean seiHasUser_data_registered_itu_t_t35=FALSE;
Boolean seiHasUser_data_unregistered=FALSE;
Boolean seiHasRandom_access_point=FALSE;
Boolean seiHasRef_pic_buffer_management_repetition=FALSE;
Boolean seiHasSpare_picture=FALSE;

Boolean seiHasSceneInformation=FALSE; // JVT-D099

Boolean seiHasSubseq_information=FALSE;
Boolean seiHasSubseq_layer_characteristics=FALSE;
Boolean seiHasSubseq_characteristics=FALSE;

/*
 ************************************************************************
 *  \basic functions on supplemental enhancement information
 *  \brief
 *     The implementations are based on FCD
 ************************************************************************
 */

//! sei_message[0]: this struct is to store the sei message packetized independently 
//! sei_message[1]: this struct is to store the sei message packetized together with slice data
sei_struct sei_message[2];

void InitSEIMessages()
{
  int i;
  for (i=0; i<2; i++)
  {
    sei_message[i].data = malloc(MAXRTPPAYLOADLEN);
    assert( sei_message[i].data != NULL );
    sei_message[i].subPacketType = SEI_PACKET_TYPE;
    clear_sei_message(i);
  }

  // init sei messages
  seiSparePicturePayload.data = NULL;
  InitSparePicture();
  InitSubseqChar();
  if (input->NumFramesInELSubSeq != 0)
    InitSubseqLayerInfo();
  InitSceneInformation(); // JVT-D099
  // init panscanrect sei message
  InitPanScanRectInfo();
  // init user_data_unregistered
  InitUser_data_unregistered();
  // init user_data_unregistered
  InitUser_data_registered_itu_t_t35();
  // init user_RandomAccess
  InitRandomAccess();
}

void CloseSEIMessages()
{
  int i;
  
  if (input->NumFramesInELSubSeq != 0)
    CloseSubseqLayerInfo();

  CloseSubseqChar();
  CloseSparePicture();
  CloseSceneInformation(); // JVT-D099
  //Shankar Regunathan Oct 2002
  ClosePanScanRectInfo();
  CloseUser_data_unregistered();
  CloseUser_data_registered_itu_t_t35();
  CloseRandomAccess();

  for (i=0; i<MAX_LAYER_NUMBER; i++)
  {
    if ( sei_message[i].data ) free( sei_message[i].data );
    sei_message[i].data = NULL;
  }
}

Boolean HaveAggregationSEI()
{
  if (sei_message[AGGREGATION_SEI].available && img->type != B_SLICE) 
    return TRUE;
  if (seiHasSubseqInfo)
    return TRUE;
  if (seiHasSubseqLayerInfo && img->number == 0)
    return TRUE;
  if (seiHasSubseqChar)
    return TRUE;
  if (seiHasSceneInformation) // JVT-D099
    return TRUE;
  if (seiHasPanScanRectInfo) // Shankar Regunathan Oct 2002
    return TRUE;
  if (seiHasUser_data_unregistered_info)
    return TRUE;
  if (seiHasUser_data_registered_itu_t_t35_info)
    return TRUE;
  if (seiHasRandomAccess_info)
    return TRUE;
  return FALSE;
//  return input->SparePictureOption && ( seiHasSpare_picture || seiHasSubseq_information || 
//    seiHasSubseq_layer_characteristics || seiHasSubseq_characteristics );
}

/*!
 ************************************************************************
 *  \brief
 *     write one sei payload to the sei message
 *  \param id
 *    0, if this is the normal packet\n
 *    1, if this is a aggregation packet
 *  \param payload
 *    a pointer that point to the sei payload. Note that the bitstream
 *    should have be byte aligned already. 
 *  \param payload_size
 *    the size of the sei payload
 *  \param payload_type
 *    the type of the sei payload
 *  \par Output
 *    the content of the sei message (sei_message[id]) is updated.
 ************************************************************************
 */
void write_sei_message(int id, byte* payload, int payload_size, int payload_type)
{
  int offset, type, size;
  assert(payload_type > SEI_ZERO && payload_type < SEI_MAX_ELEMENTS);

  type = payload_type;
  size = payload_size;
  offset = sei_message[id].payloadSize;

  while ( type > 255 )
  {
    sei_message[id].data[offset++] = 0xFF;
    type = type - 255;
  }
  sei_message[id].data[offset++] = type;

  while ( size > 255 )
  {
    sei_message[id].data[offset++] = 0xFF;
    size = size - 255;
  }
  sei_message[id].data[offset++] = size;

  memcpy(sei_message[id].data + offset, payload, payload_size);
  offset += payload_size;

  sei_message[id].payloadSize = offset;
}

/*!
 ************************************************************************
 *  \brief
 *     write rbsp_trailing_bits to the sei message
 *  \param id
 *    0, if this is the normal packet \n
 *    1, if this is a aggregation packet
 *  \par Output
 *    the content of the sei message is updated and ready for packetisation
 ************************************************************************
 */
void finalize_sei_message(int id)
{
  int offset = sei_message[id].payloadSize;

  sei_message[id].data[offset] = 0x80;
  sei_message[id].payloadSize++;

  sei_message[id].available = TRUE;
}

/*!
 ************************************************************************
 *  \brief
 *     empty the sei message buffer
 *  \param id
 *    0, if this is the normal packet \n
 *    1, if this is a aggregation packet
 *  \par Output
 *    the content of the sei message is cleared and ready for storing new 
 *      messages
 ************************************************************************
 */
void clear_sei_message(int id)
{
  memset( sei_message[id].data, 0, MAXRTPPAYLOADLEN);
  sei_message[id].payloadSize       = 0;
  sei_message[id].available         = FALSE;
}

/*!
 ************************************************************************
 *  \brief
 *     copy the bits from one bitstream buffer to another one
 *  \param dest
 *    pointer to the dest bitstream buffer
 *  \param source
 *    pointer to the source bitstream buffer
 *  \par Output
 *    the content of the dest bitstream is changed.
 ************************************************************************
 */
void AppendTmpbits2Buf( Bitstream* dest, Bitstream* source )
{
  int i, j;
  unsigned char mask;
  int bits_in_last_byte;

  // copy the first bytes in source buffer
  for (i=0; i<source->byte_pos; i++)
  {
    mask = 0x80;
    for (j=0; j<8; j++)
    {
      dest->byte_buf <<= 1;
      if (source->streamBuffer[i] & mask)
        dest->byte_buf |= 1;
      dest->bits_to_go--;
      mask >>= 1;
      if (dest->bits_to_go==0)
      {
        dest->bits_to_go = 8;
        dest->streamBuffer[dest->byte_pos++]=dest->byte_buf;
        dest->byte_buf = 0;
      }
    }
  }
  // copy the last byte, there are still (8-source->bits_to_go) bits in the source buffer
  bits_in_last_byte = 8-source->bits_to_go;
  if ( bits_in_last_byte > 0 )
  {
    mask = 1 << (bits_in_last_byte-1);
    for (j=0; j<bits_in_last_byte; j++)
    {
      dest->byte_buf <<= 1;
      if (source->byte_buf & mask)
        dest->byte_buf |= 1;
      dest->bits_to_go--;
      mask >>= 1;
      if (dest->bits_to_go==0)
      {
        dest->bits_to_go = 8;
        dest->streamBuffer[dest->byte_pos++]=dest->byte_buf;
        dest->byte_buf = 0;
      }
    }
  }
}

/*
 **++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 *  \functions on spare pictures
 *  \brief
 *     implementation of Spare Pictures related functions based on 
 *      JVT-D100
 *  \author
 *      Dong Tian                 <tian@cs.tut.fi>
 **++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 */

// global variables for spare pictures

// Tian Dong (Sept 2002)
// In current implementation, Sept 2002, the spare picture info is 
// paketized together with the immediately following frame. Thus we 
// define one set of global variables to save the info.
Boolean seiHasSparePicture = FALSE;
spare_picture_struct seiSparePicturePayload;

/*!
 ************************************************************************
 *  \brief
 *      Init the global variables for spare picture information
 ************************************************************************
 */
void InitSparePicture()
{
  if ( seiSparePicturePayload.data != NULL ) CloseSparePicture();

  seiSparePicturePayload.data = malloc( sizeof(Bitstream) );
  assert( seiSparePicturePayload.data != NULL );
  seiSparePicturePayload.data->streamBuffer = malloc(MAXRTPPAYLOADLEN);
  assert( seiSparePicturePayload.data->streamBuffer != NULL );
  memset( seiSparePicturePayload.data->streamBuffer, 0, MAXRTPPAYLOADLEN);
  seiSparePicturePayload.num_spare_pics = 0;
  seiSparePicturePayload.target_frame_num = 0;

  seiSparePicturePayload.data->bits_to_go  = 8;
  seiSparePicturePayload.data->byte_pos    = 0;
  seiSparePicturePayload.data->byte_buf    = 0;
}

/*!
 ************************************************************************
 *  \brief
 *      Close the global variables for spare picture information
 ************************************************************************
 */
void CloseSparePicture()
{
  if (seiSparePicturePayload.data->streamBuffer) 
    free(seiSparePicturePayload.data->streamBuffer);
  seiSparePicturePayload.data->streamBuffer = NULL;
  if (seiSparePicturePayload.data) 
    free(seiSparePicturePayload.data);
  seiSparePicturePayload.data = NULL;
  seiSparePicturePayload.num_spare_pics = 0;
  seiSparePicturePayload.target_frame_num = 0;
}

/*!
 ************************************************************************
 *  \brief
 *     Calculate the spare picture info, save the result in map_sp
 *      then compose the spare picture information.
 *  \par Output
 *      the spare picture payload is available in *seiSparePicturePayload*
 *      the syntax elements in the loop (see FCD), excluding the two elements
 *      at the beginning.
 ************************************************************************
 */
void CalculateSparePicture()
{
  /*
  int i, j, tmp, i0, j0, m;
  byte **map_sp;
  int delta_spare_frame_num;
  Bitstream *tmpBitstream;

  int num_of_mb=(img->height/16) * (img->width/16);
  int threshold1 = 16*16*input->SPDetectionThreshold;
  int threshold2 = num_of_mb * input->SPPercentageThreshold / 100;
  int ref_area_indicator;
  int CandidateSpareFrameNum, SpareFrameNum;
  int possible_spare_pic_num;

  // define it for debug purpose
  #define WRITE_MAP_IMAGE

#ifdef WRITE_MAP_IMAGE
  byte **y;
  int k;
  FILE* fp;
  static int first = 1;
  char map_file_name[255]="map.yuv";
#endif

  // basic check
  if (fb->picbuf_short[0]->used==0 || fb->picbuf_short[1]->used==0)
  { 
#ifdef WRITE_MAP_IMAGE
    fp = fopen( map_file_name, "wb" );
    assert( fp != NULL );
    // write the map image
    for (i=0; i < img->height; i++)
      for (j=0; j < img->width; j++)
        fputc(0, fp);

    for (k=0; k < 2; k++)
      for (i=0; i < img->height/2; i++)
        for (j=0; j < img->width/2; j++)
          fputc(128, fp);
    fclose( fp );
#endif
    seiHasSparePicture = FALSE;
    return;
  }
  seiHasSparePicture = TRUE;

  // set the global bitstream memory. 
  InitSparePicture();
  seiSparePicturePayload.target_frame_num = img->number % MAX_FN;
  // init the local bitstream memory.
  tmpBitstream = malloc(sizeof(Bitstream));
  assert( tmpBitstream != NULL );
  tmpBitstream->streamBuffer = malloc(MAXRTPPAYLOADLEN);
  assert( tmpBitstream->streamBuffer != NULL );
  memset( tmpBitstream->streamBuffer, 0, MAXRTPPAYLOADLEN);

#ifdef WRITE_MAP_IMAGE
  if ( first )
  {
    fp = fopen( map_file_name, "wb" );
    first = 0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品高清在线观看| 激情综合一区二区三区| 人人精品人人爱| 色综合久久九月婷婷色综合| 日韩欧美在线网站| 亚洲国产精品久久不卡毛片| 成人美女视频在线观看| 日韩一级二级三级精品视频| 亚洲精品中文字幕在线观看| 国产成人在线影院| 欧美一区二区三区色| 一区二区三区不卡在线观看| 成人av小说网| 国产视频一区二区在线| 热久久久久久久| 欧美日韩的一区二区| 亚洲女人****多毛耸耸8| 成人综合婷婷国产精品久久 | jiyouzz国产精品久久| 日韩欧美精品三级| 视频一区在线播放| 欧美乱妇一区二区三区不卡视频| 亚洲欧美色一区| caoporm超碰国产精品| 国产日韩成人精品| 国产超碰在线一区| 久久久美女艺术照精彩视频福利播放| 久草这里只有精品视频| 日韩精品一区二区三区在线 | 亚洲综合精品自拍| 91丝袜国产在线播放| 韩国av一区二区三区四区| 欧美日韩一区中文字幕| 午夜精品福利在线| 538prom精品视频线放| 奇米色一区二区| 日韩欧美视频一区| 高清国产一区二区| 国产精品久久久久精k8| 色偷偷久久一区二区三区| 亚洲精品视频一区| 欧美日韩免费一区二区三区视频| 亚洲资源在线观看| 91精品午夜视频| 国模娜娜一区二区三区| 欧美激情中文字幕| 91搞黄在线观看| 日韩电影免费在线| 久久久久久久久久美女| 不卡电影一区二区三区| 亚洲一区二区黄色| 日韩精品一区二区三区在线观看| 国产大陆亚洲精品国产| 亚洲免费毛片网站| 日韩欧美精品三级| 成人app网站| 日韩精品91亚洲二区在线观看| 日韩免费视频一区二区| www.爱久久.com| 天堂久久一区二区三区| 久久午夜羞羞影院免费观看| 99精品久久免费看蜜臀剧情介绍| 亚洲午夜激情av| 国产区在线观看成人精品| 色婷婷亚洲精品| 欧美一区二区三区四区久久 | 美女视频一区二区| 中文字幕+乱码+中文字幕一区| 在线观看成人小视频| 久久爱另类一区二区小说| 成人免费视频在线观看| 666欧美在线视频| eeuss鲁片一区二区三区在线看| 日韩在线一二三区| 中文字幕在线一区二区三区| 欧美日本一区二区三区四区| 国产精品12区| 三级不卡在线观看| 一区二区三区欧美久久| 久久夜色精品国产噜噜av | 日韩一区二区免费在线观看| 成人激情视频网站| 美腿丝袜亚洲一区| 亚洲黄色小说网站| 国产午夜精品一区二区三区嫩草| 欧美日免费三级在线| 99热精品一区二区| 国产一区二区三区精品欧美日韩一区二区三区 | 视频一区视频二区中文| 亚洲欧美综合色| 久久久久久久久蜜桃| 欧美一区永久视频免费观看| 91网站在线播放| 懂色av中文字幕一区二区三区| 日韩经典一区二区| 亚洲一线二线三线视频| 国产精品久久毛片av大全日韩| 日韩欧美中文字幕制服| 欧美日韩国产天堂| 在线一区二区三区| 91免费观看国产| 不卡一区二区在线| 成人视屏免费看| 精品中文字幕一区二区| 天天色图综合网| 亚洲成人免费av| 亚洲午夜日本在线观看| 亚洲欧美aⅴ...| 一区二区三区在线观看动漫| 国产精品久久久久久久久久久免费看| 久久久www成人免费毛片麻豆| 精品久久人人做人人爱| 日韩精品一区二区三区视频 | 美女网站色91| 免费一区二区视频| 日韩av电影免费观看高清完整版 | 国产91富婆露脸刺激对白| 久久国产生活片100| 久久er99精品| 国产精品69毛片高清亚洲| 激情综合色丁香一区二区| 久久99精品一区二区三区 | 首页国产丝袜综合| 日韩精品电影在线| 玖玖九九国产精品| 国产精品一区二区你懂的| 国产黑丝在线一区二区三区| 高清国产午夜精品久久久久久| 国产成人免费视频网站| av影院午夜一区| 在线观看一区二区视频| 91精品中文字幕一区二区三区| 日韩三级高清在线| 国产精品视频你懂的| 亚洲人成影院在线观看| 亚洲一级电影视频| 久久成人羞羞网站| eeuss鲁片一区二区三区在线观看| 欧洲国内综合视频| 欧美sm极限捆绑bd| 国产精品国产精品国产专区不片 | 综合在线观看色| 亚洲成人三级小说| 国产精品影视天天线| 色综合中文字幕| 欧美一级二级在线观看| 久久亚洲免费视频| 一区二区三区精品在线| 毛片av一区二区三区| 成人午夜视频网站| 欧美美女直播网站| 中文一区一区三区高中清不卡| 亚洲丶国产丶欧美一区二区三区| 在线播放视频一区| 国产日韩欧美综合一区| 亚洲午夜精品久久久久久久久| 久久99精品久久久久| 色妹子一区二区| 欧美精品一区二区三区蜜臀| 亚洲免费成人av| 国产自产视频一区二区三区| 色噜噜偷拍精品综合在线| 久久亚区不卡日本| 五月天网站亚洲| 91视视频在线直接观看在线看网页在线看 | 亚洲日本韩国一区| 国产一区二区在线观看视频| 欧美三级日韩在线| 中文字幕第一区| 狠狠网亚洲精品| 欧美日韩免费观看一区二区三区 | 精品久久人人做人人爰| 亚洲精品视频一区二区| 国产成人午夜99999| 7777精品伊人久久久大香线蕉超级流畅| 国产精品欧美极品| 国产一区二区在线观看免费| 91精品在线免费| 亚洲国产精品一区二区www在线| 不卡一区二区三区四区| www久久精品| 久久国产综合精品| 91精品在线一区二区| 亚洲亚洲精品在线观看| 一本高清dvd不卡在线观看| 国产精品视频在线看| 国产盗摄一区二区三区| 久久一日本道色综合| 国模无码大尺度一区二区三区| 欧美巨大另类极品videosbest| 亚洲线精品一区二区三区| 色狠狠色噜噜噜综合网| 玉米视频成人免费看| 色婷婷综合久色| 一区二区三区丝袜| 在线观看www91| 亚洲二区在线观看| 欧美疯狂做受xxxx富婆| 婷婷六月综合网| 91精品国产综合久久久久|