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

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

?? erc_do_i.c

?? 一個簡單的視頻會議VC++MFC工程文件
?? C
?? 第 1 頁 / 共 2 頁
字號:
  if ( condition[ (currRow+step)*maxColumn + currColumn ] > threshold ) 
  {
    predBlocks[6] = 1;
    srcCounter++;
  }
  
  return srcCounter;
}

/*!
 ************************************************************************
 * \brief
 *      Core for the Intra blocks concealment.
 *      It is called for each color component (Y,U,V) seperately
 *      Finds the corrupted blocks and calls pixel interpolation functions 
 *      to correct them, one block at a time.
 *      Scanning is done vertically and each corrupted column is corrected
 *      bi-directionally, i.e., first block, last block, first block+1, last block -1 ...
 * \param lastColumn  
 *      Number of block columns in the frame
 * \param lastRow     
 *      Number of block rows in the frame
 * \param comp
 *      color component
 * \param recfr
 *      Reconstructed frame buffer
 * \param picSizeX
 *      Width of the frame in pixels
 * \param condition
 *      The block condition (ok, lost) table
 ************************************************************************
 */
static void concealBlocks( int lastColumn, int lastRow, int comp, frame *recfr, int32 picSizeX, int *condition )
{
  int row, column, srcCounter = 0,  thr = ERC_BLOCK_CORRUPTED,
      lastCorruptedRow = -1, firstCorruptedRow = -1, currRow = 0, 
      areaHeight = 0, i = 0, smoothColumn = 0;
  int predBlocks[8], step = 1;
  
  /* in the Y component do the concealment MB-wise (not block-wise):
  this is useful if only whole MBs can be damaged or lost */
  if ( comp == 0 )
    step = 2;
  else
    step = 1;
  
  for ( column = 0; column < lastColumn; column += step ) 
  {
    for ( row = 0; row < lastRow; row += step ) 
    {
      if ( condition[row*lastColumn+column] <= thr ) 
      {
        firstCorruptedRow = row;
        /* find the last row which has corrupted blocks (in same continuous area) */
        for ( lastCorruptedRow = row+step; lastCorruptedRow < lastRow; lastCorruptedRow += step ) 
        {
          /* check blocks in the current column */
          if ( condition[ lastCorruptedRow*lastColumn + column ] > thr ) 
          {
            /* current one is already OK, so the last was the previous one */
            lastCorruptedRow -= step;
            break;
          }
        }
        if ( lastCorruptedRow >= lastRow ) 
        {
          /* correct only from above */
          lastCorruptedRow = lastRow-step;
          for ( currRow = firstCorruptedRow; currRow < lastRow; currRow += step ) 
          {
            srcCounter = ercCollect8PredBlocks( predBlocks, currRow, column, condition, lastRow, lastColumn, step, 1 );
          
            switch( comp ) 
            {
            case 0 :
              ercPixConcealIMB( recfr->yptr, currRow, column, predBlocks, picSizeX, 2 );
              break;
            case 1 :
              ercPixConcealIMB( recfr->uptr, currRow, column, predBlocks, (picSizeX>>1), 1 );
              break;
            case 2 :
              ercPixConcealIMB( recfr->vptr, currRow, column, predBlocks, (picSizeX>>1), 1 );
              break;
            }
            
            if ( comp == 0 ) 
            {
              condition[ currRow*lastColumn+column] = ERC_BLOCK_CONCEALED;
              condition[ currRow*lastColumn+column + 1] = ERC_BLOCK_CONCEALED;
              condition[ currRow*lastColumn+column + lastColumn] = ERC_BLOCK_CONCEALED;
              condition[ currRow*lastColumn+column + lastColumn + 1] = ERC_BLOCK_CONCEALED;
            }
            else 
            {
              condition[ currRow*lastColumn+column] = ERC_BLOCK_CONCEALED;
            }
            
          }
          row = lastRow;
        } 
        else if ( firstCorruptedRow == 0 ) 
        {
          /* correct only from below */
          for ( currRow = lastCorruptedRow; currRow >= 0; currRow -= step ) 
          {
            srcCounter = ercCollect8PredBlocks( predBlocks, currRow, column, condition, lastRow, lastColumn, step, 1 );
            
            switch( comp ) 
            {
            case 0 :
              ercPixConcealIMB( recfr->yptr, currRow, column, predBlocks, picSizeX, 2 );
              break;
            case 1 :
              ercPixConcealIMB( recfr->uptr, currRow, column, predBlocks, (picSizeX>>1), 1 );
              break;
            case 2 :
              ercPixConcealIMB( recfr->vptr, currRow, column, predBlocks, (picSizeX>>1), 1 );
              break;
            }
            
            if ( comp == 0 ) 
            {
              condition[ currRow*lastColumn+column] = ERC_BLOCK_CONCEALED;
              condition[ currRow*lastColumn+column + 1] = ERC_BLOCK_CONCEALED;
              condition[ currRow*lastColumn+column + lastColumn] = ERC_BLOCK_CONCEALED;
              condition[ currRow*lastColumn+column + lastColumn + 1] = ERC_BLOCK_CONCEALED;
            }
            else 
            {
              condition[ currRow*lastColumn+column] = ERC_BLOCK_CONCEALED;
            }
            
          }
          
          row = lastCorruptedRow+step;
        }
        else 
        {
          /* correct bi-directionally */
          
          row = lastCorruptedRow+step;
          areaHeight = lastCorruptedRow-firstCorruptedRow+step;
          
          /* 
          *  Conceal the corrupted area switching between the up and the bottom rows 
          */
          for ( i = 0; i < areaHeight; i += step ) 
          {
            if ( i % 2 ) 
            {
              currRow = lastCorruptedRow;
              lastCorruptedRow -= step;
            }
            else 
            {
              currRow = firstCorruptedRow;
              firstCorruptedRow += step;
            }
            
            if (smoothColumn > 0) 
            {
              srcCounter = ercCollectColumnBlocks( predBlocks, currRow, column, condition, lastRow, lastColumn, step );
            }
            else 
            {
              srcCounter = ercCollect8PredBlocks( predBlocks, currRow, column, condition, lastRow, lastColumn, step, 1 );
            }
            
            switch( comp ) 
            {
            case 0 :
              ercPixConcealIMB( recfr->yptr, currRow, column, predBlocks, picSizeX, 2 );
              break;
              
            case 1 :
              ercPixConcealIMB( recfr->uptr, currRow, column, predBlocks, (picSizeX>>1), 1 );
              break;
              
            case 2 :
              ercPixConcealIMB( recfr->vptr, currRow, column, predBlocks, (picSizeX>>1), 1 );
              break;
            }
            
            if ( comp == 0 ) 
            {
              condition[ currRow*lastColumn+column] = ERC_BLOCK_CONCEALED;
              condition[ currRow*lastColumn+column + 1] = ERC_BLOCK_CONCEALED;
              condition[ currRow*lastColumn+column + lastColumn] = ERC_BLOCK_CONCEALED;
              condition[ currRow*lastColumn+column + lastColumn + 1] = ERC_BLOCK_CONCEALED;
            }
            else 
            {
              condition[ currRow*lastColumn+column ] = ERC_BLOCK_CONCEALED;
            }
          }
        }

        lastCorruptedRow = -1;
        firstCorruptedRow = -1;

      }
    }
  }
}

/*!
 ************************************************************************
 * \brief
 *      Does the actual pixel based interpolation for block[]
 *      using weighted average
 * \param src[] 
 *      pointers to neighboring source blocks
 * \param block     
 *      destination block
 * \param blockSize
 *      16 for Y, 8 for U/V components
 * \param frameWidth
 *      Width of the frame in pixels
 ************************************************************************
 */
static void pixMeanInterpolateBlock( byte *src[], byte *block, int blockSize, int frameWidth )
{
  int row, column, k, tmp, srcCounter = 0, weight = 0, bmax = blockSize - 1;
  
  k = 0;
  for ( row = 0; row < blockSize; row++ ) 
  {
    for ( column = 0; column < blockSize; column++ ) 
    {
      tmp = 0;
      srcCounter = 0;
      /* above */
      if ( src[4] != NULL )   
      {
        weight = blockSize-row;
        tmp += weight * (*(src[4]+bmax*frameWidth+column));
        srcCounter += weight;
      }
      /* left */
      if ( src[5] != NULL )   
      {
        weight = blockSize-column;
        tmp += weight * (*(src[5]+row*frameWidth+bmax));
        srcCounter += weight;
      }
      /* below */
      if ( src[6] != NULL )   
      {
        weight = row+1;
        tmp += weight * (*(src[6]+column));
        srcCounter += weight;
      }
      /* right */
      if ( src[7] != NULL )   
      {
        weight = column+1;
        tmp += weight * (*(src[7]+row*frameWidth));
        srcCounter += weight;
      }

      if ( srcCounter > 0 )
        block[ k + column ] = (byte)(tmp/srcCounter);
      else 
        block[ k + column ] = 127;
    }
    k += frameWidth;
  }
  
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线看国产一区| 欧美日韩二区三区| 久久久欧美精品sm网站| 日韩中文字幕麻豆| 欧美成人a视频| 国产在线看一区| 国产目拍亚洲精品99久久精品| 国产成人综合自拍| 中文字幕一区二区不卡| 精品影视av免费| 亚洲国产精品t66y| 成人免费看片app下载| 亚洲欧美日韩一区| 欧美日韩国产精品成人| 免费观看30秒视频久久| 亚洲精品在线三区| 91视频免费看| 亚洲国产综合在线| 日韩视频免费观看高清完整版在线观看 | 欧美性大战久久| 日本欧美在线观看| 国产性天天综合网| 99久久精品国产导航| 亚洲成a人在线观看| 精品少妇一区二区三区在线播放| 成人看片黄a免费看在线| 一区二区三区四区激情| 欧美一区二区三区精品| 国产很黄免费观看久久| 亚洲一区二区五区| 欧美xxxxx牲另类人与| av一本久道久久综合久久鬼色| 亚洲精品高清在线| 精品国产一区二区精华| 91福利国产成人精品照片| 美国毛片一区二区三区| 自拍偷自拍亚洲精品播放| 日韩一级免费观看| 99国产精品一区| 国产一区视频网站| 亚洲成av人影院| 欧美激情一区二区三区蜜桃视频| 欧美在线色视频| 处破女av一区二区| 九一久久久久久| 图片区日韩欧美亚洲| 亚洲丝袜精品丝袜在线| 欧美一区二区福利在线| 一本一道波多野结衣一区二区| 另类小说综合欧美亚洲| 亚洲五码中文字幕| 国产精品久久久久久久久搜平片| 欧美一区二视频| 色94色欧美sute亚洲线路二| 高清久久久久久| 麻豆91在线播放| 五月婷婷综合激情| 亚洲人妖av一区二区| 国产拍欧美日韩视频二区| 精品sm在线观看| 欧美一级理论性理论a| 欧美视频一区二区三区在线观看| gogo大胆日本视频一区| 国产盗摄女厕一区二区三区| 美女网站在线免费欧美精品| 午夜av电影一区| 亚洲成人午夜影院| 一级女性全黄久久生活片免费| 亚洲人精品午夜| 中文字幕亚洲综合久久菠萝蜜| 久久精品免视看| 亚洲精品一区二区精华| 久久婷婷国产综合精品青草| 日韩小视频在线观看专区| 欧美军同video69gay| 欧美午夜不卡视频| 欧美日韩亚洲综合一区| 欧美性高清videossexo| 欧美日韩国产一二三| 在线观看一区不卡| 欧洲视频一区二区| 在线观看欧美黄色| 欧美日韩国产在线观看| 欧美日韩国产综合视频在线观看| 精品视频色一区| 51精品久久久久久久蜜臀| 91精品久久久久久久久99蜜臂 | 欧美日韩精品一区二区在线播放| 欧美综合欧美视频| 欧美色欧美亚洲另类二区| 欧美日韩一级二级三级| 69p69国产精品| 91精品婷婷国产综合久久竹菊| 91精品综合久久久久久| 日韩免费视频一区| 久久久亚洲精品石原莉奈| 日本一区二区三区四区| 中文字幕+乱码+中文字幕一区| 国产精品免费视频一区| **性色生活片久久毛片| 亚洲一区视频在线| 麻豆中文一区二区| 国产成人亚洲综合a∨婷婷| 成人av手机在线观看| 欧美主播一区二区三区| 日韩一区二区三区在线观看| 精品成人一区二区| 亚洲免费av在线| 蜜桃精品在线观看| 粉嫩一区二区三区性色av| 一本一道久久a久久精品综合蜜臀| 欧美视频三区在线播放| 日韩欧美一二区| 综合自拍亚洲综合图不卡区| 婷婷丁香久久五月婷婷| 国产精品影视天天线| 在线观看欧美精品| 2023国产精品自拍| 欧美mv和日韩mv国产网站| 亚洲桃色在线一区| 91农村精品一区二区在线| 欧美日韩国产综合一区二区三区 | 国产精品一区二区免费不卡| 91浏览器打开| 日韩精品在线网站| 自拍偷拍亚洲综合| 久久国产生活片100| 91小宝寻花一区二区三区| 91精品国产欧美一区二区成人| 日本一区二区三区高清不卡| 亚洲成av人片一区二区梦乃| 国产精品一区二区三区四区| 欧美午夜精品免费| 国产精品全国免费观看高清| 日韩av二区在线播放| 91在线精品一区二区三区| 精品久久久久久无| 亚洲成人1区2区| 91免费国产在线观看| 久久久不卡网国产精品二区| 午夜精品视频一区| 欧美大尺度电影在线| 成人黄色在线看| 2021国产精品久久精品| 偷拍一区二区三区四区| 91福利视频网站| 国产精品三级在线观看| 老司机精品视频线观看86| 欧美日韩高清一区二区三区| 欧美激情在线看| 国产一区二区三区精品欧美日韩一区二区三区 | 亚洲精选免费视频| 国产精品一级黄| 精品久久久久久综合日本欧美| 天天亚洲美女在线视频| 99久久伊人久久99| 懂色av中文字幕一区二区三区 | 亚洲欧美日韩国产综合在线| 国产成人av电影在线播放| 精品入口麻豆88视频| 日韩成人一区二区三区在线观看| 欧美专区在线观看一区| 亚洲免费观看高清完整| 91美女在线看| 亚洲欧美日韩系列| 91在线你懂得| 亚洲日韩欧美一区二区在线| 99视频在线精品| 国产精品大尺度| 91视频精品在这里| 亚洲男人电影天堂| 色乱码一区二区三区88| 亚洲欧美成人一区二区三区| 不卡一卡二卡三乱码免费网站| 国产午夜精品久久久久久免费视| 国产一区二区三区日韩| 国产日韩成人精品| 成人成人成人在线视频| 成人免费在线观看入口| av福利精品导航| 亚洲精品日韩一| 日本精品裸体写真集在线观看| 亚洲日本韩国一区| 欧美日韩色综合| 日韩激情中文字幕| 欧美成人女星排行榜| 国产乱码精品1区2区3区| 欧美高清一级片在线观看| 3d成人h动漫网站入口| 欧美日韩高清不卡| 日韩三级av在线播放| 亚洲男人的天堂一区二区| 国产在线精品一区二区不卡了 | 狠狠色丁香婷婷综合| 国产校园另类小说区| 91视频.com| 日韩主播视频在线| 久久尤物电影视频在线观看| 99久免费精品视频在线观看| 一区二区三区在线视频观看58|