在做人脸识别的时候,需要把Camera预览的图像保存成一张图片,在网上找到了以下的方法
static public void decodeYUV420SP(byte[] rgb, byte[] yuv420sp, int width, int height) { final int frameSize = width * height; int yp = 0; for (int j = 0; j < height; j++) { int uvp = frameSize + (j >> 1) * width, u = 0, v = 0; for (int i = 0; i < width; i++) { int y = (0xff & ((int) yuv420sp[yp])) - 16; if (y < 0) y = 0; if ((i & 1) == 0) { v = (0xff & yuv420sp[uvp++]) - 128; u = (0xff & yuv420sp[uvp++]) - 128; } int y1192 = 1192 * y; int r = (y1192 + 1634 * v); int g = (y1192 - 833 * v - 400 * u); int b = (y1192 + 2066 * u); // if (r < 0) r = 0; if (r > 262143) r = 262143; // if (g < 0) g = 0; if (g > 262143) g = 262143; // if (b < 0) b = 0; if (b > 262143) b = 262143; rgb[3*yp] = (byte) ((r >> 10) & 0xff); rgb[3*yp+1] = (byte) ((g >> 10) & 0xff); rgb[3*yp+2] = (byte) ((b >> 10) & 0xff); ++yp; } } } } // end of ProcessImageAndDrawResults class
原始的方法中是没有上面的三个注释的。为了保持图片的RGB的值在0-262143.但是使用上面的方法是发现图片特别不清晰,显示偏红,后面找原因才发现,因为对RGB值的限制,导致了很多的点都被过滤掉了。当按照上面的方法把小于0的限制去掉时,便没有这样的问题了,但可能会在强光的情况下有亮蓝色显示。这点暂时还没有解决。