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

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

?? mbcoder.cpp

?? JMVM MPEG MVC/3DAV 測試平臺 國際通用標準
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
      {
        RNOK( m_pcMbSymbolWriteIf->refFrame( rcMbDataAccess, eLstIdx, PART_8x16_0 ) );
      }

      if( rcMbDataAccess.getMbData().isBlockFwdBwd( B_8x8_1, eLstIdx) && ( ! bPred || ! rcMot.getMotPredFlag( PART_8x16_1 ) ) )
      {
        RNOK( m_pcMbSymbolWriteIf->refFrame( rcMbDataAccess, eLstIdx, PART_8x16_1 ) );
      }
      break;
    }
    
  case MODE_8x8:
  case MODE_8x8ref0:
    {
      for( B8x8Idx c8x8Idx; c8x8Idx.isLegal(); c8x8Idx++ )
      {
        if( BLK_SKIP != rcMbDataAccess.getMbData().getBlkMode( c8x8Idx.b8x8Index() ) &&
            rcMbDataAccess.getMbData().isBlockFwdBwd( c8x8Idx.b8x8Index(), eLstIdx ) && ( ! bPred || ! rcMot.getMotPredFlag( c8x8Idx.b8x8() ) ) )
        {
          RNOK( m_pcMbSymbolWriteIf->refFrame( rcMbDataAccess, eLstIdx, c8x8Idx.b8x8() ) );
        }
      }
      break;
    }
    
  default:
    {
      AF();
      return Err::m_nERR;
    }
  }

  return Err::m_nOK;
}




ErrVal
MbCoder::xWriteMotionVectors( MbDataAccess& rcMbDataAccess,
                              MbMode        eMbMode,
                              ListIdx       eLstIdx )
{
  AOT_DBG( rcMbDataAccess.getMbData().isIntra() );

  switch( eMbMode )
  {
  case MODE_SKIP:
    {
      return Err::m_nOK;
    }
  
  case MODE_16x16:
    {
      if( rcMbDataAccess.getMbData().isBlockFwdBwd( B_8x8_0, eLstIdx) )
      {
        RNOK( m_pcMbSymbolWriteIf->mvd( rcMbDataAccess, eLstIdx ) );
      }
      return Err::m_nOK;
    }

  case MODE_16x8:
    {
      if( rcMbDataAccess.getMbData().isBlockFwdBwd( B_8x8_0, eLstIdx) )
      {
        RNOK( m_pcMbSymbolWriteIf->mvd( rcMbDataAccess, eLstIdx, PART_16x8_0 ) );
      }

      if( rcMbDataAccess.getMbData().isBlockFwdBwd( B_8x8_2, eLstIdx) )
      {
        RNOK( m_pcMbSymbolWriteIf->mvd( rcMbDataAccess, eLstIdx, PART_16x8_1 ) );
      }
      return Err::m_nOK;
    }
  
  case MODE_8x16:
    {
      if( rcMbDataAccess.getMbData().isBlockFwdBwd( B_8x8_0, eLstIdx) )
      {
        RNOK( m_pcMbSymbolWriteIf->mvd( rcMbDataAccess, eLstIdx, PART_8x16_0 ) );
      }

      if( rcMbDataAccess.getMbData().isBlockFwdBwd( B_8x8_1, eLstIdx) )
      {
        RNOK( m_pcMbSymbolWriteIf->mvd( rcMbDataAccess, eLstIdx, PART_8x16_1 ) );
      }
      return Err::m_nOK;
    }
  
  case MODE_8x8:
  case MODE_8x8ref0:
    {
      for( B8x8Idx c8x8Idx; c8x8Idx.isLegal(); c8x8Idx++ )
      {
        if( rcMbDataAccess.getMbData().isBlockFwdBwd( c8x8Idx.b8x8Index(), eLstIdx ) )
        {
          RNOK( xWriteBlockMv( rcMbDataAccess, c8x8Idx, eLstIdx ) );
        }
      }
      return Err::m_nOK;
    }
   
  default:
    {
      AF();
      return Err::m_nERR;
    }
  }

  return Err::m_nERR;
}


#if JMVM_ONLY  // JVT-U052
ErrVal
MbCoder::xWriteIcp( MbDataAccess& rcMbDataAccess,
                    MbMode        eMbMode )
{
  AOT_DBG( rcMbDataAccess.getMbData().isIntra() );

  switch( eMbMode )
  {
  case MODE_SKIP:
    {
#if JMVM_ONLY  // JVT-U052
      if( rcMbDataAccess.getSH().isInterB() )
        RNOK( m_pcMbSymbolWriteIf->Icpd( rcMbDataAccess ) );
#endif
      return Err::m_nOK;
    }
  case MODE_16x16:
    {
      RNOK( m_pcMbSymbolWriteIf->Icpd( rcMbDataAccess ) );
      return Err::m_nOK;
    }
  case MODE_16x8:
  case MODE_8x16:
  case MODE_8x8:
  case MODE_8x8ref0:
    return Err::m_nOK;
  default:
    {
      AOT(1);
      return Err::m_nERR;
    }
  }

  return Err::m_nERR;

}
#endif



ErrVal MbCoder::xWriteTextureInfo( MbDataAccess&            rcMbDataAccess,
																	 MbDataAccess*						pcMbDataAccessBase,	// JVT-R091
                                   const MbTransformCoeffs& rcMbTCoeff,
                                   Bool											bTrafo8x8Flag
                                   )
{

  Bool bWriteDQp = true;
  UInt uiCbp = rcMbDataAccess.getMbData().getMbCbp();

  if( ! rcMbDataAccess.getMbData().isIntra16x16() )
  {
    RNOK( m_pcMbSymbolWriteIf->cbp( rcMbDataAccess ) );

    bWriteDQp = ( 0 != uiCbp );
  }


  if( bTrafo8x8Flag && ( rcMbDataAccess.getMbData().getMbCbp() & 0x0F ) )
  {
    ROT( rcMbDataAccess.getMbData().isIntra16x16() );
    ROT( rcMbDataAccess.getMbData().isIntra4x4  () );
    RNOK( m_pcMbSymbolWriteIf->transformSize8x8Flag( rcMbDataAccess ) );
  }

  if( bWriteDQp )
  {
    RNOK( m_pcMbSymbolWriteIf->deltaQp( rcMbDataAccess ) );
  }

  
  if( rcMbDataAccess.getMbData().getBLSkipFlag() ||
     !rcMbDataAccess.getMbData().isIntra() )
  {
    if( rcMbDataAccess.getSH().getAdaptivePredictionFlag() )
    {
      if( ! rcMbDataAccess.getSH().isIntra() )
      {
        RNOK( m_pcMbSymbolWriteIf->resPredFlag( rcMbDataAccess ) );
        if ( rcMbDataAccess.getMbData().getResidualPredFlag( PART_16x16 ) && 
              rcMbDataAccess.getMbData().getBLSkipFlag() )
        {
          RNOK( m_pcMbSymbolWriteIf->smoothedRefFlag( rcMbDataAccess ) );
        }
      }
    }
  }

  if( rcMbDataAccess.getMbData().isIntra16x16() )
  {
    RNOK( xScanLumaIntra16x16( rcMbDataAccess, rcMbTCoeff, rcMbDataAccess.getMbData().isAcCoded() ) );
    RNOK( xScanChromaBlocks  ( rcMbDataAccess, rcMbTCoeff, rcMbDataAccess.getMbData().getCbpChroma16x16() ) );

    return Err::m_nOK;
  }



  if( rcMbDataAccess.getMbData().isTransformSize8x8() )
  {
    for( B8x8Idx c8x8Idx; c8x8Idx.isLegal(); c8x8Idx++ )
    {
      if( (uiCbp >> c8x8Idx.b8x8Index()) & 1 )
      {
        RNOK( m_pcMbSymbolWriteIf->residualBlock8x8( rcMbDataAccess, c8x8Idx, LUMA_SCAN ) );
      }
    }
  }
  else
  {
    for( B8x8Idx c8x8Idx; c8x8Idx.isLegal(); c8x8Idx++ )
    {
      if( (uiCbp >> c8x8Idx.b8x8Index()) & 1 )
      {
        for( S4x4Idx cIdx(c8x8Idx); cIdx.isLegal(c8x8Idx); cIdx++ )
        {
          RNOK( xScanLumaBlock( rcMbDataAccess, rcMbTCoeff, cIdx ) );
        }
      }
    }
  }


  RNOK( xScanChromaBlocks( rcMbDataAccess, rcMbTCoeff, rcMbDataAccess.getMbData().getCbpChroma4x4() ) );

  return Err::m_nOK;
}






ErrVal MbCoder::xScanLumaIntra16x16( MbDataAccess& rcMbDataAccess, const MbTransformCoeffs& rcTCoeff, Bool bAC )
{
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, B4x4Idx(0), LUMA_I16_DC ) );
  ROFRS( bAC, Err::m_nOK );

  for( S4x4Idx cIdx; cIdx.isLegal(); cIdx++)
  {
    RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, cIdx, LUMA_I16_AC ) );
  }

  return Err::m_nOK;
}


ErrVal MbCoder::xScanLumaBlock( MbDataAccess& rcMbDataAccess, const MbTransformCoeffs& rcTCoeff, LumaIdx cIdx )
{
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, cIdx, LUMA_SCAN ) );
  return Err::m_nOK;
}


ErrVal MbCoder::xScanChromaDc( MbDataAccess& rcMbDataAccess, const MbTransformCoeffs& rcTCoeff )
{
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, CIdx(0), CHROMA_DC ) );
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, CIdx(4), CHROMA_DC ) );

  return Err::m_nOK;
}


ErrVal MbCoder::xScanChromaAcU( MbDataAccess& rcMbDataAccess, const MbTransformCoeffs& rcTCoeff )
{
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, CIdx(0), CHROMA_AC ) );
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, CIdx(1), CHROMA_AC ) );
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, CIdx(2), CHROMA_AC ) );
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, CIdx(3), CHROMA_AC ) );
  return Err::m_nOK;
}


ErrVal MbCoder::xScanChromaAcV( MbDataAccess& rcMbDataAccess, const MbTransformCoeffs& rcTCoeff )
{
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, CIdx(4), CHROMA_AC ) );
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, CIdx(5), CHROMA_AC ) );
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, CIdx(6), CHROMA_AC ) );
  RNOK( m_pcMbSymbolWriteIf->residualBlock( rcMbDataAccess, CIdx(7), CHROMA_AC ) );
  return Err::m_nOK;
}


ErrVal MbCoder::xScanChromaBlocks( MbDataAccess& rcMbDataAccess, const MbTransformCoeffs& rcTCoeff, UInt uiChromCbp )
{
  ROTRS( 1 > uiChromCbp, Err::m_nOK );

  RNOK( xScanChromaDc ( rcMbDataAccess, rcTCoeff ) );

  ROTRS( 2 > uiChromCbp, Err::m_nOK );

  RNOK( xScanChromaAcU( rcMbDataAccess, rcTCoeff ) );
  RNOK( xScanChromaAcV( rcMbDataAccess, rcTCoeff ) );
  return Err::m_nOK;
}

#if JMVM_ONLY //JVT-Z021
ErrVal
MbCoder::xWriteImsm(MbDataAccess& rcMbDataAccess)
{
	Bool bIsViewL1;
	if(rcMbDataAccess.getSH().getSPS().getSpsMVC()->getSingleLoopDecoding()) //SLD
	{
		bIsViewL1 = rcMbDataAccess.getSH().getSPS().getSpsMVC()->getNumNonAnchorRefsSldForListX (rcMbDataAccess.getSH().getViewId(), LIST_1);
	}
	else
	{
		bIsViewL1 = rcMbDataAccess.getSH().getSPS().getSpsMVC()->getNumNonAnchorRefsForListX (rcMbDataAccess.getSH().getViewId(), LIST_1);
	}
	if(bIsViewL1 == 0)
	{
		RNOK  ( MbCoder::m_pcMbSymbolWriteIf->MotionSkipOffset( rcMbDataAccess ) );
	}
	else
	{
		RNOK  ( MbCoder::m_pcMbSymbolWriteIf->MotionSkipListXFlag( rcMbDataAccess ) );
		if(rcMbDataAccess.getMbData().m_pcMbImsm->m_iListXFlag == LIST_0)
		{
			RNOK  ( MbCoder::m_pcMbSymbolWriteIf->MotionSkipOffset( rcMbDataAccess ) );
		}
		else
		{
			RNOK  ( MbCoder::m_pcMbSymbolWriteIf->MotionSkipOffset( rcMbDataAccess ) );
		}
	}

	return Err::m_nOK;
}
#endif //JMVM_ONLY 


H264AVC_NAMESPACE_END

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产很黄免费观看久久| 亚洲一区二区av电影| 国产精品一区二区免费不卡| 欧美成人bangbros| 国产剧情一区在线| 国产亚洲精品bt天堂精选| 成人小视频在线| 亚洲蜜桃精久久久久久久| 欧美三级蜜桃2在线观看| 青椒成人免费视频| 日本一区二区成人在线| 91女厕偷拍女厕偷拍高清| 午夜精品一区二区三区电影天堂 | 亚洲欧美aⅴ...| 欧美亚洲一区二区三区四区| 视频一区视频二区中文字幕| 久久综合成人精品亚洲另类欧美| 成人精品亚洲人成在线| 亚洲一区在线观看视频| 精品国产成人在线影院| 99视频精品在线| 日本不卡一区二区三区高清视频| 精品国产1区二区| 一本到三区不卡视频| 日韩国产精品91| 国产精品毛片久久久久久| 91丝袜美腿高跟国产极品老师| 亚洲成人动漫精品| 国产女人aaa级久久久级 | 99天天综合性| 免费在线视频一区| 日韩美女视频一区| 欧美大片在线观看一区二区| 成人少妇影院yyyy| 视频一区二区不卡| 综合久久国产九一剧情麻豆| 日韩精品中文字幕一区二区三区| 91免费在线看| 国产麻豆视频一区| 天堂在线亚洲视频| 国产精品成人免费| 91精品国产综合久久精品麻豆| 国产自产高清不卡| 亚洲第一搞黄网站| 国产精品久久久久一区二区三区 | 亚洲国产一区二区在线播放| 久久久久一区二区三区四区| 欧美乱妇15p| 色呦呦一区二区三区| 精品一区二区在线免费观看| 一区二区三区免费网站| 国产拍揄自揄精品视频麻豆| 宅男噜噜噜66一区二区66| 99re在线视频这里只有精品| 国产综合久久久久影院| 性做久久久久久久久| 亚洲女爱视频在线| 久久精品免视看| 日韩亚洲欧美一区二区三区| 欧美午夜在线观看| 在线精品视频小说1| 99视频有精品| 丰满亚洲少妇av| 免费欧美高清视频| 偷拍自拍另类欧美| 亚洲第一在线综合网站| 日韩avvvv在线播放| 亚洲国产视频网站| 亚洲欧洲国产专区| 久久精品人人做人人爽人人| 欧美电视剧在线观看完整版| 欧美日韩情趣电影| 欧美怡红院视频| 欧日韩精品视频| 欧美亚洲一区二区在线| 欧美午夜理伦三级在线观看| 在线精品观看国产| 色综合久久综合网| 欧美性生交片4| 欧美日韩国产色站一区二区三区| 欧美在线制服丝袜| 在线视频国产一区| 欧美天堂亚洲电影院在线播放| 不卡的看片网站| 色综合中文字幕国产 | 69av一区二区三区| 91精品国产麻豆国产自产在线| 欧美午夜片在线观看| 欧美午夜精品久久久| 91看片淫黄大片一级在线观看| 99久久精品国产精品久久| 91美女片黄在线| 一本一道综合狠狠老| 91美女精品福利| 不卡的电视剧免费网站有什么| 99久久国产免费看| 欧美日韩精品欧美日韩精品一综合| 欧美日韩色综合| 26uuu欧美| 国产精品久久久久久亚洲毛片 | 欧美男男青年gay1069videost | 波波电影院一区二区三区| av在线这里只有精品| 99热99精品| 欧美精品久久一区二区三区| 日韩精品一区国产麻豆| 久久精品人人做人人爽人人| 国产精品盗摄一区二区三区| 亚洲福利视频一区二区| 精品一区二区成人精品| 91视频一区二区三区| 7777精品伊人久久久大香线蕉经典版下载 | 在线精品国精品国产尤物884a | 日韩欧美国产三级| 国产精品理论片在线观看| 亚洲综合一区二区精品导航| 美女一区二区三区在线观看| 成人av资源在线| 欧美一级黄色大片| 《视频一区视频二区| 麻豆国产一区二区| av一区二区三区| 精品免费视频一区二区| 亚洲免费视频成人| 国产精品资源在线观看| 欧洲一区二区三区免费视频| 337p日本欧洲亚洲大胆色噜噜| 精品一区二区三区免费视频| 在线观看国产91| 国产清纯美女被跳蛋高潮一区二区久久w| 亚洲男人天堂av网| 韩国一区二区视频| 欧美精品久久一区| 亚洲欧美色图小说| 国内成人精品2018免费看| 欧美性猛片aaaaaaa做受| 国产色产综合产在线视频| 日韩高清一级片| 色综合夜色一区| 国产精品―色哟哟| 精品综合久久久久久8888| 欧美日本一道本| 亚洲国产三级在线| 94-欧美-setu| 国产网站一区二区| 久久国产麻豆精品| 8x8x8国产精品| 亚洲图片有声小说| 91麻豆自制传媒国产之光| 国产精品人妖ts系列视频| 久88久久88久久久| 日韩欧美一区二区视频| 香蕉久久一区二区不卡无毒影院| 色播五月激情综合网| 中文字幕亚洲一区二区va在线| 国产a久久麻豆| 久久久美女毛片| 国产精品一区三区| 久久亚区不卡日本| 国产一区二区三区四| 精品电影一区二区| 黄色日韩网站视频| 欧美大片顶级少妇| 久久爱另类一区二区小说| 日韩一区二区三区免费看| 麻豆成人av在线| 欧美电影免费观看高清完整版在线观看| 日韩制服丝袜先锋影音| 欧美日韩免费高清一区色橹橹 | 另类小说图片综合网| 日韩一级在线观看| 理论电影国产精品| 337p粉嫩大胆色噜噜噜噜亚洲 | av色综合久久天堂av综合| 国产精品色噜噜| 一本久道久久综合中文字幕| 亚洲精品综合在线| 欧美三级电影精品| 日产欧产美韩系列久久99| 精品捆绑美女sm三区| 国产福利一区在线| 综合网在线视频| 欧美二区在线观看| 精品中文字幕一区二区小辣椒| 久久久久久久久伊人| 91在线视频官网| 顶级嫩模精品视频在线看| 中文字幕一区二区不卡| 欧美亚洲一区二区在线观看| 日韩精品欧美成人高清一区二区| 欧美一二三区精品| 丰满岳乱妇一区二区三区| 亚洲蜜桃精久久久久久久| 777奇米四色成人影色区| 国产老肥熟一区二区三区| 椎名由奈av一区二区三区| 欧美福利电影网| 国产精品123| 亚洲综合色在线| 精品国产乱子伦一区|