一 遇到这样一个问题
本来录制的是hls,但是用户需要下载录制文件,一般需要mp4格式。
二 如何合并ts列表为mp4?
用两个io上下文,一个用于输入,一个用于输出。但是输出整个过程中都是同一个,
输出是一个个ts文件对应的。
详见代码:
int ConvertTsFilesToMp4(const char *input_filename,const char *output_filename,MergeTsContext *merge_ctx)
{
    
    if(input_filename == NULL || output_filename == NULL)
    {
        return NGX_ERROR;
    }
    AVFormatContext *input_format_ctx_ = NULL;
    int error = avformat_open_input(&input_format_ctx_,input_filename,NULL,0);
    if(error != 0)
    {
        printf("avformat_open_input file error\n");
        return NGX_ERROR;
    }
    
    error = avformat_find_stream_info(input_format_ctx_,NULL);
    if(error != 0)
    {
        printf("avformat_find_stream_info error\n");
        return NGX_ERROR;
    }
    //AVRational old_timebase;
   
    bool extra_data = true;  
    if(merge_ctx->has_opened == false || merge_ctx->output_format_ctx == NULL)
    {
        error = avformat_alloc_output_context2(&merge_ctx->output_format_ctx, NULL, "mp4",output_filename);
        if(error != 0)
        {
            printf("avformat_open_input file error\n");
            return NGX_ERROR;
        }

av_dump_format(input_format_ctx_,0,input_filename,0);
        for (int i = 0; i < input_format_ctx_->nb_streams; i++) 
        { 
            merge_ctx->in_stream = input_format_ctx_->streams[i]; 
            merge_ctx->out_stream = avformat_new_stream(merge_ctx->output_format_ctx, merge_ctx->in_stream->codec->codec); 
            if (!merge_ctx->out_stream) {
                printf("avformat_new_stream out stream failed ##\n");
                return NGX_ERROR;
            }       
            int ret = 0; 
            ret = avcodec_copy_context(merge_ctx->out_stream->codec, merge_ctx->in_stream->codec); 
            if (ret < 0) { 
                printf("Failed to copy context from input to output stream codec context\n"); 
                return NGX_ERROR;
            } 
            merge_ctx->out_stream->codec->codec_tag = 0; 
            if (merge_ctx->output_format_ctx->oformat->flags & AVFMT_GLOBALHEADER) 
                merge_ctx->out_stream->codec->flags |= CODEC_FLAG_GLOBAL_HEADER; 
        }  
        error = avio_open(&(merge_ctx->output_format_ctx->pb), output_filename, AVIO_FLAG_WRITE);
        if(error != 0)
        {
            printf("avformat_open_input file error\n");
            return -1;
        }  
        merge_ctx->video = av_bitstream_filter_init("h264_mp4toannexb");
    merge_ctx->audio = av_bitstream_filter_init("aac_adtstoasc");
        if(merge_ctx->video == NULL || merge_ctx->audio == NULL)
        {
            printf("av_bitstream_filter_init failed ##\n");
            return NGX_ERROR;
        }
        
        merge_ctx->has_opened = true;
        extra_data = false;
    }
    
    AVPacket packet = {0};
    AVRational new_timebase;
    new_timebase.den = 0;
    new_timebase.num = 1000;
    while(av_read_frame(input_format_ctx_,&packet) == 0)
    {
        if(extra_data == false)
        {
            error = avformat_write_header(merge_ctx->output_format_ctx, NULL);
            av_bitstream_filter_filter(merge_ctx->video, merge_ctx->out_stream->codec, NULL, &(packet.data), &(packet.size), packet.data, packet.size, \
              packet.flags & AV_PKT_FLAG_KEY);
            av_bitstream_filter_filter(merge_ctx->audio, merge_ctx->out_stream->codec, NULL, &(packet.data), &(packet.size), packet.data, packet.size, \
              packet.flags & AV_PKT_FLAG_KEY);
            extra_data = true;
        }
        
        //packet.pts = av_rescale_q_rnd(packet.pts,merge_ctx->in_stream->time_base,new_timebase, (AVRounding)(AV_ROUND_NEAR_INF|AV_ROUND_PASS_MINMAX));
        //packet.dts = av_rescale_q_rnd(packet.dts,merge_ctx->in_stream->time_base,new_timebase, (AVRounding)(AV_ROUND_NEAR_INF|AV_ROUND_PASS_MINMAX));
        //packet.duration = av_rescale_q(packet.duration, merge_ctx->in_stream->time_base, new_timebase);
       
        error = av_write_frame(merge_ctx->output_format_ctx,&packet);
    }
    avformat_close_input(&input_format_ctx_);

}

ffmpeg合并ts为mp4相关推荐

  1. 多线程下载m3u8影视资源 通过ffmpeg合并ts文件为mp4

    需要用到的ffmpeg,下载地址:Download FFmpeg  下载以后的目录. 合并.转换.切片都用到了ffmpeg.exe,其它两个我暂时没用到. <dependency>< ...

  2. ffmpeg合并M3U8加密的视频 ts 合并为 mp4

    文章引用于 ffmpeg 合并 m3u8 ts key 文件 解决 Invalid data found when 错误 如果文件没加密,可以直接用 ffmpeg -i xxx.m3u8 -vcode ...

  3. Python批量下载ts视频文件,并用ffmpeg合并

    目录 一.ts文件的由来 二.下载ts文件 1.下载index.m3u8,并做相应处理 2.下载ts文件 三.ffmpeg合并ts文件 一.ts文件的由来 ts文件,ts即"Transpor ...

  4. cmd合并多个ts文件,ffmpeg快速转ts为mp4文件,通过m3u8合并文件

    1.如何合并多个ts文件 进入目录执行如下cmd命令即可 copy /b *.ts new.ts 2.如何将ts转为mp4 ffmpeg下载 官网:https://ffmpeg.org/ github ...

  5. ffmpeg合并m3u8 ts key文件 解决Invalid data found when processing input错误

    首先我先说明一下我的使用场景和错误原因: 我使用IDM从网站中批量下载ts文件,然后下载对应的一个.m3u8文件(ts文件列表和加密信息的描述)和一个key.key文件(秘钥).以上文件全部保存在同一 ...

  6. 使用FFmpeg合并MP4视频

    使用FFmpeg合并MP4视频 1. 使用mpeg拼接 2. ==使用ts拼接== 使用FFmpeg合并MP4视频 windows/linux下均可用 1. 使用mpeg拼接 速度慢,文件大 将 mp ...

  7. 下载m3u8文件中的视频,使用FFMpeg解密合并.ts文件

    1.查看m3u8文件内容 #EXTM3U #EXT-X-VERSION:3 #EXT-X-TARGETDURATION:13 #EXT-X-MEDIA-SEQUENCE:0 #EXT-X-KEY:ME ...

  8. 将多个MP4通过FFmpeg工具合并成一个MP4文件

    原本想着通过java的IO流的方式进行MP4文件的合并,但是合并完成后发现并不是真正合并,文件的size是合并了,但是只能观看一个MP4文件,经过查询用FFmpeg合并MP4挺好使的,大体流程是: ( ...

  9. 将多个ts文件合并成一个mp4文件

    Python目录操作: 创建目录 :os.mkdir(path) 判断目录存在:os.path.exists(path) 创建多层目录:os.makedirs(path) 删除文件:os.remove ...

最新文章

  1. 【Spring】基于注解的IOC案例
  2. oracle proc 定义宿主,oracle proc 编程基础及最小化案例
  3. 软件学院学生在数据管理国际会议SIGMOD程序竞赛中喜获佳绩
  4. Core Location和MapKit的一些简单使用
  5. 第03讲. 原理探究,了解爬虫的基本原理
  6. openwrt 格式化_OPENWRT扩展系统到U盘
  7. ReactNative 踩坑之 iOS 原生组件
  8. 怎么手动升级更新ubuntu系统到最新版
  9. uva 620 Cellular Structure
  10. HTML两张图片翻转,canvas实现图片镜像翻转的2种方式
  11. 【转】【Coursera公开课】Applying to U.S. Universities(如何申请美国大学)笔记
  12. postman的操作步骤
  13. 【极乐小程序】房地产行业怎么利用小程序运营http://www.dreawer.cn/opration/605.html
  14. DOS控制台及其常用命令
  15. 互联网创业的五大定律
  16. 多视图几何笔记(二)射影变换
  17. Assignment of attribute weights with belief distributions for MADM under uncertainties
  18. 大师的话一语道破.强烈建议阅读
  19. 【JDBC】JDBCUtils工具类开发
  20. vant库 van-image标签无法引用本地图片

热门文章

  1. Flink1.11中的CDC Connectors操作实践
  2. 懂得珍惜,才能懂得爱
  3. 数据结构51题之栈和队列18题
  4. 3D 人体姿态估计简述[转]
  5. 2022年,继续奋斗。
  6. 3721软件测试,3721A-3721A电子负载│亚锐直流电子负载
  7. 软件架构师必备的职责、技能和知识(DSK)
  8. 低代码平台风口已来!
  9. matlab中元器件三相lc filter滤波器,三相PWM逆变器输出LC滤波器设计方法.pdf
  10. C++11 线程通信的三种方式