博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
NV12转化为BMP函数
阅读量:4224 次
发布时间:2019-05-26

本文共 1571 字,大约阅读时间需要 5 分钟。

void SaveBMP ( BYTE* data, int w, int h )  // data指代的是解码后的原始数据,格式为:NV12

{
FILE *f;
unsigned char *img = NULL;
int filesize = 54 + 3*w*h;          //w is your image width, h is image height, both int
if( img )  { free( img ); }

img = (unsigned char *)malloc(3*w*h);
memset(img,0,sizeof(img));
for(int j=0; j<h; j++)
{
for(int i=0; i<w; i++)
{
unsigned char r,g,b;
r = data[(((j*w)+i)*4)+2];
g = data[(((j*w)+i)*4)+1];
b = data[(((j*w)+i)*4)+0];
img[(((j*w)+i)*3)+2] = (r);
img[(((j*w)+i)*3)+1] = (g);
img[(((j*w)+i)*3)+0] = (b);
}
}
unsigned char bmpfileheader[14] = {'B','M', 0,0,0,0, 0,0, 0,0, 54,0,0,0};
unsigned char bmpinfoheader[40] = {40,0,0,0, 0,0,0,0, 0,0,0,0, 1,0, 24,0};
unsigned char bmppad[3] = {0,0,0};
bmpfileheader[ 2] = (unsigned char)(filesize    );
bmpfileheader[ 3] = (unsigned char)(filesize>> 8);
bmpfileheader[ 4] = (unsigned char)(filesize>>16);
bmpfileheader[ 5] = (unsigned char)(filesize>>24);
bmpinfoheader[ 4] = (unsigned char)(       w    );
bmpinfoheader[ 5] = (unsigned char)(       w>> 8);
bmpinfoheader[ 6] = (unsigned char)(       w>>16);
bmpinfoheader[ 7] = (unsigned char)(       w>>24);
bmpinfoheader[ 8] = (unsigned char)(       h    );
bmpinfoheader[ 9] = (unsigned char)(       h>> 8);
bmpinfoheader[10] = (unsigned char)(       h>>16);
bmpinfoheader[11] = (unsigned char)(       h>>24);
        g_FrameCapFile[] = "framecap.bmp"; //保存的图片名称
f = fopen(g_FrameCapFile,"wb");   
fwrite(bmpfileheader,1,14,f);
fwrite(bmpinfoheader,1,40,f);
for(int i=0; i<h; i++)
{
fwrite(img+(w*(h-i-1)*3),3,w,f);
fwrite(bmppad,1,(4-(w*3)%4)%4,f);
}
fclose(f);
printf("saved frame capture file width = %d, height = %d\n", w, h);
}

转载地址:http://iwkqi.baihongyu.com/

你可能感兴趣的文章
清华数据女神评选结果:第一竟然是叉院大神...?
查看>>
手把手教你从零上手Python(付安装地址、代码)
查看>>
数据蒋堂 | 大数据计算语法的SQL化
查看>>
手把手教线性回归分析(附R语言实例)
查看>>
收藏 | 一文打尽AI、机器学习网络资源!
查看>>
AI工程师必读的10本ML读物(附PDF下载)
查看>>
我们为何向霍金致敬
查看>>
数据蒋堂 | 大数据集群该不该透明化?
查看>>
手把手教 | 深度学习库PyTorch(附代码)
查看>>
吴恩达deeplearning.ai五项课程完整笔记了解一下?
查看>>
从起源到具体算法,这篇深度学习综述论文送给你
查看>>
一文解析支持向量机(附公式)
查看>>
详解何恺明团队4篇大作 !(附代码)| 从特征金字塔网络、Mask R-CNN到学习分割一切
查看>>
手把手教你用seq2seq模型创建数据产品(附代码)
查看>>
数据蒋堂 | Hadoop - 一把杀鸡用的牛刀
查看>>
详解AI Lab 21篇CVPR 2018论文(附论文)
查看>>
手把手教你Tableau高级数据分析功能(附数据集)
查看>>
大数据赋能司法新发展 政产学研嘉宾共聚清华
查看>>
近期AI领域8篇精选论文(附论文、代码)
查看>>
一文读懂神经网络(附PPT、视频)
查看>>