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

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

?? mc.cpp

?? 小波圖像變換
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
						ppxlcSrc += 8;
						ppxlcSrc2 += 8;
					}
					ppxlcRef += m_iFrameWidthY;
					ppxlcPred += MB_SIZE;
				}
			}
		}
	}
	else {
		if (!(yRef & 1)) {
			if (!(xRef & 1)) {  //!bXSubPxl && !bYSubPxl
				for (iy = 0; iy < iSize; iy++) {
					memcpy (ppxlcPred, ppxlcRef, iSize*sizeof(PixelC));
					ppxlcRef += m_iFrameWidthY;
// RRV modification
					ppxlcPred += (m_vopmd.RRVmode.iRRVOnOff == 1) ? (iSize) : (MB_SIZE);
//					ppxlcPred += MB_SIZE;
// ~RRV
				}
			}
			else {  //bXSubPxl && !bYSubPxl
				for (iy = 0; iy < iSize; iy++){
					for (ix = 0; ix < iSize; ix++)
						ppxlcPred [ix] = (ppxlcRef [ix] + ppxlcRef [ix + 1] + 1 - iRoundingControl) >> 1;
					ppxlcRef += m_iFrameWidthY;
// RRV modification
					ppxlcPred += (m_vopmd.RRVmode.iRRVOnOff == 1) ? (iSize) : (MB_SIZE);
//					ppxlcPred += MB_SIZE;
// ~RRV
				}
			}
		}
		else {
			const PixelC* ppxlcRefBot;
			if (!(xRef & 1)) {  //!bXSubPxl&& bYSubPxl
				for (iy = 0; iy < iSize; iy++) {
					ppxlcRefBot = ppxlcRef + m_iFrameWidthY;		//UPln -> pixels (xInt,yInt+1);
					for (ix = 0; ix < iSize; ix++) 
						ppxlcPred [ix] = (ppxlcRef [ix] + ppxlcRefBot [ix] + 1 - iRoundingControl) >> 1;
					ppxlcRef = ppxlcRefBot;
// RRV modification
					ppxlcPred += (m_vopmd.RRVmode.iRRVOnOff == 1) ? (iSize) : (MB_SIZE);
//					ppxlcPred += MB_SIZE;
// ~RRV
				}
			}
			else { // bXSubPxl && bYSubPxl
				for (iy = 0; iy < iSize; iy++) {
					ppxlcRefBot = ppxlcRef + m_iFrameWidthY;		//UPln -> pixels (xInt,yInt+1);
					for (ix = 0; ix < iSize; ix++){
						ppxlcPred [ix] = (
							ppxlcRef [ix + 1] + ppxlcRef [ix] +
							ppxlcRefBot [ix + 1] + ppxlcRefBot [ix] + 2 - iRoundingControl
						) >> 2;

					}
					ppxlcRef = ppxlcRefBot;
// RRV modification
					ppxlcPred += (m_vopmd.RRVmode.iRRVOnOff == 1) ? (iSize) : (MB_SIZE);
//					ppxlcPred += MB_SIZE;
// ~RRV
				}
			}
		}
	}
}

Void CVideoObject::motionCompQuarterSample (
	PixelC* ppxlcPred, // can be either Y or A
	const PixelC* ppxlcRefLeftTop, // point to left-top of the frame
	Int iSize, // either MB or BLOCK size
	CoordI xRef, CoordI yRef, // x + mvX in quarter pel unit
	Int iRoundingControl, // rounding control
	CRct *prctMVLimit // extended bounding box
    )
{
	CoordI ix, iy;
    U8 *ppxlcblk;
    
	limitMVRangeToExtendedBBQuarterPel(xRef,yRef,prctMVLimit,iSize);
    
    Int blkSizeX, blkSizeY;
    if (iSize == 0) { // INTERLACED
      blkSizeX = 16;
      blkSizeY = 8;
      
      ppxlcblk = (U8*) calloc(blkSizeX*blkSizeX,sizeof(U8));
      blkInterpolateY (ppxlcRefLeftTop,iSize,xRef,yRef,ppxlcblk,iRoundingControl);
      
      for (iy = 0; iy < blkSizeX; iy++) { 
        if (!(iy&1)) 
          for (ix = 0; ix < blkSizeX; ix++) { 
            ppxlcPred [ix] = *(ppxlcblk+ix+iy*blkSizeX);
          }
        ppxlcPred += blkSizeX;
      }
    } //~INTERLACED
    else { 
      blkSizeX = iSize;
      blkSizeY = iSize;
      
      ppxlcblk = (U8*) calloc(blkSizeX*blkSizeX,sizeof(U8));
      blkInterpolateY (ppxlcRefLeftTop,iSize,xRef,yRef,ppxlcblk,iRoundingControl);
      
      for (iy = 0; iy < blkSizeX; iy++) { 
        for (ix = 0; ix < blkSizeX; ix++) { 
          ppxlcPred [ix] = *(ppxlcblk+ix+iy*blkSizeX);
        }
        ppxlcPred += MB_SIZE;
      }
    }

    free(ppxlcblk);
}

Void CVideoObject::motionCompDirectMode(                // Interlaced direct mode
    CoordI x, CoordI y,
    CMBMode *pmbmd,
    const CMotionVector *pmvRef,
    CRct *prctMVLimitFwd, CRct *prctMVLimitBak,
	Int plane	// plane=1 for grey scale, plane=0 for texture, 02-17-99

                                        )
{
	Int* rgiMvRound;
	UInt uiDivisor = 0;
	Int xRefUVF,yRefUVF,xRefUVB,yRefUVB;

// begin of new changes 10/21/98
	Int iMBX,iMBY;
	const CMBMode *pmbmdRef; 

	if(m_volmd.fAUsage != RECTANGLE)
	{
		iMBX=(x-m_rctCurrVOPY.left)/MB_SIZE;
		iMBY=(y-m_rctCurrVOPY.top)/MB_SIZE;
		pmbmdRef= m_rgmbmdRef +
				(iMBX+iMBY*m_iNumMBXRef);
	}
	else
	{
		iMBX=x/MB_SIZE;
		iMBY=y/MB_SIZE;
		pmbmdRef= m_rgmbmdRef +
				iMBX+iMBY*m_iNumMBXRef;
	}
// end of new changes 10/21/98

  if (pmbmdRef->m_rgTranspStatus[0]==ALL) {
    static CMotionVector mvZero[5];
    pmvRef = mvZero;
  }

	if ((iMBX<m_iNumMBXRef && iMBX>=0 && iMBY<m_iNumMBYRef && iMBY>=0)&& // new change 10/21/98
		(pmbmdRef->m_bFieldMV&&pmbmdRef->m_rgTranspStatus[0]!=ALL)) {
      static I8 iTROffsetTop[] = {  0, 0,  1, 1, 0, 0, -1, -1 };
      static I8 iTROffsetBot[] = { -1, 0, -1, 0, 1, 0,  1,  0 };
      CoordI iXFwdTop, iXFwdBot, iXBakTop, iXBakBot;
      CoordI iYFwdTop, iYFwdBot, iYBakTop, iYBakBot;
      CoordI iXFTQSUV, iXFBQSUV, iXBTQSUV, iXBBQSUV;
      CoordI iYFTQSUV, iYFBQSUV, iYBTQSUV, iYBBQSUV;
      const CMotionVector *pmvRefTop, *pmvRefBot;
      Int iTopRefFldOffset = 0, iBotRefFldOffset = 0;
      Int iCode = (Int)(vopmd().bTopFieldFirst) << 2;
      
      pmbmd->m_bFieldMV = 1;  // set field direct mode for grey scale, Krit 02-17-99

      assert((pmbmdRef->m_dctMd != INTRA) && (pmbmdRef->m_dctMd != INTRAQ));
      if (pmbmdRef->m_bForwardTop) {
        iCode |= 2;
        iTopRefFldOffset = 1;
        pmvRefTop = pmvRef + 6;
      } else
        pmvRefTop = pmvRef + 5;
      if (pmbmdRef->m_bForwardBottom) {
        iCode |= 1;
        iBotRefFldOffset = 1;
        pmvRefBot = pmvRef + 8;
      } else
        pmvRefBot = pmvRef + 7;
      Int iTempRefDTop = 2*(m_tFutureRef - m_tPastRef) + iTROffsetTop[iCode];
      Int iTempRefDBot = 2*(m_tFutureRef - m_tPastRef) + iTROffsetBot[iCode];
      Int iTempRefBTop = 2*(m_t          - m_tPastRef) + iTROffsetTop[iCode];
      Int iTempRefBBot = 2*(m_t          - m_tPastRef) + iTROffsetBot[iCode];
      
      assert(iTempRefDTop > 0); assert(iTempRefDBot > 0); assert(iTempRefBTop > 0); assert(iTempRefBBot > 0);
      
      // Find MVs for the top field
      iXFwdTop = (pmvRefTop->m_vctTrueHalfPel.x * iTempRefBTop) / iTempRefDTop + pmbmd->m_vctDirectDeltaMV.x;
      iYFwdTop = (pmvRefTop->m_vctTrueHalfPel.y * iTempRefBTop) / iTempRefDTop + pmbmd->m_vctDirectDeltaMV.y;
      iXBakTop = pmbmd->m_vctDirectDeltaMV.x ? (iXFwdTop - pmvRefTop->m_vctTrueHalfPel.x) :
        ((pmvRefTop->m_vctTrueHalfPel.x * (iTempRefBTop - iTempRefDTop)) / iTempRefDTop);
      iYBakTop = pmbmd->m_vctDirectDeltaMV.y ? (iYFwdTop - pmvRefTop->m_vctTrueHalfPel.y) :
        ((pmvRefTop->m_vctTrueHalfPel.y * (iTempRefBTop - iTempRefDTop)) / iTempRefDTop);
      
      // Find MVs for the bottom field
      iXFwdBot = (pmvRefBot->m_vctTrueHalfPel.x * iTempRefBBot) / iTempRefDBot + pmbmd->m_vctDirectDeltaMV.x;
      iYFwdBot = (pmvRefBot->m_vctTrueHalfPel.y * iTempRefBBot) / iTempRefDBot + pmbmd->m_vctDirectDeltaMV.y;
      iXBakBot = pmbmd->m_vctDirectDeltaMV.x ? (iXFwdBot - pmvRefBot->m_vctTrueHalfPel.x) :
        ((pmvRefBot->m_vctTrueHalfPel.x * (iTempRefBBot - iTempRefDBot)) / iTempRefDBot);
      iYBakBot = pmbmd->m_vctDirectDeltaMV.y ? (iYFwdBot - pmvRefBot->m_vctTrueHalfPel.y) :
        ((pmvRefBot->m_vctTrueHalfPel.y * (iTempRefBBot - iTempRefDBot)) / iTempRefDBot);
    
      // Motion compensate the top field forward
      if (m_volmd.bQuarterSample) {
        iXFTQSUV = iXFwdTop/2; 
        iYFTQSUV = iYFwdTop/2;
        iXBTQSUV = iXBakTop/2; 
        iYBTQSUV = iYBakTop/2;

        iXFBQSUV = iXFwdBot/2;
        iYFBQSUV = iYFwdBot/2;
        iXBBQSUV = iXBakBot/2; 
        iYBBQSUV = iYBakBot/2;

        iYFwdTop = iYFwdTop & ~1;
        iYBakTop = iYBakTop & ~1;
        iYFwdBot = iYFwdBot & ~1;
        iYBakBot = iYBakBot & ~1;
    
        iXFwdTop += 4*x; iYFwdTop += 4*y;
//        limitMVRangeToExtendedBBQuarterPel(iXFwdTop, iYFwdTop, prctMVLimitFwd, MB_SIZE); // deleted by Y.Suzuki for the extended bounding box support
		if (plane==0) {  // texture MC
          motionCompQuarterSample(m_ppxlcPredMBY, 
                                  m_pvopcRefQ0->pixelsY() + iTopRefFldOffset * m_iFrameWidthY, 0, 
                                  iXFwdTop, iYFwdTop, m_vopmd.iRoundingControl, prctMVLimitFwd);
          
//          iXFTQSUV += 2*x; iYFTQSUV += 2*y; // deleted by Y.Suzuki for the extended bounding box support
//          limitMVRangeToExtendedBBHalfPel(iXFTQSUV, iYFTQSUV, prctMVLimitFwd, MB_SIZE); // deleted by Y.Suzuki for the extended bounding box support
//          iXFTQSUV -= 2*x; iYFTQSUV -= 2*y; // deleted by Y.Suzuki for the extended bounding box support
          motionCompFieldUV(m_ppxlcPredMBU, m_ppxlcPredMBV, m_pvopcRefQ0, x, y,
                            (iXFTQSUV & 3) ? ((iXFTQSUV >> 1) | 1) : (iXFTQSUV >> 1),
                            (iYFTQSUV & 6) ? ((iYFTQSUV >> 1) | 2) : (iYFTQSUV >> 1), 
                            iTopRefFldOffset,
                            prctMVLimitFwd); // added by Y.Suzuki for the extended bounding box support
		}
		else {  // plane=1, grey scale MC
          for(Int iAuxComp=0;iAuxComp<m_volmd.iAuxCompCount;iAuxComp++) { // MAC (SB) 26-Nov-99
            motionCompQuarterSample(m_ppxlcPredMBA[iAuxComp], 
              m_pvopcRefQ0->pixelsA(iAuxComp) + iTopRefFldOffset * m_iFrameWidthY, 0, 
              iXFwdTop, iYFwdTop, m_vopmd.iRoundingControl, prctMVLimitFwd);
          }
		}
      }
      else {
          iXFwdTop += 2*x; iYFwdTop += 2*y;
//        limitMVRangeToExtendedBBHalfPel(iXFwdTop, iYFwdTop, prctMVLimitFwd, MB_SIZE); // deleted by Y.Suzuki for the extended bounding box support
		if (plane==0) {  // texture MC
          motionCompYField(m_ppxlcPredMBY,
                           m_pvopcRefQ0->pixelsY() + iTopRefFldOffset * m_iFrameWidthY, iXFwdTop, iYFwdTop,
                           prctMVLimitFwd); // added by Y.Suzuki for the extended bounding box support
          iXFwdTop -= 2*x; iYFwdTop -= 2*y;
          motionCompFieldUV(m_ppxlcPredMBU, m_ppxlcPredMBV, m_pvopcRefQ0, x, y,
                            (iXFwdTop & 3) ? ((iXFwdTop >> 1) | 1) : (iXFwdTop >> 1),
                            (iYFwdTop & 6) ? ((iYFwdTop >> 1) | 2) : (iYFwdTop >> 1), iTopRefFldOffset,
                            prctMVLimitFwd); // added by Y.Suzuki for the extended bounding box support
		}
		else {  // plane=1, grey scale MC
          for(Int iAuxComp=0;iAuxComp<m_volmd.iAuxCompCount;iAuxComp++) { // MAC (SB) 26-Nov-99
            motionCompYField(m_ppxlcPredMBA[iAuxComp],
                           m_pvopcRefQ0->pixelsA(iAuxComp) + iTopRefFldOffset * m_iFrameWidthY, iXFwdTop, iYFwdTop,
						   prctMVLimitFwd); // added by Y.Suzuki for the extended bounding box support
          }

          iXFwdTop -= 2*x; iYFwdTop -= 2*y;
		}
      }
    

      // Motion compensate the top field backward
    if (m_volmd.bQuarterSample) {
      iXBakTop += 4*x; iYBakTop += 4*y;
//      limitMVRangeToExtendedBBQuarterPel(iXBakTop, iYBakTop, prctMVLimitFwd, MB_SIZE); // deleted by Y.Suzuki for the extended bounding box support
      if (plane==0) {  // texture MC
        motionCompQuarterSample(m_ppxlcPredMBBackY, 
                                m_pvopcRefQ1->pixelsY(), 0, 
                                iXBakTop, iYBakTop, m_vopmd.iRoundingControl, prctMVLimitBak);
        
//        iXBTQSUV += 2*x; iYBTQSUV += 2*y; // deleted by Y.Suzuki for the extended bounding box support
//        limitMVRangeToExtendedBBHalfPel(iXBTQSUV, iYBTQSUV, prctMVLimitBak, MB_SIZE); // deleted by Y.Suzuki for the extended bounding box support
//        iXBTQSUV -= 2*x; iYBTQSUV -= 2*y; // deleted by Y.Suzuki for the extended bounding box support
        motionCompFieldUV(m_ppxlcPredMBBackU, m_ppxlcPredMBBackV, m_pvopcRefQ1, x, y,
                          (iXBTQSUV & 3) ? ((iXBTQSUV >> 1) | 1) : (iXBTQSUV >> 1),
                          (iYBTQSUV & 6) ? ((iYBTQSUV >> 1) | 2) : (iYBTQSUV >> 1), 
                          0,
                          prctMVLimitBak); // added by Y.Suzuki for the extended bounding box support
      }
      else {  // plane=1, grey scale MC
        for(Int iAuxComp=0;iAuxComp<m_volmd.iAuxCompCount;iAuxComp++) { // MAC (SB) 26-Nov-99
          motionCompQuarterSample(m_ppxlcPredMBBackA[iAuxComp], 
                                  m_pvopcRefQ1->pixelsA(iAuxComp), 0, 
                                  iXBakTop, iYBakTop, m_vopmd.iRoundingControl, prctMVLimitBak);
        }
	  }
    }
    else {
      iXBakTop += 2*x; iYBakTop += 2*y;
//      limitMVRangeToExtendedBBHalfPel(iXBakTop, iYBakTop, prctMVLimitBak, MB_SIZE); // deleted by Y.Suzuki for the extended bounding box support
      if (plane==0) {  // texture MC
        motionCompYField(m_ppxlcPredMBBackY, m_pvopcRefQ1->pixelsY(), iXBakTop,  iYBakTop,
			prctMVLimitBak); // added by Y.Suzuki for the extended bounding box support

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产乱妇无码大片在线观看| 亚洲欧美日韩中文播放| 国产精品麻豆一区二区 | 国内精品不卡在线| 成人免费三级在线| 欧美日韩一级黄| 久久久噜噜噜久噜久久综合| 亚洲精品免费在线观看| 日产国产高清一区二区三区| 成人免费视频视频在线观看免费| 欧美性色黄大片| 亚洲精品一线二线三线| 亚洲美腿欧美偷拍| 九一九一国产精品| 91原创在线视频| 欧美xxxx在线观看| 亚洲精品一卡二卡| 国内久久精品视频| 在线观看欧美精品| 久久亚洲春色中文字幕久久久| 亚洲欧美日韩国产手机在线| 麻豆中文一区二区| 在线观看视频91| 久久嫩草精品久久久久| 亚洲aⅴ怡春院| 成人18精品视频| 精品女同一区二区| 亚洲福利国产精品| 成人的网站免费观看| 欧美本精品男人aⅴ天堂| 洋洋av久久久久久久一区| 国产一区二区精品在线观看| 欧美乱熟臀69xxxxxx| 中文字幕一区二区在线播放| 欧洲另类一二三四区| 国产农村妇女精品| 久久爱www久久做| 欧美亚男人的天堂| 日韩毛片视频在线看| 国产一区二区视频在线| 777精品伊人久久久久大香线蕉| 中文字幕一区二区在线观看| 国产中文字幕精品| 欧美一二区视频| 亚洲成av人影院在线观看网| 99国产精品久久久久久久久久| 久久久久久久久久久黄色| 美女国产一区二区| 欧美精品xxxxbbbb| 亚洲第一狼人社区| 在线国产电影不卡| 中文字幕亚洲一区二区va在线| 激情欧美一区二区三区在线观看| 欧美一卡二卡三卡| 日韩激情一二三区| 欧美日韩视频一区二区| 亚洲午夜激情av| 在线视频你懂得一区| 亚洲欧美日本韩国| 99精品国产热久久91蜜凸| 国产精品视频你懂的| 国产91在线观看丝袜| 国产亚洲成年网址在线观看| 捆绑变态av一区二区三区| 日韩一级黄色大片| 免费成人av资源网| 欧美一区二区视频在线观看| 日日欢夜夜爽一区| 欧美高清激情brazzers| 日本在线不卡视频| 日韩免费在线观看| 国内外精品视频| 久久奇米777| 成人永久aaa| 亚洲视频在线一区二区| 91女厕偷拍女厕偷拍高清| 亚洲色大成网站www久久九九| 91美女精品福利| 亚洲伦理在线免费看| 欧美亚洲动漫精品| 丝袜亚洲另类欧美综合| 欧美一区二区三区四区高清| 日韩av中文在线观看| 日韩午夜激情视频| 精品在线免费观看| 337p粉嫩大胆色噜噜噜噜亚洲| 久久精品久久久精品美女| 日韩一区二区在线看| 国产一区二区福利| 欧美精品一区二区三区蜜桃视频| 美腿丝袜亚洲一区| 精品国产91洋老外米糕| 国产乱码精品一区二区三区五月婷 | 日本特黄久久久高潮| 欧美老年两性高潮| 日韩综合小视频| 欧美一区二区在线免费播放| 久久国产夜色精品鲁鲁99| 欧美tk—视频vk| 国产ts人妖一区二区| 91麻豆精品国产91久久久资源速度| 麻豆精品一区二区三区| 精品久久国产老人久久综合| 久久成人精品无人区| 国产欧美精品一区二区色综合朱莉| 国产乱码一区二区三区| 国产精品久久久久婷婷| 成人的网站免费观看| 亚洲妇熟xx妇色黄| 日韩欧美另类在线| 国产一区二区三区久久悠悠色av| 久久婷婷国产综合精品青草| 国产精品88888| 亚洲欧洲精品天堂一级| 色综合一个色综合亚洲| 免费精品视频在线| 久久精品视频免费| 色天使色偷偷av一区二区| 国产91富婆露脸刺激对白| 亚洲欧美成aⅴ人在线观看 | 国产精品国模大尺度视频| 欧美三级电影网站| 狠狠色狠狠色综合系列| 国产精品人成在线观看免费| 日本韩国一区二区三区| 美女视频黄 久久| 国产精品免费久久| 日本韩国欧美在线| 韩国一区二区三区| 亚洲精品欧美在线| 精品日产卡一卡二卡麻豆| 99久久亚洲一区二区三区青草| 亚洲大片一区二区三区| 日韩欧美高清dvd碟片| 91香蕉视频在线| 日韩福利视频导航| 国产精品久久久久一区二区三区共| 欧美日韩国产中文| 成人手机在线视频| 亚洲制服丝袜在线| 久久九九影视网| 欧美三级在线视频| 毛片基地黄久久久久久天堂| 中文字幕一区二区三区在线不卡 | 综合久久久久久久| www国产精品av| 日本高清不卡在线观看| 国产一区在线观看麻豆| 亚洲国产人成综合网站| 国产欧美日韩不卡免费| 91精品免费在线观看| 在线观看三级视频欧美| 国产精品一区二区视频| 亚洲第一主播视频| 亚洲视频一区在线观看| 精品日韩在线观看| 欧美性大战久久| 丁香激情综合五月| 精品在线视频一区| 午夜精品久久久久影视| 国产午夜三级一区二区三| 日韩精品一区二区三区三区免费 | av欧美精品.com| 美女在线一区二区| 亚洲香肠在线观看| 日本一区二区成人在线| 日韩欧美在线综合网| 91香蕉国产在线观看软件| youjizz国产精品| 国产精一区二区三区| 免费在线欧美视频| 亚洲一二三区视频在线观看| 国产亚洲精品超碰| 久久久99精品免费观看| 亚洲视频 欧洲视频| 久久久不卡网国产精品二区| 日韩欧美一级特黄在线播放| 欧美色偷偷大香| 不卡电影一区二区三区| 国产一区二区在线观看免费| 免费人成精品欧美精品| 三级成人在线视频| 亚洲成人av电影在线| 日韩激情视频网站| 亚洲高清久久久| 亚洲一区二区三区四区在线观看| 亚洲视频一二三| 136国产福利精品导航| 亚洲精品中文在线影院| 综合欧美亚洲日本| 亚洲欧美中日韩| 中文字幕久久午夜不卡| 久久久三级国产网站| 欧美激情在线一区二区| 亚洲国产精品99久久久久久久久| 久久久久久久国产精品影院| 欧美精品一区二区精品网| 日韩欧美一级在线播放| 国产亚洲精久久久久久| 国产精品天天看|