Mercurial > mplayer.hg
annotate DOCS/encoding.html @ 8930:2c572a9c153f
fixes
author | gabucino |
---|---|
date | Sun, 12 Jan 2003 21:24:19 +0000 |
parents | f51cf48503f3 |
children | ace727b8c2dc |
rev | line source |
---|---|
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> |
2674 | 2 <HTML> |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4919
diff
changeset
|
3 |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4919
diff
changeset
|
4 <HEAD> |
6882
f3f87f6bf5cf
Added a uniform title: something - MPlayer - The Movie Player for Linux.
diego
parents:
6724
diff
changeset
|
5 <TITLE>Encoding - MEncoder - The Movie Encoder for Linux</TITLE> |
6391 | 6 <LINK REL="stylesheet" TYPE="text/css" HREF="default.css"> |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
7 <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1"> |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4919
diff
changeset
|
8 </HEAD> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4919
diff
changeset
|
9 |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
10 <BODY> |
2674 | 11 |
12 | |
8851
636c1e894a27
Appendix B and E numbered, encoding moved to a separate section.
diego
parents:
8816
diff
changeset
|
13 <H1><A NAME="encoding">7. Encoding with MEncoder</A></H1> |
6974 | 14 |
8133
630360b15089
Redundant compilation section removed, MEncoder features section moved to
diego
parents:
8035
diff
changeset
|
15 <P>For the complete list of available MEncoder options and examples, please see |
8895 | 16 the man page. For a series of hands-on examples and detailed guides on using |
17 several encoding parameters, read the | |
18 <A HREF="tech/encoding-tips.txt">encoding-tips</A> that were collected from | |
19 several mailing list threads on | |
20 <A HREF="http://mplayerhq.hu/mailman/listinfo/mplayer-users">mplayer-users</A>. | |
21 Search the <A HREF="http://mplayerhq.hu/pipermail/mplayer-users/">archives</A> | |
22 for a wealth of discussions about all aspects of and problems related to | |
23 encoding with MEncoder.</P> | |
3721 | 24 |
8851
636c1e894a27
Appendix B and E numbered, encoding moved to a separate section.
diego
parents:
8816
diff
changeset
|
25 |
8930 | 26 <H2><A NAME="2pass">7.1 Encoding 2 or 3-pass MPEG-4 ("DivX")</A></H2> |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2745
diff
changeset
|
27 |
6960 | 28 <P><U><B>2-pass encoding:</B></U> the name comes from the fact that this method |
29 encodes the file <I>twice</I>. The first encoding (dubbed <I>pass</I>) | |
30 creates some temporary files (*.log) with a size of few megabytes, do not | |
31 delete them yet (you can delete the AVI). In the second pass, the 2-pass | |
32 output file is created, using the bitrate data from the temporary files. The | |
33 resulting file will have much better image quality. If this is the first time | |
34 you heard about this, you should consult some guides available on the | |
35 Net.</P> | |
2848
33c32f3d9f1f
many small updates, fixes (some/more to be completed soon)
gabucino
parents:
2745
diff
changeset
|
36 |
8816
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
37 <P>This example shows how to encode a DVD to a 2-pass MPEG-4 ("DIVX") AVI. Just |
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
38 two commands are needed:<BR> |
6960 | 39 <CODE> rm frameno.avi</CODE> - remove this file, which |
40 can come from a previous 3-pass encoding (it interferes with current | |
41 one)<BR> | |
7640 | 42 <CODE> mencoder -dvd 2 -ovc lavc -lavcopts |
8497 | 43 vcodec=mpeg4:vpass=1 -oac copy -o movie.avi<BR> |
7699
5d4b0446a557
Cosmetics: Converted 2 spaces to one in section titles, changed some ugly
diego
parents:
7640
diff
changeset
|
44 mencoder -dvd 2 -ovc lavc -lavcopts |
8497 | 45 vcodec=mpeg4:vpass=2 -oac copy -o movie.avi</CODE></P> |
4397 | 46 |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
47 <P><U><B>3-pass encoding:</B></U> this is an extension of 2-pass encoding, |
4397 | 48 where the audio encoding takes place in a separate pass. This method enables |
49 estimation of recommended video bitrate in order to fit on a CD. Also, the | |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
50 audio is encoded only once, unlike in 2-pass mode. The schematics:</P> |
4397 | 51 |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
52 <OL> |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
53 <LI>Remove conflicting temporary file: |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
54 <P><CODE>rm frameno.avi</CODE></P></LI> |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
55 <LI>First pass: |
8497 | 56 <P><CODE>mencoder <file/DVD> -ovc frameno -oac mp3lame -lameopts vbr=3 -o frameno.avi</CODE></P> |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
57 <P>An audio-only avi file will be created, containing |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
58 <B>only</B> the requested audio stream. Don't forget <CODE>-lameopts</CODE>, |
7814 | 59 if you need to set it. If you were encoding a long movie, MEncoder |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
60 prints the recommended bitrate values for 650Mb, 700Mb, and 800Mb |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
61 destination sizes, after this pass finishes.</P></LI> |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
62 <LI>Second pass: |
8035
533e212cd282
document new 2pass syntax, remove/fix lots of obsolete junk in docs
rfelker
parents:
7814
diff
changeset
|
63 <P><CODE>mencoder <file/DVD> -oac copy |
533e212cd282
document new 2pass syntax, remove/fix lots of obsolete junk in docs
rfelker
parents:
7814
diff
changeset
|
64 -ovc lavc -lavcopts vcodec=mpeg4:vpass=1:vbitrate=<bitrate></CODE></P> |
8816
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
65 <P>This is the first pass of video encoding. |
7814 | 66 Optionally specify the video bitrate MEncoder printed at the end of |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
67 the previous pass.</P></LI> |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
68 <LI>Third pass: |
8035
533e212cd282
document new 2pass syntax, remove/fix lots of obsolete junk in docs
rfelker
parents:
7814
diff
changeset
|
69 <P><CODE>mencoder <file/DVD> -oac copy |
533e212cd282
document new 2pass syntax, remove/fix lots of obsolete junk in docs
rfelker
parents:
7814
diff
changeset
|
70 -ovc lavc -lavcopts vcodec=mpeg4:vpass=2:vbitrate=<bitrate></CODE></P> |
8816
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
71 <P>This is the second pass of video encoding. |
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
72 Specify the same bitrate as in the previous pass unless you really know |
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
73 what you are doing. In this pass, audio from <CODE>frameno.avi</CODE> |
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
74 will be inserted into the destination file.. and it's all ready!</P></LI> |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
75 </OL> |
4397 | 76 |
7047 | 77 <H4>Example for 3-pass encoding:</H4> |
4397 | 78 |
79 <P><CODE> rm frameno.avi</CODE> - remove this file, | |
80 which can come from a previous 3-pass encoding (it interferes with current | |
81 one)<BR> | |
6960 | 82 <CODE> mencoder -dvd 2 -ovc frameno |
8497 | 83 -o frameno.avi -oac mp3lame -lameopts vbr=3<BR> |
7640 | 84 mencoder -dvd 2 -ovc lavc |
8497 | 85 -lavcopts vcodec=mpeg4:vpass=1 -oac copy -o movie.avi<BR> |
7640 | 86 mencoder -dvd 2 -ovc lavc |
8497 | 87 -lavcopts vcodec=mpeg4:vpass=2 -oac copy -o movie.avi</CODE></P> |
4397 | 88 |
8851
636c1e894a27
Appendix B and E numbered, encoding moved to a separate section.
diego
parents:
8816
diff
changeset
|
89 |
636c1e894a27
Appendix B and E numbered, encoding moved to a separate section.
diego
parents:
8816
diff
changeset
|
90 <H2><A NAME="rescaling">7.2 Rescaling movies</A></H2> |
3438 | 91 |
8260 | 92 <P>Often the need to resize movie images' size emerges. Its reasons can be |
93 many: decreasing file size, network bandwidth, etc. Most people | |
94 even do rescaling when converting DVDs or SVCDs to DivX AVI. <B>This is bad.</B> | |
95 Instead of even you doing so, read the <A HREF="#aspect">Preserving | |
96 aspect ratio</A> section.</P> | |
3438 | 97 |
5968 | 98 <P>The scaling process is handled by the <I>'scale'</I> video filter: |
8260 | 99 <CODE>-vop scale=widht:height</CODE>. Its quality can be set with the |
7814 | 100 <CODE>-sws</CODE> option. If it's not specified, MEncoder will use 0: |
5968 | 101 fast bilinear.</P> |
3438 | 102 |
8260 | 103 <H5>Usage:</H5> |
104 | |
105 <P><CODE> mencoder input.mpg -ovc lavc -lavcopts | |
8497 | 106 vcodec=mpeg4 -vop scale=640:480 -oac copy -o |
8260 | 107 output.avi</CODE></P> |
3438 | 108 |
4680 | 109 |
8851
636c1e894a27
Appendix B and E numbered, encoding moved to a separate section.
diego
parents:
8816
diff
changeset
|
110 <H2><A NAME="copying">7.3 Stream copying</A></H2> |
2868 | 111 |
7814 | 112 <P>MEncoder can handle input streams in two ways: <B>encode</B> or |
3438 | 113 <B>copy</B> them. This section is about <B>copying</B>.</P> |
2868 | 114 |
3438 | 115 <UL> |
6960 | 116 <LI><B>Video stream</B> (option <CODE>-ovc copy</CODE>): nice stuff can be |
117 done :)<BR> | |
6998
83a386e88f9e
Applied patch by Andras Mohari <mayday at varoshaza . nagyatad . hu>
diego
parents:
6974
diff
changeset
|
118 Like, putting (not converting) FLI or VIVO or MPEG1 video into |
7814 | 119 an AVI file. Of course only MPlayer can play such files :) And it |
6960 | 120 probably has no real life value at all. Rationally: video stream copying |
121 can be useful for example when only the audio stream has to be encoded | |
122 (like, uncompressed PCM to MP3).</LI> | |
3438 | 123 |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
124 <LI><B>Audio stream</B> (option <CODE>-oac copy</CODE>): straightforward. |
6960 | 125 It is possible to take an external audio file (MP3, Vorbis) and mux it |
126 into the output stream. Use the <CODE>-audiofile <filename></CODE> | |
127 option for this.</LI> | |
3438 | 128 </UL> |
129 | |
4680 | 130 |
8851
636c1e894a27
Appendix B and E numbered, encoding moved to a separate section.
diego
parents:
8816
diff
changeset
|
131 <H2><A NAME="fixing">7.4 Fixing AVIs with broken index or interleaving</A></H2> |
3583 | 132 |
133 <P>Easiest thing. We simply copy the video and audio streams, and | |
7814 | 134 MEncoder generates the index. Of course this cannot fix possible bugs |
6960 | 135 in the video and/or audio streams. It also fixes files with broken |
136 interleaving, thus the <CODE>-ni</CODE> option won't be needed for them | |
137 anymore.</P> | |
3583 | 138 |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
139 <P>Command: <CODE>mencoder -idx input.avi -ovc copy -oac copy -o output.avi</CODE></P> |
3583 | 140 |
3721 | 141 |
8851
636c1e894a27
Appendix B and E numbered, encoding moved to a separate section.
diego
parents:
8816
diff
changeset
|
142 <H2><A NAME="libavcodec">7.5 Encoding with the libavcodec codec family</A></H2> |
3721 | 143 |
6906
3274d0725fde
Changed all link names from the section number to a sensible label.
diego
parents:
6882
diff
changeset
|
144 <P><A HREF="codecs.html#libavcodec">libavcodec</A> provides simple encoding to a |
6960 | 145 lot of interesting video and audio formats (currently its audio codecs are |
146 unsupported). You can encode to the following codecs:</P> | |
3721 | 147 |
148 <UL> | |
149 <LI>mjpeg - Motion JPEG</LI> | |
3774 | 150 <LI>h263 - H263</LI> |
3721 | 151 <LI>h263p - H263 Plus</LI> |
8930 | 152 <LI>mpeg4 - ISO standard MPEG-4 (DivX 5, XVID compatible)</LI> |
8816
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
153 <LI>msmpeg4 - pre-standard MPEG-4 variant by MS, v3 (aka DivX3)</LI> |
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
154 <LI>msmpeg4v2 - pre-standard MPEG-4 by MS, v2 (used in old asf files)</LI> |
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
155 <LI>wmv1 - Windows Media Video, version 1 (aka WMV7)</LI> |
3721 | 156 <LI>rv10 - an old RealVideo codec</LI> |
157 <LI>mpeg1video - MPEG1 video :)</LI> | |
8816
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
158 <LI>huffyuv - lossless compression</LI> |
3721 | 159 </UL> |
160 | |
161 <P>The first column contains the codec names that should be passed after the | |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
162 <CODE>vcodec</CODE> config, like: <CODE>-lavcopts vcodec=msmpeg4</CODE></P> |
3721 | 163 |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
164 <P>An example, with MJPEG compression:<BR> |
6960 | 165 <CODE> mencoder -dvd 2 -o title2.avi -ovc lavc |
7640 | 166 -lavcopts vcodec=mjpeg -oac copy</CODE></P> |
3912 | 167 |
4680 | 168 |
8851
636c1e894a27
Appendix B and E numbered, encoding moved to a separate section.
diego
parents:
8816
diff
changeset
|
169 <H2><A NAME="image_files">7.6 Encoding from multiple input image files (JPEGs, PNGs or TGAs)</A></H2> |
4919 | 170 |
7814 | 171 <P>MEncoder is capable of creating movies from one or more JPEG, PNG or TGA |
7366 | 172 files. With simple framecopy it can create MJPEG (Motion JPEG), MPNG |
173 (Motion PNG) or MTGA (Motion TGA) files.</P> | |
4919 | 174 |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
175 Explanation of the process: |
4919 | 176 |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
177 <OL> |
7814 | 178 <LI>MEncoder <I>decodes</I> the input image(s) with |
7699
5d4b0446a557
Cosmetics: Converted 2 spaces to one in section titles, changed some ugly
diego
parents:
7640
diff
changeset
|
179 <CODE>libjpeg</CODE> (when decoding PNGs, it will use <B>libpng</B>).</LI> |
4919 | 180 |
7814 | 181 <LI>MEncoder then feeds the decoded image to the chosen video compressor |
8816
341d8083491a
fix lots of stuff that was outdated, unclear, inaccurate, or
rfelker
parents:
8497
diff
changeset
|
182 (DivX4, Xvid, ffmpeg msmpeg4, etc...).</LI> |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7061
diff
changeset
|
183 </OL> |
4919 | 184 |
7047 | 185 <H4>Examples</H4> |
4919 | 186 |
187 <P>The explanation of the <CODE>-mf</CODE> option can be found below in the | |
6906
3274d0725fde
Changed all link names from the section number to a sensible label.
diego
parents:
6882
diff
changeset
|
188 global <A HREF="#options">Options</A> section and in the man page.</P> |
4919 | 189 |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
190 <P><I>Creating a DivX4 file from all the JPEG files in the current dir:</I><BR> |
7699
5d4b0446a557
Cosmetics: Converted 2 spaces to one in section titles, changed some ugly
diego
parents:
7640
diff
changeset
|
191 <CODE>mencoder \*.jpg -mf on:w=800:h=600:fps=25 -ovc divx4 |
8454
1a558102e0d4
bunkus: Removed "-oac copy" from the mf examples. Removed the paragraph about the "internal lavc controller": the examples right above that paragraph already use this syntax.
mosu
parents:
8402
diff
changeset
|
192 -o output.avi</CODE></P> |
4919 | 193 |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
194 <P><I>Creating a DivX4 file from some JPEG files in the current dir:</I><BR> |
7699
5d4b0446a557
Cosmetics: Converted 2 spaces to one in section titles, changed some ugly
diego
parents:
7640
diff
changeset
|
195 <CODE>mencoder frame001.jpg,frame002.jpg -mf on:w=800:h=600:fps=25 |
8454
1a558102e0d4
bunkus: Removed "-oac copy" from the mf examples. Removed the paragraph about the "internal lavc controller": the examples right above that paragraph already use this syntax.
mosu
parents:
8402
diff
changeset
|
196 -ovc divx4 -o output.avi</CODE></P> |
5378 | 197 |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
198 <P><I>Creating a Motion JPEG (MJPEG) file from all the JPEG files in the current dir:</I><BR> |
4919 | 199 <CODE>mencoder \*.jpg -mf on:w=800:h=600:fps=25 -ovc copy |
8454
1a558102e0d4
bunkus: Removed "-oac copy" from the mf examples. Removed the paragraph about the "internal lavc controller": the examples right above that paragraph already use this syntax.
mosu
parents:
8402
diff
changeset
|
200 -o output.avi</CODE></P> |
4919 | 201 |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
202 <P><I>Creating an uncompressed file from all the PNG files in the current dir:</I><BR> |
7699
5d4b0446a557
Cosmetics: Converted 2 spaces to one in section titles, changed some ugly
diego
parents:
7640
diff
changeset
|
203 <CODE>mencoder \*.png -mf on:w=800:h=600:fps=25:type=png -ovc raw |
8454
1a558102e0d4
bunkus: Removed "-oac copy" from the mf examples. Removed the paragraph about the "internal lavc controller": the examples right above that paragraph already use this syntax.
mosu
parents:
8402
diff
changeset
|
204 -o output.avi</CODE></P> |
4919 | 205 |
6427
41b149822666
Background now set by CSS, added doctype and charset.
diego
parents:
6393
diff
changeset
|
206 <P><I>Creating a Motion PNG (MPNG) file from all the PNG files in the current dir:</I><BR> |
7699
5d4b0446a557
Cosmetics: Converted 2 spaces to one in section titles, changed some ugly
diego
parents:
7640
diff
changeset
|
207 <CODE>mencoder \*.png -mf on:w=800:h=600:fps=25:type=png -ovc copy |
8454
1a558102e0d4
bunkus: Removed "-oac copy" from the mf examples. Removed the paragraph about the "internal lavc controller": the examples right above that paragraph already use this syntax.
mosu
parents:
8402
diff
changeset
|
208 -o output.avi</CODE></P> |
4919 | 209 |
7366 | 210 <P><I>Creating a Motion TGA (MTGA) file from all the TGA files in the current dir:</I><BR> |
7699
5d4b0446a557
Cosmetics: Converted 2 spaces to one in section titles, changed some ugly
diego
parents:
7640
diff
changeset
|
211 <CODE>mencoder \*.tga -mf on:w=800:h=600:fps=25:type=tga -ovc copy |
8454
1a558102e0d4
bunkus: Removed "-oac copy" from the mf examples. Removed the paragraph about the "internal lavc controller": the examples right above that paragraph already use this syntax.
mosu
parents:
8402
diff
changeset
|
212 -o output.avi</CODE></P> |
7366 | 213 |
4919 | 214 |
8851
636c1e894a27
Appendix B and E numbered, encoding moved to a separate section.
diego
parents:
8816
diff
changeset
|
215 <H2><A NAME="vobsub">7.7 Extracting DVD subtitles to a Vobsub file</A></H2> |
6711 | 216 |
7814 | 217 <P>MEncoder is capable of extracting subtitles from a DVD into |
6960 | 218 Vobsub fomat files. They consist of a pair of files ending in |
219 <CODE>.idx</CODE> and <CODE>.sub</CODE> and are usually packaged in a single | |
7814 | 220 <CODE>.rar</CODE> archive. MPlayer can play these with the |
6960 | 221 <CODE>-vobsub</CODE> and <CODE>-vobsubid</CODE> options.</P> |
6711 | 222 |
6724
ab3d2c60b454
Some spellchecking, moved the section to the correct position, some
diego
parents:
6711
diff
changeset
|
223 <P>You specify the basename (i.e without the <CODE>.idx</CODE> or |
6960 | 224 <CODE>.sub</CODE> extension) of the output files with <CODE>-vobsubout</CODE> |
225 and the index for this subtitle in the resulting files with | |
226 <CODE>-vobsuboutindex</CODE>.</P> | |
6711 | 227 |
6724
ab3d2c60b454
Some spellchecking, moved the section to the correct position, some
diego
parents:
6711
diff
changeset
|
228 <P>If the input is not from a DVD you should use <CODE>-ifo</CODE> to |
6960 | 229 indicate the <CODE>.ifo</CODE> file needed to construct the resulting |
230 <CODE>.idx</CODE> file.</P> | |
6711 | 231 |
6960 | 232 <P>If the input is not from a DVD and you do not have the <CODE>.ifo</CODE> |
233 file you will need to use the <CODE>-vobsubid</CODE> option to let it know | |
234 what language id to put in the <CODE>.idx</CODE> file.</P> | |
6711 | 235 |
6724
ab3d2c60b454
Some spellchecking, moved the section to the correct position, some
diego
parents:
6711
diff
changeset
|
236 <P>Each run will append the running subtitle if the <CODE>.idx</CODE> and |
6960 | 237 <CODE>.sub</CODE> files already exist. So you should remove any before |
238 starting.</P> | |
6711 | 239 |
7047 | 240 <H4>Examples</H4> |
6711 | 241 |
242 <P><I>Copying two subtitles from a DVD while doing 3-pass encoding</I><BR> | |
6960 | 243 <CODE>rm subtitles.idx subtitles.sub</CODE><BR> |
244 <CODE>mencoder -dvd 1 -vobsubout subtitles -vobsuboutindex 0 | |
7640 | 245 -sid 2 -o frameno.avi -ovc frameno -oac mp3lame -lameopts vbr=3</CODE><BR> |
8035
533e212cd282
document new 2pass syntax, remove/fix lots of obsolete junk in docs
rfelker
parents:
7814
diff
changeset
|
246 <CODE>mencoder -dvd 1 -oac copy -ovc divx4 -divx4opts pass=1</CODE><BR> |
533e212cd282
document new 2pass syntax, remove/fix lots of obsolete junk in docs
rfelker
parents:
7814
diff
changeset
|
247 <CODE>mencoder -dvd 1 -oac copy -ovc divx4 -divx4opts pass=2 -vobsubout |
6960 | 248 subtitles -vobsuboutindex 1 -sid 5</CODE></P> |
6711 | 249 |
250 <P><I>Copying a french subtitle from an MPEG file</I><BR> | |
6960 | 251 <CODE>rm subtitles.idx subtitles.sub</CODE><BR> |
252 <CODE>mencoder movie.mpg -ifo movie.ifo -vobsubout subtitles | |
253 -vobsuboutindex 0 -vobsuboutid fr -sid 1</CODE></P> | |
6711 | 254 |
7047 | 255 |
8851
636c1e894a27
Appendix B and E numbered, encoding moved to a separate section.
diego
parents:
8816
diff
changeset
|
256 <H2><A NAME="aspect">7.8 Preserving aspect ratio</A></H2> |
8260 | 257 |
258 <P>DVDs and SVCDs (i.e. MPEG1/2) files contain an aspect ratio value, | |
259 which describes how should the player scale the video stream, so humans | |
260 won't have egg heads (ex.: 480x480 + 4:3 = 640x480). However when encoding | |
261 to AVI (DivX) files, you have be aware that AVI headers don't store this | |
262 value. Rescaling the movie is disgusting and time consuming, there | |
263 must be a better feature!</P> | |
264 | |
265 <P>There is.</P> | |
266 | |
267 <P>MPEG4 has an unique feature: the video stream can contain | |
268 its needed aspect ratio. Yes, just like MPEG1/2 files (DVD, SVCD). | |
269 Regretfully, there are <U>no</U> video players outside which support this | |
270 attribute. Except MPlayer.</P> | |
271 | |
272 <P>This feature can be used only with <B>libavcodec</B>'s <CODE>mpeg4</CODE> | |
273 codec. Keep in mind: although MPlayer will correctly play the created file, | |
274 other players will use the wrong aspect ratio.</P> | |
275 | |
276 <P>You seriously should crop the black bands over and below the movie image. | |
8402 | 277 See the manpage about the usage of the <CODE>cropdetect</CODE> and |
278 <CODE>crop</CODE> filters.</P> | |
8260 | 279 |
280 <H5>Usage:</H5> | |
281 | |
282 <P><CODE>$ mencoder sample-svcd.mpg -ovc lavc -lavcopts | |
283 vcodec=mpeg4:aspect=16.0/9.0 -vop crop=714:548:0:14 -oac copy -o output.avi</CODE></P> | |
284 | |
2674 | 285 </BODY> |
286 </HTML> |