在做人脸识别的时候,需要把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的限制去掉时,便没有这样的问题了,但可能会在强光的情况下有亮蓝色显示。这点暂时还没有解决。