我有一个包含 H264/AVC 流的 MP4,其中包含多种分辨率。
mediainfo
以下是该文件的输出:
General
Complete name : known.mp4
Format : MPEG-4
Format profile : Base Media
Codec ID : isom
File size : 661 KiB
Duration : 15s 960ms
Overall bit rate : 340 Kbps
Writing application : Lavf54.49.102
Video
ID : 1
Format : AVC
Format/Info : Advanced Video Codec
Format profile : [email protected]
Format settings, CABAC : No
Format settings, ReFrames : 1 frame
Codec ID : avc1
Codec ID/Info : Advanced Video Coding
Duration : 15s 960ms
Bit rate : 338 Kbps
Width : 176 pixels
Original width : 352 pixels
Height : 144 pixels
Original height : 288 pixels
Display aspect ratio : 1.222
Frame rate mode : Constant
Frame rate : 25.000 fps
Color space : YUV
Chroma subsampling : 4:2:0
Bit depth : 8 bits
Scan type : Progressive
Bits/(Pixel*Frame) : 0.534
Stream size : 659 KiB (100%)
经过一番研究,该值Lavf54.49.102
似乎表明使用 ffmpeg 对该文件进行编码。
ffplay
以下是该文件的输出:
ffplay known.mp4
ffplay version 2.4.3 Copyright (c) 2003-2014 the FFmpeg developers
built on Nov 9 2014 17:21:35 with gcc 4.8 (Ubuntu 4.8.2-19ubuntu1)
configuration: --extra-libs=-ldl --prefix=/opt/ffmpeg --enable-avresample --disable-debug --enable-nonfree --enable-gpl --enable-version3 --enable-x11grab --enable-libpulse --enable-libopencore-amrnb --enable-libopencore-amrwb --disable-decoder=amrnb --disable-decoder=amrwb --enable-libx264 --enable-libx265 --enable-libfdk-aac --enable-libvorbis --enable-libmp3lame --enable-libopus --enable-libvpx --enable-libspeex --enable-libass --enable-avisynth --enable-libsoxr --enable-libxvid
libavutil 54. 7.100 / 54. 7.100
libavcodec 56. 1.100 / 56. 1.100
libavformat 56. 4.101 / 56. 4.101
libavdevice 56. 0.100 / 56. 0.100
libavfilter 5. 1.100 / 5. 1.100
libavresample 2. 1. 0 / 2. 1. 0
libswscale 3. 0.100 / 3. 0.100
libswresample 1. 1.100 / 1. 1.100
libpostproc 53. 0.100 / 53. 0.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'known.mp4':= 0B f=0/0
Metadata:
major_brand : isom
minor_version : 512
compatible_brands: isomiso2avc1mp41
encoder : Lavf54.49.102
Duration: 00:00:15.96, start: 0.000000, bitrate: 339 kb/s
Stream #0:0(und): Video: h264 (Constrained Baseline) (avc1 / 0x31637661), yuv420p, 176x144, 338 kb/s, 25 fps, 25 tbr, 1200k tbn, 2400k tbc (default)
Metadata:
handler_name : VideoHandler
[h264 @ 0x7f756800b540] Reinit context to 352x288, pix_fmt: yuv420p
注意最后一行[h264 @ 0x7f756800b540] Reinit context to 352x288, pix_fmt: yuv420p
;此时ffplay
改变大小以匹配新的分辨率。
我目前正在尝试重现这种“多分辨率”效果,首先在同一视频上解码然后重新编码,一旦成功,我计划以相同的方式编码另一个视频以(希望)实现相同的效果。一旦成功,我将尝试使用支持此功能的其他编解码器实现相同的效果。
我迄今为止的努力,甚至使用对同一视频进行重新编码ffmpeg
,都产生了一个视频,其中一个分辨率被简单地缩放为与另一个分辨率相同的大小,而不是实际上用两种不同的分辨率对流进行编码。
我尝试了所有能想到的方法,从简单的重新编码到ffmpeg
将的输出重新导入ffmpeg
,将配置文件强制为基线,将流转换为mpg
,等等。似乎都没有用。
我的问题是,如何保留ffmpeg
*内的分辨率变化,而不是对其进行缩放?
提前感谢您的帮助!
* 但是如果用另一个编码器能够达到同样的效果,那也很好!
答案1
答案是ffmpeg
根本不使用。事实证明,H264/AVC 流支持连接,因此只需采用两个不同分辨率的独立流并使用就可以cat
完美运行。
因此,有两个不同分辨率的流......
cat stream_a.h264 stream_b.h264 >> stream_c.h264
然后将其包装到您想要的任何容器中。