Opened 2 years ago
Last modified 2 years ago
#9867 open defect
Cannot remove "default" disposition of mov_text subtitle in mp4
Reported by: | liancea | Owned by: | |
---|---|---|---|
Priority: | normal | Component: | avformat |
Version: | git-master | Keywords: | |
Cc: | Blocked By: | ||
Blocking: | Reproduced by developer: | no | |
Analyzed by developer: | no |
Description
Summary of the bug:
When trying to remove the default disposition of a mov_text subtitle inside mp4 with either -disposition:s:0 0
or -disposition:s:0 -default
, the output file still has the default disposition enabled.
Setting -default_mode
to infer_no_subs
or passthrough
doesn't change the outcome. (This may only have worked for mkv in the first place, but I wasn't sure.)
I included instructions for a minimal file for reproducing the issue, but I could also upload a real world example with audio and video in it, if desired. The behavior was identical for me.
How to reproduce:
# Create sample file (linux/mac shell) % echo -e '1\n00:00:00,000 --> 00:01:00,000\nTest' > subtest.srt % ffmpeg -i subtest.srt -map 0 -c mov_text subtest.mp4 # Check if sample file has a default subtitle % ffmpeg -hide_banner -i subtest.mp4 Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'subtest.mp4': Metadata: major_brand : isom minor_version : 512 compatible_brands: isomiso2mp41 encoder : Lavf59.30.100 Duration: 00:01:00.00, start: 0.000000, bitrate: 0 kb/s Stream #0:0[0x1](und): Subtitle: mov_text (tx3g / 0x67337874), 0 kb/s (default) Metadata: handler_name : SubtitleHandler At least one output file must be specified # Try to remove default disposition % ffmpeg -i subtest.mp4 -map 0 -c copy -disposition:s:0 0 subtest-after.mp4 # or ... % ffmpeg -i subtest.mp4 -map 0 -c copy -disposition:s:0 -default subtest-after.mp4 ffmpeg version N-107731-g5cdf4c0bed Copyright (c) 2000-2022 the FFmpeg developers built with gcc 11 (Ubuntu 11.2.0-19ubuntu1) configuration: --prefix=/home/pauling/ffmpeg_build --pkg-config-flags=--static --extra-cflags=-I/home/pauling/ffmpeg_build/include --extra-ldflags=-L/home/pauling/ffmpeg_build/lib --extra-libs='-lpthread -lm' --ld=g++ --bindir=/home/pauling/bin --enable-gpl --enable-gnutls --enable-libaom --enable-libass --enable-libfdk-aac --enable-libfreetype --enable-libmp3lame --enable-libopus --enable-libsvtav1 --enable-libdav1d --enable-libvorbis --enable-libvpx --enable-libx264 --enable-libx265 --enable-nonfree libavutil 57. 32.101 / 57. 32.101 libavcodec 59. 42.100 / 59. 42.100 libavformat 59. 30.100 / 59. 30.100 libavdevice 59. 8.101 / 59. 8.101 libavfilter 8. 46.101 / 8. 46.101 libswscale 6. 8.102 / 6. 8.102 libswresample 4. 8.100 / 4. 8.100 libpostproc 56. 7.100 / 56. 7.100 Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'subtest.mp4': Metadata: major_brand : isom minor_version : 512 compatible_brands: isomiso2mp41 encoder : Lavf59.30.100 Duration: 00:01:00.00, start: 0.000000, bitrate: 0 kb/s Stream #0:0[0x1](und): Subtitle: mov_text (tx3g / 0x67337874), 0 kb/s (default) Metadata: handler_name : SubtitleHandler Output #0, mp4, to 'subtest-after.mp4': Metadata: major_brand : isom minor_version : 512 compatible_brands: isomiso2mp41 encoder : Lavf59.30.100 Stream #0:0(und): Subtitle: mov_text (tx3g / 0x67337874), 0 kb/s Metadata: handler_name : SubtitleHandler Stream mapping: Stream #0:0 -> #0:0 (copy) Press [q] to stop, [?] for help size= 1kB time=00:00:00.00 bitrate=N/A speed= 0x video:0kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 12933.333008% # Confirm whether default disposition is gone % ffmpeg -hide_banner -i subtest-after.mp4 Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'subtest-after.mp4': Metadata: major_brand : isom minor_version : 512 compatible_brands: isomiso2mp41 encoder : Lavf59.30.100 Duration: 00:01:00.00, start: 0.000000, bitrate: 0 kb/s Stream #0:0[0x1](und): Subtitle: mov_text (tx3g / 0x67337874), 0 kb/s (default) Metadata: handler_name : SubtitleHandler At least one output file must be specified
I can confirm that default_mode is an mkv-muxer option that will definitely be ignored by the mp4 muxer.
The mov muxer always sets one stream of each type to default; this is done in enable_tracks() (mainly the last loop in it, lines 6704-6715 in libavformat/movenc.c as of this writing). One would have to add an option similar to the mkv muxer's default_mode to do as you want (or one would have to directly map the AV_DISPOSITION_DEFAULT to MOV_TRACK_ENABLED).