YUV420转RGB888
yuv420的数据存储方式是planar,就是在一帧中先存y分量,存完y存u,接着v分量。而在yuv420中有y分量widthheight byte,uv分量各是widthheight1/4,一帧中总的数据是widthheight3/2(widthheight12/8).所以当时认为,yuv分量代入转换公式的话,uv分量是不是少了。其实不然,因为是每四个y分量共用一个u分量一个v分量,但也不是[YiYi+1Yi+2Yi+3]共用[Ui],[Vi],因为是一个22的窗口内的Y分量共用一个uv,所以[YiYi+1Yi+wYi+w+1],其中i是偶数。uv分量由于是分别按水平方向和垂直方向2:1采样,所以[U(i/2*w/2+j/2)],V分量同理。
#include <iostream>
#include <stdio.h>
#include<fstream>
using namespace std;
bool yuv420ToRgb(char *yuv, int w, int h, char *rgb)
{
unsigned char *y = new unsigned char[w*h];
unsigned char *u = new unsigned char[w*h / 4];
unsigned char *v = new unsigned char[w*h / 4];
memcpy(y, yuv, w*h);
memcpy(u, yuv + w * h, w*h / 4);
memcpy(v, yuv + w * h * 5 / 4, w*h / 4);
for (int i = 0; i < h; i++)
{
for (int j = 0; j < w; j++)
{
rgb[i*w*3 + 3*j] = 1.164*(y[i*w+j] - 16) + 1.596*(v[i / 4 * w + j / 2] - 128);//R
rgb[i*w*3 + 3*j+1] = 1.164*(y[i*w + j] - 16) - 0.392*(u[i / 4*w+j/2] - 128) - 0.813*(v[i / 4 * w + j / 2] - 128);//G
rgb[i*w*3 + 3*j+2] = 1.164*(y[i*w + j] - 16) + 2.017*(u[i / 4 * w + j / 2] - 128); //B
}
}
free(y);
free(u);
free(v);
return true;
}
int main(int argc, char* argv[])
{
FILE *yuv, *out;
int len = 832 * 480 * 3 / 2;
char *yuvbuff = ( char *)malloc(len);
char *rgbbuff = ( char *)malloc(len*2);
char *buff = (char *)malloc(len * 2);
yuv = fopen("D://movie player//BasketballDrill_832x480_50.yuv", "rb");
out= fopen("D://movie player//rgb888.txt", "wb+");
ifstream fl("D://movie player//BasketballDrill_832x480_50.yuv", ios::binary);
fl.seekg(0, ios::end);
int size = fl.tellg();
int inFrameNum = (width*height * 3 / 2);
int frameNum = size / inFrameNum;
for (int i = 0; i <frameNum; i++) {
fread(yuvbuff, 1, width*height * 3/2, yuv);
yuv420ToRgb(yuvbuff, width, height, rgbbuff);
fwrite(rgbbuff, 1, width*height * 3 ,out);
}
return 0;
}
在Laravel中使用cursor来查询并处理数据 (轻松处理千万级的数据) 事发现场 最近...
marquee标签,它是成对出现的标签,首标签marquee和尾标签/marquee之间的内容就...
简单来说,使用Ioc模式需要两个步骤,第一是把服务注册到容器中,第二是从容器中...
实体 有五种预定义的XML实体,HTML编码者应该熟悉。XML文档中的字符、、、"和'被...
一、问题 有个打印log的函数,想知道该函数执行的时候,之前执行了哪些函数? 二...
1,快速实现授权验证 什么是 JWT ?为什么要用 JWT ?JWT 的组成? 这些百度可以...
A7的第一个博客 一自我介绍 大家好我是来自陕西科技大学2019级电子科学与技术的...
在Intel的早期,Andy Grove遇到一个雇员 - 他 建议公司在芯片的基础上开发个人计...
前言 从这篇起我们来一起学习 JS。 在二十一世纪二十年代的今天想必不会有人再对...
一.前言 开局先唠嗑一下,许久未曾更新博客,一直在调整自己的状态,去年是我的...