NY12 格式转化成RGB格式

来源:互联网 发布:网络市场监管系统 编辑:程序博客网 时间:2024/06/03 18:07

int NV12ToBGR(unsigned char * srcYVU, unsigned char * destBGR, int width, int height)
{

 unsigned char * srcVU = srcYVU + width * height;

 unsigned char Y, U, V;
 int B, G, R;
 int i,j;
 for ( i = 0; i < height; i++)
 {
  for ( j = 0; j < width; j++)
  {
   Y = srcYVU[i * width + j];
   V = srcVU[(i / 2 * width / 2 + j / 2) * 2 + 0];
   U = srcVU[(i / 2 * width / 2 + j / 2) * 2 + 1];


   R = 1.164*(Y - 16) + 1.596*(V - 128);
   G = 1.164*(Y - 16) - 0.813*(V - 128) - 0.392*(U - 128);
   B = 1.164*(Y - 16) + 2.017*(U - 128);

   destBGR[(i * width + j) * 3 + 0] = clamp_g(B, 0, 255);
   destBGR[(i * width + j) * 3 + 1] = clamp_g(G, 0, 255);
   destBGR[(i * width + j) * 3 + 2] = clamp_g(R, 0, 255);


  }
 }
 return 0;
}

0 0