YUV格式有两大类:planar和packed。
对于planar的YUV格式,先连续存储所有像素点的Y,紧接着存储所有像素点的U,随后是所有像素点的V。
对于packed的YUV格式,每个像素点的Y,U,V是连续交*存储的。
YUV,分为三个分量,“Y”表示明亮度(Luminance或Luma),也就是灰度值;而“U”和“V” 表示的则是色度(Chrominance或Chroma),作用是描述影像色彩及饱和度,用于指定像素的颜色。
planar的YUV格式分为YUV420P和YUV420SP,YUV420P包含I420和YV12。I420格式和YV12格式的不同处在U平面和V平面的位置不同。在I420格式中,U平面紧跟在Y平面之后,然后才是V平面(即:YUV);但YV12则是相反(即:YVU)。
YUV420SP, Y分量平面格式,UV打包格式, 即NV12。 NV12与NV21类似,U 和 V 交错排列,不同在于UV顺序。
I420: YYYYYYYY UU VV =>YUV420P
YV12: YYYYYYYY VV UU =>YUV420P
NV12: YYYYYYYY UVUV =>YUV420SP
NV21: YYYYYYYY VUVU =>YUV420SP
yuvI420ToYV12
void yuvI420ToYV12(char *I420,int w,int h,char *YV12)
{
memcpy(YV12,I420,w*h);//y分量
memcpy(YV12+W*H,I420+W*H,w*h/4);//V分量
memcpy(YV12+W*H+w*h/4,I420+W*H+W*H/4,w*h/4);//u分量
}
yuvYV12ToI420
void yuvYV12ToI420(char *YV12,int w,int h,char *I420)
{
memcpy(I420,YV12,w*h);//y分量
memcpy(I420+W*H,YV12+W*H,w*h/4);//V分量
memcpy(I420+W*H+w*h/4,YV12+W*H+W*H/4,w*h/4);//u分量
}
yuvNV12ToNV21
void yuvNV12ToNV21(char *NV12,int w,int h,char *NV21)
{
memcpy(NV21,NV12,w*h);//y分量
for(int i = 0;i
yuvNV21ToNV12
void yuvNV21ToNV12(char *NV21,int w,int h,char *NV12)
{
memcpy(NV12,NV21,w*h);//y分量
for(int i = 0;i
yuvI420ToNV12
void yuvI420ToNV12(char *I420,int w,int h,char *NV12)
{
memcpy(NV12,I420,w*h);//y分量
for(int i = 0,j = 0;i
yuvNV12ToI420
void yuvNV12ToI420(char *NV12,int w,int h,char *I420)
{
memcpy(I420,NV12,w*h);//y分量
for(int i = 0,j = 0;i
yuvI420ToNV21
void yuvI420ToNV21(char *I420,int w,int h,char *NV21)
{
memcpy(NV12,I420,w*h);//y分量
for(int i = 0,j = 0;i
yuvNV21ToI420
void yuvNV21ToI420(char *NV21,int w,int h,char *I420)
{
memcpy(I420,NV21,w*h);//y分量
for(int i = 0,j = 0;i
yuvYV12ToNV12
void yuvYV12ToNV12(char *YV12,int w,int h,char *NV12)
{
memcpy(NV12,YV12,w*h);//y分量
for(int i = 0,j = 0;i
yuvNV12ToYV12
void yuvNV12ToYV12(char *NV12,int w,int h,char *YV12)
{
memcpy(YV12,NV12,w*h);//y分量
for(int i = 0,j = 0;i
yuvyv12ToNV21
void yuvyv12ToNV21(char *yv12,int w,int h,char *NV21)
{
memcpy(NV12,yv12,w*h);//y分量
for(int i = 0,j = 0;i
yuvNV21ToYV12
void yuvNV21ToYV12(char *NV21,int w,int h,char *YV12)
{
memcpy(YV12,NV21,w*h);//y分量
for(int i = 0,j = 0;i