1,步骤
1. 读取RGB文件转换为yuv
2. 压缩为h264
3. 封装为MP4
3X3RGB图像存放方式(连续)
![在这里插入图片描述](https://img-blog.csdnimg.cn/eef377a517b4477db5c847fcda434331.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bGx5rW35LiN5py9,size_20,color_FFFFFF,t_70,g_se,x_16)
每一个颜色放入一个字节,一个像素点称为一个RGB
YUV
“Y”表示明亮度,也就是灰度值
“U”和“V”表示色度
![在这里插入图片描述](https://img-blog.csdnimg.cn/03de3b708023413b924967bc47944fd3.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5bGx5rW35LiN5py9,size_20,color_FFFFFF,t_70,g_se,x_16)
code
#include <iostream>
using namespace std;
extern "C"
{
#include <libavformat/avformat.h>
#include <libswscale/swscale.h>
}
#pragma comment(lib,"avformat.lib")
#pragma comment(lib,"avcodec.lib")
#pragma comment(lib,"avutil.lib")
#pragma comment(lib,"/swscale.lib")
int p = 0;
int main()
{
const char* iPath = "./file/test.rgb";
const char* oPath = "./file/rgb.mp4";
av_register_all();
avcodec_register_all();
FILE* fp = fopen(iPath, "rb");
if (!fp)
{
cout << "fopen" << endl;
return -1;
}
int width = 848;
int height = 480;
int fps = 25;
AVCodec* codec = avcodec_find_encoder(AV_CODEC_ID_H264);
if (!codec)
{
cout << "avcodec_find_encoder" << endl;
return -1;
}
AVCodecContext* c = avcodec_alloc_context3(codec);
if (!c)
{
cout << "avcodec_alloc_context3" << endl;
return -1;
}
c->bit_rate = 4000000000;
c->width = width;
c->height = height;
c->time_base = { 1,fps };
c->framerate = { fps,1 };
c->gop_size = 50;
c->max_b_frames = 0;
c->pix_fmt = AV_PIX_FMT_YUV420P;
c->codec_id = AV_CODEC_ID_H264;
c->flags |= AV_CODEC_FLAG_GLOBAL_HEADER;
c->thread_count = 4;
int ret = avcodec_open2(c, codec, NULL);
if (ret < 0)
{
cout << "avcodec_open2" << endl;
}
cout << "avcodec_open success!" << endl;
AVFormatContext* oc = NULL;
avformat_alloc_output_context2(&oc, 0, 0, oPath);
AVStream* st = avformat_new_stream(oc, NULL);
st->id = 0;
st->codecpar->codec_tag = 0;
avcodec_parameters_from_context(st->codecpar, c);
cout << ".//" << endl;
av_dump_format(oc, 0, oPath,1);
SwsContext* ctx = NULL;
sws_getCachedContext(ctx,
width, height, AV_PIX_FMT_BGRA,
width, height, AV_PIX_FMT_YUV420P,
SWS_BICUBIC, NULL, NULL, NULL);
unsigned char* rgb = new unsigned char[width * height * 4];
AVFrame* yuv = av_frame_alloc();
yuv->format = AV_PIX_FMT_YUV420P;
yuv->width = width;
yuv->height = height;
ret = av_frame_get_buffer(yuv,32);
if (ret < 0)
{
cout << "av_frame_get_buffer" << endl;
return -1;
}
ret = avio_open(&oc->pb, oPath, AVIO_FLAG_WRITE);
if (ret < 0)
{
cout << "avio_open" << endl;
return - 1;
}
ret = avformat_write_header(oc, NULL);
if (ret < 0)
{
cout << "avformat_write_header" << endl;
return -1;
}
cout << "测试" << endl;
for (;;)
{
int len = fread(rgb, 1, width * height * 4, fp);
if (len <= 0)
break;
uint8_t* indata[AV_NUM_DATA_POINTERS] = { 0 };
indata[0] = rgb;
int inlinesize[AV_NUM_DATA_POINTERS] = { 0 };
inlinesize[0] = width * 4;
int h = sws_scale(ctx, indata, inlinesize, 0, height,
yuv->data, yuv->linesize);
if (h <= 0)
break;
yuv->pts = p;
p = p + 3600;
ret = avcodec_send_frame(c, yuv);
if (ret != 0)
{
cout << "avcodec_send_frame" << endl;
return -1;
}
AVPacket pkt;
av_init_packet(&pkt);
ret = avcodec_receive_packet(c, &pkt);
if (ret != 0)
{
cout << "avcodec_receive_packet" << endl;
continue;
}
cout << "《" << pkt.size << "》" << endl;
av_interleaved_write_frame(oc, &pkt);
}
av_write_trailer(oc);
avio_close(oc->pb);
avformat_free_context(oc);
avcodec_close(c);
avcodec_free_context(&c);
cout << "---------------------end----------------" << endl;
delete rgb;
getchar();
return 0;
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)