argb888与rgb888转换程序_通过相机获取bayer 图像数据转换成RGB888数据并保存

#include #include#include#include#include#include#include#include#include#include#include#include

/*位图头文件数据结构*/typedefstructtagBITMAPFILEHEADER {

unsignedchar bfType[2]; //位图文件类型,必须为'B' 'M'

unsigned long bfSize; //位图文件大小(以字节为单位)

unsigned short bfReserved1; //位图文件保留字,必须为0

unsigned short bfReserved2; //位图文件保留字,必须为0

unsigned long bfOffBits; //位图数据的起始位置,以相对位图文件头的偏移量(单位字节)

}BITMAPFILEHEADER ; //共14Byte/*位图信息数据结构*/typedefstructtagBITMAPINFOHEADER{

unsignedlong biSize; //本结构所占用字节数

long biWidth; //位图宽度,以像素为单位

long biHeight; //位图高度,以像素为单位

unsigned short biPlanes; //目标设备级别,必须为1

unsigned short biBitCount; //每个像素所需的位数,1(双色),4(16色),8(256色),24(真彩色)

unsigned long biCompression; //位图的压缩类型,必须是0(示不压缩),1(BI_RLE8压缩类型),2(BI_RLE4压缩类型)之一

unsigned long biSizeImage; //位图大小以字节为单位

long biXPixPerMeter; //图像水平分辨率,每米像素数

long biYPixPerMeter; //图像垂直分辨率,每米像素数

unsigned long biClrUsed; //位图实际使用的颜色表中的颜色数

unsigned long biClrImporant; //位图显示过程中重要的颜色数

}BITMAPINFOHEADER; //共40Byte

structbuffer {void *start;

size_t length;

};#define CLEAR(x) memset(&(x), 0, sizeof(x))

static void xioctl(int fh, int request, void *arg)

{intr;do{

r=ioctl(fh, request, arg);

}while (r == -1 && ((errno == EINTR) || (errno ==EAGAIN)));if (r == -1) {

fprintf(stderr,"error %d, %s\n", errno, strerror(errno));

exit(EXIT_FAILURE);

}

}void saveImage(void *data,int imageWidth,intimageHeight)

{

BITMAPFILEHEADER*bitmapFileHeader;

BITMAPINFOHEADER*bitmapInfoHeader;

FILE*fp;if((fp=fopen("2345.bmp", "wb"))==NULL){

fprintf(stderr,"file cannot open\n");

exit(1);

}

bitmapFileHeader=(BITMAPFILEHEADER *)m

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是argb888rgb888转换程序的示例代码: ```java public static int[] argb888ToRgb888(int[] argb888) { int[] rgb888 = new int[argb888.length]; for (int i = 0; i < argb888.length; i++) { int argb = argb888[i]; int alpha = (argb >> 24) & 0xff; int red = (argb >> 16) & 0xff; int green = (argb >> 8) & 0xff; int blue = (argb) & 0xff; int rgb = ((red << 16) | (green << 8) | (blue)); rgb888[i] = rgb; } return rgb888; } ``` 而将Android camera2 api YUV_420_888转换RGB程序,则需要使用ColorSpace和ColorConverter类来进行转换。示例代码如下: ```java private void convertYuvToRgb(Image image) { Image.Plane[] planes = image.getPlanes(); ByteBuffer yBuffer = planes[0].getBuffer(); ByteBuffer uBuffer = planes[1].getBuffer(); ByteBuffer vBuffer = planes[2].getBuffer(); int ySize = yBuffer.remaining(); int uSize = uBuffer.remaining(); int vSize = vBuffer.remaining(); byte[] yBytes = new byte[ySize]; byte[] uBytes = new byte[uSize]; byte[] vBytes = new byte[vSize]; yBuffer.get(yBytes); uBuffer.get(uBytes); vBuffer.get(vBytes); ColorSpace cs = ColorSpace.get(ColorSpace.Named.SRGB); ColorSpace csYuv = ColorSpace.get(ColorSpace.Named.YUV_420_888); ColorConverter cc = new ColorConverter(csYuv, cs); float[] yuvFloat = new float[yBytes.length + uBytes.length + vBytes.length]; for (int i = 0; i < ySize; i++) { yuvFloat[i] = (float) (yBytes[i] & 0xff); } for (int i = 0; i < uSize; i++) { yuvFloat[ySize + i] = (float) (uBytes[i] & 0xff); } for (int i = 0; i < vSize; i++) { yuvFloat[ySize + uSize + i] = (float) (vBytes[i] & 0xff); } float[] rgbFloat = new float[yBytes.length * 3]; cc.convert(yuvFloat, rgbFloat); int[] rgb888 = new int[yBytes.length]; for (int i = 0; i < yBytes.length; i++) { int r = (int) rgbFloat[i * 3]; int g = (int) rgbFloat[i * 3 + 1]; int b = (int) rgbFloat[i * 3 + 2]; rgb888[i] = (r << 16) | (g << 8) | b; } } ``` 注意:上述代码仅为示例代码,实际应用中可能需要根据具体情况进行调整和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值