ffmpeg 转码总结.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ffmpeg 转码总结

FFmpeg 转码总结转码参数 输入、输出 音频、视频编码器、码率、是否帧内压缩 转码流程处理输入文件处理输入文件 打开输入文件,获取文件内的流信息初始化AVFormatContextAVFormatContext* ic = avformat_alloc_context();打开输入文件,获取流信息av_open_input_file(ic, filename, NULL, 0, NULL);如果成功,ic中包含了输入文件的流信息处理输出文件初始化 AVFormatContextAVFormatContext* oc = avformat_alloc_context();设置输入文件的名称av_strlcpy(oc-filename,filename,sizeof(oc-filename));给输出文件增加视频流新建一个流AVStream *st = av_new_stream(oc, oc-nb_streams);设置视频编码器的相关参数编码线程, 最小为1avcodec_thread_init(st-codec, thread_count);设置编码器codec_id=find_codec_or_die(video_codec_name,CODEC_TYPE_VIDEO,1)AVCodec*codec = avcodec_find_encoder((CodecID)codec_id);AVCodecContext *video_enc = st-codec;Video_enc-codec_type = CODEC_TYPE_VIDEO;Video_enc-codec_id = (CodecID)codec_id;//设置帧率 25帧每秒video_enc-time_base.den = 25;video_enc-time_base.num = 1;设置视频宽高video_enc-width = 576;video_enc-height = 420;设置显示横宽比 4:3video_enc-sample_aspect_ratio.num = 4;video_enc-sample_aspect_ratio.den = 3;如果帧内编码video_enc-gop_size = 0;给输出文件增加音频流新建一个音频流AVStream *st = av_new_stream(oc, oc-nb_streams);audio_enc = st-codec;audio_enc-codec_type = CODEC_TYPE_AUDIO;设置音频编码器codec_id = find_codec_or_die(audio_codec_name, CODEC_TYPE_AUDIO, 1);audio_enc-codec_id = (CodecID)codec_id;设置音频参数audio_enc-thread_count = thread_count;audio_enc-channels = audio_channels;audio_enc-channel_layout = channel_layout;const enum SampleFormat *p= codec-sample_fmts;for(; *p!=-1; p++){if(*p == audio_enc-sample_fmt)break;}if(*p == -1)audio_enc-sample_fmt = codec-sample_fmts[0];audio_enc-sample_rate = audio_sample_rate;audio_enc-time_base.num = 1;audio_enc-time_base.den = audio_sample_rate;打开编码器 和 解码器avcodec_open(st-codec, codec)写输出文件的头信息av_write_header(os)循环读取每一帧av_read_frame(is, pkt)计算pts与dtspkt.dts+= av_rescale_q(input_files_ts_offset[ist-file_index], m_AV_Time_Base_Q, ist-st-time_base);pkt.pts+= av_rescale_q(input_files_ts_offset[ist-file_index], m_AV_Time_Base_Q, ist-st-time_base);帧解码音频:avcodec_decode_audio2(ist-st-codec, samples, data_size,ptr, len);视频:avcodec_decode_video(ist-st-codec

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档