- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
概括
当使用 -c copy
调用时,Ffmpeg concat demuxer 会改变视频流的开始时间选项。
再生产
给定一个 before.mp4
包含 start_time=0
的视频和音频流和 start_pts=0
.
给定 concat demuxer 输入文件 concat.txt
内容:
file before.mp4
运行命令
ffmpeg -f concat -i concat.txt -c copy concat.mp4
运行命令
ffprobe concat.mp4 -show_streams
并观察视频流
start_time
和
start_pts
现在非零(在我的测试中,这种变化的幅度很小,在 0 -> 0.022969 的范围内)。
before.mp4
时看到的内容。 ;右边是我们第一次打开时看到的
concat.mp4
:
mp4
时会出现此问题文件也。为了便于复制,我只使用了上面的一个文件。
before.mp4
的 ffprobe 输出。以下:
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'before.mp4':
Metadata:
major_brand : isom
minor_version : 512
compatible_brands: isomiso2avc1mp41
encoder : Lavf58.45.100
Duration: 00:00:06.50, start: 0.000000, bitrate: 998 kb/s
Stream #0:0(und): Video: h264 (High) (avc1 / 0x31637661), yuv420p, 1024x768 [SAR 1:1 DAR 4:3], 865 kb/s, 50 fps, 50 tbr, 12800 tbn, 100 tbc (default)
Metadata:
handler_name : VideoHandler
Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 126 kb/s (default)
Metadata:
handler_name : SoundHandler
我想做什么
-c copy
调用 concat demuxer (即没有重新编码)没有对输出视频流开始时间的意外调整。
start_time
和
start_pts
当处理后的视频在没有任何过滤器的情况下重新编码时重置为 0:
ffmpeg -i concat.mp4 concat_reencoded.mp4
.
-c copy
的情况下调用 concat demuxer 时不会出现此问题选项。
before.mp4
也不存在此问题被重新混合到
before.mkv
通过
ffmpeg -i before.mp4 -c copy before.mkv
在被 concat demuxer 处理之前。但是,这会导致 fps 略有变化(例如 30 -> 29.96),我还没有弄清楚如何在不重新编码的情况下避免这种变化。
最佳答案
我也遇到过 concat demuxer 的问题。如果您随后将这些视频的 start_pts 和 start_time 不为 0 并尝试将它们与其他视频连接起来,您最终会收到很多非单调 DTS 警告,并且可能会在某些播放器中引入一些卡顿。
虽然假设你有一个恒定的帧率视频,但我已经找到了一个解决方案:
ffmpeg -i questions_video.mp4 -c 复制有问题的_video.h264
ffmpeg -fflags +genpts -r 30 -i 有问题的视频.h264 -i 有问题的视频.mp4 -c 复制 -aspect 16:9 -map 0:v -map 1:a -video_track_timescale 90000 固定视频.mp4
在第一次 ffmpeg 运行中,您将原始 .h264 流从有问题的视频中提取出来
在第二次 ffmpeg 运行中,我们告诉它生成新的 PTS 值并告诉它输入帧率。您还需要告诉它纵横比,否则 ffprobe 将显示 DAR/SAR 的“N/A”。最后提供您在有问题的视频.mp4 中使用的 time_base。
您会在第二个 ffmpeg 命令中看到很多关于缺少 PTS 值的警告,但是视频在完成处理后应该没问题。
我已将您需要更改的值加粗,具体取决于您的特定视频。您可以通过运行获得这些值:
ffprobe -show_streams -select_streams v有问题的视频.mp4
...
显示纵横比: 16:9
r_frame_rate: 30 /1
时基:1/ 90000
...
如果您现在对 fixed_video.mp4 进行 ffprobe,您应该会看到 start_time 和 start_pts 为 0 的所有不错的值。您可能在有问题的_video.mp4 中获得的不稳定的平均/最小帧速率值也应该被修复。
我不是 ffmpeg 的专家,所以可能还有其他解决方案,但这是在这些情况下对我有用的解决方案。
关于video - Ffmpeg concat demuxer 改变视频流开始时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64277299/
数据库设置: http://sqlfiddle.com/#!2/4d1c2/1 以下查询选择属于productID的所有标签及其位置,逗号分隔: SELECT CONCAT_WS(',', GROUP
要连接两个文件,它看起来像这样: concat: { src: ['common.js','js/app.js'], dest: 'assets/js/app.js' } 如果
我有一个执行 SQL 脚本的 PDI(Kettle)转换,脚本的输出是一列,如下所示: val1 val2 val3 val4 "more values"... 我需要像这样在一个 Excel 单元格
我正在尝试传递一个参数 [例如@X nvarchar(MAX)] 转换成变量 [例如@message nvarchar(MAX)] 在存储过程中。该变量使用 CONCAT 组合字符串值和变量,它最终成
我不知道如何解释我的问题... 这是我的sql请求: SELECT DISTINCT CONCAT (nompropre, ' ', Auteur, ' de ', localite) AS aute
如何在与另一个表连接的表中使用 concat 和 group concat。架构如下所示: 第一表: MariaDB [ittresnamuda]> select * from tb_tipe_req
在我的 CREATE VIEW 中,我想: SELECT CONCAT( t.str1, t.str2 ) AS Title, CHAR_LENGTH( Title ) AS Length 但这会产生
我正在使用 CriteriaBuilder.concat 连接 2 个字符串,代码如下: Expression concat = criteriaBuilder.concat(expr1, expr2
我有以下继承 IEnumerable 的类 public class LinesEnumerable : IEnumerable { protected readonly IPointSeri
_.concat 和有什么区别lodash 和 Array.prototype.concat() ?. 最佳答案 欢迎来到 Stackoverflow! 这些函数的工作方式相同,但语法不同: _.co
我有一个非常大的表(几百万条记录)。表中的列 A 目前是这样的:id、道路名称、纬度、经度,其中 id 是自动增量 PK。 目前,1 个道路名称可以在表中包含多个条目,因为每条道路都映射到多个(纬度、
我测试了各种数组连接技术,并不是因为它实际上对我的代码很重要,而只是顺便说一句,看看我们现在在哪里。正如预期的那样,非常新的 ES 2015 传播运算符在 JavaScript 数组上被旧的 conc
我有一个数组,我需要使用一些编辑重新编译。我是在 async.concat() 的帮助下完成的,但有些东西不起作用。告诉我,哪里错了? async.concat(dialogs, function(d
在 JavaScript 中,我遇到过以两种主要方式编写的代码,用于连接两个(或更多)使用 .concat() 的数组。 Array 上的方法目的。 (假设在下文中,arr1 和 arr2 是作为 .
我之前曾使用 stack over flow 来解决我的 sql 问题并且成功了。 这一次我的下一期可能不会那么成功。 我有一个名为 Statements_1 的表,该表大约有 50 列,假设有 10
我在想以一种相当奇怪的方式从数据库获取东西时遇到了一些麻烦。假设我有下一张 table ID | Rating 229 | 3 229 | 2 229 | 4 229 | 2 2
我有类似表中的内容 mysql> select uuid , short-uuid FROM sampleUUID WHERE identifier ="test123"; +------------
我有一个查询,用于获取我离开加入两个表的帖子: 类别和标签:LEFT JOIN 到链接表→‖INNER JOIN 到类别和标签名称表。 LEFT JOIN wp_term_relationships
我目前正在开发一个大型 angular.js 项目。我使用 grunt 将所有文件合并/丑化为一个大的 target.js 文件,然后将其包含在索引页中。 我已经意识到,这使得在开发环境中调试变得非常
我的表中有三列:firstName、lastName 和 jobTitle。我想将 firstName 和 lastName 连接为 Fullname,然后连接 Fullname 和 jobTitle
我是一名优秀的程序员,十分优秀!