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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sei.c

?? jm_frext22.ZIP的壓縮文件,主要用于嵌入式系統圖象的編解碼的開發.
?? C
?? 第 1 頁 / 共 4 頁
字號:
      fp = fopen( filename, "ab" );
    assert( fp != NULL );
    for (kk=0; kk<num_spare_pics; kk++)
    {
      for (i=0; i < img->height/16; i++)
        for (j=0; j < img->width/16; j++)
        {
          tmp=map[kk][i][j]==0? img->max_imgpel_value : 0;
          for (i0=0; i0<16; i0++)
            for (j0=0; j0<16; j0++)
              Y[i*16+i0][j*16+j0]=tmp;
        }

      // write the map image
      for (i=0; i < img->height; i++)
        for (j=0; j < img->width; j++)
          fwrite(&(Y[i][j]), symbol_size_in_bytes, 1, p_out);
        
      for (k=0; k < 2; k++)
        for (i=0; i < img->height/2; i++)
          for (j=0; j < img->width/2; j++)
            fwrite(&(img->dc_pred_value), symbol_size_in_bytes, 1, p_out);
    }
    fclose( fp );
    free_mem2Dnew( Y, sizeof(imgpel));
  }
  // end of writing map image
#undef WRITE_MAP_IMAGE
#endif

  free_mem3D( map, num_spare_pics );

  free(buf);
}


/*!
 ************************************************************************
 *  \brief
 *     Interpret the Sub-sequence information SEI message
 *  \param payload
 *     a pointer that point to the sei payload
 *  \param size
 *     the size of the sei message
 *  \param img
 *     the image pointer
 *    
 ************************************************************************
 */
void interpret_subsequence_info( byte* payload, int size, ImageParameters *img )
{
  Bitstream* buf;
  int sub_seq_layer_num, sub_seq_id, first_ref_pic_flag, leading_non_ref_pic_flag, last_pic_flag, 
      sub_seq_frame_num_flag, sub_seq_frame_num;

  buf = malloc(sizeof(Bitstream));
  buf->bitstream_length = size;
  buf->streamBuffer = payload;
  buf->frame_bitoffset = 0;

  UsedBits = 0;

  sub_seq_layer_num        = ue_v("SEI: sub_seq_layer_num"       , buf);
  sub_seq_id               = ue_v("SEI: sub_seq_id"              , buf);
  first_ref_pic_flag       = u_1 ("SEI: first_ref_pic_flag"      , buf);
  leading_non_ref_pic_flag = u_1 ("SEI: leading_non_ref_pic_flag", buf);
  last_pic_flag            = u_1 ("SEI: last_pic_flag"           , buf);
  sub_seq_frame_num_flag   = u_1 ("SEI: sub_seq_frame_num_flag"  , buf);
  if (sub_seq_frame_num_flag)
  {
    sub_seq_frame_num        = ue_v("SEI: sub_seq_frame_num"       , buf);
  }

#ifdef PRINT_SUBSEQUENCE_INFO
  printf("Sub-sequence information SEI message\n");
  printf("sub_seq_layer_num        = %d\n", sub_seq_layer_num );
  printf("sub_seq_id               = %d\n", sub_seq_id);
  printf("first_ref_pic_flag       = %d\n", first_ref_pic_flag);
  printf("leading_non_ref_pic_flag = %d\n", leading_non_ref_pic_flag);
  printf("last_pic_flag            = %d\n", last_pic_flag);
  printf("sub_seq_frame_num_flag   = %d\n", sub_seq_frame_num_flag);
  if (sub_seq_frame_num_flag)
  {
    printf("sub_seq_frame_num        = %d\n", sub_seq_frame_num);
  }
#endif

  free(buf);
#ifdef PRINT_SUBSEQUENCE_INFO
#undef PRINT_SUBSEQUENCE_INFO
#endif
}

/*!
 ************************************************************************
 *  \brief
 *     Interpret the Sub-sequence layer characteristics SEI message
 *  \param payload
 *     a pointer that point to the sei payload
 *  \param size
 *     the size of the sei message
 *  \param img
 *     the image pointer
 *    
 ************************************************************************
 */
void interpret_subsequence_layer_characteristics_info( byte* payload, int size, ImageParameters *img )
{
  Bitstream* buf;
  long num_sub_layers, accurate_statistics_flag, average_bit_rate, average_frame_rate;
  int i;

  buf = malloc(sizeof(Bitstream));
  buf->bitstream_length = size;
  buf->streamBuffer = payload;
  buf->frame_bitoffset = 0;

  UsedBits = 0;

  num_sub_layers = 1 + ue_v("SEI: num_sub_layers_minus1", buf);

#ifdef PRINT_SUBSEQUENCE_LAYER_CHAR
  printf("Sub-sequence layer characteristics SEI message\n");
  printf("num_sub_layers_minus1 = %d\n", num_sub_layers - 1);
#endif

  for (i=0; i<num_sub_layers; i++)
  {
    accurate_statistics_flag = u_1(   "SEI: accurate_statistics_flag", buf);
    average_bit_rate         = u_v(16,"SEI: average_bit_rate"        , buf);
    average_frame_rate       = u_v(16,"SEI: average_frame_rate"      , buf);

#ifdef PRINT_SUBSEQUENCE_LAYER_CHAR
    printf("layer %d: accurate_statistics_flag = %ld \n", i, accurate_statistics_flag);
    printf("layer %d: average_bit_rate         = %ld \n", i, average_bit_rate);
    printf("layer %d: average_frame_rate       = %ld \n", i, average_frame_rate);
#endif
  }
  free (buf);
}


/*!
 ************************************************************************
 *  \brief
 *     Interpret the Sub-sequence characteristics SEI message
 *  \param payload
 *     a pointer that point to the sei payload
 *  \param size
 *     the size of the sei message
 *  \param img
 *     the image pointer
 *    
 ************************************************************************
 */
void interpret_subsequence_characteristics_info( byte* payload, int size, ImageParameters *img )
{
  Bitstream* buf;
  int i;
  int sub_seq_layer_num, sub_seq_id, duration_flag, average_rate_flag, accurate_statistics_flag;
  unsigned long sub_seq_duration, average_bit_rate, average_frame_rate;
  int num_referenced_subseqs, ref_sub_seq_layer_num, ref_sub_seq_id, ref_sub_seq_direction;

  buf = malloc(sizeof(Bitstream));
  buf->bitstream_length = size;
  buf->streamBuffer = payload;
  buf->frame_bitoffset = 0;

  UsedBits = 0;

  sub_seq_layer_num = ue_v("SEI: sub_seq_layer_num", buf);
  sub_seq_id        = ue_v("SEI: sub_seq_id", buf);
  duration_flag     = u_1 ("SEI: duration_flag", buf);

#ifdef PRINT_SUBSEQUENCE_CHAR
  printf("Sub-sequence characteristics SEI message\n");
  printf("sub_seq_layer_num = %d\n", sub_seq_layer_num );
  printf("sub_seq_id        = %d\n", sub_seq_id);
  printf("duration_flag     = %d\n", duration_flag);
#endif

  if ( duration_flag )
  {
    sub_seq_duration = u_v (32, "SEI: duration_flag", buf);
#ifdef PRINT_SUBSEQUENCE_CHAR
    printf("sub_seq_duration = %ld\n", sub_seq_duration);
#endif
  }

  average_rate_flag = u_1 ("SEI: average_rate_flag", buf);

#ifdef PRINT_SUBSEQUENCE_CHAR
  printf("average_rate_flag = %d\n", average_rate_flag);
#endif

  if ( average_rate_flag )
  {
    accurate_statistics_flag = u_1 (    "SEI: accurate_statistics_flag", buf);
    average_bit_rate         = u_v (16, "SEI: average_bit_rate", buf);
    average_frame_rate       = u_v (16, "SEI: average_frame_rate", buf);

#ifdef PRINT_SUBSEQUENCE_CHAR
    printf("accurate_statistics_flag = %d\n", accurate_statistics_flag);
    printf("average_bit_rate         = %ld\n", average_bit_rate);
    printf("average_frame_rate       = %ld\n", average_frame_rate);
#endif
  }

  num_referenced_subseqs  = ue_v("SEI: num_referenced_subseqs", buf);

#ifdef PRINT_SUBSEQUENCE_CHAR
  printf("num_referenced_subseqs = %d\n", num_referenced_subseqs);
#endif

  for (i=0; i<num_referenced_subseqs; i++)
  {
    ref_sub_seq_layer_num  = ue_v("SEI: ref_sub_seq_layer_num", buf);
    ref_sub_seq_id         = ue_v("SEI: ref_sub_seq_id", buf);
    ref_sub_seq_direction  = u_1 ("SEI: ref_sub_seq_direction", buf);

#ifdef PRINT_SUBSEQUENCE_CHAR
    printf("ref_sub_seq_layer_num = %d\n", ref_sub_seq_layer_num);
    printf("ref_sub_seq_id        = %d\n", ref_sub_seq_id);
    printf("ref_sub_seq_direction = %d\n", ref_sub_seq_direction);
#endif
  }

  free( buf );
#ifdef PRINT_SUBSEQUENCE_CHAR
#undef PRINT_SUBSEQUENCE_CHAR
#endif
}


/*!
 ************************************************************************
 *  \brief
 *     Interpret the Scene information SEI message
 *  \param payload
 *     a pointer that point to the sei payload
 *  \param size
 *     the size of the sei message
 *  \param img
 *     the image pointer
 *    
 ************************************************************************
 */
void interpret_scene_information( byte* payload, int size, ImageParameters *img )
{
  Bitstream* buf;
  int scene_id, scene_transition_type, second_scene_id;

  buf = malloc(sizeof(Bitstream));
  buf->bitstream_length = size;
  buf->streamBuffer = payload;
  buf->frame_bitoffset = 0;

  UsedBits = 0;

  scene_id              = ue_v("SEI: scene_id"             , buf);
  scene_transition_type = ue_v("SEI: scene_transition_type", buf);
  if ( scene_transition_type > 3 )
  {
    second_scene_id     = ue_v("SEI: scene_transition_type", buf);;
  }

#ifdef PRINT_SCENE_INFORMATION
  printf("Scene information SEI message\n");
  printf("scene_transition_type = %d\n", scene_transition_type);
  printf("scene_id              = %d\n", scene_id);
  if ( scene_transition_type > 3 )
  {
    printf("second_scene_id       = %d\n", second_scene_id);
  }
#endif
  free( buf );
#ifdef PRINT_SCENE_INFORMATION
#undef PRINT_SCENE_INFORMATION
#endif
}


/*!
 ************************************************************************
 *  \brief
 *     Interpret the Filler payload SEI message
 *  \param payload
 *     a pointer that point to the sei payload
 *  \param size
 *     the size of the sei message
 *  \param img
 *     the image pointer
 *    
 ************************************************************************
 */
void interpret_filler_payload_info( byte* payload, int size, ImageParameters *img )
{
  int  offset = 0;
  byte payload_cnt = 0;

  while (offset<size)
  {
    if (payload[offset] == 0xFF)
    {
       payload_cnt++;
    }
  }


#ifdef PRINT_FILLER_PAYLOAD_INFO
  printf("Filler payload SEI message\n");
  if (payload_cnt==size)
  {
    printf("read %d bytes of filler payload\n", payload_cnt);
  }
  else
  {
    printf("error reading filler payload: not all bytes are 0xFF (%d of %d)\n", payload_cnt, size);
  }
#endif

#ifdef PRINT_FILLER_PAYLOAD_INFO
#undef PRINT_FILLER_PAYLOAD_INFO
#endif
}


/*!
 ************************************************************************
 *  \brief
 *     Interpret the User data unregistered SEI message
 *  \param payload
 *     a pointer that point to the sei payload
 *  \param size
 *     the size of the sei message
 *  \param img
 *     the image pointer
 *    
 ************************************************************************
 */
void interpret_user_data_unregistered_info( byte* payload, int size, ImageParameters *img )
{
  int offset = 0;
  byte payload_byte;

#ifdef PRINT_USER_DATA_UNREGISTERED_INFO
  printf("User data unregistered SEI message\n");
  printf("uuid_iso_11578 = 0x");
#endif
  assert (size>=16);

  for (offset = 0; offset < 16; offset++)
  {
#ifdef PRINT_USER_DATA_UNREGISTERED_INFO
    printf("%02x",payload[offset]);
#endif
  }

#ifdef PRINT_USER_DATA_UNREGISTERED_INFO
    printf("\n");
#endif

  while (offset < size)
  {
    payload_byte = payload[offset];
    offset ++;
#ifdef PRINT_USER_DATA_UNREGISTERED_INFO
    printf("Unreg data payload_byte = %d\n", payload_byte);
#endif
  }
#ifdef PRINT_USER_DATA_UNREGISTERED_INFO
#undef PRINT_USER_DATA_UNREGISTERED_INFO
#endif
}


/*!
 ************************************************************************
 *  \brief
 *     Interpret the User data registered by ITU-T T.35 SEI message
 *  \param payload
 *     a pointer that point to the sei payload
 *  \param size

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区四区视频 | 欧美日韩一区三区| 91超碰这里只有精品国产| 久久蜜桃香蕉精品一区二区三区| 最新国产成人在线观看| 图片区日韩欧美亚洲| 国产v综合v亚洲欧| 欧美xxxxx裸体时装秀| 亚洲精品日韩一| 成人免费看视频| 日韩免费福利电影在线观看| 亚洲精品免费播放| 成人一区二区三区中文字幕| 日韩女优av电影| 亚瑟在线精品视频| 91网站最新地址| 国产精品美女视频| 国产乱理伦片在线观看夜一区| 欧美日韩精品是欧美日韩精品| 国产精品大尺度| 粉嫩嫩av羞羞动漫久久久| 欧美成人a在线| 激情综合色播五月| 日韩欧美成人激情| 蜜臀久久久久久久| 欧美日韩成人综合| 亚洲精品国产成人久久av盗摄| 国产69精品久久久久777| 精品国产乱码久久久久久夜甘婷婷| 亚洲一区二区偷拍精品| 色悠悠久久综合| 日韩伦理电影网| 91丨porny丨首页| 亚洲精品欧美激情| 在线观看亚洲专区| 天天综合天天综合色| 在线播放欧美女士性生活| 亚洲电影在线免费观看| 欧美日韩精品一区二区天天拍小说 | 欧美日韩亚洲国产综合| 亚洲精品老司机| 欧美在线观看一二区| 五月激情综合婷婷| 精品入口麻豆88视频| 韩国av一区二区三区| 欧美不卡视频一区| 精品影视av免费| 久久久国产精品午夜一区ai换脸| 国产馆精品极品| 国产精品久久一级| 91网站在线播放| 日韩在线卡一卡二| 亚洲精品一区二区三区精华液| 国产一区欧美一区| 国产欧美一区二区精品性色| 91免费视频观看| 香港成人在线视频| 久久亚洲欧美国产精品乐播 | 国产亚洲欧美激情| 成人va在线观看| 一区二区三区四区亚洲| 欧美日韩免费观看一区三区| 免费日本视频一区| 国产亚洲欧美色| 色综合久久66| 青青草国产精品亚洲专区无| 久久免费看少妇高潮| 不卡区在线中文字幕| 国产 欧美在线| 亚洲自拍与偷拍| 国产日韩亚洲欧美综合| 91在线看国产| 日本欧美一区二区| 亚洲视频1区2区| 久久噜噜亚洲综合| 精品视频999| 成人晚上爱看视频| 日本美女视频一区二区| 国产三区在线成人av| 欧美美女喷水视频| 成人美女在线观看| 麻豆视频观看网址久久| 国产精品毛片高清在线完整版| 欧美二区三区的天堂| 91丝袜美女网| 成人午夜短视频| 九色|91porny| 丝袜a∨在线一区二区三区不卡| 国产欧美日韩精品一区| 91精品国产一区二区三区蜜臀| 韩国一区二区视频| 国产精品日产欧美久久久久| 国产成人精品午夜视频免费 | 色综合久久综合| 国产中文字幕一区| 天堂影院一区二区| 国产精品视频一二三| 日韩亚洲欧美一区| 国产精品黄色在线观看| 3751色影院一区二区三区| 在线观看欧美日本| 91麻豆123| 国产成人精品亚洲777人妖| 精品一区二区在线看| 日韩福利电影在线观看| 亚洲国产sm捆绑调教视频| 中文字幕一区二区三区四区| 欧美激情综合在线| 国产日韩精品一区| 久久综合九色综合97婷婷| 4hu四虎永久在线影院成人| 欧美日韩亚洲综合在线| 色诱亚洲精品久久久久久| 99精品国产99久久久久久白柏| 国产精品一区二区三区99| 韩国一区二区三区| 国模娜娜一区二区三区| 久久精品99久久久| 久久精品国产精品亚洲精品| 日本特黄久久久高潮| 日韩福利电影在线| 久久精品国内一区二区三区| 裸体健美xxxx欧美裸体表演| 开心九九激情九九欧美日韩精美视频电影 | 亚洲午夜视频在线观看| 亚洲欧美激情插| 亚洲一区二区三区在线看| 亚洲va国产va欧美va观看| 亚洲一区二区美女| 日产国产欧美视频一区精品| 亚洲第一在线综合网站| 美日韩一区二区| 国产精品88av| 99精品欧美一区二区蜜桃免费| 色综合久久中文综合久久97 | 91视频免费观看| 欧美性大战xxxxx久久久| 日韩视频永久免费| 久久久久久久久久久久电影| 国产三级欧美三级| 一区二区三区成人在线视频| 亚洲成a人片在线不卡一二三区| 老司机免费视频一区二区| 国产精品69久久久久水密桃| 一本到三区不卡视频| 91精品国产综合久久国产大片| 久久亚洲综合色| 国产乱妇无码大片在线观看| 成人国产视频在线观看| 欧美日韩美女一区二区| 精品久久久三级丝袜| 国产精品久久久久久久久动漫| 一区二区三区在线视频播放| 日本欧美久久久久免费播放网| 成人一级视频在线观看| 欧美日韩国产欧美日美国产精品| 2024国产精品| 亚洲成a人片在线不卡一二三区| 国产精品18久久久久久久久久久久 | 丁香六月久久综合狠狠色| 欧美在线一区二区三区| 久久综合色8888| 亚洲国产精品人人做人人爽| 国产精品影视网| 欧美精品久久久久久久多人混战| 国产欧美日韩不卡免费| 男人的天堂亚洲一区| 在线观看亚洲a| 国产精品美女久久久久aⅴ国产馆| 日韩激情一二三区| 91麻豆swag| 国产精品初高中害羞小美女文| 免费在线欧美视频| 欧美伊人精品成人久久综合97| 久久精品男人的天堂| 免费av网站大全久久| 欧美视频日韩视频在线观看| 国产精品麻豆99久久久久久| 美女一区二区三区| 欧美精品一二三| 中文字幕一区av| 国产91在线看| 久久精品人人做人人综合| 久久国产三级精品| 欧美日韩色一区| 尤物在线观看一区| 99综合影院在线| 国产精品萝li| 国产成人精品免费在线| 久久精品网站免费观看| 黄色日韩网站视频| 精品国产一区二区亚洲人成毛片| 亚洲国产精品久久艾草纯爱| 97精品电影院| 亚洲黄色免费网站| 精品视频资源站| 三级精品在线观看| 欧美精品自拍偷拍动漫精品| 亚洲国产精品视频| 欧美一区二区视频在线观看2020|