源码如下:

// ConsoleApplication1.cpp : Defines the entry point for the console application.
#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h> #define XSIZE 1920
#define YSIZE 1080 #define RGB_SIZE XSIZE * YSIZE * 3
typedef unsigned char byte; double YUV2RGB_CONVERT_MATRIX[3][3] = { { 1, 0, 1.4022 }, { 1, -0.3456, -0.7145 }, { 1, 1.771, 0 } }; void ConvertYUV2RGB(unsigned char *yuvFrame, unsigned char *rgbFrame, int width, int height)
{
int uIndex = width * height;
int vIndex = uIndex + ((width * height) >> 2);
int gIndex = width * height;
int bIndex = gIndex * 2;
int temp, x, y; for (y = 0; y < height; y++)
{
for (x = 0; x < width; x++)
{
// R分量
temp = (int)(yuvFrame[y * width + x] + (yuvFrame[vIndex + (y / 2) * (width / 2) + x / 2] - 128) * YUV2RGB_CONVERT_MATRIX[0][2]);
rgbFrame[y * width + x] = (byte)(temp < 0 ? 0 : (temp > 255 ? 255 : temp));
// G分量
temp = (int)(yuvFrame[y * width + x] + (yuvFrame[uIndex + (y / 2) * (width / 2) + x / 2] - 128) * YUV2RGB_CONVERT_MATRIX[1][1] + (yuvFrame[vIndex + (y / 2) * (width / 2) + x / 2] - 128) * YUV2RGB_CONVERT_MATRIX[1][2]);
rgbFrame[gIndex + y * width + x] = (byte)(temp < 0 ? 0 : (temp > 255 ? 255 : temp));
// B分量
temp = (int)(yuvFrame[y * width + x] + (yuvFrame[uIndex + (y / 2) * (width / 2) + x / 2] - 128) * YUV2RGB_CONVERT_MATRIX[2][1]);
rgbFrame[bIndex + y * width + x] = (byte)(temp < 0 ? 0 : (temp > 255 ? 255 : temp));
}
}
} int main(){
int i, j, y, x;
long width, height;
unsigned char *data;
unsigned char *image; //用于存放读取的yuv数据
unsigned char *image_bmp; FILE *fp_r; width = XSIZE;
height = YSIZE;
long int bytePerLine = width * 3; //申请空间
image = (unsigned char *)malloc(width * height * 3 / 2);
image_bmp = (unsigned char *)malloc(width * height * 3);
data = (unsigned char*)malloc(bytePerLine * height); if ((NULL == image) || (image_bmp == NULL) || (data == NULL))
{
printf("faied to malloc the image\n");
return -1;
} /********读取yuv 文件***********/
fp_r = fopen("test.yuv", "rb"); //打开yuv 文件
if (NULL == fp_r)
{
printf("failed to open the fp_r\n");
return -1;
} fread(image, sizeof(unsigned char), XSIZE * YSIZE * 3 / 2, fp_r);
fclose(fp_r); for (i = 0; i<width *height * 3; i++)
*(image_bmp + i) = 255; //写bmp图片
int gIndex = width * height;
int bIndex = gIndex * 2; unsigned char header[54] = {
0x42, 0x4d, //WORD bfType----------- [0,1]
0, 0, 0, 0, //DWORD bfSize----------- [2,3,4,5]
0, 0, //WORD bfReserved1------ [6,7]
0, 0, //WORD bfReserved2------ [8,9]
54, 0, 0, 0, //WORD bfOffBits-------- [10,11,12,13] 40, 0, 0, 0, //DWORD biSize----------- [14,15,16,17]
0, 0, 0, 0, //LONG biWidth---------- [18,19,20,21]
0, 0, 0, 0, //LONG biHeight--------- [22,23,24,25]
1, 0, //WORD biplanes--------- [26,27]
24, 0, //WORD biCount---------- [28,29]
0, 0, 0, 0, //DWORD biCompression---- [30,31,32,33]
0, 0, 0, 0, //DWORD biSizeImage------ [34,35,36,37]
0, 0, 0, 0, //LONG biXPelsPerMeter-- [38,39,40,41]
0, 0, 0, 0, //LONG biYPelsPerMeter-- [42,43,44,45]
0, 0, 0, 0, //DWORD biClrUsed-------- [46,47,48,49]
0, 0, 0, 0 //DWORD biClrImportant--- [50,51,52,53]
};
long file_size = (long)width * (long)height * 3 + 54;
header[2] = (unsigned char)(file_size & 0x000000ff);
header[3] = (file_size >> 8) & 0x000000ff;
header[4] = (file_size >> 16) & 0x000000ff;
header[5] = (file_size >> 24) & 0x000000ff; header[18] = width & 0x000000ff;
header[19] = (width >> 8) & 0x000000ff;
header[20] = (width >> 16) & 0x000000ff;
header[21] = (width >> 24) & 0x000000ff; header[22] = height & 0x000000ff;
header[23] = (height >> 8) & 0x000000ff;
header[24] = (height >> 16) & 0x000000ff;
header[25] = (height >> 24) & 0x000000ff; char filename[6] = "1.bmp"; ConvertYUV2RGB(image, image_bmp, width, height); for (y = height - 1, j = 0; y >= 0; y--, j++)
{
for (x = 0, i = 0; x < width; x++)
{
data[y * bytePerLine + i++] = image_bmp[bIndex + j * width + x];
// B data[y * bytePerLine + i++] = image_bmp[gIndex + j * width + x];
// G data[y * bytePerLine + i++] = image_bmp[j * width + x];
// R
}
}
//sprintf(filename, "%d.bmp",1); FILE *fp_w;
if (!(fp_w = fopen(filename, "wb")))
return -1; fwrite(header, sizeof(unsigned char), 54, fp_w); fwrite(data, sizeof(unsigned char), XSIZE * YSIZE * 3, fp_w); fclose(fp_w);
free(image);
return(0);
}

yuv420 转换成 bmp的更多相关文章

  1. 音视频入门-03-RGB转成BMP图片

    * 音视频入门文章目录 * BMP 文件格式解析 BMP 文件由文件头.位图信息头.颜色信息和图形数据四部分组成. 位图文件头(14个字节) 位图信息头(40个字节) 颜色信息 图形数据 文件头与信息 ...

  2. 通过FFmpeg将多媒体文件解码后保存成Bmp图像(YUV420 RGB32)

    /* g++ -o test test.cpp -lavformat -lavcodec -lavutil -lz -lm -lpthread -lswscale */ #include <st ...

  3. 实现同时将一批.bmp文件转换成.mat格式

    %% 功能:实现同时对一批.bmp文件的转换成.mat格式PicFormat = {'*.bmp','Bitmap image (*.bmp)';... '*.jpg','JPEG image (*. ...

  4. 15个最好的PDF转word的在线转换器,将PDF文件转换成doc文件

    PDF是一种文件格式,包含文本,图像,数据等,这是独立于操作系统的文件类型.它是一个开放的标准,压缩,另一方面DOC文件和矢量图形是由微软文字处理文件.该文件格式将纯文本格式转换为格式化文档.它支持几 ...

  5. webp怎么打开 webp怎么转换成jpg

    webp怎么打开 webp怎么转换成jpg   2 3 4 5 6 7 分步阅读 在使用google服务的时候(比如 google play),我们会发现保存的图都是webp格式. 那webp是什么东 ...

  6. Android网络图片转换成bitmap保存到本地指定文件夹

    下列代码,请求网络图片转换为bitmap,然后保存到指定文件夹,微信,QQ分享,要求缩略图不大于32kb 压缩图片代码,使用了Glide来进行图片压缩处理 Glide.get(ShopDetailsA ...

  7. data:image/png;base64 上传图像将图片转换成base64格式

    大家可能注意到了,网页上有些图片的src或css背景图片的url后面跟了一大串字符,比如: data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAkAAAAJ ...

  8. delphi将图片转换成Base64编码函数

    {************************************************************************** 名称: BaseImage 参数: fn: TF ...

  9. android将drawable下的图片转换成bitmap

    将drawable下的图片转换成bitmap 1. Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.xx ...

随机推荐

  1. Java中的 Invalid character constant(无效的字符常数)

    将双引号误写成单引号,会出现这个错误. 1 package dftpkg; 2 3 public class Test { 4 5 public static void main(String[] a ...

  2. 几个简单js,普通写法和高逼格写法比较

    1. 取数组中的数据,并对空值设置默认值: 常规写法: let arr = [0, 1, null, '', 'abc']; let newArr = []; arr.forEach((item, i ...

  3. c# 多线程多个参数

    for (int i = 0; i <count; i++) //根据选择的串口号数量创建对应数量的线程 { thread = new Thread(new ParameterizedThrea ...

  4. 【2019.7.26 NOIP模拟赛 T1】数字查找(figure)(数学)

    推式子 我们设\(n=kp+w\),则: \[(kp+w)a^{kp+w}\equiv b(mod\ p)\] 将系数中的\(kp+w\)向\(p\)取模,指数中的\(kp+w\)根据欧拉定理向\(p ...

  5. [LeetCode] 545. Boundary of Binary Tree 二叉树的边界

    Given a binary tree, return the values of its boundary in anti-clockwise direction starting from roo ...

  6. 用Python搞定九宫格式的朋友圈。内附“马云”朋友圈

    PIL(Python Imaging Library)是一个非常强大的Python库,但是它支持Python2.X, 在Python3中则使用的是Pillow库,它是从PIL中fork出来的一个分支. ...

  7. c# linq分组 lambda分组

    var groupResults = from gr in models && gr.Temperature != && gr.Humidity != &&am ...

  8. 目标检测 <二> TensorFlow安装

    一:创建TensorFlow工作环境目录 1. 在anconda安装目录下找到envs目录然后进入 2. 在当前目录下创建一个文件夹改名为tensorflow 二: 创建TensorFlow工作环境 ...

  9. html。PROGRESS进度条使用测试

    效果图 : 代码: ----------------------------------- //本文来自:https://www.cnblogs.com/java2sap/p/11199126.htm ...

  10. 【前端知识体系-CSS相关】CSS基础知识强化

    1.CSS样式(选择器)的优先级? 1.1 权重的计算规则 第一优先级:无条件优先的属性只需要在属性后面使用!important.它会覆盖页面内任何位置定义的元素样式.(ie6支持上有些bug). 第 ...