1 Star 0 Fork 23

niwotahao/AVDataProcess

forked from 黄老邪/AVDataProcess 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
yuv444p_split.cpp 1.19 KB
一键复制 编辑 原始数据 按行查看 历史
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef int BOOL;
#define TRUE 1
#define FALSE 0
//## 分离YUV444P像素数据中的Y、U、V分量
BOOL yuv444p_split(const char *file, int width, int height)
{
if (file == NULL) {
return FALSE;
}
FILE *fp = fopen(file, "rb+");
FILE *fp0 = fopen("./out/output_444p_yuv.y", "wb+");
FILE *fp1 = fopen("./out/output_444p_y.y", "wb+");
FILE *fp2 = fopen("./out/output_444p_u.y", "wb+");
FILE *fp3 = fopen("./out/output_444p_v.y", "wb+");
unsigned char *data = (unsigned char *)malloc(width*height*3);
memset(data, 0, width*height*3);
fread(data, 1, width*height*3, fp);
fwrite(data, 1, width*height*3, fp0);
fwrite(data, 1, width*height, fp1); //Y
fwrite(data+width*height, 1, width*height, fp2); //U
fwrite(data+width*height*2, 1, width*height, fp3); //V
free(data);
fclose(fp);
fclose(fp0);
fclose(fp1);
fclose(fp2);
fclose(fp3);
return TRUE;
}
int main(int argc, char *argv[])
{
if (argc == 4) {
yuv444p_split(argv[1], atoi(argv[2]), atoi(argv[3]));
}
return 0;
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/niwotahao/AVDataProcess.git
git@gitee.com:niwotahao/AVDataProcess.git
niwotahao
AVDataProcess
AVDataProcess
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385