web-dev-qa-db-ja.com

ffmpegがmp3、mp4をマージし、コピーコーデックで音が出ない

私はffmpegを使用してビデオを作成しています。ソースは、png画像のセット(フレームごとに1つ)とmp3ファイルです。音のあるmp4を作りたいです。

今のところ2段階でやっています。ステップ1はpngをmp4に変換します:

%d%\ffmpeg -r 25 -i png\%1-%%06d.png -s 1280x720 -c:v libx264 -pix_fmt yuv420p -b:v 500k -profile:v baseline -movflags faststart temp.mp4

ステップ2は、サウンドと一時的なmp4をマージします。

%d%\ffmpeg -i temp.mp4 -i %1\%1.mp3 %1.mp4

これは機能しますが、音が非常に悪いです。私はそれがaacにmp3をしていると思います。

だから私はこれを試しました:

%d%\ffmpeg -i temp.mp4 -i %1\%1.mp3 -c copy -map 0:0 -map 1:0 %1.mp4

音が出ない。他の多くのオプション、異なるコーデック、他のオーディオパラメータの変更を試しましたが、音が出ません。

サウンドを取得する唯一の方法は、オーディオをデフォルトのままにすることであるように思われますが、それは品質が低すぎます。

ここで編集は出力です

C:\ffmpeg\bin\ffmpeg -r 25 -i png\scene2-%06d.png -s 1280x720 -c:v libx264 -pix_fmt yuv420p
 -b:v 500k -profile:v baseline -movflags faststart temp.mp4
ffmpeg version N-57057-g024bf3a Copyright (c) 2000-2013 the FFmpeg developers
  built on Oct 11 2013 18:01:59 with gcc 4.8.1 (GCC)
  configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-av
isynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enab
le-iconv --enable-libass --enable-libbluray --enable-libcaca --enable-libfreetyp
e --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3lame --ena
ble-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-l
ibopus --enable-librtmp --enable-libschroedinger --enable-libsoxr --enable-libsp
eex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvo-aa
cenc --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavp
ack --enable-libx264 --enable-libxavs --enable-libxvid --enable-zlib
  libavutil      52. 46.101 / 52. 46.101
  libavcodec     55. 35.100 / 55. 35.100
  libavformat    55. 19.100 / 55. 19.100
  libavdevice    55.  4.100 / 55.  4.100
  libavfilter     3. 88.101 /  3. 88.101
  libswscale      2.  5.101 /  2.  5.101
  libswresample   0. 17.103 /  0. 17.103
  libpostproc    52.  3.100 / 52.  3.100
Input #0, image2, from 'png\scene2-%06d.png':
  Duration: 00:00:13.00, start: 0.000000, bitrate: N/A
    Stream #0:0: Video: png, rgba, 1280x720 [SAR 3779:3779 DAR 16:9], 25 fps, 25
 tbr, 25 tbn, 25 tbc
[libx264 @ 003f36a0] using SAR=1/1
[libx264 @ 003f36a0] using cpu capabilities: MMX2 SSE2Fast SSSE3 SSE4.1 Cache64
[libx264 @ 003f36a0] profile Constrained Baseline, level 3.1
[libx264 @ 003f36a0] 264 - core 138 r2358 9e941d1 - H.264/MPEG-4 AVC codec - Cop
yleft 2003-2013 - http://www.videolan.org/x264.html - options: cabac=0 ref=3 deb
lock=1:0:0 analyse=0x1:0x111 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=1 m
e_range=16 chroma_me=1 trellis=1 8x8dct=0 cqm=0 deadzone=21,11 fast_pskip=1 chro
ma_qp_offset=-2 threads=6 lookahead_threads=1 sliced_threads=0 nr=0 decimate=1 i
nterlaced=0 bluray_compat=0 constrained_intra=0 bframes=0 weightp=0 keyint=250 k
eyint_min=25 scenecut=40 intra_refresh=0 rc_lookahead=40 rc=abr mbtree=1 bitrate
=500 ratetol=1.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 ip_ratio=1.40 aq=1:1.00
Output #0, mp4, to 'temp.mp4':
  Metadata:
    encoder         : Lavf55.19.100
    Stream #0:0: Video: h264 (libx264) ([33][0][0][0] / 0x0021), yuv420p, 1280x7
20 [SAR 1:1 DAR 16:9], q=-1--1, 500 kb/s, 12800 tbn, 25 tbc
Stream mapping:
  Stream #0:0 -> #0:0 (png -> libx264)
Press [q] to stop, [?] for help
frame=   57 fps= 56 q=35.0 size=      16kB time=00:00:00.40 bitrate= 320.3kbits/
frame=   84 fps= 55 q=26.0 size=      39kB time=00:00:01.48 bitrate= 214.0kbits/
frame=  113 fps= 56 q=19.0 size=      60kB time=00:00:02.64 bitrate= 186.0kbits/
frame=  141 fps= 55 q=21.0 size=     152kB time=00:00:03.76 bitrate= 332.0kbits/
frame=  167 fps= 55 q=24.0 size=     268kB time=00:00:04.80 bitrate= 457.8kbits/
frame=  190 fps= 53 q=25.0 size=     353kB time=00:00:05.72 bitrate= 506.2kbits/
frame=  213 fps= 52 q=26.0 size=     412kB time=00:00:06.64 bitrate= 508.0kbits/
frame=  238 fps= 52 q=23.0 size=     419kB time=00:00:07.64 bitrate= 449.1kbits/
frame=  262 fps= 51 q=22.0 size=     454kB time=00:00:08.60 bitrate= 432.5kbits/
frame=  286 fps= 51 q=22.0 size=     523kB time=00:00:09.56 bitrate= 448.1kbits/
frame=  309 fps= 50 q=25.0 size=     660kB time=00:00:10.48 bitrate= 515.8kbits/
[mp4 @ 003f3160] Starting second pass: moving the moov atom to the beginning of
the file
frame=  325 fps= 47 q=-1.0 Lsize=     794kB time=00:00:13.00 bitrate= 500.5kbits
/s
video:792kB audio:0kB subtitle:0 global headers:0kB muxing overhead 0.256995%
[libx264 @ 003f36a0] frame I:2     Avg QP:13.55  size: 24853
[libx264 @ 003f36a0] frame P:323   Avg QP:15.10  size:  2356
[libx264 @ 003f36a0] mb I  I16..4: 91.3%  0.0%  8.8%
[libx264 @ 003f36a0] mb P  I16..4:  1.5%  0.0%  0.2%  P16..4:  2.4%  1.0%  0.4%
 0.0%  0.0%    skip:94.5%
[libx264 @ 003f36a0] final ratefactor: 19.04
[libx264 @ 003f36a0] coded y,uvDC,uvAC intra: 6.3% 15.8% 12.8% inter: 1.3% 2.5%
1.4%
[libx264 @ 003f36a0] i16 v,h,dc,p: 82% 17%  2%  0%
[libx264 @ 003f36a0] i4 v,h,dc,ddl,ddr,vr,hd,vl,hu: 39% 18% 25%  3%  3%  4%  3%
 2%  3%
[libx264 @ 003f36a0] i8c dc,h,v,p: 69% 23%  8%  1%
[libx264 @ 003f36a0] ref P L0: 75.5% 14.7%  9.8%
[libx264 @ 003f36a0] kb/s:498.84

C:\ffmpeg\bin\ffmpeg -i temp.mp4 -i scene2\scene2.mp3 -c copy -map 0:0 -map 1:0 scene2.mp4

ffmpeg version N-57057-g024bf3a Copyright (c) 2000-2013 the FFmpeg developers
  built on Oct 11 2013 18:01:59 with gcc 4.8.1 (GCC)
  configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-av
isynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enab
le-iconv --enable-libass --enable-libbluray --enable-libcaca --enable-libfreetyp
e --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3lame --ena
ble-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-l
ibopus --enable-librtmp --enable-libschroedinger --enable-libsoxr --enable-libsp
eex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvo-aa
cenc --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavp
ack --enable-libx264 --enable-libxavs --enable-libxvid --enable-zlib
  libavutil      52. 46.101 / 52. 46.101
  libavcodec     55. 35.100 / 55. 35.100
  libavformat    55. 19.100 / 55. 19.100
  libavdevice    55.  4.100 / 55.  4.100
  libavfilter     3. 88.101 /  3. 88.101
  libswscale      2.  5.101 /  2.  5.101
  libswresample   0. 17.103 /  0. 17.103
  libpostproc    52.  3.100 / 52.  3.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'temp.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf55.19.100
  Duration: 00:00:13.00, start: 0.000000, bitrate: 500 kb/s
    Stream #0:0(und): Video: h264 (Constrained Baseline) (avc1 / 0x31637661), yu
v420p, 1280x720 [SAR 1:1 DAR 16:9], 499 kb/s, 25 fps, 25 tbr, 12800 tbn, 50 tbc
(default)
    Metadata:
      handler_name    : VideoHandler
Input #1, mp3, from 'scene2\scene2.mp3':
  Metadata:
    genre           : Blues
  Duration: 00:00:09.86, start: 0.000000, bitrate: 128 kb/s
    Stream #1:0: Audio: mp3, 16000 Hz, mono, s16p, 128 kb/s
Output #0, mp4, to 'scene2.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf55.19.100
    Stream #0:0(und): Video: h264 ([33][0][0][0] / 0x0021), yuv420p, 1280x720 [S
AR 1:1 DAR 16:9], q=2-31, 499 kb/s, 25 fps, 12800 tbn, 12800 tbc (default)
    Metadata:
      handler_name    : VideoHandler
    Stream #0:1: Audio: mp3 (i[0][0][0] / 0x0069), 16000 Hz, mono, 128 kb/s
Stream mapping:
  Stream #0:0 -> #0:0 (copy)
  Stream #1:0 -> #0:1 (copy)
Press [q] to stop, [?] for help
frame=  325 fps=0.0 q=-1.0 Lsize=     951kB time=00:00:12.96 bitrate= 601.4kbits
/s
video:792kB audio:154kB subtitle:0 global headers:0kB muxing overhead 0.540095%

-iscene2.mp4の追加出力を編集します

C:\ffmpeg\bin\ffmpeg -i scene2.mp4
ffmpeg version N-57057-g024bf3a Copyright (c) 2000-2013 the FFmpeg developers
  built on Oct 11 2013 18:01:59 with gcc 4.8.1 (GCC)
  configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-av
isynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enab
le-iconv --enable-libass --enable-libbluray --enable-libcaca --enable-libfreetyp
e --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3lame --ena
ble-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-l
ibopus --enable-librtmp --enable-libschroedinger --enable-libsoxr --enable-libsp
eex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvo-aa
cenc --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavp
ack --enable-libx264 --enable-libxavs --enable-libxvid --enable-zlib
  libavutil      52. 46.101 / 52. 46.101
  libavcodec     55. 35.100 / 55. 35.100
  libavformat    55. 19.100 / 55. 19.100
  libavdevice    55.  4.100 / 55.  4.100
  libavfilter     3. 88.101 /  3. 88.101
  libswscale      2.  5.101 /  2.  5.101
  libswresample   0. 17.103 /  0. 17.103
  libpostproc    52.  3.100 / 52.  3.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'scene2.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf55.19.100
  Duration: 00:00:13.00, start: 0.000000, bitrate: 599 kb/s
    Stream #0:0(und): Video: h264 (Constrained Baseline) (avc1 / 0x31637661), yu
v420p, 1280x720 [SAR 1:1 DAR 16:9], 499 kb/s, 25 fps, 25 tbr, 12800 tbn, 50 tbc
(default)
    Metadata:
      handler_name    : VideoHandler
    Stream #0:1(und): Audio: mp3 (mp4a / 0x6134706D), 16000 Hz, mono, s16p, 128
kb/s (default)
    Metadata:
      handler_name    : SoundHandler
At least one output file must be specified
5
Martin McBride

Windows Media Playerは、MP4コンテナ形式のMP3に関しては注意が必要です。 32 kHz未満のオーディオサンプルレートも、96 kHz以上も好きではありません(正確な上限についてはテストしていません)。

QuickTimeは、MP4コンテナにMP3を含むサンプルファイルを再生しませんでした。

この制限に対処するには、いくつかのオプションがあります。

1.別のプレーヤーを使用する

[〜#〜] vlc [〜#〜] は機能し、優れたプレーヤーです。このオプションには、オーディオを再エンコードする代わりに、オーディオを(実行中に)ストリーミング ストリーミング できるという利点があります。したがって、品質を維持します。

2.別のコンテナ形式を使用する

.movなど。前のオプションと同様に、これにより元のオーディオをストリーミングコピーすることもできます。

3.別のオーディオ形式を使用する

WMPを使用する必要がある場合は、オーディオを再エンコードする必要があります。 AACオーディオはMP4コンテナの標準であるため、次を使用できます:-c:a aac。詳細については、 FFmpeg Wiki:AACオーディオエンコーディングガイド を参照してください。

4.オーディオサンプルレートを変更します

出力MP3をミューズする場合は、-arなどの-ar 48000オプションを試してください。これが最後に試すオプションです。


ワンステップですべてを行う

これで、機能するものができたので、追加の不必要な手順でビデオを再エンコードする代わりに、すべてを一度に実行できます。

コピーオーディオのストリーム

ffmpeg -framerate 25 -i %06d.png -i input.mp3 -c:v libx264 \
-vf scale=1280:-2,format=yuv420p -c:a copy -movflags +faststart output.mp4

オーディオを再エンコードする

ffmpeg -framerate 25 -i %06d.png -i input.mp3 -c:v libx264 \
-vf scale=1280:-2,format=yuv420p -c:a aac -movflags +faststart output.mp4

ノート

8
llogan