日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

RGB 24和YUY2相互转换

發布時間:2023/12/13 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 RGB 24和YUY2相互转换 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

YUY2經常用于電視制式以及許多攝像頭的輸出格式.而我們在處理時經常需要將其轉化為RGB進行處理,這里簡單介紹下YUY2(YUV)與RGB之間相互轉化的關系:

http://msdn2.microsoft.com/en-us/library/ms893078.aspx

?

YUY2(YUV) To RGB:

C = Y - 16

D = U - 128

E = V - 128

R = clip(( 298 * C + 409 * E + 128) >> 8) G = clip(( 298 * C - 100 * D - 208 * E + 128) >> 8) B = clip(( 298 * C + 516 * D + 128) >> 8)

其中 clip()為限制函數,將其取值限制在0-255之間.

?

RGB To YUY2(YUV):

Y = ( ( 66 * R + 129 * G + 25 * B + 128) >> 8) + 16 U = ( ( -38 * R - 74 * G + 112 * B + 128) >> 8) + 128 V = ( ( 112 * R - 94 * G - 18 * B + 128) >> 8) + 128上述兩個公式在代碼中的 int YUV2RGB(void* pYUV, void* pRGB, int width, int height, bool alphaYUV, bool alphaRGB); int RGB2YUV(void* pRGB, void* pYUVX, int width, int height, bool alphaYUV, bool alphaRGB); 函數中轉換。在諸如攝像頭的數據獲取中,我們往往需要直接在YUY2(YUV)空間上進行一些圖象處理,我們希望能夠在YUY2 (YUV)進行一些RGB上可以做到的處理。這里已blending為例,將兩張帶有透明度的YUY2(YUV)圖片進行疊加, 以達到在RGB空間進行圖像合成的效果。RGB空間進行圖像疊加,通常背景(BG)是不透明的,而前景(FG)是帶有透明度的。在RGB空間,可以簡單表示為: Rdest = Rfg*alpha + Rbg*(1-alpha); Gdest = Gfg*alpha + Gbg*(1-alpha); Bdest = Bfg*alpha + Bbg*(1-alpha); // Rdest、Gdest、Bdest 為最終合成后的像素值考慮到 Y = ( ( 66 * R + 129 * G + 25 * B + 128) >> 8) + 16 U = ( ( -38 * R - 74 * G + 112 * B + 128) >> 8) + 128 V = ( ( 112 * R - 94 * G - 18 * B + 128) >> 8) + 128 我們可以推導出(Ydest-16)<<8 = ((Yfg-16)<<8)*alpha + ((Ybg-16)<<8)*(1-alpha); (Udest-128)<<8 = ((Ufg-128)<<8)*alpha + ((Ubg-128)<<8)*(1-alpha); (Vdest-128)<<8 = ((Vfg-128)<<8)*alpha + ((Vbg-128)<<8)*(1-alpha);從而可以得到 Ydest = (Yfg-16)*alpha + (Ybg-16)*(1-alpha) + 16; Udest = (Ufg-128)*alpha + (Ubg-128)*(1-alpha) + 128; Vdest = (Vfg-128)*alpha + (Vbg-128)*(1-alpha) + 128;這個疊加過程在函數 int YUVBlending(void* pBGYUV, void* pFGYUV, int width, int height, bool alphaBG, bool alphaFG) 中實現。由于本文針對攝像頭采集所得的數據進行處理,因此數據為YUY2格式,即4個字節來表示兩個像素點的YUV信息, 排列為Y1 U1 Y2 V2, 對于像素點1為(Y1, U1, V1),像素點2為(Y2, U1, V1)。即兩個像素點共用U、V信息。這里假設帶有alpha透明度的YUV格式用6個字節來表示兩個像素點的YUV以及alpha信息,排列為 Y1 U1 Y2 V1 alpha1 alpha2 其中像素點1為(Y1, U1, V1, alpha1),像素點2為(Y2, U1, V1, alpha2)。其中alpha為對應點的透明度信息。而帶有alpha透明度RGB格式的圖片,假設為32bits的BMP圖片,每個像素點用4bytes來表示,分別為B G R alpha信息。上述函數的具體實現為: view plaincopy to clipboardprint?
  • // ??
  • //?YUV2RGB ??
  • //?pYUV?????????point?to?the?YUV?data ??
  • //?pRGB?????????point?to?the?RGB?data ??
  • //?width????????width?of?the?picture ??
  • //?height???????height?of?the?picture ??
  • //?alphaYUV?????is?there?an?alpha?channel?in?YUV ??
  • //?alphaRGB?????is?there?an?alpha?channel?in?RGB ??
  • // ??
  • int?YUV2RGB(void*?pYUV,?void*?pRGB,?int?width,?int?height,?bool?alphaYUV,?bool?alphaRGB)??
  • {??
  • ????if?(NULL?==?pYUV)??
  • ????{??
  • ????????return?-1;??
  • ????}??
  • ????unsigned?char*?pYUVData?=?(unsigned?char?*)pYUV;??
  • ????unsigned?char*?pRGBData?=?(unsigned?char?*)pRGB;??
  • ????if?(NULL?==?pRGBData)??
  • ????{??
  • ????????if?(alphaRGB)??
  • ????????{??
  • ????????????pRGBData?=?new?unsigned?char[width*height*4];??
  • ????????}??
  • ????????else??
  • ????????????pRGBData?=?new?unsigned?char[width*height*3];??
  • ????}??
  • ????int?Y1,?U1,?V1,?Y2,?alpha1,?alpha2,?R1,?G1,?B1,?R2,?G2,?B2;??
  • ????int?C1,?D1,?E1,?C2;??
  • ????if?(alphaRGB)??
  • ????{??
  • ????????if?(alphaYUV)??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????Y1?=?*(pYUVData+i*width*3+j*6);??
  • ????????????????????U1?=?*(pYUVData+i*width*3+j*6+1);??
  • ????????????????????Y2?=?*(pYUVData+i*width*3+j*6+2);??
  • ????????????????????V1?=?*(pYUVData+i*width*3+j*6+3);??
  • ????????????????????alpha1?=?*(pYUVData+i*width*3+j*6+4);??
  • ????????????????????alpha2?=?*(pYUVData+i*width*3+j*6+5);??
  • ????????????????????C1?=?Y1-16;??
  • ????????????????????C2?=?Y2-16;??
  • ????????????????????D1?=?U1-128;??
  • ????????????????????E1?=?V1-128;??
  • ????????????????????R1?=?((298*C1?+?409*E1?+?128)>>8>255???255?:?(298*C1?+?409*E1?+?128)>>8);??
  • ????????????????????G1?=?((298*C1?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C1?-?100*D1?-?208*E1?+?128)>>8);????
  • ????????????????????B1?=?((298*C1+516*D1?+128)>>8>255???255?:?(298*C1+516*D1?+128)>>8);????
  • ????????????????????R2?=?((298*C2?+?409*E1?+?128)>>8>255???255?:?(298*C2?+?409*E1?+?128)>>8);??
  • ????????????????????G2?=?((298*C2?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C2?-?100*D1?-?208*E1?+?128)>>8);??
  • ????????????????????B2?=?((298*C2?+?516*D1?+128)>>8>255???255?:?(298*C2?+?516*D1?+128)>>8);????
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+2)?=?R1<0???0?:?R1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+1)?=?G1<0???0?:?G1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8)?=?B1<0???0?:?B1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+3)?=?alpha1;??????
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+6)?=?R2<0???0?:?R2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+5)?=?G2<0???0?:?G2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+4)?=?B2<0???0?:?B2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+7)?=?alpha2;??????
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????????else??
  • ????????{??
  • ????????????int?alpha?=?255;??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????Y1?=?*(pYUVData+i*width*2+j*4);??
  • ????????????????????U1?=?*(pYUVData+i*width*2+j*4+1);??
  • ????????????????????Y2?=?*(pYUVData+i*width*2+j*4+2);??
  • ????????????????????V1?=?*(pYUVData+i*width*2+j*4+3);??
  • ????????????????????C1?=?Y1-16;??
  • ????????????????????C2?=?Y2-16;??
  • ????????????????????D1?=?U1-128;??
  • ????????????????????E1?=?V1-128;??
  • ????????????????????R1?=?((298*C1?+?409*E1?+?128)>>8>255???255?:?(298*C1?+?409*E1?+?128)>>8);??
  • ????????????????????G1?=?((298*C1?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C1?-?100*D1?-?208*E1?+?128)>>8);????
  • ????????????????????B1?=?((298*C1+516*D1?+128)>>8>255???255?:?(298*C1+516*D1?+128)>>8);????
  • ????????????????????R2?=?((298*C2?+?409*E1?+?128)>>8>255???255?:?(298*C2?+?409*E1?+?128)>>8);??
  • ????????????????????G2?=?((298*C2?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C2?-?100*D1?-?208*E1?+?128)>>8);??
  • ????????????????????B2?=?((298*C2?+?516*D1?+128)>>8>255???255?:?(298*C2?+?516*D1?+128)>>8);????
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+2)?=?R1<0???0?:?R1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+1)?=?G1<0???0?:?G1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8)?=?B1<0???0?:?B1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+3)?=?alpha;???
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+6)?=?R2<0???0?:?R2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+5)?=?G2<0???0?:?G2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+4)?=?B2<0???0?:?B2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+7)?=?alpha;???
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????}??
  • ????else??
  • ????{??
  • ????????if?(alphaYUV)??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????Y1?=?*(pYUVData+i*width*3+j*4);??
  • ????????????????????U1?=?*(pYUVData+i*width*3+j*4+1);??
  • ????????????????????Y2?=?*(pYUVData+i*width*3+j*4+2);??
  • ????????????????????V1?=?*(pYUVData+i*width*3+j*4+3);??
  • ????????????????????C1?=?Y1-16;??
  • ????????????????????C2?=?Y2-16;??
  • ????????????????????D1?=?U1-128;??
  • ????????????????????E1?=?V1-128;??
  • ????????????????????R1?=?((298*C1?+?409*E1?+?128)>>8>255???255?:?(298*C1?+?409*E1?+?128)>>8);??
  • ????????????????????G1?=?((298*C1?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C1?-?100*D1?-?208*E1?+?128)>>8);????
  • ????????????????????B1?=?((298*C1+516*D1?+128)>>8>255???255?:?(298*C1+516*D1?+128)>>8);????
  • ????????????????????R2?=?((298*C2?+?409*E1?+?128)>>8>255???255?:?(298*C2?+?409*E1?+?128)>>8);??
  • ????????????????????G2?=?((298*C2?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C2?-?100*D1?-?208*E1?+?128)>>8);??
  • ????????????????????B2?=?((298*C2?+?516*D1?+128)>>8>255???255?:?(298*C2?+?516*D1?+128)>>8);????
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+2)?=?R1<0???0?:?R1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+1)?=?G1<0???0?:?G1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6)?=?B1<0???0?:?B1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+5)?=?R2<0???0?:?R2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+4)?=?G2<0???0?:?G2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+3)?=?B2<0???0?:?B2;??
  • ????????????????}??
  • ????????????}??
  • ????????}??
  • ????????else??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????Y1?=?*(pYUVData+i*width*2+j*4);??
  • ????????????????????U1?=?*(pYUVData+i*width*2+j*4+1);??
  • ????????????????????Y2?=?*(pYUVData+i*width*2+j*4+2);??
  • ????????????????????V1?=?*(pYUVData+i*width*2+j*4+3);??
  • ????????????????????C1?=?Y1-16;??
  • ????????????????????C2?=?Y2-16;??
  • ????????????????????D1?=?U1-128;??
  • ????????????????????E1?=?V1-128;??
  • ????????????????????R1?=?((298*C1?+?409*E1?+?128)>>8>255???255?:?(298*C1?+?409*E1?+?128)>>8);??
  • ????????????????????G1?=?((298*C1?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C1?-?100*D1?-?208*E1?+?128)>>8);????
  • ????????????????????B1?=?((298*C1+516*D1?+128)>>8>255???255?:?(298*C1+516*D1?+128)>>8);????
  • ????????????????????R2?=?((298*C2?+?409*E1?+?128)>>8>255???255?:?(298*C2?+?409*E1?+?128)>>8);??
  • ????????????????????G2?=?((298*C2?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C2?-?100*D1?-?208*E1?+?128)>>8);??
  • ????????????????????B2?=?((298*C2?+?516*D1?+128)>>8>255???255?:?(298*C2?+?516*D1?+128)>>8);????
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+2)?=?R1<0???0?:?R1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+1)?=?G1<0???0?:?G1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6)?=?B1<0???0?:?B1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+5)?=?R2<0???0?:?R2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+4)?=?G2<0???0?:?G2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+3)?=?B2<0???0?:?B2;??
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????}??
  • ????return?0;??
  • }??
  • ??
  • // ??
  • //?RGB2YUV ??
  • //?pRGB?????????point?to?the?RGB?data ??
  • //?pYUV?????????point?to?the?YUV?data ??
  • //?width????????width?of?the?picture ??
  • //?height???????height?of?the?picture ??
  • //?alphaYUV?????is?there?an?alpha?channel?in?YUV ??
  • //?alphaRGB?????is?there?an?alpha?channel?in?RGB ??
  • // ??
  • int?RGB2YUV(void*?pRGB,?void*?pYUV,?int?width,?int?height,?bool?alphaYUV,?bool?alphaRGB)??
  • {??
  • ????if?(NULL?==?pRGB)??
  • ????{??
  • ????????return?-1;??
  • ????}??
  • ????unsigned?char*?pRGBData?=?(unsigned?char?*)pRGB;??
  • ????unsigned?char*?pYUVData?=?(unsigned?char?*)pYUV;??
  • ????if?(NULL?==?pYUVData)??
  • ????{??
  • ????????if?(alphaYUV)??
  • ????????{??
  • ????????????pYUVData?=?new?unsigned?char[width*height*3];??
  • ????????}??
  • ????????else??
  • ????????????pYUVData?=?new?unsigned?char[width*height*2];??
  • ????}??
  • ????int?R1,?G1,?B1,?R2,?G2,?B2,?Y1,?U1,?Y2,?V1;??
  • ????int?alpha1,?alpha2;??
  • ????if?(alphaYUV)??
  • ????{??
  • ????????if?(alphaRGB)??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????B1?=?*(pRGBData+(height-i-1)*width*4+j*8);??
  • ????????????????????G1?=?*(pRGBData+(height-i-1)*width*4+j*8+1);??
  • ????????????????????R1?=?*(pRGBData+(height-i-1)*width*4+j*8+2);??
  • ????????????????????alpha1?=?*(pRGBData+(height-i-1)*width*4+j*8+3);??
  • ????????????????????B2?=?*(pRGBData+(height-i-1)*width*4+j*8+4);??
  • ????????????????????G2?=?*(pRGBData+(height-i-1)*width*4+j*8+5);??
  • ????????????????????R2?=?*(pRGBData+(height-i-1)*width*4+j*8+6);??
  • ????????????????????alpha2?=?*(pRGBData+(height-i-1)*width*4+j*8+7);??
  • ????????????????????Y1?=?(((66*R1+129*G1+25*B1+128)>>8)?+?16)?>?255???255?:?(((66*R1+129*G1+25*B1+128)>>8)?+?16);??
  • ????????????????????U1?=?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128)>255???255?:?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128);??
  • ????????????????????Y2?=?(((66*R2+129*G2+25*B2+128)>>8)?+?16)>255???255?:?((66*R2+129*G2+25*B2+128)>>8)?+?16;??
  • ????????????????????V1?=?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128)>255???255?:?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128);??
  • ????????????????????*(pYUVData+i*width*3+j*6)?=?Y1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+1)?=?U1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+2)?=?Y2;??
  • ????????????????????*(pYUVData+i*width*3+j*6+3)?=?V1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+4)?=?alpha1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+5)?=?alpha2;??
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????????else??
  • ????????{??
  • ????????????unsigned?char?alpha?=?255;??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????B1?=?*(pRGBData+(height-i-1)*width*3+j*6);??
  • ????????????????????G1?=?*(pRGBData+(height-i-1)*width*3+j*6+1);??
  • ????????????????????R1?=?*(pRGBData+(height-i-1)*width*3+j*6+2);??
  • ????????????????????B2?=?*(pRGBData+(height-i-1)*width*3+j*6+3);??
  • ????????????????????G2?=?*(pRGBData+(height-i-1)*width*3+j*6+4);??
  • ????????????????????R2?=?*(pRGBData+(height-i-1)*width*3+j*6+5);??
  • ????????????????????Y1?=?((66*R1+129*G1+25*B1+128)>>8)?+?16;??
  • ????????????????????U1?=?((-38*R1-74*G1+112*B1+128)>>8+(-38*R2-74*G2+112*B2+128)>>8)/2?+?128;??
  • ????????????????????Y2?=?((66*R2+129*G2+25*B2+128)>>8)?+?16;??
  • ????????????????????V1?=?((112*R1-94*G1-18*B1+128)>>8?+?(112*R2-94*G2-18*B2+128)>>8)/2?+?128;??
  • ????????????????????Y1?=?(((66*R1+129*G1+25*B1+128)>>8)?+?16)?>?255???255?:?(((66*R1+129*G1+25*B1+128)>>8)?+?16);??
  • ????????????????????U1?=?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128)>255???255?:?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128);??
  • ????????????????????Y2?=?(((66*R2+129*G2+25*B2+128)>>8)?+?16)>255???255?:?((66*R2+129*G2+25*B2+128)>>8)?+?16;??
  • ????????????????????V1?=?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128)>255???255?:?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128);??
  • ????????????????????*(pYUVData+i*width*3+j*6)?=?Y1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+1)?=?U1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+2)?=?Y2;??
  • ????????????????????*(pYUVData+i*width*3+j*6+3)?=?V1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+4)?=?alpha;??
  • ????????????????????*(pYUVData+i*width*3+j*6+5)?=?alpha;??
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????}??
  • ????else??
  • ????{??
  • ????????if?(alphaRGB)??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????B1?=?*(pRGBData+(height-i-1)*width*4+j*8);??
  • ????????????????????G1?=?*(pRGBData+(height-i-1)*width*4+j*8+1);??
  • ????????????????????R1?=?*(pRGBData+(height-i-1)*width*4+j*8+2);??
  • ????????????????????B2?=?*(pRGBData+(height-i-1)*width*4+j*8+4);??
  • ????????????????????G2?=?*(pRGBData+(height-i-1)*width*4+j*8+5);??
  • ????????????????????R2?=?*(pRGBData+(height-i-1)*width*4+j*8+6);??
  • ????????????????????Y1?=?(((66*R1+129*G1+25*B1+128)>>8)?+?16)?>?255???255?:?(((66*R1+129*G1+25*B1+128)>>8)?+?16);??
  • ????????????????????U1?=?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128)>255???255?:?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128);??
  • ????????????????????Y2?=?(((66*R2+129*G2+25*B2+128)>>8)?+?16)>255???255?:?((66*R2+129*G2+25*B2+128)>>8)?+?16;??
  • ????????????????????V1?=?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128)>255???255?:?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128);??
  • ????????????????????*(pYUVData+i*width*2+j*4)?=?Y1;??
  • ????????????????????*(pYUVData+i*width*2+j*4+1)?=?U1;??
  • ????????????????????*(pYUVData+i*width*2+j*4+2)?=?Y2;??
  • ????????????????????*(pYUVData+i*width*2+j*4+3)?=?V1;??
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????????else??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????B1?=?*(pRGBData+(height-i-1)*width*3+j*6);??
  • ????????????????????G1?=?*(pRGBData+(height-i-1)*width*3+j*6+1);??
  • ????????????????????R1?=?*(pRGBData+(height-i-1)*width*3+j*6+2);??
  • ????????????????????B2?=?*(pRGBData+(height-i-1)*width*3+j*6+3);??
  • ????????????????????G2?=?*(pRGBData+(height-i-1)*width*3+j*6+4);??
  • ????????????????????R2?=?*(pRGBData+(height-i-1)*width*3+j*6+5);??
  • ????????????????????Y1?=?(((66*R1+129*G1+25*B1+128)>>8)?+?16)?>?255???255?:?(((66*R1+129*G1+25*B1+128)>>8)?+?16);??
  • ????????????????????U1?=?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128)>255???255?:?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128);??
  • ????????????????????Y2?=?(((66*R2+129*G2+25*B2+128)>>8)?+?16)>255???255?:?((66*R2+129*G2+25*B2+128)>>8)?+?16;??
  • ????????????????????V1?=?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128)>255???255?:?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128);??
  • ????????????????????*(pYUVData+i*width*2+j*4)?=?Y1;??
  • ????????????????????*(pYUVData+i*width*2+j*4+1)?=?U1;??
  • ????????????????????*(pYUVData+i*width*2+j*4+2)?=?Y2;??
  • ????????????????????*(pYUVData+i*width*2+j*4+3)?=?V1;??
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????}??
  • ????return?0;??
  • }??
  • ??
  • // ??
  • //?pGBYUV???????????point?to?the?background?YUV?data ??
  • //?pFGYUV???????????point?to?the?foreground?YUV?data ??
  • //?width????????????width?of?the?picture ??
  • //?height???????????height?of?the?picture ??
  • //?alphaBG??????????is?there?an?alpha?channel?in?background?YUV?data ??
  • //?alphaFG??????????is?there?an?alpha?channel?in?fourground?YUV?data ??
  • // ??
  • int?YUVBlending(void*?pBGYUV,?void*?pFGYUV,?int?width,?int?height,?bool?alphaBG,?bool?alphaFG)??
  • {??
  • ????if?(NULL?==?pBGYUV?||?NULL?==?pFGYUV)??
  • ????{??
  • ????????return?-1;??
  • ????}??
  • ????unsigned?char*?pBGData?=?(unsigned?char*)pBGYUV;??
  • ????unsigned?char*?pFGData?=?(unsigned?char*)pFGYUV;??
  • ????if?(!alphaFG)??
  • ????{??
  • ????????if?(!alphaBG)??
  • ????????{??
  • ????????????memcpy(pBGData,?pFGData,?width*height*2);??
  • ????????}??
  • ????????else??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????*(pBGData+i*width*2+j*4)?=?*(pFGData+i*width*2+j*4);??
  • ????????????????????*(pBGData+i*width*2+j*4+1)?=?*(pFGData+i*width*2+j*4+1);??
  • ????????????????????*(pBGData+i*width*2+j*4+2)?=?*(pFGData+i*width*2+j*4+2);??
  • ????????????????????*(pBGData+i*width*2+j*4+3)?=?*(pFGData+i*width*2+j*4+3);??
  • ????????????????}??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????int?Y11,?U11,?V11,?Y12,?Y21,?U21,?V21,?Y22;??
  • ????int?alpha1,?alpha2;??
  • ????if?(!alphaBG)??
  • ????{??
  • ????????for?(int?i=0;?i<height;?++i)??
  • ????????{??
  • ????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????{??
  • ????????????????Y11?=?*(pBGData+i*width*2+j*4);??
  • ????????????????U11?=?*(pBGData+i*width*2+j*4+1);??
  • ????????????????Y12?=?*(pBGData+i*width*2+j*4+2);??
  • ????????????????V11?=?*(pBGData+i*width*2+j*4+3);??
  • ??
  • ????????????????Y21?=?*(pFGData+i*width*3+j*6);??
  • ????????????????U21?=?*(pFGData+i*width*3+j*6+1);??
  • ????????????????Y22?=?*(pFGData+i*width*3+j*6+2);??
  • ????????????????V21?=?*(pFGData+i*width*3+j*6+3);??
  • ????????????????alpha1?=?*(pFGData+i*width*3+j*6+4);??
  • ????????????????alpha2?=?*(pFGData+i*width*3+j*6+5);??
  • ??
  • ????????????????*(pBGData+i*width*2+j*4)?=?(Y21-16)*alpha1/255+(Y11-16)*(255-alpha1)/255+16;??
  • ????????????????*(pBGData+i*width*2+j*4+1)?=?((U21-128)*alpha1/255+(U11-128)*(255-alpha1)/255?+?(U21-128)*alpha2/255+(U11-128)*(255-alpha2)/255)/2+128;??
  • ????????????????*(pBGData+i*width*2+j*4+3)?=?((V21-128)*alpha1/255+(V11-128)*(255-alpha1)/255?+?(V21-128)*alpha2/255+(V11-128)*(255-alpha2)/255)/2+128;??
  • ????????????????*(pBGData+i*width*2+j*4+2)?=?(Y22-16)*alpha2/255+(Y12-16)*(255-alpha2)/255+16;??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????else??
  • ????{??
  • ????????for?(int?i=0;?i<height;?++i)??
  • ????????{??
  • ????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????{??
  • ????????????????Y11?=?*(pBGData+i*width*3+j*6);??
  • ????????????????U11?=?*(pBGData+i*width*3+j*6+1);??
  • ????????????????Y12?=?*(pBGData+i*width*3+j*6+2);??
  • ????????????????V11?=?*(pBGData+i*width*3+j*6+3);??
  • ??
  • ????????????????Y21?=?*(pFGData+i*width*3+j*6);??
  • ????????????????U21?=?*(pFGData+i*width*3+j*6+1);??
  • ????????????????Y22?=?*(pFGData+i*width*3+j*6+2);??
  • ????????????????V21?=?*(pFGData+i*width*3+j*6+3);??
  • ????????????????alpha1?=?*(pFGData+i*width*3+j*6+4);??
  • ????????????????alpha2?=?*(pFGData+i*width*3+j*6+5);??
  • ??
  • ????????????????*(pBGData+i*width*3+j*6)?=?(Y21-16)*alpha1/255+(Y11-16)*(255-alpha1)/255+16;??
  • ????????????????*(pBGData+i*width*3+j*6+1)?=?((U21-128)*alpha1/255+(U11-128)*(255-alpha1)/255?+?(U21-128)*alpha2/255+(U11-128)*(255-alpha2)/255)/2+128;??
  • ????????????????*(pBGData+i*width*3+j*6+3)?=?((V21-128)*alpha1/255+(V11-128)*(255-alpha1)/255?+?(V21-128)*alpha2/255+(V11-128)*(255-alpha2)/255)/2+128;??
  • ????????????????*(pBGData+i*width*3+j*6+2)?=?(Y22-16)*alpha2/255+(Y12-16)*(255-alpha2)/255+16;??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????return?0;??
  • }??
  • [c-sharp] view plaincopyprint?
  • //??
  • //?YUV2RGB??
  • //?pYUV?????????point?to?the?YUV?data??
  • //?pRGB?????????point?to?the?RGB?data??
  • //?width????????width?of?the?picture??
  • //?height???????height?of?the?picture??
  • //?alphaYUV?????is?there?an?alpha?channel?in?YUV??
  • //?alphaRGB?????is?there?an?alpha?channel?in?RGB??
  • //??
  • int?YUV2RGB(void*?pYUV,?void*?pRGB,?int?width,?int?height,?bool?alphaYUV,?bool?alphaRGB)??
  • {??
  • ????if?(NULL?==?pYUV)??
  • ????{??
  • ????????return?-1;??
  • ????}??
  • ????unsigned?char*?pYUVData?=?(unsigned?char?*)pYUV;??
  • ????unsigned?char*?pRGBData?=?(unsigned?char?*)pRGB;??
  • ????if?(NULL?==?pRGBData)??
  • ????{??
  • ????????if?(alphaRGB)??
  • ????????{??
  • ????????????pRGBData?=?new?unsigned?char[width*height*4];??
  • ????????}??
  • ????????else??
  • ????????????pRGBData?=?new?unsigned?char[width*height*3];??
  • ????}??
  • ????int?Y1,?U1,?V1,?Y2,?alpha1,?alpha2,?R1,?G1,?B1,?R2,?G2,?B2;??
  • ????int?C1,?D1,?E1,?C2;??
  • ????if?(alphaRGB)??
  • ????{??
  • ????????if?(alphaYUV)??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????Y1?=?*(pYUVData+i*width*3+j*6);??
  • ????????????????????U1?=?*(pYUVData+i*width*3+j*6+1);??
  • ????????????????????Y2?=?*(pYUVData+i*width*3+j*6+2);??
  • ????????????????????V1?=?*(pYUVData+i*width*3+j*6+3);??
  • ????????????????????alpha1?=?*(pYUVData+i*width*3+j*6+4);??
  • ????????????????????alpha2?=?*(pYUVData+i*width*3+j*6+5);??
  • ????????????????????C1?=?Y1-16;??
  • ????????????????????C2?=?Y2-16;??
  • ????????????????????D1?=?U1-128;??
  • ????????????????????E1?=?V1-128;??
  • ????????????????????R1?=?((298*C1?+?409*E1?+?128)>>8>255???255?:?(298*C1?+?409*E1?+?128)>>8);??
  • ????????????????????G1?=?((298*C1?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C1?-?100*D1?-?208*E1?+?128)>>8);????
  • ????????????????????B1?=?((298*C1+516*D1?+128)>>8>255???255?:?(298*C1+516*D1?+128)>>8);????
  • ????????????????????R2?=?((298*C2?+?409*E1?+?128)>>8>255???255?:?(298*C2?+?409*E1?+?128)>>8);??
  • ????????????????????G2?=?((298*C2?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C2?-?100*D1?-?208*E1?+?128)>>8);??
  • ????????????????????B2?=?((298*C2?+?516*D1?+128)>>8>255???255?:?(298*C2?+?516*D1?+128)>>8);????
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+2)?=?R1<0???0?:?R1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+1)?=?G1<0???0?:?G1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8)?=?B1<0???0?:?B1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+3)?=?alpha1;??????
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+6)?=?R2<0???0?:?R2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+5)?=?G2<0???0?:?G2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+4)?=?B2<0???0?:?B2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+7)?=?alpha2;??????
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????????else??
  • ????????{??
  • ????????????int?alpha?=?255;??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????Y1?=?*(pYUVData+i*width*2+j*4);??
  • ????????????????????U1?=?*(pYUVData+i*width*2+j*4+1);??
  • ????????????????????Y2?=?*(pYUVData+i*width*2+j*4+2);??
  • ????????????????????V1?=?*(pYUVData+i*width*2+j*4+3);??
  • ????????????????????C1?=?Y1-16;??
  • ????????????????????C2?=?Y2-16;??
  • ????????????????????D1?=?U1-128;??
  • ????????????????????E1?=?V1-128;??
  • ????????????????????R1?=?((298*C1?+?409*E1?+?128)>>8>255???255?:?(298*C1?+?409*E1?+?128)>>8);??
  • ????????????????????G1?=?((298*C1?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C1?-?100*D1?-?208*E1?+?128)>>8);????
  • ????????????????????B1?=?((298*C1+516*D1?+128)>>8>255???255?:?(298*C1+516*D1?+128)>>8);????
  • ????????????????????R2?=?((298*C2?+?409*E1?+?128)>>8>255???255?:?(298*C2?+?409*E1?+?128)>>8);??
  • ????????????????????G2?=?((298*C2?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C2?-?100*D1?-?208*E1?+?128)>>8);??
  • ????????????????????B2?=?((298*C2?+?516*D1?+128)>>8>255???255?:?(298*C2?+?516*D1?+128)>>8);????
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+2)?=?R1<0???0?:?R1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+1)?=?G1<0???0?:?G1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8)?=?B1<0???0?:?B1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+3)?=?alpha;???
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+6)?=?R2<0???0?:?R2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+5)?=?G2<0???0?:?G2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+4)?=?B2<0???0?:?B2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*4+j*8+7)?=?alpha;???
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????}??
  • ????else??
  • ????{??
  • ????????if?(alphaYUV)??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????Y1?=?*(pYUVData+i*width*3+j*4);??
  • ????????????????????U1?=?*(pYUVData+i*width*3+j*4+1);??
  • ????????????????????Y2?=?*(pYUVData+i*width*3+j*4+2);??
  • ????????????????????V1?=?*(pYUVData+i*width*3+j*4+3);??
  • ????????????????????C1?=?Y1-16;??
  • ????????????????????C2?=?Y2-16;??
  • ????????????????????D1?=?U1-128;??
  • ????????????????????E1?=?V1-128;??
  • ????????????????????R1?=?((298*C1?+?409*E1?+?128)>>8>255???255?:?(298*C1?+?409*E1?+?128)>>8);??
  • ????????????????????G1?=?((298*C1?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C1?-?100*D1?-?208*E1?+?128)>>8);????
  • ????????????????????B1?=?((298*C1+516*D1?+128)>>8>255???255?:?(298*C1+516*D1?+128)>>8);????
  • ????????????????????R2?=?((298*C2?+?409*E1?+?128)>>8>255???255?:?(298*C2?+?409*E1?+?128)>>8);??
  • ????????????????????G2?=?((298*C2?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C2?-?100*D1?-?208*E1?+?128)>>8);??
  • ????????????????????B2?=?((298*C2?+?516*D1?+128)>>8>255???255?:?(298*C2?+?516*D1?+128)>>8);????
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+2)?=?R1<0???0?:?R1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+1)?=?G1<0???0?:?G1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6)?=?B1<0???0?:?B1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+5)?=?R2<0???0?:?R2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+4)?=?G2<0???0?:?G2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+3)?=?B2<0???0?:?B2;??
  • ????????????????}??
  • ????????????}??
  • ????????}??
  • ????????else??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????Y1?=?*(pYUVData+i*width*2+j*4);??
  • ????????????????????U1?=?*(pYUVData+i*width*2+j*4+1);??
  • ????????????????????Y2?=?*(pYUVData+i*width*2+j*4+2);??
  • ????????????????????V1?=?*(pYUVData+i*width*2+j*4+3);??
  • ????????????????????C1?=?Y1-16;??
  • ????????????????????C2?=?Y2-16;??
  • ????????????????????D1?=?U1-128;??
  • ????????????????????E1?=?V1-128;??
  • ????????????????????R1?=?((298*C1?+?409*E1?+?128)>>8>255???255?:?(298*C1?+?409*E1?+?128)>>8);??
  • ????????????????????G1?=?((298*C1?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C1?-?100*D1?-?208*E1?+?128)>>8);????
  • ????????????????????B1?=?((298*C1+516*D1?+128)>>8>255???255?:?(298*C1+516*D1?+128)>>8);????
  • ????????????????????R2?=?((298*C2?+?409*E1?+?128)>>8>255???255?:?(298*C2?+?409*E1?+?128)>>8);??
  • ????????????????????G2?=?((298*C2?-?100*D1?-?208*E1?+?128)>>8>255???255?:?(298*C2?-?100*D1?-?208*E1?+?128)>>8);??
  • ????????????????????B2?=?((298*C2?+?516*D1?+128)>>8>255???255?:?(298*C2?+?516*D1?+128)>>8);????
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+2)?=?R1<0???0?:?R1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+1)?=?G1<0???0?:?G1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6)?=?B1<0???0?:?B1;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+5)?=?R2<0???0?:?R2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+4)?=?G2<0???0?:?G2;??
  • ????????????????????*(pRGBData+(height-i-1)*width*3+j*6+3)?=?B2<0???0?:?B2;??
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????}??
  • ????return?0;??
  • }??
  • ??
  • //??
  • //?RGB2YUV??
  • //?pRGB?????????point?to?the?RGB?data??
  • //?pYUV?????????point?to?the?YUV?data??
  • //?width????????width?of?the?picture??
  • //?height???????height?of?the?picture??
  • //?alphaYUV?????is?there?an?alpha?channel?in?YUV??
  • //?alphaRGB?????is?there?an?alpha?channel?in?RGB??
  • //??
  • int?RGB2YUV(void*?pRGB,?void*?pYUV,?int?width,?int?height,?bool?alphaYUV,?bool?alphaRGB)??
  • {??
  • ????if?(NULL?==?pRGB)??
  • ????{??
  • ????????return?-1;??
  • ????}??
  • ????unsigned?char*?pRGBData?=?(unsigned?char?*)pRGB;??
  • ????unsigned?char*?pYUVData?=?(unsigned?char?*)pYUV;??
  • ????if?(NULL?==?pYUVData)??
  • ????{??
  • ????????if?(alphaYUV)??
  • ????????{??
  • ????????????pYUVData?=?new?unsigned?char[width*height*3];??
  • ????????}??
  • ????????else??
  • ????????????pYUVData?=?new?unsigned?char[width*height*2];??
  • ????}??
  • ????int?R1,?G1,?B1,?R2,?G2,?B2,?Y1,?U1,?Y2,?V1;??
  • ????int?alpha1,?alpha2;??
  • ????if?(alphaYUV)??
  • ????{??
  • ????????if?(alphaRGB)??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????B1?=?*(pRGBData+(height-i-1)*width*4+j*8);??
  • ????????????????????G1?=?*(pRGBData+(height-i-1)*width*4+j*8+1);??
  • ????????????????????R1?=?*(pRGBData+(height-i-1)*width*4+j*8+2);??
  • ????????????????????alpha1?=?*(pRGBData+(height-i-1)*width*4+j*8+3);??
  • ????????????????????B2?=?*(pRGBData+(height-i-1)*width*4+j*8+4);??
  • ????????????????????G2?=?*(pRGBData+(height-i-1)*width*4+j*8+5);??
  • ????????????????????R2?=?*(pRGBData+(height-i-1)*width*4+j*8+6);??
  • ????????????????????alpha2?=?*(pRGBData+(height-i-1)*width*4+j*8+7);??
  • ????????????????????Y1?=?(((66*R1+129*G1+25*B1+128)>>8)?+?16)?>?255???255?:?(((66*R1+129*G1+25*B1+128)>>8)?+?16);??
  • ????????????????????U1?=?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128)>255???255?:?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128);??
  • ????????????????????Y2?=?(((66*R2+129*G2+25*B2+128)>>8)?+?16)>255???255?:?((66*R2+129*G2+25*B2+128)>>8)?+?16;??
  • ????????????????????V1?=?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128)>255???255?:?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128);??
  • ????????????????????*(pYUVData+i*width*3+j*6)?=?Y1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+1)?=?U1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+2)?=?Y2;??
  • ????????????????????*(pYUVData+i*width*3+j*6+3)?=?V1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+4)?=?alpha1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+5)?=?alpha2;??
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????????else??
  • ????????{??
  • ????????????unsigned?char?alpha?=?255;??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????B1?=?*(pRGBData+(height-i-1)*width*3+j*6);??
  • ????????????????????G1?=?*(pRGBData+(height-i-1)*width*3+j*6+1);??
  • ????????????????????R1?=?*(pRGBData+(height-i-1)*width*3+j*6+2);??
  • ????????????????????B2?=?*(pRGBData+(height-i-1)*width*3+j*6+3);??
  • ????????????????????G2?=?*(pRGBData+(height-i-1)*width*3+j*6+4);??
  • ????????????????????R2?=?*(pRGBData+(height-i-1)*width*3+j*6+5);??
  • ????????????????????Y1?=?((66*R1+129*G1+25*B1+128)>>8)?+?16;??
  • ????????????????????U1?=?((-38*R1-74*G1+112*B1+128)>>8+(-38*R2-74*G2+112*B2+128)>>8)/2?+?128;??
  • ????????????????????Y2?=?((66*R2+129*G2+25*B2+128)>>8)?+?16;??
  • ????????????????????V1?=?((112*R1-94*G1-18*B1+128)>>8?+?(112*R2-94*G2-18*B2+128)>>8)/2?+?128;??
  • ????????????????????Y1?=?(((66*R1+129*G1+25*B1+128)>>8)?+?16)?>?255???255?:?(((66*R1+129*G1+25*B1+128)>>8)?+?16);??
  • ????????????????????U1?=?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128)>255???255?:?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128);??
  • ????????????????????Y2?=?(((66*R2+129*G2+25*B2+128)>>8)?+?16)>255???255?:?((66*R2+129*G2+25*B2+128)>>8)?+?16;??
  • ????????????????????V1?=?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128)>255???255?:?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128);??
  • ????????????????????*(pYUVData+i*width*3+j*6)?=?Y1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+1)?=?U1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+2)?=?Y2;??
  • ????????????????????*(pYUVData+i*width*3+j*6+3)?=?V1;??
  • ????????????????????*(pYUVData+i*width*3+j*6+4)?=?alpha;??
  • ????????????????????*(pYUVData+i*width*3+j*6+5)?=?alpha;??
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????}??
  • ????else??
  • ????{??
  • ????????if?(alphaRGB)??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????B1?=?*(pRGBData+(height-i-1)*width*4+j*8);??
  • ????????????????????G1?=?*(pRGBData+(height-i-1)*width*4+j*8+1);??
  • ????????????????????R1?=?*(pRGBData+(height-i-1)*width*4+j*8+2);??
  • ????????????????????B2?=?*(pRGBData+(height-i-1)*width*4+j*8+4);??
  • ????????????????????G2?=?*(pRGBData+(height-i-1)*width*4+j*8+5);??
  • ????????????????????R2?=?*(pRGBData+(height-i-1)*width*4+j*8+6);??
  • ????????????????????Y1?=?(((66*R1+129*G1+25*B1+128)>>8)?+?16)?>?255???255?:?(((66*R1+129*G1+25*B1+128)>>8)?+?16);??
  • ????????????????????U1?=?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128)>255???255?:?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128);??
  • ????????????????????Y2?=?(((66*R2+129*G2+25*B2+128)>>8)?+?16)>255???255?:?((66*R2+129*G2+25*B2+128)>>8)?+?16;??
  • ????????????????????V1?=?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128)>255???255?:?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128);??
  • ????????????????????*(pYUVData+i*width*2+j*4)?=?Y1;??
  • ????????????????????*(pYUVData+i*width*2+j*4+1)?=?U1;??
  • ????????????????????*(pYUVData+i*width*2+j*4+2)?=?Y2;??
  • ????????????????????*(pYUVData+i*width*2+j*4+3)?=?V1;??
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????????else??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????B1?=?*(pRGBData+(height-i-1)*width*3+j*6);??
  • ????????????????????G1?=?*(pRGBData+(height-i-1)*width*3+j*6+1);??
  • ????????????????????R1?=?*(pRGBData+(height-i-1)*width*3+j*6+2);??
  • ????????????????????B2?=?*(pRGBData+(height-i-1)*width*3+j*6+3);??
  • ????????????????????G2?=?*(pRGBData+(height-i-1)*width*3+j*6+4);??
  • ????????????????????R2?=?*(pRGBData+(height-i-1)*width*3+j*6+5);??
  • ????????????????????Y1?=?(((66*R1+129*G1+25*B1+128)>>8)?+?16)?>?255???255?:?(((66*R1+129*G1+25*B1+128)>>8)?+?16);??
  • ????????????????????U1?=?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128)>255???255?:?((((-38*R1-74*G1+112*B1+128)>>8)+((-38*R2-74*G2+112*B2+128)>>8))/2?+?128);??
  • ????????????????????Y2?=?(((66*R2+129*G2+25*B2+128)>>8)?+?16)>255???255?:?((66*R2+129*G2+25*B2+128)>>8)?+?16;??
  • ????????????????????V1?=?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128)>255???255?:?((((112*R1-94*G1-18*B1+128)>>8)?+?((112*R2-94*G2-18*B2+128)>>8))/2?+?128);??
  • ????????????????????*(pYUVData+i*width*2+j*4)?=?Y1;??
  • ????????????????????*(pYUVData+i*width*2+j*4+1)?=?U1;??
  • ????????????????????*(pYUVData+i*width*2+j*4+2)?=?Y2;??
  • ????????????????????*(pYUVData+i*width*2+j*4+3)?=?V1;??
  • ????????????????}??
  • ????????????}?????
  • ????????}??
  • ????}??
  • ????return?0;??
  • }??
  • ??
  • //??
  • //?pGBYUV???????????point?to?the?background?YUV?data??
  • //?pFGYUV???????????point?to?the?foreground?YUV?data??
  • //?width????????????width?of?the?picture??
  • //?height???????????height?of?the?picture??
  • //?alphaBG??????????is?there?an?alpha?channel?in?background?YUV?data??
  • //?alphaFG??????????is?there?an?alpha?channel?in?fourground?YUV?data??
  • //??
  • int?YUVBlending(void*?pBGYUV,?void*?pFGYUV,?int?width,?int?height,?bool?alphaBG,?bool?alphaFG)??
  • {??
  • ????if?(NULL?==?pBGYUV?||?NULL?==?pFGYUV)??
  • ????{??
  • ????????return?-1;??
  • ????}??
  • ????unsigned?char*?pBGData?=?(unsigned?char*)pBGYUV;??
  • ????unsigned?char*?pFGData?=?(unsigned?char*)pFGYUV;??
  • ????if?(!alphaFG)??
  • ????{??
  • ????????if?(!alphaBG)??
  • ????????{??
  • ????????????memcpy(pBGData,?pFGData,?width*height*2);??
  • ????????}??
  • ????????else??
  • ????????{??
  • ????????????for?(int?i=0;?i<height;?++i)??
  • ????????????{??
  • ????????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????????{??
  • ????????????????????*(pBGData+i*width*2+j*4)?=?*(pFGData+i*width*2+j*4);??
  • ????????????????????*(pBGData+i*width*2+j*4+1)?=?*(pFGData+i*width*2+j*4+1);??
  • ????????????????????*(pBGData+i*width*2+j*4+2)?=?*(pFGData+i*width*2+j*4+2);??
  • ????????????????????*(pBGData+i*width*2+j*4+3)?=?*(pFGData+i*width*2+j*4+3);??
  • ????????????????}??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????int?Y11,?U11,?V11,?Y12,?Y21,?U21,?V21,?Y22;??
  • ????int?alpha1,?alpha2;??
  • ????if?(!alphaBG)??
  • ????{??
  • ????????for?(int?i=0;?i<height;?++i)??
  • ????????{??
  • ????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????{??
  • ????????????????Y11?=?*(pBGData+i*width*2+j*4);??
  • ????????????????U11?=?*(pBGData+i*width*2+j*4+1);??
  • ????????????????Y12?=?*(pBGData+i*width*2+j*4+2);??
  • ????????????????V11?=?*(pBGData+i*width*2+j*4+3);??
  • ??
  • ????????????????Y21?=?*(pFGData+i*width*3+j*6);??
  • ????????????????U21?=?*(pFGData+i*width*3+j*6+1);??
  • ????????????????Y22?=?*(pFGData+i*width*3+j*6+2);??
  • ????????????????V21?=?*(pFGData+i*width*3+j*6+3);??
  • ????????????????alpha1?=?*(pFGData+i*width*3+j*6+4);??
  • ????????????????alpha2?=?*(pFGData+i*width*3+j*6+5);??
  • ??
  • ????????????????*(pBGData+i*width*2+j*4)?=?(Y21-16)*alpha1/255+(Y11-16)*(255-alpha1)/255+16;??
  • ????????????????*(pBGData+i*width*2+j*4+1)?=?((U21-128)*alpha1/255+(U11-128)*(255-alpha1)/255?+?(U21-128)*alpha2/255+(U11-128)*(255-alpha2)/255)/2+128;??
  • ????????????????*(pBGData+i*width*2+j*4+3)?=?((V21-128)*alpha1/255+(V11-128)*(255-alpha1)/255?+?(V21-128)*alpha2/255+(V11-128)*(255-alpha2)/255)/2+128;??
  • ????????????????*(pBGData+i*width*2+j*4+2)?=?(Y22-16)*alpha2/255+(Y12-16)*(255-alpha2)/255+16;??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????else??
  • ????{??
  • ????????for?(int?i=0;?i<height;?++i)??
  • ????????{??
  • ????????????for?(int?j=0;?j<width/2;?++j)??
  • ????????????{??
  • ????????????????Y11?=?*(pBGData+i*width*3+j*6);??
  • ????????????????U11?=?*(pBGData+i*width*3+j*6+1);??
  • ????????????????Y12?=?*(pBGData+i*width*3+j*6+2);??
  • ????????????????V11?=?*(pBGData+i*width*3+j*6+3);??
  • ??
  • ????????????????Y21?=?*(pFGData+i*width*3+j*6);??
  • ????????????????U21?=?*(pFGData+i*width*3+j*6+1);??
  • ????????????????Y22?=?*(pFGData+i*width*3+j*6+2);??
  • ????????????????V21?=?*(pFGData+i*width*3+j*6+3);??
  • ????????????????alpha1?=?*(pFGData+i*width*3+j*6+4);??
  • ????????????????alpha2?=?*(pFGData+i*width*3+j*6+5);??
  • ??
  • ????????????????*(pBGData+i*width*3+j*6)?=?(Y21-16)*alpha1/255+(Y11-16)*(255-alpha1)/255+16;??
  • ????????????????*(pBGData+i*width*3+j*6+1)?=?((U21-128)*alpha1/255+(U11-128)*(255-alpha1)/255?+?(U21-128)*alpha2/255+(U11-128)*(255-alpha2)/255)/2+128;??
  • ????????????????*(pBGData+i*width*3+j*6+3)?=?((V21-128)*alpha1/255+(V11-128)*(255-alpha1)/255?+?(V21-128)*alpha2/255+(V11-128)*(255-alpha2)/255)/2+128;??
  • ????????????????*(pBGData+i*width*3+j*6+2)?=?(Y22-16)*alpha2/255+(Y12-16)*(255-alpha2)/255+16;??
  • ????????????}??
  • ????????}??
  • ????}??
  • ????return?0;??
  • }??
  • 經測試,功能已經實現,如有錯誤或者不妥的地方,懇請指出。 mosesyuan at gmail dot com

    總結

    以上是生活随笔為你收集整理的RGB 24和YUY2相互转换的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    亚洲精品国产成人 | 中文字幕在线电影 | 天堂av在线免费 | 亚洲精品一区二区网址 | 欧美一级片播放 | 在线天堂中文www视软件 | 九九久久久 | 毛片888 | 成人午夜剧场在线观看 | 992tv人人网tv亚洲精品 | 免费视频久久久久久久 | 涩五月婷婷 | av福利超碰网站 | 婷婷色在线播放 | 色噜噜噜| 69国产精品视频免费观看 | aaa日本高清在线播放免费观看 | 伊人午夜 | 日韩精品极品视频 | 亚洲影视资源 | 激情综合五月网 | 日韩免费中文字幕 | av免费网站在线观看 | 久久久久久免费网 | 国产精品青草综合久久久久99 | 亚洲每日更新 | 在线a亚洲视频播放在线观看 | 国产区精品 | 国产亚洲婷婷 | 国产精品黄色 | 91精品国产乱码在线观看 | 在线观看免费视频 | 天天干,天天射,天天操,天天摸 | 久久99国产综合精品 | 97视频网站 | 日日干,天天干 | 国产精品区在线观看 | 国产私拍在线 | 成人av电影免费在线观看 | 在线观看视频精品 | 婷婷丁香综合 | 久久激情视频网 | 激情av在线播放 | 在线91播放 | 免费av福利 | 久久成人久久 | 九九热免费视频在线观看 | 视频在线观看一区 | 欧美成人h版在线观看 | 日韩一区二区免费视频 | 在线观看黄色免费视频 | 成人h视频在线播放 | av在线播放国产 | 麻豆精品传媒视频 | 国产精品自产拍在线观看桃花 | 国产99久久久国产精品成人免费 | 亚洲一区av | 成人网在线免费视频 | 在线高清av | 曰韩在线| 亚洲成a人片在线观看中文 中文字幕在线视频第一页 狠狠色丁香婷婷综合 | 久久99精品热在线观看 | av电影免费| 天天色播 | 久久超碰99 | www.99在线观看 | 在线看污网站 | 成人免费视频播放 | 天天干天天上 | av在线一级| 91在线观看黄 | 一级精品视频在线观看宜春院 | 国产精品 日韩 欧美 | 在线观看国产中文字幕 | 丁香婷婷深情五月亚洲 | 欧美三级高清 | 欧美在线你懂的 | 午夜性福利 | 人人干人人模 | 五月婷av | 国产成人性色生活片 | 99久久精品国产一区二区三区 | 九九九热精品免费视频观看网站 | 成年人在线免费视频观看 | 久久久久电影网站 | 日韩在线视 | 99热最新精品 | 成人av电影在线播放 | 亚洲午夜av | 亚洲影视九九影院在线观看 | 日韩精品免费一区二区三区 | 91mv.cool在线观看 | 国产在线一区观看 | 日韩精品不卡在线观看 | 国产一级精品视频 | 久久69精品 | 中文字幕丝袜一区二区 | 亚洲综合视频在线 | 国产日本三级 | 91麻豆免费版 | 久久久久国产成人免费精品免费 | 丁香午夜 | 中文字幕电影网 | 午夜神马福利 | 亚洲精品国偷自产在线99热 | 视频福利在线观看 | 婷婷久久精品 | 日本精品视频在线 | 在线看片日韩 | 天天玩夜夜操 | 九九亚洲精品 | 日韩视频三区 | 免费福利在线视频 | 2019免费中文字幕 | 天天色天天操综合网 | 综合久久影院 | 四虎在线影视 | 日韩欧美高清一区二区三区 | 免费亚洲黄色 | 九九免费精品视频 | 天天操狠狠操 | 国产成人精品一区二三区 | av成人在线电影 | 九七视频在线观看 | 色综合天天色综合 | 91网页版免费观看 | 丁香久久久 | 亚洲91中文字幕无线码三区 | 国产精品嫩草69影院 | 99精品久久久久 | 国产黄色免费在线观看 | 中文字幕a∨在线乱码免费看 | 亚洲专区中文字幕 | av3级在线 | 超碰人人在 | 精品久久久久久久久久久久久久久久 | 国产一区视频在线播放 | 中文字幕日本特黄aa毛片 | 在线播放 日韩专区 | 成人一区电影 | 久久五月婷婷综合 | 国产97视频 | 欧美日韩精品网站 | 超碰免费97 | 超碰97国产 | 一区二区三区免费在线 | 日韩在线免费播放 | 国产一级在线视频 | 六月丁香激情综合 | 97碰碰精品嫩模在线播放 | 在线观看av中文字幕 | aaa亚洲精品一二三区 | 狠狠色香婷婷久久亚洲精品 | 色插综合 | 最近高清中文在线字幕在线观看 | 欧美激情xxxx | 91看片在线观看 | 成人精品一区二区三区中文字幕 | 亚洲a成人v | 97香蕉久久超级碰碰高清版 | 91亚洲国产成人久久精品网站 | 欧洲一区二区在线观看 | 狠狠干 狠狠操 | 97视频一区 | 亚洲午夜小视频 | 久久草在线免费 | 五月在线| 中文字幕日韩高清 | 久久精品中文字幕免费mv | 久久无码av一区二区三区电影网 | 五月开心激情 | 激情在线网站 | 国产91精品看黄网站在线观看动漫 | 中文字幕美女免费在线 | 91精品国产综合久久福利不卡 | 女人18毛片90分钟 | 丁香激情综合久久伊人久久 | 日日干天夜夜 | 国产一级黄大片 | 亚洲一区欧美精品 | 欧美一级片在线免费观看 | av成人免费在线 | 久久国产精品影视 | 狠狠色丁香婷婷综合最新地址 | 天天鲁天天干天天射 | av中文字幕亚洲 | 国产+日韩欧美 | 91精品欧美 | 欧美做受高潮 | 亚洲手机天堂 | 久久99久久久久 | 97福利| 国产一区黄色 | 久久超| 国产成人av电影在线 | 亚州精品视频 | 精品一区二区在线观看 | 国产亚洲成人网 | 99久久精品久久久久久动态片 | 91丨九色丨蝌蚪丨老版 | 99精品偷拍视频一区二区三区 | 成人免费影院 | 激情网站网址 | 在线v片免费观看视频 | 久久在线免费 | 亚洲极色 | 99精品久久久 | 夜色资源站国产www在线视频 | 日韩视频一区二区三区 | 欧美伦理一区二区三区 | 毛片美女网站 | 在线精品视频免费播放 | 国产在线更新 | 少妇高潮流白浆在线观看 | 国产欧美精品在线观看 | 黄色a一级视频 | 亚洲人成综合 | 国产黄大片在线观看 | 欧美十八 | 久久最新 | 久久亚洲婷婷 | 在线观看免费国产小视频 | 丁香色综合 | 成人一区在线观看 | 97人人模人人爽人人少妇 | 久草视频在线新免费 | 天天射天天射天天射 | 97国产大学生情侣白嫩酒店 | 人人澡澡人人 | 久久综合五月婷婷 | 日本精品久久 | 香蕉久草 | 在线三级播放 | 婷婷丁香狠狠爱 | 毛片a级片 | 免费无遮挡动漫网站 | 香蕉视频在线网站 | 狠狠操操操 | 国产一性一爱一乱一交 | 狠狠狠色丁香综合久久天下网 | 欧美极品久久 | 日批视频在线播放 | 欧美一区二区三区不卡 | 欧美日韩免费观看一区=区三区 | 中文字幕视频在线播放 | 少妇自拍av | 97视频在线观看免费 | 亚洲最新av在线网站 | 日韩成人av在线 | 日韩精品网址 | 久久久久亚洲国产精品 | 亚洲成人精品久久 | 国产人成免费视频 | 国内精品久久久久影院日本资源 | 亚洲综合成人专区片 | 欧美美女视频在线观看 | 色婷婷精品大在线视频 | 天天看天天干 | 一级做a爱片性色毛片www | 欧美日韩高清在线 | 亚洲精品国产成人av在线 | 人人添人人澡 | 成人高清在线观看 | 欧美午夜剧场 | 九九日韩 | 国产91精品一区二区 | 国产精品久久久久久久久久久久午 | 国产99精品在线观看 | 午夜天使 | 久草a在线| 免费a视频在线 | 国产精品大全 | 国产精品 中文字幕 亚洲 欧美 | 国产午夜精品久久久久久久久久 | 中文字幕乱在线伦视频中文字幕乱码在线 | 亚洲综合色网站 | 97超碰中文字幕 | 成年人免费av网站 | 丝袜av一区 | 午夜精品视频一区二区三区在线看 | 国产日产在线观看 | 激情婷婷综合网 | 500部大龄熟乱视频使用方法 | 91在线九色| 天天爽天天碰狠狠添 | 高清精品在线 | 日韩精品资源 | 欧美成人影音 | 日韩av一区在线观看 | 一区二区欧美激情 | 国产精品99久久久 | 色综合久久久 | 黄视频网站大全 | 亚洲国产激情 | 91亚洲精品国偷拍 | 国产精品久久久久久影院 | 国产日韩在线视频 | 精品一二三四五区 | 国产精品免费久久 | 亚洲成人av影片 | 热久久免费视频精品 | 精品一区二区在线播放 | 亚洲综合网站在线观看 | 日本中文字幕系列 | 久草在线最新免费 | 人人干人人超 | 久久爱综合 | 中文字幕在线影视资源 | 美女网站视频免费都是黄 | 国产精彩视频 | 91大神在线看 | 国产精品99免视看9 国产精品毛片一区视频 | 九九导航 | 色吊丝在线永久观看最新版本 | 精品一区精品二区 | 欧美淫视频 | 精品一区二区三区香蕉蜜桃 | 国产精品一区二区av日韩在线 | 在线观看播放av | 天天干,天天插 | 久久精品国产免费 | 欧美另类网站 | 中文字幕黄网 | 在线观看国产麻豆 | 日韩在线视频看看 | 国产高清永久免费 | 91激情视频在线播放 | 国产一线二线三线在线观看 | 日韩中文在线视频 | 欧美一区二视频在线免费观看 | 黄色av成人在线 | 色综合 久久精品 | 精品国产aⅴ麻豆 | 99热在线看 | 久久久受www免费人成 | 婷婷久久五月天 | 91亚洲精品乱码久久久久久蜜桃 | 99精品免费久久久久久日本 | 在线免费观看视频一区二区三区 | 久草免费福利在线观看 | 色五丁香 | 午夜精品一区二区三区视频免费看 | 日本精品va在线观看 | 九九热在线观看 | 国产精品1区2区在线观看 | 久久激情视频 | 久久激五月天综合精品 | 国产一级高清 | 激情文学综合丁香 | 国产精品 中文字幕 亚洲 欧美 | 在线观看岛国 | 婷婷视频 | 国产精品欧美在线 | 国际精品久久久 | 91在线一区 | 91在线小视频 | 精品国产乱码久久久久久浪潮 | 五月婷在线播放 | 中文字幕在线播放视频 | 99精品视频一区二区 | av日韩国产 | 日韩美在线观看 | 在线看黄色的网站 | 久久激情五月激情 | 国产精品18久久久久久久久久久久 | av在线播放一区二区三区 | 国产成在线观看免费视频 | 81国产精品久久久久久久久久 | 天天天天色射综合 | 黄色大片中国 | 日韩一三区 | 在线视频观看国产 | 天天天干天天天操 | 日韩毛片在线播放 | 中文字幕 在线看 | 91传媒在线看 | 日韩精品一区二区不卡 | 国产精品免费观看久久 | 伊人久久精品久久亚洲一区 | 欧洲一区二区三区精品 | av一区二区三区在线观看 | 欧美一区二区精美视频 | 久久这里只有精品9 | 视色网站 | 深夜免费福利网站 | 国产精品大片免费观看 | 狠狠色丁香婷综合久久 | 在线国产视频 | 日本不卡一区二区 | 色多多视频在线 | 国产在线高清 | 午夜精品剧场 | 一级特黄av| 永久精品视频 | 最近中文国产在线视频 | 国产成人av网 | 欧洲精品久久久久毛片完整版 | 日韩大片免费在线观看 | 国产玖玖在线 | 中文字幕亚洲综合久久五月天色无吗'' | 人人爽人人爽人人爽学生一级 | 天天干夜夜擦 | 国产亚洲综合精品 | 国产精品久久99综合免费观看尤物 | 永久免费精品视频网站 | 国产精品999久久久 久产久精国产品 | 午夜免费在线观看 | 欧美日韩在线免费观看视频 | 在线免费高清一区二区三区 | www五月天 | 怡红院久久 | 在线91色| 97看片网| 国产精品6999成人免费视频 | 国产涩涩在线观看 | 在线视频一区观看 | www.狠狠干| 国产最新在线观看 | 狠狠的操狠狠的干 | 日本黄色免费看 | 91在线小视频 | 精品国产伦一区二区三区观看体验 | 四虎影视www| 五月天激情视频在线观看 | 91av在线看 | 久久这里只有精品视频99 | 久久九九国产视频 | 久久tv视频 | 久久久久久久久久久久久9999 | 激情五月看片 | 麻豆传媒视频在线播放 | 69精品 | 97超碰人人模人人人爽人人爱 | 麻豆视频观看 | 国模一二三区 | 特级黄色视频毛片 | 婷婷日 | 亚洲天天摸日日摸天天欢 | 黄色在线观看网站 | 天天se天天cao天天干 | 国产精品欧美一区二区 | 97人人模人人爽人人喊网 | 欧美高清成人 | av在线播放快速免费阴 | 国内精自线一二区永久 | 丁香六月天婷婷 | 日韩大片免费观看 | 中文字幕超清在线免费 | 欧美a影视| 久久试看 | 天天舔夜夜操 | 午夜精品在线看 | 久草在线在线视频 | 在线天堂中文在线资源网 | 亚洲资源片| 在线成人短视频 | 成人国产亚洲 | 久草在线99 | 日狠狠 | 麻豆久久一区二区 | 免费观看91视频 | 国产黄色片一级三级 | 丁香久久久 | 欧美精选一区二区三区 | 最新日韩中文字幕 | 五月婷婷丁香在线观看 | 玖玖玖国产精品 | 国产色视频123区 | 亚洲精品国产区 | 三级性生活视频 | www.xxxx欧美| 久久国产精品久久久 | 黄色特一级片 | 日韩激情片在线观看 | 韩国一区二区三区在线观看 | 91视频麻豆视频 | 婷婷亚洲五月色综合 | 一本一道久久a久久精品 | 天堂视频中文在线 | 久久精品福利视频 | 久久精品婷婷 | 天天天天色综合 | 亚洲资源网 | 久久久亚洲网站 | 国产精品国产三级国产专区53 | 久久久久久久综合色一本 | 这里只有精品视频在线 | 中文字幕4| 成人在线视频一区 | 一区二区三区四区不卡 | 99色人| 亚洲女同videos | 米奇狠狠狠888 | 国产 一区二区三区 在线 | 日本69hd| 亚洲精品国产第一综合99久久 | 日韩精品一区二区三区在线播放 | 五月婷在线观看 | 久久视屏网 | av电影免费 | 在线国产片 | 久久国产精品视频免费看 | 超碰97人人干| 久久精品牌麻豆国产大山 | 精品久久精品 | 二区精品视频 | 丁香婷婷射| 黄视频色网站 | 久久久久久久久久影视 | 成人黄大片视频在线观看 | 成人一级电影在线观看 | 免费看的黄色的网站 | 婷婷综合激情 | av一本久道久久波多野结衣 | 日韩r级在线| 国产日产亚洲精华av | 中文字幕在线观看一区 | 亚洲第一中文网 | 特级毛片在线免费观看 | 伊人资源视频在线 | 欧美午夜理伦三级在线观看 | www.777奇米 | 久久一精品 | 91完整视频| 1000部国产精品成人观看 | 99精品国产亚洲 | 国产精品入口66mio女同 | 91成人网页版 | 91污视频在线观看 | 国产精品乱码一区二区视频 | 网站在线观看你们懂的 | 国产字幕在线观看 | 99久久久国产精品美女 | 97电影手机 | 最近免费在线观看 | 久久欧美综合 | 欧美精品久久久久久久久老牛影院 | 狠狠色丁香婷婷综合久小说久 | 在线观看国产v片 | 99精品在线直播 | 中文字幕在线播放av | 91免费的视频在线播放 | 久久一区91| 又粗又长又大又爽又黄少妇毛片 | 蜜臀av网站 | 91av视频播放| 中文国产字幕在线观看 | 黄色影院在线观看 | 精品二区久久 | 综合五月 | 亚洲国产成人高清精品 | 久久天天躁夜夜躁狠狠躁2022 | 青青河边草观看完整版高清 | 日韩视频一区二区在线 | av看片在线观看 | 91精品久| 97超碰免费在线 | 九九久久在线看 | 久久婷婷精品 | 久久婷婷一区 | 免费看国产精品 | 久久久久久久久久久影院 | 日本性生活免费看 | 免费看av在线 | 久久深爱网 | 天天色官网 | 中文字幕2021 | 国产精品久久久久久久久久久久久 | 正在播放国产一区二区 | 欧美一区二区三区不卡 | 亚洲精品国偷自产在线91正片 | 欧美日本一二三 | 中文字幕视频三区 | 色橹橹欧美在线观看视频高清 | 69国产成人综合久久精品欧美 | 天天搞天天干天天色 | 最新一区二区三区 | av短片在线 | 久久高视频 | 一个色综合网站 | 久久论理 | 日韩精品一区二区三区免费观看视频 | 久久久久麻豆v国产 | 国产免费久久av | 亚洲精品视频在线观看免费 | 国内精品久久久久影院优 | 久久爽久久爽久久av东京爽 | 超碰人人在线观看 | 亚洲电影久久久 | 久久在线免费 | 亚洲高清久久久 | 亚洲精区二区三区四区麻豆 | 久久精品999| 久久免费公开视频 | 久久久久久久久久久久国产精品 | 国产高清免费在线观看 | 97成人在线观看 | 久草免费在线视频观看 | 国产精品岛国久久久久久久久红粉 | www色av| 波多野结衣网址 | 亚洲精品h| 91麻豆精品国产91久久久使用方法 | 日日干夜夜干 | 日韩高清www | 欧美日韩啪啪 | av播放在线 | 国产 日韩 在线 亚洲 字幕 中文 | 久草在线91 | 成年人在线看视频 | 久久伦理电影 | 久久国产精品久久精品国产演员表 | 天天干天天插 | 日韩黄在线观看 | 欧美成人区 | 久久视频国产精品免费视频在线 | 欧美另类tv | 免费国产视频 | 毛片网站在线看 | 国产成人av网址 | 国产高h视频 | 91自拍视频在线 | 国产69精品久久app免费版 | 国产日韩欧美在线免费观看 | 在线www色| 久久久久久久久久网站 | 尤物97国产精品久久精品国产 | 色一级片 | 亚洲91中文字幕无线码三区 | 欧美日韩国产伦理 | 久久新视频 | 亚洲综合爱 | 国产精品一区二区免费视频 | 97视频中文字幕 | 欧美日韩免费一区二区三区 | 久热这里有精品 | 久久久久久免费毛片精品 | 久久国产三级 | 天堂网中文在线 | 伊人五月天婷婷 | 天天干天天操av | av在线免费观看不卡 | 欧美在线日韩在线 | 波多野结衣在线视频免费观看 | 色视频在线 | 国产精品久久久久久婷婷天堂 | 日本精品久久久久久 | 免费网站在线观看成人 | www久久久 | 91精品在线免费 | 91男人影院 | 久精品在线 | 日本巨乳在线 | av色影院 | 91在线免费公开视频 | 亚洲激情电影在线 | 国产精品久久一区二区三区不卡 | 探花视频在线观看免费 | 亚洲欧洲视频 | 日日草天天草 | 欧美日韩另类在线观看 | 91在线视频播放 | 免费在线黄色av | 国产精品美乳一区二区免费 | 青春草免费在线视频 | 狠狠婷婷 | www视频在线播放 | 黄色1级毛片 | 亚洲电影影音先锋 | 国产一级二级在线观看 | www.看片网站| 中文字幕在线成人 | 国产精品丝袜久久久久久久不卡 | avsex| 西西www4444大胆在线 | 在线观看免费黄视频 | 啪啪动态视频 | 欧美日韩一区久久 | 国产精品久久久久9999 | 在线久热| 婷婷中文字幕在线观看 | 国产精品黄网站在线观看 | 中文视频在线播放 | 国产精品乱码在线 | av青草| 欧美成人精品三级在线观看播放 | 久久99在线观看 | 天天干天天草天天爽 | 天天操天天插 | 人人干人人上 | 17videosex性欧美 | 五月天久久婷 | 伊人五月天.com | av在线专区 | 国产高清在线不卡 | 婷婷免费视频 | 日韩欧美有码在线 | 免费视频97 | 久久99亚洲精品 | 国产高清视频在线播放一区 | 日韩一区二区三区高清免费看看 | 日韩视频在线观看免费 | 五月天天天操 | av免费观看在线 | 久热香蕉视频 | 色天天天 | 亚洲精品免费观看视频 | 欧美99久久 | 黄色a一级视频 | 黄网站色 | 天天激情综合 | 五月婷婷影视 | 国产伦精品一区二区三区照片91 | 中文字幕在线观看国产 | 又色又爽的网站 | 黄色资源在线观看 | 欧美精品一区二区蜜臀亚洲 | 中文字幕在线观看三区 | 国产一区视频在线播放 | www.黄色片.com | 99热这里是精品 | 在线看片a | 国产欧美在线一区 | 丁香激情视频 | 午夜色婷婷 | 91福利在线导航 | 中文字幕视频网站 | 婷婷色网| 精品久久久久久综合 | 国产精品久久久久久一区二区 | 日韩中文字幕免费电影 | 香蕉蜜桃视频 | 99热在线网站 | 日韩电影黄色 | 超碰在线最新地址 | 免费网址在线播放 | 91在线观看视频 | 亚洲自拍偷拍色图 | 中文字幕黄色 | zzijzzij日本成熟少妇 | 一区二区三区在线观看免费视频 | 欧美激情精品久久久久久变态 | 97人人模人人爽人人喊网 | www.干| 婷婷色网站 | 97人人澡人人添人人爽超碰 | 中文字幕一区二区三区四区视频 | 国产精品久久久久永久免费看 | 亚洲国产一区二区精品专区 | 色综合亚洲精品激情狠狠 | 爱爱一区 | 免费成人黄色 | 女人18精品一区二区三区 | 天天色天天骑天天射 | 久久久免费精品视频 | 91av视频在线免费观看 | 最新真实国产在线视频 | 亚洲影院一区 | 国产成人精品三级 | 精品一区二区在线免费观看 | 狠狠综合久久av | 久久调教视频 | 激情五月网站 | 91视频首页 | www.狠狠插.com | 免费99精品国产自在在线 | 国产精品自产拍在线观看 | 亚洲国产精品电影 | 日韩视频免费观看高清完整版在线 | 这里只有精品视频在线观看 | 一区二区三区免费在线播放 | 三级黄色a | 久久综合婷婷国产二区高清 | 日本中文在线 | 天天色天天干天天色 | 国产亚洲欧美日韩高清 | 久久久亚洲精华液 | 99精品观看| 丁香婷婷在线观看 | 一色屋精品视频在线观看 | 国产一级黄色av | 青青看片| 黄色片免费看 | 99精品视频免费在线观看 | 91视频在线网址 | 五月婷丁香 | 中文字幕在线观看资源 | 国产手机在线视频 | 99热精品在线观看 | 国产精品久久久久国产精品日日 | 久久国产免费看 | 国产精品视频永久免费播放 | 亚洲免费精品视频 | 热精品 | 五月亚洲婷婷 | 日韩一区二区免费视频 | 欧美视频国产视频 | 91系列在线 | 日韩在线观看三区 | 96亚洲精品久久久蜜桃 | 91黄色视屏 | 久久国产精品免费视频 | 欧美午夜寂寞影院 | 国产一级性生活 | 777久久久| a在线播放 | 97人人模人人爽人人喊中文字 | 视频国产 | 伊人黄色网 | 午夜婷婷网 | 久久96国产精品久久99漫画 | 97在线免费视频 | 日日夜夜精品视频天天综合网 | 亚洲精品乱码久久久久v最新版 | 久操97 | 成人在线电影观看 | 婷婷激情五月 | 欧美成人基地 | 国产三级av在线 | 麻豆首页 | 国产黄免费 | 手机av看片| 久久久久观看 | 久久,天天综合 | 欧美一区二区三区激情视频 | 中文字幕av专区 | 91麻豆高清视频 | 国产午夜在线观看 | 亚洲精品日韩av | 日韩美女久久 | 天天摸天天操天天爽 | 欧美9999| 久久国产精品视频免费看 | 久久免视频 | 超碰在97| 中文字幕在线观看第三页 | 日日夜精品 | avove黑丝 | 激情久久久 | 麻豆传媒视频在线播放 | 精品免费视频123区 午夜久久成人 | 天天操天天干天天操天天干 | 精品久久综合 | 国产精品久久伊人 | 国产精品久久久久av福利动漫 | 国产黄色一级片在线 | 激情电影在线观看 | 超级碰碰免费视频 | 黄视频网站大全 | 婷婷av色综合 | 欧美另类视频 | 国产精品网红直播 | 一级一级一片免费 | 日韩在线视频免费观看 | 久草在线视频首页 | 欧美日韩性视频在线 | 337p日本欧洲亚洲大胆裸体艺术 | www.888av| 精品国产乱码久久久久 | 欧美日韩国内在线 | 欧美在线一二区 | 日韩久久精品一区二区三区下载 | 天天操狠狠操夜夜操 | 永久免费毛片在线观看 | 国产亚洲精品日韩在线tv黄 | 色久网 | 天天透天天插 | 国产成人精品电影久久久 | 伊人五月天.com | 欧美在线视频第一页 | 天天色天天操天天爽 | 国产精品一区在线观看你懂的 | www.在线观看av| 久久亚洲人 | 亚洲伊人成综合网 | 亚洲成人午夜在线 | 69久久久久久久 | 欧美一级黄色网 | 韩国三级在线一区 | 国产黄色一级片在线 | 国产999久久久| 欧美精品999 | 国产美女精彩久久 | wwwww.国产 | 精品综合久久久 | 亚洲动漫在线观看 | 国产高清视频在线播放一区 | 热99在线 | 国产精品免费大片视频 | 免费三级网 | 国产成人在线观看 | 免费在线一区二区 | 久久99久久99精品中文字幕 | 在线观看视频国产一区 | 91精品国产欧美一区二区成人 | 天天操天天摸天天爽 | 欧美性一级观看 | 亚洲精品一区二区久 | 婷婷中文字幕在线观看 | 91久久精品一区二区三区 | 又黄又刺激 | 国产精品毛片久久久久久久 | 99亚洲精品 | 国产美女无遮挡永久免费 | 在线v| 精品国产伦一区二区三区观看说明 | 在线黄色国产电影 | 国产视频久久 | 国产免费专区 | www日韩视频| 特黄特黄的视频 | 亚洲精品高清在线观看 | 久久8精品 | 97电影在线观看 | 欧美a√在线| 日韩精品一卡 | 91精品久久久久久综合乱菊 | 久久成人在线视频 | 天天舔天天射天天操 | 麻豆影视在线观看 | 日韩高清一二区 | 亚洲一区二区三区四区在线视频 | 国产色秀视频 | www.久久久.cum| 精品在线观看一区二区 | 日本在线观看一区二区 | 国产一二三区在线观看 | 9999精品免费视频 | 国产高清视频在线免费观看 | 在线观看黄 | 日日夜夜操操操操 | 色婷婷综合成人av | 国产人成在线观看 | 国产精品婷婷午夜在线观看 | 91成人午夜| 国产色啪| 国内精品在线观看视频 | 欧美另类交在线观看 | 国产 字幕 制服 中文 在线 | 91av免费看 | 久久精品免费 | 婷婷五天天在线视频 | 亚洲精品国产精品国产 | 国产中文在线播放 | 中文一二区 | 91亚洲欧美激情 | 精品国产一区二区三区久久久蜜月 | 免费看污片| 亚洲一级免费观看 | 国产馆在线播放 | 人成在线免费视频 | www免费黄色 | 91成人午夜 | 天天干,天天射,天天操,天天摸 | 国产在线精品一区二区不卡了 | 国产日韩精品一区二区 | 久草视频免费在线播放 | 国产成人精品不卡 | 国产破处在线播放 | 天天草天天干天天射 | 久草在线视频新 | 久久久久久久久久免费 | 黄色av电影免费观看 | 中文字幕中文中文字幕 | 精品嫩模福利一区二区蜜臀 | 三上悠亚一区二区在线观看 | 黄色在线成人 | 国产高清在线看 | 美女视频a美女大全免费下载蜜臀 | 91九色精品女同系列 | 免费a视频 | 91黄色在线看 | 亚洲三级国产 | 久久伊人精品一区二区三区 | 成人一级免费电影 | 午夜色婷婷 | 欧美日韩在线视频一区二区 | 国产免费高清视频 | 亚洲精品456在线播放乱码 | 91成版人在线观看入口 | 日本三级吹潮在线 | av在线亚洲天堂 | 免费在线中文字幕 | 国产精品成人久久久久久久 | 日韩av图片| 日韩av一区二区三区在线观看 | 毛片精品免费在线观看 | 亚洲黄色在线播放 | 国产亚洲视频在线 | 国产视频一级 | 久久久久久国产一区二区三区 | 国产精品自产拍在线观看中文 | 国产色秀视频 | 欧美日韩国产在线观看 | 欧美巨乳波霸 | 亚洲精品国精品久久99热一 | 久草在线久草在线2 | 91亚洲精 |