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

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

?? mb_access.c

?? h264標準的VC實現
?? C
?? 第 1 頁 / 共 2 頁
字號:
                   yM = yN>> 1;
                }
              }
            }
          }
          else
          {
            // bottom
            pix->mb_addr   = currMb->mbAddrA;
            pix->available = currMb->mbAvailA;
            if (currMb->mbAvailA)
            {
              if(!img->mb_data[currMb->mbAddrA].mb_field)
              {
                (pix->mb_addr)++;
                 yM = yN;
              }
              else
              {
                if (yN %2 == 0)
                {
                   yM = (yN + maxH) >> 1;
                }
                else
                {
                  (pix->mb_addr)++;
                   yM = (yN + maxH) >> 1;
                }
              }
            }
          }
        }
        else
        {
          // field
          if (curr_mb_nr % 2 == 0)
          {
            // top
            pix->mb_addr  = currMb->mbAddrA;
            pix->available = currMb->mbAvailA;
            if (currMb->mbAvailA)
            {
              if(!img->mb_data[currMb->mbAddrA].mb_field)
              {
                if (yN < (maxH / 2))
                {
                   yM = yN << 1;
                }
                else
                {
                  (pix->mb_addr)++;
                   yM = (yN << 1 ) - maxH;
                }
              }
              else
              {
                 yM = yN;
              }
            }
          }
          else
          {
            // bottom
            pix->mb_addr  = currMb->mbAddrA;
            pix->available = currMb->mbAvailA;
            if (currMb->mbAvailA)
            {
              if(!img->mb_data[currMb->mbAddrA].mb_field)
              {
                if (yN < (maxH / 2))
                {
                  yM = (yN << 1) + 1;
                }
                else
                {
                  (pix->mb_addr)++;
                   yM = (yN << 1 ) + 1 - maxH;
                }
              }
              else
              {
                (pix->mb_addr)++;
                 yM = yN;
              }
            }
          }
        }
      }
    }
  }
  else
  { // xN >= 0
    if (xN >= 0 && xN < maxW)
    {
      if (yN<0)
      {
        if (!currMb->mb_field)
        {
          //frame
          if (curr_mb_nr % 2 == 0)
          {
            //top
            pix->mb_addr  = currMb->mbAddrB;
            // for the deblocker if the current MB is a frame and the one above is a field
            // then the neighbor is the top MB of the pair
            if (currMb->mbAvailB)
            {
              if (!(img->DeblockCall == 1 && (img->mb_data[currMb->mbAddrB]).mb_field))
                pix->mb_addr  += 1;
            }
            
            pix->available = currMb->mbAvailB;
            yM = yN;
          }
          else
          {
            // bottom
            pix->mb_addr   = curr_mb_nr - 1;
            pix->available = 1;
            yM = yN;
          }
        }
        else
        {
          // field
          if (curr_mb_nr % 2 == 0)
          {
            // top
            pix->mb_addr   = currMb->mbAddrB;
            pix->available = currMb->mbAvailB;
            if (currMb->mbAvailB)
            {
              if(!img->mb_data[currMb->mbAddrB].mb_field)
              {
                (pix->mb_addr)++;
                 yM = 2* yN;
              }
              else
              {
                 yM = yN;
              }
            }
          }
          else
          {
            // bottom
            pix->mb_addr   = currMb->mbAddrB + 1;
            pix->available = currMb->mbAvailB;
            yM = yN;
          }
        }
      }
      else
      {
        // yN >=0
        // for the deblocker if this is the extra edge then do this special stuff
        if (yN == 0 && img->DeblockCall == 2)
        {
          pix->mb_addr  = currMb->mbAddrB + 1;
          pix->available = 1;
          yM = yN - 1;
        }

        else if ((yN >= 0) && (yN <maxH))
        {
          pix->mb_addr   = curr_mb_nr;
          pix->available = 1;
          yM = yN;
        }
      }
    }
    else
    { // xN >= maxW
      if(yN < 0)
      {
        if (!currMb->mb_field)
        {
          // frame
          if (curr_mb_nr % 2 == 0)
          {
            // top
            pix->mb_addr  = currMb->mbAddrC + 1;
            pix->available = currMb->mbAvailC;
            yM = yN;
          }
          else
          {
            // bottom
            pix->available = 0;
          }
        }
        else
        {
          // field
          if (curr_mb_nr % 2 == 0)
          {
            // top
            pix->mb_addr   = currMb->mbAddrC;
            pix->available = currMb->mbAvailC;
            if (currMb->mbAvailC)
            {
              if(!img->mb_data[currMb->mbAddrC].mb_field)
              {
                (pix->mb_addr)++;
                 yM = 2* yN;
              }
              else
              {
                yM = yN;
              }
            }
          }
          else
          {
            // bottom
            pix->mb_addr   = currMb->mbAddrC + 1;
            pix->available = currMb->mbAvailC;
            yM = yN;
          }
        }
      }
    }
  }
  if (pix->available || img->DeblockCall)
  {
    pix->x = (xN + maxW) % maxW;
    pix->y = (yM + maxH) % maxH;
    get_mb_pos(pix->mb_addr, &(pix->pos_x), &(pix->pos_y));
    if (luma)
    {
      pix->pos_x += pix->x;
      pix->pos_y += pix->y;
    }
    else
    {
      pix->pos_x = pix->pos_x/(16/img->mb_cr_size_x) + pix->x;
      pix->pos_y = pix->pos_y/(16/img->mb_cr_size_y) + pix->y;
    }
  }
}


/*!
 ************************************************************************
 * \brief
 *    get neighbouring positions. MB AFF is automatically used from img structure
 * \param curr_mb_nr
 *   current macroblock number (decoding order)
 * \param xN
 *    input x position
 * \param yN
 *    input y position
 * \param luma
 *    1 if luma coding, 0 for chroma
 * \param pix
 *    returns position informations
 ************************************************************************
 */
void getNeighbour(int curr_mb_nr, int xN, int yN, int luma, PixelPos *pix)
{
  if (curr_mb_nr<0)
    error ("getNeighbour: invalid macroblock number", 100);

  if (img->MbaffFrameFlag)
    getAffNeighbour(curr_mb_nr, xN, yN, luma, pix);
  else
    getNonAffNeighbour(curr_mb_nr, xN, yN, luma, pix);
}


/*!
 ************************************************************************
 * \brief
 *    get neighbouring  get neighbouring 4x4 luma block
 * \param curr_mb_nr
 *   current macroblock number (decoding order)
 * \param block_x
 *    input x block position
 * \param block_y
 *    input y block position
 * \param rel_x
 *    relative x position of neighbor
 * \param rel_y
 *    relative y position of neighbor
 * \param pix
 *    returns position informations
 ************************************************************************
 */
void getLuma4x4Neighbour (int curr_mb_nr, int block_x, int block_y, int rel_x, int rel_y, PixelPos *pix)
{
  int x = 4* block_x + rel_x;
  int y = 4* block_y + rel_y;

  getNeighbour(curr_mb_nr, x, y, 1, pix);

  if (pix->available)
  {
    pix->x /= 4;
    pix->y /= 4;
    pix->pos_x /= 4;
    pix->pos_y /= 4;
  }
}


/*!
 ************************************************************************
 * \brief
 *    get neighbouring 4x4 chroma block
 * \param curr_mb_nr
 *   current macroblock number (decoding order)
 * \param block_x
 *    input x block position
 * \param block_y
 *    input y block position
 * \param rel_x
 *    relative x position of neighbor
 * \param rel_y
 *    relative y position of neighbor
 * \param pix
 *    returns position informations
 ************************************************************************
 */
void getChroma4x4Neighbour (int curr_mb_nr, int block_x, int block_y, int rel_x, int rel_y, PixelPos *pix)
{
  int x = 4* block_x + rel_x;
  int y = 4* block_y + rel_y;

  getNeighbour(curr_mb_nr, x, y, 0, pix);

  if (pix->available)
  {
    pix->x /= 4;
    pix->y /= 4;
    pix->pos_x /= 4;
    pix->pos_y /= 4;
  }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
www.一区二区| 国产成人av一区| 亚洲女爱视频在线| 亚洲国产精品v| 欧美激情一区二区三区在线| 久久男人中文字幕资源站| 久久精品夜夜夜夜久久| 久久久久久久一区| 国产精品色婷婷| 亚洲男人的天堂av| 136国产福利精品导航| 一区二区三区在线视频播放| 夜夜嗨av一区二区三区中文字幕| 亚洲电影在线免费观看| 日韩—二三区免费观看av| 欧美aⅴ一区二区三区视频| 美女精品自拍一二三四| 国产激情视频一区二区三区欧美| 成人开心网精品视频| 欧美在线观看一区二区| 91精品在线麻豆| 国产偷国产偷亚洲高清人白洁| 国产精品久久国产精麻豆99网站| 一区二区三区四区不卡在线 | 高清在线观看日韩| 不卡av电影在线播放| 欧美性受xxxx黑人xyx性爽| 欧美r级电影在线观看| 91精品免费在线观看| 国产日韩欧美不卡在线| 一区二区在线观看av| 日本伊人午夜精品| 成人av网在线| 欧美电影一区二区三区| 中文一区在线播放| 午夜精品福利久久久| 国产精品一级片| 欧美性视频一区二区三区| 日韩精品一区二区三区四区视频| 亚洲欧美福利一区二区| 国产乱理伦片在线观看夜一区| 在线一区二区观看| 欧美国产丝袜视频| 美日韩一区二区三区| 91麻豆国产香蕉久久精品| 日韩欧美一二区| 伊人一区二区三区| 国产一区二区在线免费观看| 在线国产电影不卡| 国产精品对白交换视频| 国产精品自拍毛片| 91精品国产综合久久福利| 国产精品另类一区| 国产一区高清在线| 日韩欧美国产麻豆| 午夜久久久久久久久| 色猫猫国产区一区二在线视频| 日本一区二区视频在线| 久久99精品久久久久久久久久久久| 在线观看日产精品| 亚洲激情综合网| 国产精品1024| 国产天堂亚洲国产碰碰| 国产精品中文有码| 久久蜜桃av一区二区天堂| 日本欧美一区二区| 制服丝袜亚洲网站| 秋霞午夜av一区二区三区| 欧美日韩一级黄| 视频一区国产视频| 欧美精品少妇一区二区三区| 亚洲小说春色综合另类电影| 欧美午夜不卡在线观看免费| 亚洲愉拍自拍另类高清精品| 91久久精品网| 亚洲一级二级在线| 欧美顶级少妇做爰| 激情丁香综合五月| 久久精品欧美日韩| 成人h精品动漫一区二区三区| 国产精品美女一区二区三区| 9l国产精品久久久久麻豆| 国产精品久久久久久久第一福利| 成人av电影在线播放| 亚洲午夜激情网页| 在线视频中文字幕一区二区| 亚洲国产一区视频| 欧美一级一区二区| 看电视剧不卡顿的网站| 久久久激情视频| 成人黄色一级视频| 亚洲国产精品欧美一二99| 欧美精品视频www在线观看| 男人的天堂久久精品| 国产亚洲欧美一区在线观看| 国产99久久久久久免费看农村| 国产精品久久久久久久久搜平片 | 欧美高清视频在线高清观看mv色露露十八 | 精品国产乱码久久久久久1区2区| 国产在线视频不卡二| 国产精品国产三级国产专播品爱网| 色哟哟在线观看一区二区三区| 亚洲成a人在线观看| 久久美女高清视频| 欧美影院一区二区三区| 精品中文字幕一区二区小辣椒| 国产精品免费视频一区| 欧美日韩精品一区视频| 成人网在线播放| 日韩福利电影在线观看| 亚洲图片你懂的| 日韩欧美电影一区| 91亚洲精品久久久蜜桃| 精品综合久久久久久8888| 亚洲精品欧美二区三区中文字幕| 日韩一区二区三区四区| av在线综合网| 韩国午夜理伦三级不卡影院| 亚洲免费观看在线观看| 国产亚洲自拍一区| 欧美三级韩国三级日本一级| 成人三级伦理片| 美女www一区二区| 一区二区激情小说| 国产精品婷婷午夜在线观看| 欧美电影免费观看高清完整版在线观看 | 欧美视频在线一区| 国产传媒久久文化传媒| 丝袜美腿亚洲一区| 亚洲色欲色欲www在线观看| 国产性天天综合网| 日韩三级免费观看| 欧美日韩高清一区二区不卡| 99久久久精品免费观看国产蜜| 国产美女在线精品| 韩国女主播成人在线| 日韩精品免费视频人成| 亚洲狠狠丁香婷婷综合久久久| 国产精品天干天干在观线| 精品国产乱码久久久久久老虎 | 国产亚洲一二三区| 欧美日韩欧美一区二区| 色综合久久88色综合天天免费| 国产成人午夜高潮毛片| 精品一区二区三区香蕉蜜桃| 免费国产亚洲视频| 日韩在线a电影| 日本不卡一区二区三区高清视频| 亚洲aaa精品| 天天色综合天天| 免费在线观看精品| 爽好久久久欧美精品| 天天影视网天天综合色在线播放| 亚洲成人激情av| 日本欧美一区二区在线观看| 美女视频黄 久久| 国产一二精品视频| 成人激情小说乱人伦| 一本久久精品一区二区| 欧美丝袜丝交足nylons| 欧美一卡2卡3卡4卡| 久久久一区二区三区| 国产精品嫩草99a| 亚洲视频狠狠干| 午夜精品一区二区三区电影天堂 | 国产成人免费视频精品含羞草妖精| 寂寞少妇一区二区三区| 国产精品77777| 91在线国产福利| 欧美日韩一区二区三区免费看| 日韩欧美一二三区| 亚洲国产激情av| 伊人一区二区三区| 老司机免费视频一区二区| 激情另类小说区图片区视频区| 国产盗摄视频一区二区三区| 日本高清无吗v一区| 欧美一区二区三区在线电影| 久久久久久免费毛片精品| 一区在线观看视频| 日韩成人精品在线| 不卡一区二区在线| 欧美日本一区二区| 国产精品久久777777| 石原莉奈在线亚洲二区| 国产91精品一区二区麻豆亚洲| 在线免费观看日本一区| 久久九九全国免费| 亚洲国产日韩在线一区模特| 国产精品夜夜嗨| 91精品国产丝袜白色高跟鞋| 中文乱码免费一区二区| 五月天中文字幕一区二区| 成人黄色片在线观看| 制服丝袜激情欧洲亚洲| 日韩毛片高清在线播放| 韩国v欧美v日本v亚洲v| 在线影院国内精品| 日本一区二区三区视频视频| 日本午夜精品视频在线观看|