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

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

?? vlc.c

?? G729、h263、h264、MPEG4四種最流行的音頻和視頻標準的壓縮和解壓算法的源代碼.rar
?? C
?? 第 1 頁 / 共 3 頁
字號:
  code = 1;
  frame_bitoffset += len;

  if (len < 15)
  {
    sign = (len - 1) & 1;
    level = (len-1) / 2 + 1;
  }
  else if (len == 15)
  {
    // escape code
    code = (code << 4) | ShowBits(buf, frame_bitoffset, BitstreamLengthInBytes, 4);
    len += 4;
    frame_bitoffset += 4;
    sign = (code & 1);
    level = ((code >> 1) & 0x7) + 8;
  }
  else if (len == 16)
  {
    // escape code
    code = (code << 12) | ShowBits(buf, frame_bitoffset, BitstreamLengthInBytes, 12);
    len += 12;
    frame_bitoffset += 12;
    sign =  (code & 1);
    level = ((code >> 1) & 0x7ff) + 16;
  }
  else
  {
    printf("ERROR reading Level code\n");
    exit(-1);
  }

  if (sign)
    level = -level;

  sym->inf = level;
  sym->len = len;

#if TRACE
  tracebits2(sym->tracestring, sym->len, code);
#endif
  currStream->frame_bitoffset = frame_bitoffset;
  return 0;

}

/*!
 ************************************************************************
 * \brief
 *    read Level VLC codeword from UVLC-partition 
 ************************************************************************
 */
int readSyntaxElement_Level_VLCN(SyntaxElement *sym, int vlc, struct datapartition *dP)  
{
  
  Bitstream   *currStream = dP->bitstream;
  int frame_bitoffset = currStream->frame_bitoffset;
  byte *buf = currStream->streamBuffer;
  int BitstreamLengthInBytes = currStream->bitstream_length;
  
  int levabs, sign;
  int len = 0;
  int code, sb;
  
  int numPrefix;
  int shift = vlc-1;
  int escape = (15<<shift)+1;
  
  // read pre zeros
  numPrefix = 0;
  while (!ShowBits(buf, frame_bitoffset+numPrefix, BitstreamLengthInBytes, 1))
    numPrefix++;
  
  
  len = numPrefix+1;
  code = 1;
  
  if (numPrefix < 15)
  {
    levabs = (numPrefix<<shift) + 1;
    
    // read (vlc-1) bits -> suffix
    if (vlc-1)
    {
      sb =  ShowBits(buf, frame_bitoffset+len, BitstreamLengthInBytes, vlc-1);
      code = (code << (vlc-1) )| sb;
      levabs += sb;
      len += (vlc-1);
    }
    
    // read 1 bit -> sign
    sign = ShowBits(buf, frame_bitoffset+len, BitstreamLengthInBytes, 1);
    code = (code << 1)| sign;
    len ++;
  }
  else  // escape
  {
    // read 11 bits -> levabs
    // levabs += escape
    sb = ShowBits(buf, frame_bitoffset+len, BitstreamLengthInBytes, 11);
    code = (code << 11 )| sb;
    
    levabs =  sb + escape;
    len+=11;
    
    // read 1 bit -> sign
    sign = ShowBits(buf, frame_bitoffset+len, BitstreamLengthInBytes, 1);
    code = (code << 1)| sign;
    len++;
  }
  
  sym->inf = (sign)?-levabs:levabs;
  sym->len = len;
  
  currStream->frame_bitoffset = frame_bitoffset+len;
  
#if TRACE
  tracebits2(sym->tracestring, sym->len, code);
#endif
  
  return 0;
}

/*!
 ************************************************************************
 * \brief
 *    read Total Zeros codeword from UVLC-partition 
 ************************************************************************
 */
int readSyntaxElement_TotalZeros(SyntaxElement *sym,  DataPartition *dP)
{
  int vlcnum, retval;
  int code, *ct, *lt;

  int lentab[TOTRUN_NUM][16] = 
  {
    
    { 1,3,3,4,4,5,5,6,6,7,7,8,8,9,9,9},  
    { 3,3,3,3,3,4,4,4,4,5,5,6,6,6,6},  
    { 4,3,3,3,4,4,3,3,4,5,5,6,5,6},  
    { 5,3,4,4,3,3,3,4,3,4,5,5,5},  
    { 4,4,4,3,3,3,3,3,4,5,4,5},  
    { 6,5,3,3,3,3,3,3,4,3,6},  
    { 6,5,3,3,3,2,3,4,3,6},  
    { 6,4,5,3,2,2,3,3,6},  
    { 6,6,4,2,2,3,2,5},  
    { 5,5,3,2,2,2,4},  
    { 4,4,3,3,1,3},  
    { 4,4,2,1,3},  
    { 3,3,1,2},  
    { 2,2,1},  
    { 1,1},  
  };

  int codtab[TOTRUN_NUM][16] = 
  {
    {1,3,2,3,2,3,2,3,2,3,2,3,2,3,2,1},
    {7,6,5,4,3,5,4,3,2,3,2,3,2,1,0},
    {5,7,6,5,4,3,4,3,2,3,2,1,1,0},
    {3,7,5,4,6,5,4,3,3,2,2,1,0},
    {5,4,3,7,6,5,4,3,2,1,1,0},
    {1,1,7,6,5,4,3,2,1,1,0},
    {1,1,5,4,3,3,2,1,1,0},
    {1,1,1,3,3,2,2,1,0},
    {1,0,1,3,2,1,1,1,},
    {1,0,1,3,2,1,1,},
    {0,1,1,2,1,3},
    {0,1,1,1,1},
    {0,1,1,1},
    {0,1,1},
    {0,1},  
  };
  vlcnum = sym->value1;

  lt = &lentab[vlcnum][0];
  ct = &codtab[vlcnum][0];

  retval = code_from_bitstream_2d(sym, dP, lt, ct, 16, 1, &code);

  if (retval)
  {
    printf("ERROR: failed to find Total Zeros\n");
    exit(-1);
  }


#if TRACE
    tracebits2(sym->tracestring, sym->len, code);

#endif

  return retval;
}    

/*!
 ************************************************************************
 * \brief
 *    read Total Zeros Chroma DC codeword from UVLC-partition 
 ************************************************************************
 */
int readSyntaxElement_TotalZerosChromaDC(SyntaxElement *sym,  DataPartition *dP)
{
  int vlcnum, retval;
  int code, *ct, *lt;

  int lentab[3][4] = 
  {
    { 1, 2, 3, 3,},
    { 1, 2, 2, 0,},
    { 1, 1, 0, 0,}, 
  };

  int codtab[3][4] = 
  {
    { 1, 1, 1, 0,},
    { 1, 1, 0, 0,},
    { 1, 0, 0, 0,},
  };

  vlcnum = sym->value1;

  lt = &lentab[vlcnum][0];
  ct = &codtab[vlcnum][0];

  retval = code_from_bitstream_2d(sym, dP, lt, ct, 4, 1, &code);

  if (retval)
  {
    printf("ERROR: failed to find Total Zeros\n");
    exit(-1);
  }


#if TRACE
    tracebits2(sym->tracestring, sym->len, code);

#endif

  return retval;
}    


/*!
 ************************************************************************
 * \brief
 *    read  Run codeword from UVLC-partition 
 ************************************************************************
 */
int readSyntaxElement_Run(SyntaxElement *sym,  DataPartition *dP)
{
  int vlcnum, retval;
  int code, *ct, *lt;

  int lentab[TOTRUN_NUM][16] = 
  {
    {1,1},
    {1,2,2},
    {2,2,2,2},
    {2,2,2,3,3},
    {2,2,3,3,3,3},
    {2,3,3,3,3,3,3},
    {3,3,3,3,3,3,3,4,5,6,7,8,9,10,11},
  };

  int codtab[TOTRUN_NUM][16] = 
  {
    {1,0},
    {1,1,0},
    {3,2,1,0},
    {3,2,1,1,0},
    {3,2,3,2,1,0},
    {3,0,1,3,2,5,4},
    {7,6,5,4,3,2,1,1,1,1,1,1,1,1,1},
  };

  vlcnum = sym->value1;

  lt = &lentab[vlcnum][0];
  ct = &codtab[vlcnum][0];

  retval = code_from_bitstream_2d(sym, dP, lt, ct, 16, 1, &code);

  if (retval)
  {
    printf("ERROR: failed to find Run\n");
    exit(-1);
  }


#if TRACE
    tracebits2(sym->tracestring, sym->len, code);
#endif

  return retval;
}    


/*!
 ************************************************************************
 * \brief
 *  Reads bits from the bitstream buffer
 *
 * \param buffer
 *    containing VLC-coded data bits
 * \param totbitoffset
 *    bit offset from start of partition
 * \param info
 *    returns value of the read bits
 * \param bytecount
 *    total bytes in bitstream
 * \param numbits
 *    number of bits to read
 *
 ************************************************************************
 */
int GetBits (byte buffer[],int totbitoffset,int *info, int bytecount, 
             int numbits)
{

  register int inf;
  long byteoffset;      // byte from start of buffer
  int bitoffset;      // bit from start of byte

  int bitcounter=numbits;

  byteoffset= totbitoffset/8;
  bitoffset= 7-(totbitoffset%8);

  inf=0;
  while (numbits)
  {
    inf <<=1;
    inf |= (buffer[byteoffset] & (0x01<<bitoffset))>>bitoffset;
    numbits--;
    bitoffset--;
    if (bitoffset < 0)
    {
      byteoffset++;
      bitoffset += 8;
      if (byteoffset > bytecount)
      {
        return -1;
      }
    }
  }

  *info = inf;
  return bitcounter;           // return absolute offset in bit from start of frame
}     

/*!
 ************************************************************************
 * \brief
 *  Reads bits from the bitstream buffer
 *
 * \param buffer
 *    buffer containing VLC-coded data bits
 * \param totbitoffset
 *    bit offset from start of partition
 * \param bytecount
 *    total bytes in bitstream
 * \param numbits
 *    number of bits to read
 *
 ************************************************************************
 */

int ShowBits (byte buffer[],int totbitoffset,int bytecount, int numbits)
{

  register int inf;
  long byteoffset;      // byte from start of buffer
  int bitoffset;      // bit from start of byte

  byteoffset= totbitoffset/8;
  bitoffset= 7-(totbitoffset%8);

  inf=0;
  while (numbits)
  {
    inf <<=1;
    inf |= (buffer[byteoffset] & (0x01<<bitoffset))>>bitoffset;
    numbits--;
    bitoffset--;
    if (bitoffset < 0)
    {
      byteoffset++;
      bitoffset += 8;
      if (byteoffset > bytecount)
      {
        return -1;
      }
    }
  }

  return inf;           // return absolute offset in bit from start of frame
}     


/*!
 ************************************************************************
 * \brief
 *    peek at the next 2 UVLC codeword from UVLC-partition to determine
 *    if a skipped MB is field/frame
 ************************************************************************
 */
int peekSyntaxElement_UVLC(SyntaxElement *sym, struct img_par *img, struct inp_par *inp, struct datapartition *dP)
{
  Bitstream   *currStream = dP->bitstream;
  int frame_bitoffset = currStream->frame_bitoffset;
  byte *buf = currStream->streamBuffer;
  int BitstreamLengthInBytes = currStream->bitstream_length;


  sym->len =  GetVLCSymbol (buf, frame_bitoffset, &(sym->inf), BitstreamLengthInBytes);
  if (sym->len == -1)
    return -1;
  frame_bitoffset += sym->len;
  sym->mapping(sym->len,sym->inf,&(sym->value1),&(sym->value2));


#if TRACE
  tracebits(sym->tracestring, sym->len, sym->inf, sym->value1);
#endif

  return 1;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产精品激情在线观看 | 国产精品久久久久久亚洲毛片| 色狠狠桃花综合| 顶级嫩模精品视频在线看| 久久99在线观看| 麻豆中文一区二区| 精品在线一区二区| 久久国产夜色精品鲁鲁99| 午夜精品成人在线视频| 亚洲国产精品影院| 午夜视频久久久久久| 婷婷一区二区三区| 日本亚洲三级在线| 久久激五月天综合精品| 国产又粗又猛又爽又黄91精品| 国产一区二区三区国产| 成人午夜视频在线| 成人h精品动漫一区二区三区| 成人毛片在线观看| av一本久道久久综合久久鬼色| 国产成a人亚洲精品| 97se亚洲国产综合在线| 欧美日韩精品专区| 亚洲精品一区二区精华| 国产精品久久午夜夜伦鲁鲁| 一区二区三区丝袜| 蜜桃在线一区二区三区| 国产成人综合亚洲91猫咪| 成人黄色网址在线观看| 91久久久免费一区二区| 欧美成人免费网站| 最近中文字幕一区二区三区| 理论片日本一区| 国产精品一卡二| 97精品电影院| 精品裸体舞一区二区三区| 亚洲欧洲日韩一区二区三区| 亚洲bdsm女犯bdsm网站| 国产乱对白刺激视频不卡| 一本色道久久综合精品竹菊| 欧美一区二区精品在线| 国产精品久久久久久久第一福利| 亚洲福利一二三区| 国产ts人妖一区二区| 欧美日韩国产综合一区二区| 国产午夜精品久久久久久免费视 | thepron国产精品| 宅男噜噜噜66一区二区66| 国产欧美一区二区精品性色| 亚洲一区二区视频在线观看| 国产精品一级片| 欧美一区二视频| 亚洲老妇xxxxxx| 国产成人8x视频一区二区| 3atv在线一区二区三区| 亚洲人吸女人奶水| 国产成人精品三级| 精品嫩草影院久久| 香蕉成人伊视频在线观看| 91亚洲精华国产精华精华液| 久久精品网站免费观看| 蜜臀av性久久久久蜜臀aⅴ四虎| 色婷婷综合中文久久一本| 亚洲国产高清aⅴ视频| 韩国三级在线一区| 精品三级在线看| 日本不卡123| 欧美乱熟臀69xxxxxx| 一区二区三区不卡视频在线观看| 国产成人精品影视| 久久久精品蜜桃| 久草这里只有精品视频| 日韩欧美国产成人一区二区| 爽好久久久欧美精品| 欧美日韩专区在线| 亚洲国产日韩精品| 欧美在线看片a免费观看| 一区二区三区日韩欧美精品| 99re这里都是精品| 中文字幕一区二区三区不卡| 国产精品69久久久久水密桃| 日韩欧美一二三区| 久久99精品久久久久久国产越南 | 精品乱人伦小说| 久久国产精品72免费观看| 欧美一区二区啪啪| 久久99久久久欧美国产| 欧美精品一区二区精品网| 韩国一区二区在线观看| 久久久美女毛片| 成人国产亚洲欧美成人综合网| 国产精品免费观看视频| 99re热这里只有精品免费视频| 亚洲日本中文字幕区| 日本精品一区二区三区四区的功能| 亚洲精选免费视频| 在线观看91精品国产麻豆| 日韩激情中文字幕| 久久午夜色播影院免费高清| 丁香桃色午夜亚洲一区二区三区| 国产精品黄色在线观看| 日韩手机在线导航| 国产另类ts人妖一区二区| 国产精品拍天天在线| 色哟哟在线观看一区二区三区| 亚洲 欧美综合在线网络| 91精品中文字幕一区二区三区| 精品午夜一区二区三区在线观看| 国产欧美日韩精品在线| 91精彩视频在线| 美女视频黄频大全不卡视频在线播放| 337p粉嫩大胆色噜噜噜噜亚洲| 99免费精品视频| 亚洲成av人影院在线观看网| 欧美精品一区二区三区蜜桃视频| 成人app在线| 青草av.久久免费一区| 精品国产123| 91福利国产精品| 久久99久久99| 亚洲综合一区二区三区| 精品动漫一区二区三区在线观看| av电影一区二区| 日本不卡123| 亚洲人成在线观看一区二区| 日韩欧美久久久| 91久久精品一区二区三| 久久精品免费看| 亚洲国产综合91精品麻豆| 久久久精品天堂| 91精品国产综合久久久久久漫画| www.欧美日韩| 国产成人亚洲综合色影视| 亚洲动漫第一页| 亚洲理论在线观看| 中文字幕欧美激情| 精品福利在线导航| 日韩一区二区视频| 欧美精品在线一区二区| 成人免费av网站| 国产做a爰片久久毛片| 日本不卡视频在线观看| 亚洲综合男人的天堂| 亚洲免费成人av| 中文字幕欧美一| 中文字幕精品综合| 久久久久久电影| 久久综合色8888| 精品久久一区二区| 精品对白一区国产伦| 日韩精品专区在线影院观看| 欧美一区欧美二区| 欧美一级理论性理论a| 欧美男男青年gay1069videost| 在线观看av一区| 欧美伊人精品成人久久综合97 | 91麻豆精品国产自产在线观看一区 | 一本色道**综合亚洲精品蜜桃冫| 久久97超碰色| 蜜桃精品视频在线观看| 日韩1区2区日韩1区2区| 水野朝阳av一区二区三区| 五月婷婷久久丁香| 视频一区二区三区在线| 日韩专区一卡二卡| 日韩极品在线观看| 麻豆国产精品官网| 精品一区二区综合| 国产一区不卡在线| 成人丝袜视频网| 成人黄色在线网站| 成人av网址在线| 91首页免费视频| 在线欧美日韩国产| 欧美日韩三级在线| 欧美精品丝袜中出| 欧美电影免费观看高清完整版在| 日韩免费在线观看| 国产日韩欧美不卡在线| 国产欧美久久久精品影院 | 99九九99九九九视频精品| 国产不卡免费视频| 91天堂素人约啪| 欧美日韩国产首页| 久久久久国产成人精品亚洲午夜| 中文字幕av一区二区三区高| 日韩美女视频一区| 丝袜亚洲另类丝袜在线| 国产一区福利在线| 日本国产一区二区| 欧美一级日韩一级| 国产精品网站一区| 一级中文字幕一区二区| 韩国精品免费视频| 538在线一区二区精品国产| 久久综合久久综合亚洲| 亚洲一区二区在线观看视频| 美国毛片一区二区三区| 91丨九色porny丨蝌蚪| 欧美大片顶级少妇|