我有一个带有 VP8 轨道的 .webm 文件,由外部服务(TokBox 归档)从 WebRTC 流中记录。流是自适应的,因此轨道中的每一帧都可以有不同的分辨率。大多数播放器(在 webkit 浏览器中)使用轨道描述中的视频分辨率(始终为 640x480)并将帧缩放到此分辨率。 Firefox 和 VLC 播放器使用真实帧分辨率,分别改变视频分辨率。
我想实现两个目标:
所以,我的计划是:
一切都正确吗?我怎样才能做到这一点?这个算法可以以某种方式优化吗?
我尝试使用 ffmpeg 提取图像,但它不使用轨道头中的分辨率解析真实的帧分辨率。
我认为一些 libwebm 函数可以帮助我(解析帧头和提取图像)。也许有人有一些代码片段可以做到这一点?
示例 .webm(下载源,不要播放 google 转换的版本):https://drive.google.com/file/d/0BwFZRvYNn9CKcndhMzlVa0psX00/view?usp=sharing
TokBox 支持的自适应流官方描述:https://support.tokbox.com/hc/en-us/community/posts/206241666-Archived-video-resolution-is-supposed-to-be-720x1280-but-reports-as-640x480
最佳答案
如果你跑
ffprobe -show_entries frame=width,height -of compact=p=0:nk=1 video.webm
您将获得如下所示的输出:
1254|800
1058|800
890|800
774|800
672|800
左列是每个框架的实际宽度,右列是高度。然后,您可以检查每列中的最大值,以用于 Canvas 大小。
然后运行
ffmpeg -i video.webm -vf pad=MAXW:MAXH:(MAXW-iw)/2:(MAXH-ih)/2 out.mp4
其中 MAXW 和 MAXH 应替换为您发现的值。
关于video - 如何将不同帧分辨率的VP8轨道转换为h264,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39467909/