Mercurial > mplayer.hg
annotate DOCS/codecs.html @ 5304:6175c9cfab11
Support for decoder specific config from mp4 header for AAC decoder.
author | atmos4 |
---|---|
date | Sun, 24 Mar 2002 03:08:20 +0000 |
parents | 0a56406fb224 |
children | 1a7fd8f13ac0 |
rev | line source |
---|---|
1612 | 1 <HTML> |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
2 |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
3 <HEAD> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
4 <STYLE> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
5 .text |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
6 {font-family : Verdana, Arial, Helvetica, sans-serif; |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
7 font-size : 14px;} |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
8 </STYLE> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
9 </HEAD> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
10 |
1712 | 11 <BODY BGCOLOR=WHITE> |
1704 | 12 |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
13 <FONT CLASS="text"> |
1612 | 14 |
2745 | 15 <P><B><A NAME=2.2>2.2. Supported codecs</A></B></P> |
1612 | 16 |
17 | |
2745 | 18 <P><B><A NAME=2.2.1>2.2.1. Video codecs</A></B></P> |
1612 | 19 |
1731 | 20 <P>See <A HREF="http://www.mplayerhq.hu/DOCS/codecs-status.html">http://www.mplayerhq.hu/DOCS/codecs-status.html</A> for the complete, |
1869 | 21 daily generated list!!!</P> |
1612 | 22 |
2745 | 23 <P>The most important ones above all:<BR> |
1682 | 24 <UL> |
2290 | 25 <LI>MPEG1 (VCD) and MPEG2 (DVD) video</LI> |
5114 | 26 <LI>DivX ;-), OpenDivX (DivX4), DivX 5.00, 3ivX and other MPEG4 variants</LI> |
2290 | 27 <LI>Windows Media Video 7 (WMV1) and 8 (WMV2) used in .wmv files</LI> |
5114 | 28 <LI>Cinepak and Intel Indeo codecs (3.1,3.2,4.1,5.0)</LI> |
29 <LI>MJPEG, AVID, VCR2, ASV2 and other hardware formats</LI> | |
30 <LI>VIVO 1.0, 2.0, I263 and other h263(+) variants</LI> | |
31 <LI>FLI/FLC</LI> | |
3806 | 32 <LI>RealVideo 1.0</LI> |
5114 | 33 <LI>Various old simple RLE-like formats</LI> |
1682 | 34 </UL></P> |
1612 | 35 |
2745 | 36 <P>If you have a Win32 codec not listed here, and not supported yet, just read the <A |
37 HREF="#2.2.3">codec importing</A> to get info about how to help us adding support | |
1731 | 38 for it!</P> |
1612 | 39 |
5018 | 40 <P><B><A NAME=2.2.1.1>2.2.1.1. DivX4/DivX5</A></B></P> |
1612 | 41 |
1682 | 42 <P>This section contains information about the DivX4 codec of |
43 <A HREF="http://www.projectmayo.com">ProjectMayo</A>. Their first available alpha version was the OpenDivX 4.0 | |
44 alpha 47 and 48. Support for this was/is included in <B>MPlayer</B>, and built by | |
2240
5d476d03e2b3
ide vmi nagy hulyeseget akartam irni de elfelejtettem
gabucino
parents:
2153
diff
changeset
|
45 default. We used to use its postprocessing code to optionally enhance visual |
5d476d03e2b3
ide vmi nagy hulyeseget akartam irni de elfelejtettem
gabucino
parents:
2153
diff
changeset
|
46 quality of MPEG1/2 movies. Now we use our own.</P> |
1612 | 47 |
1682 | 48 <P>The new generation of this codec can even decode movies made with the |
49 infamous DivX codec! And it's not everything, it's MUCH faster than the | |
5018 | 50 traditional Win32 DivX DLL's (note that libavcodec's decoder is EVEN FASTER, |
51 so the usage of this codec is <B>DISCOURAGED</B> - you need it only for | |
52 encoding). See below for configuration. The only disadvantage of this codec is | |
53 that it's currently closed-source. :(</P> | |
1612 | 54 |
1682 | 55 <P>The codec can be downloaded from the following URL:</P> |
56 | |
3583 | 57 <P> <A HREF="http://avifile.sourceforge.net">http://avifile.sourceforge.net</A></P> |
58 | |
59 <P>If it doesn't work, try :</P> | |
60 | |
61 <P> <A HREF="http://divx.com">http://divx.com</A></P> | |
1612 | 62 |
2684 | 63 <P>Unpack it, and run <CODE>./install.sh</CODE> as root.</P> |
1612 | 64 |
4177 | 65 <P>Note: do NOT forget to add <CODE>/usr/local/lib</CODE> to your |
66 <CODE>/etc/ld.so.conf</CODE> and running <CODE>ldconfig</CODE> !</P> | |
1612 | 67 |
5018 | 68 <P><B>MPlayer</B> autodetects if DivX4/DivX5 is (properly) installed, just |
69 compile as usual. If it doesn't detect it, you didn't install it exactly as | |
70 above, and/or has messed up config (see last question of 5.1 section).</P> | |
1682 | 71 |
4177 | 72 <P>Using it is a bit tricky. As it conflicts with the old OpenDivX (its API is |
1682 | 73 very similar to OpenDivX's), OpenDivX code is disabled, and the OpenDivX |
74 driver calls this library too.</P> | |
75 | |
76 <P>Generally we can pinpoint this issue to that you have two options to use | |
77 this codec:</P> | |
78 | |
79 <P><TABLE BORDER=0> | |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
80 <TD> </TD><TD VALIGN=top><FONT CLASS="text">-vc odivx</TD><TD> </TD> |
5018 | 81 <TD><FONT CLASS="text">using the codec as a new version of OpenDivX. |
1682 | 82 in this case it produces YV12 image in its own buffer, |
1987 | 83 and <B>MPlayer</B> (libvo) does colorspace conversion. (<B>RECOMMENDED!</B>)</TD><TR> |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
84 <TD></TD><TD VALIGN=top><FONT CLASS="text">-vc divx4</TD><TD></TD> |
5018 | 85 <TD><FONT CLASS="text">using the codec's colorspace conversion. |
2095 | 86 in this mode, you can use YUY2/UYVY too.</TD></TR> |
1682 | 87 </TABLE></P> |
1612 | 88 |
1682 | 89 <P>The 'odivx' method is usually faster, due to the fact that it transfers |
90 image data in YV12 (planar YUV 4:2:0) format, thus requiring much less | |
91 bandwidth on the bus. For packed YUV modes (YUY2, UYVY) use the 'divx4' | |
92 method. For RGB modes you can choose freely, their speed is same, maybe | |
93 differ according to the current bpp.</P> | |
94 | |
5114 | 95 <P>NOTE: If your -vo driver supports direct rendering, then -vc divx4 may be |
96 faster, or even the fastest solution.</P> | |
97 | |
5230 | 98 <P>Note: <B>OLD</B> OpenDivX supports postprocessing too (use option |
99 <CODE>-oldpp</CODE> to enable using it), but range of values is strange: </P> | |
1612 | 100 |
1682 | 101 <P><TABLE BORDER=0> |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
102 <TD> </TD><TD><FONT CLASS="text">0</TD><TD> </TD> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
103 <TD><FONT CLASS="text">no postproc</TD><TR> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
104 <TD></TD><TD><FONT CLASS="text">10 .. 20</TD> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
105 <TD></TD><TD><FONT CLASS="text">postprocessing, normal (like level 2 with divxds)</TD><TR> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
106 <TD></TD><TD><FONT CLASS="text">30 .. 60</TD> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
107 <TD></TD><TD><FONT CLASS="text">hard prostprocessing, eats many CPU (like level 4 with divxds</TD><TR> |
1682 | 108 </TABLE></P> |
1612 | 109 |
2745 | 110 <P><B><A NAME=2.2.1.2>2.2.1.2. ffmpeg's DivX/libavcodec</A></B></P> |
1682 | 111 |
5018 | 112 <P>Beginning with version 0.4.2 , |
113 <A HREF="http://ffmpeg.sourceforge.net">ffmpeg</A> contains an | |
114 <B>opensource</B> DivX codec, which is compatible with the traditional DivX. | |
115 <B>MPlayer</B> supports this codec, and this makes it possible to <B>watch | |
116 DivX/DivX4/DivX5 movies on non-x86 platforms</B>, and gain much faster | |
117 <B>DivX/DivX4/DivX5</B> decoding speed than the Win32 codecs and the original | |
118 DivX4 library has!</P> | |
4022 | 119 |
120 <P>It also contains lots of nice codecs, such as RealVideo 1.0, MJPEG, h263, | |
121 h263+, etc.</P> | |
122 | |
123 <P>If you use MPlayer | |
124 | |
125 <UL> | |
126 <LI>from release : then you have libavcodec right in the package, just | |
127 build <B>MPlayer</B> as usual.</LI> | |
128 <LI>from CVS : you have to download it manually directly from <B>FFmpeg</B>'s | |
5114 | 129 CVS tree (ffmpeg 0.4.5 version will NOT work with mplayer!): |
1682 | 130 |
131 <P><CODE> | |
1987 | 132 cvs -d:pserver:anonymous@cvs.ffmpeg.sourceforge.net:/cvsroot/ffmpeg login<BR> |
1612 | 133 cvs -d:pserver:anonymous@cvs.ffmpeg.sourceforge.net:/cvsroot/ffmpeg co ffmpeg |
1682 | 134 </CODE></P> |
1612 | 135 |
1682 | 136 <P>Note: <I>if you copy with CVS subdirs, next time it's enough to do |
137 'cvs update'.</I></P> | |
138 <P>Now, move the newly downloaded ffmpeg source's <B>libavcodec</B> directory, | |
139 (with all it's subdirectories) to <B>MPlayer</B>'s tree, so it will look | |
140 like this:</P> | |
1612 | 141 |
1682 | 142 <P> <CODE>main/libavcodec</CODE></P> |
1612 | 143 |
1869 | 144 <P>Symlinking is NOT enough, you have to copy/move it!!!</P> |
1668 | 145 |
4022 | 146 </LI> |
147 </UL> | |
148 </P> | |
149 | |
3140 | 150 <P>Then compile. configure detects if it's alright, and can be compiled. The |
151 codec also <B>supports postprocessing!</B></P> | |
1612 | 152 |
3694 | 153 <P>In order to use it, update your codecs.conf file, and do as the manpage, |
1682 | 154 or the example.conf says (the -vfm option).</P> |
1612 | 155 |
2290 | 156 <P>To achieve the <B>greatest speed</B> on my K6, I remove the |
157 <CODE>ffmpeg12</CODE> section from codecs.conf (this codec isn't optimized, and | |
158 libmpeg2 is twice as fast), and place <CODE>vfm=5</CODE> in my config file. | |
159 Then <B>MPlayer</B> always uses <B>ffdivx/ffodivx</B> to decode | |
5018 | 160 <B>DivX</B> files, and libmpeg2 for MPEG1/2 . With this and my |
161 Matrox G400, I can view even the highest resolution DivX movies on my | |
162 K6/2 500, without framedrop.</P> | |
1612 | 163 |
164 | |
2745 | 165 <P><B><A NAME=2.2.1.3>2.2.1.3. XAnim codecs</A></B></P> |
2411 | 166 |
5187 | 167 <P>Foreword: |
168 Be advised that the XAnim binary codecs are packaged with a piece of text | |
169 claiming to be a legally binding software license which, among other | |
170 absurdities, forbids the user to use the codecs in conjunction with any | |
171 program other than XAnim. As the XAnim author has yet to bring legal | |
172 action against anyone for codec-related issues, the MPlayer developers | |
173 don't lose too much sleep over this and you probably shouldn't, either. | |
174 </P> | |
2411 | 175 |
176 <P>So yes, <B>MPlayer</B> can use XAnim's codecs for decoding. It's very | |
177 easy to enable them:</P> | |
178 | |
179 <P> | |
180 <UL> | |
181 <LI>download the codecs you wish to use from the | |
182 <A HREF="http://xanim.va.pubnix.com">XAnim site</A>. The <B>3ivx</B> codec | |
183 isn't there, so download it from the <A HREF="http://www.3ivx.com">3ivx site</A>.</LI> | |
184 | |
2664 | 185 <LI>use the <CODE>--with-xanimlibdir</CODE> option to tell configure where |
5114 | 186 it can find the xanim codecs. By default, it checks them at |
187 <CODE>/usr/local/lib/xanim/mods, /usr/lib/xanim/mods and /usr/lib/xanim</CODE>. | |
4704
1e936c3cc3fa
XANIM_MOD_DIR can be used for XAnim codecs' path specifying
gabucino
parents:
4339
diff
changeset
|
188 Alternatively you can set the environment variable <I>XANIM_MOD_DIR</I> to |
1e936c3cc3fa
XANIM_MOD_DIR can be used for XAnim codecs' path specifying
gabucino
parents:
4339
diff
changeset
|
189 the dir of the XAnim codecs.</LI> |
3163 | 190 |
5114 | 191 <LI>rename/symlink the filenames by cutting out the architecture stuff, so they will |
3163 | 192 have filenames like these : <CODE>vid_cvid.xa, vid_h263.xa, vid_iv50.xa</CODE> |
193 | |
2411 | 194 </UL> |
195 </P> | |
196 | |
197 <P>They are video codec family number 10, so you may want to use <CODE>-vfm 10</CODE> | |
198 option to tell <B>MPlayer</B> to use them if possible.</P> | |
199 | |
200 <P>Tested codecs are: <B>Indeo 3.2</B>, <B>4.1</B>, <B>5.0</B>, <B>CVID</B>, <B>3ivX</B>, <B>h263</B>.</P> | |
201 | |
2452 | 202 |
2745 | 203 <P><B><A NAME=2.2.1.4>2.2.1.4. VIVO video</A></B></P> |
204 | |
2855 | 205 <P><B>MPlayer</B> can play Vivo (1.0 and 2.0) videos. The most suitable codec |
3027 | 206 for 1.0 files is FFmpeg's H263 decoder, you can use it with the <CODE>-vc |
3566 | 207 ffh263</CODE> option (default) (you'll need the newest libavcodec !). For 2.0 files, use |
3174
4164be267d0f
misinfo fixed (notified by Al3x. At least 65535 times:)
gabucino
parents:
3163
diff
changeset
|
208 the <CODE>ivvideo.dll</CODE> Win32 DLL file (from <A |
3027 | 209 HREF="http://www.mplayerhq.hu/MPlayer/samples/drivers32/ivvideo.dll">here</A>), |
2855 | 210 and install it under <CODE>/usr/lib/win32</CODE> or wherever you store the |
211 Win32 codecs. This latter codec doesn't support YV12 nor YUY2 only BGR modes, | |
3174
4164be267d0f
misinfo fixed (notified by Al3x. At least 65535 times:)
gabucino
parents:
3163
diff
changeset
|
212 thus usable only with the X11 and OpenGL outputs. Hopefully ffh263 will support |
4164be267d0f
misinfo fixed (notified by Al3x. At least 65535 times:)
gabucino
parents:
3163
diff
changeset
|
213 VIVO 2.0 files in the future.</P> |
2855 | 214 |
2745 | 215 |
216 <P><B><A NAME=2.2.1.5>2.2.1.5. MPEG 1/2 video</A></B></P> | |
217 | |
218 <P>MPEG1 and MPEG2 are decoded with the native library <B>libmpeg2</B>. | |
5114 | 219 Its source code is included in <B>MPlayer</B>, and of course it is multiplatform. |
220 We handle buggy MPEG 1/2 video files by catching sig11 (segmentation fault), | |
221 and quickly reinitializing the codec, and continue exactly from where the failure | |
222 did occur. | |
2745 | 223 No speed decrease is measurable.</P> |
224 | |
225 | |
2855 | 226 <P><B><A NAME=2.2.1.6>2.2.1.6. MS Video1</A></B></P> |
227 | |
228 <P>This is a very old and very bad codec of Microsoft. In the past it was | |
229 decoded with the <CODE>msvidc32.dll</CODE> Win32 codec, now we have our own | |
230 open-source implementation (by <A HREF="mailto:melanson@pcisys.net">Mike | |
231 Melanson</A>).</P> | |
232 | |
233 | |
3163 | 234 <P><B><A NAME=2.2.1.7>2.2.1.7. Cinepak CVID</A></B></P> |
235 | |
3647 | 236 <P><B>MPlayer</B> now has its own opensource, multiplatform Cinepak decoder. |
237 Supports YUV outputs, thus hardware scaling if video output driver allows. | |
238 Used by default.</P> | |
3163 | 239 |
240 | |
3806 | 241 <P><B><A NAME=2.2.1.8>2.2.1.8. RealVideo</A></B></P> |
242 | |
243 <P>Currently ONLY the RealVideo 1.0 (fourcc RV10) codec is supported, through | |
244 ffmpeg. Sadly, no new RealMedia files come with this one, only with the newer | |
245 RV20 and RV30 codecs which are closed-source. Their future support is | |
246 unlikely :(</P> | |
247 | |
248 | |
5022 | 249 <P><B><A NAME=2.2.1.9>2.2.1.9. XViD</A></B></P> |
250 | |
251 <P><B>XViD</B> is another development from good old OpenDivX (first | |
252 development was DivX4).</P> | |
253 | |
254 <P><B>Advantages</B> : | |
255 <UL> | |
256 <LI>opensource</LI> | |
257 <LI>its API is compatible with DivX4 so it's easy to add support for | |
258 it</LI> | |
259 <LI>2-pass encoding support</LI> | |
260 <LI>nice encoding quality, higher speed than DivX4 (you can optimize it for | |
261 your box while compiling)</LI> | |
262 </UL> | |
263 </P> | |
264 | |
265 <P><B>Disadvantages</B> : | |
266 <UL> | |
5114 | 267 <LI>currently it doesn't properly <B>decode</B> all DivX/DivX4 files (but who cares, we can play them using libavcodec)</LI> |
5022 | 268 <LI>you have to choose between DivX4 <B>OR</B> XViD support at |
269 compiletime</LI> | |
270 <LI>under development</LI> | |
271 </UL> | |
272 </P> | |
273 | |
274 <P><B>Installation</B> : it's currently available only in CVS. Here are the | |
275 downloading and installation instructions :<BR> | |
276 <CODE>cvs -z3 -d:pserver:anonymous@cvs.xvid.org:/xvid | |
277 login</CODE><BR> | |
278 <CODE>cvs -z3 -d:pserver:anonymous@cvs.xvid.org:/xvid co | |
279 xvidcore</CODE><BR> | |
280 <CODE>cd xvidcore/build/generic</CODE><BR> | |
281 <CODE>Edit Makefile.linux to fit your needs</CODE><BR> | |
282 <CODE>make -f Makefile.linux</CODE><BR> | |
5114 | 283 Get encore2.h and decore.h from Divx4linux package, and copy them to <CODE>/usr/local/include/</CODE><BR> |
5022 | 284 <CODE>recompile <B>MPlayer</B> with |
285 --with-xvidcore=/path/to/libcore.a</CODE><BR> | |
286 </P> | |
287 | |
288 | |
2745 | 289 <P><B><A NAME=2.2.2>2.2.2. Audio codecs</A></B></P> |
290 | |
291 <P>The most important audio codecs above all :<BR> | |
292 <UL> | |
293 <LI>MPEG layer 2, and layer 3 (MP3) audio (<B>native</B> code, with MMX/SSE/3DNow! optimization)</LI> | |
294 <LI>MPEG layer 1 audio (<B>native</B> code, with libavcodec)</LI> | |
5114 | 295 <LI>AC3 Dolby audio (<B>native</B> code, with MMX/SSE/3DNow! optimization)</LI> |
2745 | 296 <LI>Ogg Vorbis audio codec (<B>native</B> lib)</LI> |
297 <LI>Voxware audio (using DirectShow DLL)</LI> | |
298 <LI>alaw, msgsm, pcm and other simple old audio formats</LI> | |
3566 | 299 <LI>VIVO audio (g723, Vivo Siren)</LI> |
3806 | 300 <LI>RealAudio: DNET (low bitrate AC3)</LI> |
2745 | 301 </UL></P> |
302 | |
303 | |
3239
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
304 <P><B><A NAME=2.2.2.1>2.2.2.1. Software AC3 decoding</A></B></P> |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
305 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
306 <P>This is the default decoder used for files with AC3 audio.</P> |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
307 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
308 <P>The AC3 decoder can create output audio mixes for 2, 4, or 6 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
309 speakers. When configured for 6 speakers, this decoder provides |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
310 separate output of all the AC3 channels to the soundcard driver, |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
311 allowing the full "surround sound" experience without the external AC3 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
312 decoder required to use the hwac3 codec.</P> |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
313 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
314 <P>Use the <CODE>-channels</CODE> option to select the number of output channels. |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
315 Use <CODE>-channels 2</CODE> for a stereo downmix. For a 4 channel downmix (Left |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
316 Front, Right Front, Left Surround and Right Surround outputs), use |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
317 <CODE>-channels 4</CODE>. In this case, any Centre channel will be mixed |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
318 equally to the front channels. Lastly, "-channels 6" will output all the AC3 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
319 channels as they are encoded - in the order Left, Right, Left Surround, Right |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
320 Surround, Centre and LFE.</P> |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
321 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
322 <P>The default number of output channels is 2.</P> |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
323 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
324 <P>To use more than 2 output channels, you'll need to be using OSS, |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
325 and to have a soundcard driver that supports the appropriate number of |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
326 output channels via the SNDCTL_DSP_CHANNELS ioctl. For example, a |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
327 version of the emu10k1 driver (used with the SB Live cards) newer than |
4200 | 328 August 2001 should be suitable (I heard newest ALSA CVS supports this too).</P> |
3239
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
329 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
330 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
331 <P><B><A NAME=2.2.2.2>2.2.2.2. Hardware AC3 decoding</A></B></P> |
2745 | 332 |
333 <P>You'll need an AC3 capable soundcard, with digital out (SP/DIF). The | |
5114 | 334 card's driver must properly support the AFMT_AC3 format (like C-Media does). |
2745 | 335 Connect your AC3 decoder to the SP/DIF output, and use the '-ac hwac3' |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
336 option. It may or may not work (experimental). It will work with C-Media |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
337 cards, and with SB Live! + ALSA driver. It won't work with Live!'s OSS |
5114 | 338 driver!</P> |
2745 | 339 |
340 | |
3239
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
341 <P><B><A NAME=2.2.2.3>2.2.2.3. libmad support</A></B></P> |
2452 | 342 |
343 <P><A HREF="http://mad.sourceforge.net">libmad</A> is a multiplatform MPEG audio | |
344 decoding library. If you don't know why is it good, you probably don't need it.</P> | |
345 | |
5160 | 346 <P>It doesn't handle broken files well, and sometimes has problems with seeking.</P> |
5114 | 347 |
2452 | 348 <P>To enable support, compile with the <CODE>--enable-mad</CODE> configure |
349 option.</P> | |
350 | |
351 | |
3239
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
352 <P><B><A NAME=2.2.2.4>2.2.2.4. VIVO audio</A></B></P> |
2855 | 353 |
2865 | 354 <P>The audio codec used in VIVO files depends on whether it's a VIVO/1.0 or |
355 VIVO/2.0 file. VIVO/1.0 files have <B>g.723</B> audio, and VIVO/2.0 files | |
3566 | 356 have <B>Vivo Siren</B>. Both is <U>supported</U>. You can grab the g.723/Siren |
357 Win32 DLL from | |
2855 | 358 <A HREF="http://www.mplayerhq.hu/MPlayer/samples/drivers32/vivog723.acm">here</A>, |
359 then copy it into the <CODE>/usr/lib/win32</CODE> directory, or respectively.</P> | |
360 | |
361 | |
3806 | 362 <P><B><A NAME=2.2.2.5>2.2.2.5. RealAudio</A></B></P> |
363 | |
364 <P>Currently the only supported one is the DNET codec. Actually it's a | |
365 low-bitrate version of the well-known AC3 codec. It can be found either in | |
366 old and new RealMedia movies.</P> | |
367 | |
368 | |
2745 | 369 <P><B><A NAME=2.2.3>2.2.3. Win32 codec importing howto</A></B></P> |
1682 | 370 |
2745 | 371 <P><B><A NAME=2.2.3.1>2.2.3.1. VFW codecs</A></B></P> |
1682 | 372 |
373 <P>VfW (Video for Windows) is the old Video API for Windows. Its codecs have | |
374 the .DLL or (rarely) .DRV extension. | |
375 If <B>MPlayer</B> fails with your AVI:</P> | |
376 | |
377 <P> <CODE>UNKNOWN video codec: HFYU (0x55594648)</CODE></P> | |
1612 | 378 |
1682 | 379 <P>It means your AVI is encoded with a codec which has the HFYU fourcc (HFYU = |
380 HuffYUV codec, DIV3 = DivX Low Motion, etc...). Now that we know this, we'll | |
381 have to find out which DLL Windows loads in order to play this file. In our | |
382 case, the system.ini contains this (with many others):</P> | |
1612 | 383 |
1682 | 384 <P> <CODE>VIDC.HFYU=huffyuv.dll</CODE></P> |
385 | |
386 <P>So we'll need the huffyuv.dll file. Note that the audio codecs are specified | |
387 with the MSACM prefix:</P> | |
388 | |
389 <P> <CODE>msacm.l3acm=L3codeca.acm</CODE></P> | |
1612 | 390 |
391 | |
1682 | 392 <P>This is the MP3 codec. |
393 So, now we have all the info needed (fourcc, codec file, sample AVI), submit | |
394 your codec support request in mail, and upload these files to the FTP:</P> | |
1612 | 395 |
1869 | 396 <P> <CODE>ftp://ftp.mplayerhq.hu/MPlayer/incoming/[codecname]/</CODE></P> |
1612 | 397 |
398 | |
2745 | 399 <P><B><A NAME=2.2.3.2>2.2.3.2. DirectShow codecs</A></B></P> |
1612 | 400 |
1682 | 401 <P>DirectShow is the newer Video API, which is even worse than its predecessor. |
402 Things are harder with DirectShow, since | |
403 <UL> | |
404 <LI>system.ini doesn't contain the needed information, instead it's stored in | |
405 the registry :( | |
406 <LI>we'll need the GUID of the codec. | |
407 </UL></P> | |
1612 | 408 |
1682 | 409 <P>So let's search that goddamn registry.. |
410 <UL> | |
411 <LI>Start 'regedit' | |
412 <LI>press ctrl-f, disable the first two checkbox, and enable the third. Type | |
413 the fourcc of the codec. (for ex.: TM20) | |
414 <LI>you should see a field which contains the path and filename | |
415 (for ex. : C:\WINDOWS\SYSTEM\TM20DEC.AX) | |
416 <LI>now that we have the file, we'll need the GUID. Try searching again, but | |
417 now we'll search for the codec's name, not the fourcc. Its name can be acquired | |
418 when Media Player is playing that file, by checking File/Properties/Advanced. | |
419 If not, bad luck ;) Try guessing. | |
420 (for ex. search for : TrueMotion) | |
421 <LI>if found (in registry), there should be a FriendlyName field, and a CLSID | |
422 field. Write down that 16 byte of CLSID, this is the GUID required by us. | |
423 </UL></P> | |
424 | |
425 <P>NOTE: if searching fails, try to enable all the checkboxes.. you may have | |
426 false hits, but maybe you'll have the right, too...</P> | |
427 <P>NOTE: dump that M$ shit.</P> | |
1612 | 428 |
429 | |
1682 | 430 <P>So, now we have all the info needed (fourcc, GUID, codec file, sample AVI), |
431 submit your codec support request in mail, and upload these files to the FTP:<BR> | |
1869 | 432 ftp://ftp.mplayerhq.hu/MPlayer/incoming/[codecname]/</P> |
1612 | 433 |
434 </BODY> | |
435 </HTML> |