複数の解像度を含む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
を使用して同じビデオを再エンコードする場合でも、実際に2つの異なる解像度でストリームをエンコードするのではなく、一方の解像度をもう一方の解像度と同じサイズに単純にスケーリングしたビデオを生成しました。
単純な再エンコードから、ffmpeg
の出力をffmpeg
に戻す、プロファイルをベースラインに強制する、ストリームをmpg
に変換するなど、考えられるすべてのことを試しました。何も機能していないようです。
私の質問は、どうすれば解決策の変更をffmpeg
内に保存できるかということです。*、スケーリングされるのではなく?
よろしくお願いします!
*別のエンコーダーでも同じ結果が得られる場合でも、それも良いことです。
答えは、ffmpeg
をまったく使用しないことでした。 H264/AVCストリームは連結をサポートしていることが判明したため、異なる解像度で2つの別々のストリームを取得し、cat
を使用するだけで完全に機能します。
したがって、異なる解像度の2つのストリームで...
cat stream_a.h264 stream_b.h264 >> stream_c.h264
次に、好きな容器に包みます。