1.0版本没学习:https://blog.csdn.net/leixiaohua1020/article/details/8652605
直接学习sdl2.0版本的:https://blog.csdn.net/leixiaohua1020/article/details/38868499
AVFormatContext:
pFormatCtx = avformat_alloc_context();
给pFormatCtx 分配空间
if(avformat_open_input(&pFormatCtx,filepath,NULL,NULL)!=0){
打开输入文件
会填充pFormatCtx
if(avformat_find_stream_info(pFormatCtx,NULL)<0){
查找流信息
注意:此函数avformat_find_stream_info会改变AVFormatContext的一些字段?
此处得到视频流的index:
查找解码器:
pCodec=avcodec_find_decoder(pCodecCtx->codec_id);
AVCodecContext:
AVCodec:
打开编码器:
if(avcodec_open2(pCodecCtx, pCodec,NULL)<0){
AVFrame:
pFrame=av_frame_alloc();
分配AVFrame内存空间
avpicture_get_size:
将pFrameYUV和out_buffer关联起来了(指针地址相同)
sws_getContext
*接下来会使用 struct SwsContext img_convert_ctx;来进行转换
疑问: linesize的值和width不同
雷神在文章最后也解释了这一点:
实验了一下:【将pFrameYUV改为pFrame】现象为:
最后这段代码解决的是:解码视频时,视频尾巴上会丢掉几帧
此处注意:传入的packet->size = 0; packet->data = NULL;
雷神关于此处的解释: