Mercurial > mplayer.hg
annotate DOCS/codecs.html @ 7502:6a2b6f3d619c
best audio/video codec selection & init moved to libmpcodecs
author | arpi |
---|---|
date | Wed, 25 Sep 2002 23:45:34 +0000 |
parents | be83aac30445 |
children | 427935644581 |
rev | line source |
---|---|
6408
d0b1f3d75900
Background now uses CSS, added doctype and charset, removed leftover
diego
parents:
6393
diff
changeset
|
1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> |
1612 | 2 <HTML> |
4982
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
3 |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
4 <HEAD> |
6882
f3f87f6bf5cf
Added a uniform title: something - MPlayer - The Movie Player for Linux.
diego
parents:
6775
diff
changeset
|
5 <TITLE>Codecs - MPlayer - The Movie Player for Linux</TITLE> |
6391 | 6 <LINK REL="stylesheet" TYPE="text/css" HREF="default.css"> |
6408
d0b1f3d75900
Background now uses CSS, added doctype and charset, removed leftover
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:
4704
diff
changeset
|
8 </HEAD> |
6cb9d9a1716d
HTML: different font handling - idea from new hp dezign
gabucino
parents:
4704
diff
changeset
|
9 |
6408
d0b1f3d75900
Background now uses CSS, added doctype and charset, removed leftover
diego
parents:
6393
diff
changeset
|
10 <BODY> |
1704 | 11 |
1612 | 12 |
7047 | 13 <H2><A NAME="codecs">2.2 Supported codecs</A></H2> |
1612 | 14 |
15 | |
7047 | 16 <H3><A NAME="video_codecs">2.2.1 Video codecs</A></H3> |
1612 | 17 |
6974 | 18 <P>See the <A HREF="http://www.mplayerhq.hu/DOCS/codecs-status.html">codec status table</A> |
6998
83a386e88f9e
Applied patch by Andras Mohari <mayday at varoshaza . nagyatad . hu>
diego
parents:
6974
diff
changeset
|
19 for the complete, daily generated list.</P> |
1612 | 20 |
5534 | 21 <P>The most important ones above all:</P> |
1682 | 22 <UL> |
6960 | 23 <LI>MPEG1 (VCD) and MPEG2 (DVD) video</LI> |
24 <LI>native decoders for DivX ;-), OpenDivX, DivX4, DivX5, | |
25 M$ MPEG4 v1, v2 and other MPEG4 variants</LI> | |
26 <LI>native decoder for Windows Media Video 7 (WMV1), and Win32 DLL decoder for | |
27 Windows Media Video 8 (WMV2), both used in .wmv files</LI> | |
28 <LI><B>native Sorenson (SVQ1) decoder</B></LI> | |
29 <LI>3ivx decoder</LI> | |
7373 | 30 <LI>Cinepak and Intel Indeo codecs (3.1, 3.2, 4.1, 5.0)</LI> |
6960 | 31 <LI>MJPEG, AVID, VCR2, ASV2 and other hardware formats</LI> |
32 <LI>VIVO 1.0, 2.0, I263 and other h263(+) variants</LI> | |
33 <LI>FLI/FLC</LI> | |
34 <LI>RealVideo 1.0 codec from libavcodec, and RealVideo 2.0, 3.0 codecs using | |
35 RealPlayer libraries</LI> | |
36 <LI>native decoder for HuffYUV</LI> | |
6974 | 37 <LI>various old simple RLE-like formats</LI> |
5534 | 38 </UL> |
1612 | 39 |
6960 | 40 <P>If you have a Win32 codec not listed here which is not supported yet, please |
41 read the <A HREF="#importing">codec importing HOWTO</A> and help us add support | |
6998
83a386e88f9e
Applied patch by Andras Mohari <mayday at varoshaza . nagyatad . hu>
diego
parents:
6974
diff
changeset
|
42 for it.</P> |
1612 | 43 |
6974 | 44 |
7047 | 45 <H4><A NAME="divx">2.2.1.1 DivX4/DivX5</A></H4> |
1612 | 46 |
6960 | 47 <P>This section contains information about the DivX4 and DivX5 codecs of |
48 <A HREF="http://www.projectmayo.com">Project Mayo</A>. Their first available | |
49 alpha version was OpenDivX 4.0 alpha 47 and 48. Support for this was included | |
50 in <B>MPlayer</B> in the past, and built by default. We also used its | |
51 postprocessing code to optionally enhance visual quality of MPEG1/2 movies. | |
52 Now we use our own, for all file types.</P> | |
1612 | 53 |
6960 | 54 <P>The new generation of this codec is called DivX4 and can even decode |
55 movies made with the infamous DivX codec! In addition it is much faster than | |
56 the native Win32 DivX DLLs but slower than libavcodec. Hence its usage as a | |
57 decoder is <B>DISCOURAGED</B>. However, it is useful for encoding. One | |
58 disadvantage of this codec is that it is currently closed source.</P> | |
1612 | 59 |
5534 | 60 <P>The codec can be downloaded from one of the following URLs:</P> |
3583 | 61 |
5534 | 62 <P> <A HREF="http://avifile.sourceforge.net">http://avifile.sourceforge.net</A><BR> |
6960 | 63 <A HREF="http://divx.com">http://divx.com</A></P> |
1612 | 64 |
2684 | 65 <P>Unpack it, and run <CODE>./install.sh</CODE> as root.</P> |
1612 | 66 |
6775
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
67 <P><B>Note:</B> Do <B>not</B> forget adding <CODE>/usr/local/lib</CODE> to your |
6960 | 68 <CODE>/etc/ld.so.conf</CODE> and running <CODE>ldconfig</CODE>!</P> |
1612 | 69 |
5534 | 70 <P><B>MPlayer</B> autodetects DivX4/DivX5 if it is properly installed, just |
6960 | 71 compile as usual. If it does not detect it, you did not install or configure |
72 it correctly.</P> | |
1682 | 73 |
6583 | 74 <P>DivX4Linux works in two modes:</P> |
1682 | 75 |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
76 <DL> |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
77 <DT><CODE>-vc odivx</CODE></DT> |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
78 <DD>Uses the codec in OpenDivX fashion. In this case it |
6974 | 79 produces YV12 images in its own buffer, and <B>MPlayer</B> does colorspace |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
80 conversion via libvo. (<B>Fast, recommended!</B>)</DD> |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
81 |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
82 <DT><CODE>-vc divx4</CODE></DT> |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
83 <DD>Uses the colorspace conversion of the codec. |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
84 In this mode you can use YUY2/UYVY, too. (<B>SLOW</B>)</DD> |
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
85 </DL> |
1612 | 86 |
6960 | 87 <P>The <CODE>-vc odivx</CODE> method is usually faster, due to the fact that it |
88 transfers image data in YV12 (planar YUV 4:2:0) format, thus requiring much | |
89 less bandwidth on the bus. For packed YUV modes (YUY2, UYVY) use the | |
90 <CODE>-vc divx4</CODE> method. For RGB modes the speed is the same, differing | |
91 at best according to your current color depth.</P> | |
1682 | 92 |
6775
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
93 <P><B>Note:</B> If your <CODE>-vo</CODE> driver supports direct rendering, then |
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
94 <CODE>-vc divx4</CODE> may be faster or even the fastest solution.</P> |
5114 | 95 |
5968 | 96 |
7047 | 97 <H4><A NAME="libavcodec">2.2.1.2 FFmpeg DivX/libavcodec</A></H4> |
1682 | 98 |
6960 | 99 <P><A HREF="http://ffmpeg.sourceforge.net">FFmpeg</A> contains an |
6974 | 100 <B>open source</B> codec package, which is capable of decoding video streams |
6960 | 101 encoded with |
102 H263/MJPEG/RV10/DivX3/DivX4/DivX5/MP41/MP42/WMV1 | |
103 codecs. Not only some of them can be encoded with, but it also offers higher | |
104 speed than the Win32 codecs or the ProjectMayo DivX4/5 library!</P> | |
4022 | 105 |
6960 | 106 <P>It contains a lot of nice codecs, especially important are the MPEG4 |
107 variants: | |
108 DivX 3, DivX 4, DivX 5, Windows Media Video 7 (WMV1)</P> | |
4022 | 109 |
6960 | 110 <P>If you use an <B>MPlayer</B> release you have libavcodec right in the |
111 package, just build as usual. If you use <B>MPlayer</B> from CVS you have to | |
112 extract libavcodec from the FFmpeg CVS tree as FFmpeg 0.4.5 does <B>not</B> | |
113 work with <B>MPlayer</B>. In order to achieve this do:</P> | |
1612 | 114 |
5534 | 115 <OL> |
116 <LI><CODE>cvs -d:pserver:anonymous@cvs.ffmpeg.sourceforge.net:/cvsroot/ffmpeg login</CODE></LI> | |
117 <LI><CODE>cvs -d:pserver:anonymous@cvs.ffmpeg.sourceforge.net:/cvsroot/ffmpeg co ffmpeg</CODE></LI> | |
118 <LI>Move the <CODE>libavcodec</CODE> directory from the FFmpeg sources to the | |
119 root of the <B>MPlayer</B> CVS tree. It should look like this: | |
120 <P> <CODE>main/libavcodec</CODE></P> | |
6998
83a386e88f9e
Applied patch by Andras Mohari <mayday at varoshaza . nagyatad . hu>
diego
parents:
6974
diff
changeset
|
121 Symlinking is <B>not</B> enough, you have to copy or move it!</LI> |
5534 | 122 <LI>Compile. Configure should detect problems before compilation.</LI> |
123 </OL> | |
1668 | 124 |
6775
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
125 <P><B>Note:</B> MPlayer from CVS does contain a libavcodec |
6998
83a386e88f9e
Applied patch by Andras Mohari <mayday at varoshaza . nagyatad . hu>
diego
parents:
6974
diff
changeset
|
126 subdirectory, but it does <B>not</B> contain the source for libavcodec! |
6960 | 127 You must follow the steps above to obtain the source for this library.</P> |
5534 | 128 |
129 <P>With FFmpeg and my Matrox G400, I can view even the highest resolution DivX | |
130 movies without dropped frames on my K6/2 500.</P> | |
1612 | 131 |
132 | |
7047 | 133 <H4><A NAME="xanim">2.2.1.3 XAnim codecs</A></H4> |
2411 | 134 |
5534 | 135 <P>Foreword:<BR> |
6960 | 136 Be advised that the XAnim binary codecs are packaged with a piece of text |
137 claiming to be a legally binding software license which, besides other | |
138 restrictions, forbids the user to use the codecs in conjunction with any | |
139 program other than XAnim. However, the XAnim author has yet to bring legal | |
140 action against anyone for codec-related issues. | |
5187 | 141 </P> |
2411 | 142 |
5534 | 143 <P><B>MPlayer</B> is capable of employing the XAnim codecs for decoding. Follow |
6960 | 144 the instructions to enable them:</P> |
2411 | 145 |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
146 <OL> |
5534 | 147 <LI>Download the codecs you wish to use from the |
6974 | 148 <A HREF="http://xanim.va.pubnix.com">XAnim site</A>. The <B>3ivx</B> codec |
149 is not there, but at the <A HREF="http://www.3ivx.com">3ivx site</A>.</LI> | |
5534 | 150 <LI>Use the <CODE>--with-xanimlibdir</CODE> option to tell configure where |
6974 | 151 to find the XAnim codecs. By default, it looks for them at |
152 <CODE>/usr/local/lib/xanim/mods, /usr/lib/xanim/mods and /usr/lib/xanim</CODE>. | |
153 Alternatively you can set the environment variable <I>XANIM_MOD_DIR</I> to | |
154 the directory of the XAnim codecs.</LI> | |
5534 | 155 <LI>Rename/symlink the files, cutting out the architecture stuff, so they will |
6974 | 156 have filenames like these: <CODE>vid_cvid.xa, vid_h263.xa, vid_iv50.xa</CODE>.</LI> |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
157 </OL> |
2411 | 158 |
5534 | 159 <P>XAnim is video codec family number 10, so you may want to use the <CODE>-vfm 10</CODE> |
6960 | 160 option to tell <B>MPlayer</B> to use them if possible.</P> |
2411 | 161 |
6974 | 162 <P>Tested codecs include: <B>Indeo 3.2</B>, <B>4.1</B>, <B>5.0</B>, <B>CVID</B>, |
163 <B>3ivX</B>, <B>h263</B>.</P> | |
2411 | 164 |
2452 | 165 |
7047 | 166 <H4><A NAME="vivo_video">2.2.1.4 VIVO video</A></H4> |
2745 | 167 |
2855 | 168 <P><B>MPlayer</B> can play Vivo (1.0 and 2.0) videos. The most suitable codec |
6960 | 169 for 1.0 files is FFmpeg's H263 decoder, you can use it with the <CODE>-vc |
170 ffh263</CODE> option (default) (requires up-to-date libavcodec). For 2.0 | |
7076
3275af5787e0
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, slightly
diego
parents:
7047
diff
changeset
|
171 files, use the |
3275af5787e0
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, slightly
diego
parents:
7047
diff
changeset
|
172 <A HREF="http://www.mplayerhq.hu/MPlayer/samples/drivers32/ivvideo.dll">ivvideo.dll</A> |
3275af5787e0
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, slightly
diego
parents:
7047
diff
changeset
|
173 Win32 DLL file, and install it under <CODE>/usr/lib/win32</CODE> or wherever you store the |
6960 | 174 Win32 codecs. This latter codec does not support YV12 nor YUY2 only BGR |
175 modes, restricting it to the X11 and OpenGL outputs. Hopefully ffh263 will | |
176 support VIVO 2.0 files in the future.</P> | |
2855 | 177 |
2745 | 178 |
7047 | 179 <H4><A NAME="mpeg">2.2.1.5 MPEG 1/2 video</A></H4> |
2745 | 180 |
6960 | 181 <P>MPEG1 and MPEG2 are decoded by the multiplatform native <B>libmpeg2</B> |
182 library, whose source code is included in <B>MPlayer</B>. We handle buggy | |
183 MPEG 1/2 video files by catching sig11 (segmentation fault), and quickly | |
184 reinitializing the codec, continuing exactly from where the failure occurred. | |
185 This recovery technique has no measurable speed penalty.</P> | |
2745 | 186 |
187 | |
7047 | 188 <H4><A NAME="ms_video1">2.2.1.6 MS Video1</A></H4> |
2855 | 189 |
5534 | 190 <P>This is a very old and very bad codec from Microsoft. In the past it was |
6960 | 191 decoded with the <CODE>msvidc32.dll</CODE> Win32 codec, now we have our own |
192 open source implementation (by <A HREF="mailto:melanson@pcisys.net">Mike | |
193 Melanson</A>).</P> | |
2855 | 194 |
195 | |
7047 | 196 <H4><A NAME="cinepak">2.2.1.7 Cinepak CVID</A></H4> |
3163 | 197 |
5534 | 198 <P><B>MPlayer</B> uses its own open source, multiplatform Cinepak decoder by |
6960 | 199 default. It supports YUV outputs, so that hardware scaling is possible if the |
200 video output driver permits it.</P> | |
3163 | 201 |
202 | |
7047 | 203 <H4><A NAME="realvideo">2.2.1.8 RealVideo</A></H4> |
3806 | 204 |
6408
d0b1f3d75900
Background now uses CSS, added doctype and charset, removed leftover
diego
parents:
6393
diff
changeset
|
205 <B>MPlayer</B> supports decoding all versions of RealVideo: |
6974 | 206 |
6408
d0b1f3d75900
Background now uses CSS, added doctype and charset, removed leftover
diego
parents:
6393
diff
changeset
|
207 <UL> |
d0b1f3d75900
Background now uses CSS, added doctype and charset, removed leftover
diego
parents:
6393
diff
changeset
|
208 <LI>RealVideo 1.0 (fourcc RV10) - en/decoding supported by <B>libavcodec</B></LI> |
7190
5137e9fb57e7
All RealVideo codecs liste on one line - less wasted space.
diego
parents:
7154
diff
changeset
|
209 <LI>RealVideo 2.0, 3.0, 4.0 (fourcc RV20, RV30, RV40) - decoding supported by <B>RealPlayer libraries</B></LI> |
6408
d0b1f3d75900
Background now uses CSS, added doctype and charset, removed leftover
diego
parents:
6393
diff
changeset
|
210 </UL> |
6357 | 211 |
6775
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
212 <P>It is recommended to download and install RealPlayer8 or RealONE, because |
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
213 <B>MPlayer</B> can use their libraries to decode files with RealVideo 2.0 or |
6960 | 214 RealVideo 3.0 video. The <B>MPlayer</B> configure script should detect the |
215 RealPlayer libraries in the standard locations of a full installation. If it | |
216 does not, tell configure where to look with the | |
217 <CODE>--with-reallibdir</CODE> switch.</P> | |
6775
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
218 |
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
219 <P><B>Note:</B> RealPlayer libraries currently <B>only work with Linux, FreeBSD, |
6998
83a386e88f9e
Applied patch by Andras Mohari <mayday at varoshaza . nagyatad . hu>
diego
parents:
6974
diff
changeset
|
220 NetBSD and Cygwin on the x86 platform.</B></P> |
6775
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
221 |
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
222 <P><B>Note2:</B> We cannot distribute the RealPlayer libraries, the license does |
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
223 not allow this. You have to get them yourself.</P> |
3806 | 224 |
225 | |
7047 | 226 <H4><A NAME="xvid">2.2.1.9 XViD</A></H4> |
5022 | 227 |
6596 | 228 <P><B>XViD</B> is a forked development of the OpenDivX codec. It happened when |
229 ProjectMayo changed OpenDivX to closed-source DivX4, and the non-ProjectMayo | |
230 people working on OpenDivX got angry, then started XViD. So both projects | |
231 have the same origin.</P> | |
5022 | 232 |
7047 | 233 <H4>Advantages:</H4> |
6974 | 234 |
235 <UL> | |
236 <LI>open source</LI> | |
237 <LI>its API is compatible with DivX4 so adding support for | |
238 it is easy</LI> | |
239 <LI>2-pass encoding support</LI> | |
240 <LI>nice encoding quality, higher speed than DivX4 (you can optimize it for | |
241 your box while compiling)</LI> | |
242 </UL> | |
5022 | 243 |
7047 | 244 <H4>Disadvantages:</H4> |
6974 | 245 |
246 <UL> | |
247 <LI>currently it does not properly <B>decode</B> all DivX/DivX4 files (no problem as libavcodec can play them)</LI> | |
248 <LI>you have to choose between DivX4 <B>OR</B> XViD support at | |
249 compiletime</LI> | |
250 <LI>under development</LI> | |
251 </UL> | |
5022 | 252 |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
253 <P>XViD is currently available only from CVS. Here are the |
5534 | 254 download and installation instructions:</P> |
6974 | 255 |
256 <OL> | |
257 <LI><CODE>cvs -z3 -d:pserver:anonymous@cvs.xvid.org:/xvid login</CODE></LI> | |
258 <LI><CODE>cvs -z3 -d:pserver:anonymous@cvs.xvid.org:/xvid co xvidcore</CODE></LI> | |
259 <LI><CODE>cd xvidcore/build/generic</CODE></LI> | |
260 <LI>Edit <CODE>Makefile.linux</CODE> to fit your needs.</LI> | |
261 <LI><CODE>make -f Makefile.linux</CODE></LI> | |
262 <LI>Get <CODE>encore2.h</CODE> and <CODE>decore.h</CODE> from the DivX4Linux | |
263 package, and copy them to <CODE>/usr/local/include/</CODE>.</LI> | |
264 <LI>Recompile <B>MPlayer</B> with <CODE>--with-xvidcore=/path/to/libcore.a</CODE>.</LI> | |
265 </OL> | |
5022 | 266 |
267 | |
7047 | 268 <H4><A NAME="sorenson">2.2.1.10 Sorenson</A></H4> |
6583 | 269 |
270 <P><B>Sorenson</B> is a video codec developed by Apple. We are currently | |
6775
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
271 able to decode the first version (SVQ1) with a native decoder.</P> |
6583 | 272 |
7047 | 273 <H4>Advantages:</H4> |
6974 | 274 |
275 <UL> | |
276 <LI>Fast, even old Macintosh machines were able to decode it.</LI> | |
277 </UL> | |
6583 | 278 |
7047 | 279 <H4>Disadvantages:</H4> |
6974 | 280 |
281 <UL> | |
282 <LI>SVQ3 is still not reverse engineered.</LI> | |
283 </UL> | |
6583 | 284 |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
285 <P>The Sorenson decoder is compiled and usable per default.</P> |
6583 | 286 |
287 | |
7047 | 288 <H3><A NAME="audio_codecs">2.2.2 Audio codecs</A></H3> |
2745 | 289 |
5534 | 290 <P>The most important audio codecs above all:<BR></P> |
6974 | 291 |
2745 | 292 <UL> |
6960 | 293 <LI>MPEG layer 2, and layer 3 (MP3) audio (<B>native</B> code, with |
294 MMX/SSE/3DNow! optimization)</LI> | |
295 <LI>MPEG layer 1 audio (<B>native</B> code, with libavcodec)</LI> | |
296 <LI>AC3 Dolby audio (<B>native</B> code, with MMX/SSE/3DNow! | |
297 optimization)</LI> | |
7373 | 298 <LI>AC3 passing through soundcard hardware</LI> |
6960 | 299 <LI>Ogg Vorbis audio codec (<B>native</B> library)</LI> |
300 <LI>Voxware audio (using DirectShow DLL)</LI> | |
301 <LI>alaw, msgsm, pcm and other simple old audio formats</LI> | |
302 <LI>VIVO audio (g723, Vivo Siren)</LI> | |
303 <LI>RealAudio: DNET (low bitrate AC3), Cook</LI> | |
5534 | 304 </UL> |
2745 | 305 |
306 | |
7047 | 307 <H4><A NAME="software_ac3">2.2.2.1 Software AC3 decoding</A></H4> |
3239
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
308 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
309 <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
|
310 |
6960 | 311 <P>The AC3 decoder can create audio output mixes for 2, 4, or 6 speakers. When |
312 configured for 6 speakers, this decoder provides separate output of all the | |
313 AC3 channels to the sound driver, allowing for full "surround sound" | |
314 experience without the external AC3 decoder required to use the hwac3 | |
315 codec.</P> | |
3239
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
316 |
6960 | 317 <P>Use the <CODE>-channels</CODE> option to select the number of output |
318 channels. Use <CODE>-channels 2</CODE> for a stereo downmix. For a 4 | |
319 channel downmix (Left Front, Right Front, Left Surround and Right Surround | |
320 outputs), use <CODE>-channels 4</CODE>. In this case, any center channel will | |
321 be mixed equally to the front channels. <CODE>-channels 6</CODE> will output | |
322 all the AC3 channels as they are encoded - in the order Left, Right, Left | |
323 Surround, Right Surround, Center and LFE.</P> | |
3239
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
324 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
325 <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
|
326 |
6960 | 327 <P>To use more than 2 output channels, you will need to use OSS, and have a |
328 sound card that supports the appropriate number of output channels via the | |
329 SNDCTL_DSP_CHANNELS ioctl. An example of a suitable driver is emu10k1 (used | |
330 by Soundblaster Live! cards) from August 2001 or newer (ALSA CVS is also | |
331 supposed to work).</P> | |
3239
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
332 |
ef38487113b1
"Software AC3 decoding" section. Patch by Stephen Davies <steve@daviesfam.org>
gabucino
parents:
3174
diff
changeset
|
333 |
7047 | 334 <H4><A NAME="hardware_ac3">2.2.2.2 Hardware AC3 decoding</A></H4> |
2745 | 335 |
6960 | 336 <P>You need an AC3 capable sound card, with digital out (SP/DIF). The card's |
337 driver must properly support the AFMT_AC3 format (C-Media does). Connect | |
338 your AC3 decoder to the SP/DIF output, and use the <CODE>-ac hwac3</CODE> | |
7270
60a3b83b73bf
DXR3 docs updated. Patch by David Holm <david@realityrift.com>, further
diego
parents:
7190
diff
changeset
|
339 option. It is experimental but known to work with C-Media cards, |
60a3b83b73bf
DXR3 docs updated. Patch by David Holm <david@realityrift.com>, further
diego
parents:
7190
diff
changeset
|
340 Soundblaster Live! using ALSA (but not OSS) drivers and DXR3/Hollywood+ MPEG |
60a3b83b73bf
DXR3 docs updated. Patch by David Holm <david@realityrift.com>, further
diego
parents:
7190
diff
changeset
|
341 decoder cards.</P> |
2745 | 342 |
343 | |
7047 | 344 <H4><A NAME="libmad">2.2.2.3 libmad support</A></H4> |
2452 | 345 |
6960 | 346 <P><A HREF="http://mad.sourceforge.net">libmad</A> is a multiplatform MPEG |
347 audio decoding library. It does not handle broken files well, and it | |
348 sometimes has problems with seeking.</P> | |
5114 | 349 |
2452 | 350 <P>To enable support, compile with the <CODE>--enable-mad</CODE> configure |
6960 | 351 option.</P> |
2452 | 352 |
353 | |
7047 | 354 <H4><A NAME="vivo_audio">2.2.2.4 VIVO audio</A></H4> |
2855 | 355 |
5534 | 356 <P>The audio codec used in VIVO files depends on whether it is a VIVO/1.0 or |
6960 | 357 VIVO/2.0 file. VIVO/1.0 files have <B>g.723</B> audio, and VIVO/2.0 files |
358 have <B>Vivo Siren</B> audio. Both are supported. You can grab the | |
7076
3275af5787e0
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, slightly
diego
parents:
7047
diff
changeset
|
359 <A HREF="http://www.mplayerhq.hu/MPlayer/samples/drivers32/vivog723.acm">g.723/Siren</A> |
3275af5787e0
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, slightly
diego
parents:
7047
diff
changeset
|
360 Win32 DLL from the MPlayer site, |
6960 | 361 then copy it into the <CODE>/usr/lib/win32</CODE> directory.</P> |
2855 | 362 |
363 | |
7047 | 364 <H4><A NAME="realaudio">2.2.2.5 RealAudio</A></H4> |
3806 | 365 |
6960 | 366 <B>MPlayer</B> supports decoding nearly all versions of RealAudio: |
6974 | 367 |
6408
d0b1f3d75900
Background now uses CSS, added doctype and charset, removed leftover
diego
parents:
6393
diff
changeset
|
368 <UL> |
6594 | 369 <LI>RealAudio DNET - decoding supported by <B>liba52</B></LI> |
7131 | 370 <LI>RealAudio Cook/Sipro - decoding supported by <B>RealPlayer libraries</B></LI> |
7154 | 371 <LI>RealAudio atrc - decoding not yet supported</LI> |
6408
d0b1f3d75900
Background now uses CSS, added doctype and charset, removed leftover
diego
parents:
6393
diff
changeset
|
372 </UL> |
d0b1f3d75900
Background now uses CSS, added doctype and charset, removed leftover
diego
parents:
6393
diff
changeset
|
373 |
6391 | 374 <P>On how to install RealPlayer libraries, see the |
6906
3274d0725fde
Changed all link names from the section number to a sensible label.
diego
parents:
6882
diff
changeset
|
375 <A HREF="formats.html#real">RealMedia file format</A> section.</P> |
6357 | 376 |
3806 | 377 |
7047 | 378 <H3><A NAME="importing">2.2.3 Win32 codec importing HOWTO</A></H3> |
1682 | 379 |
6974 | 380 |
7047 | 381 <H4><A NAME="importing_vfw">2.2.3.1 VFW codecs</A></H4> |
1682 | 382 |
5534 | 383 <P>VFW (Video for Windows) is the old Video API for Windows. Its codecs have |
6974 | 384 the .DLL or (rarely) .DRV extension. |
385 If <B>MPlayer</B> fails at playing your AVI with this kind of message:</P> | |
1682 | 386 |
387 <P> <CODE>UNKNOWN video codec: HFYU (0x55594648)</CODE></P> | |
1612 | 388 |
1682 | 389 <P>It means your AVI is encoded with a codec which has the HFYU fourcc (HFYU = |
6974 | 390 HuffYUV codec, DIV3 = DivX Low Motion, etc...). Now that you know this, you |
391 have to find out which DLL Windows loads in order to play this file. In our | |
392 case, the <CODE>system.ini</CODE> contains this information in a line that | |
393 reads:</P> | |
1612 | 394 |
1682 | 395 <P> <CODE>VIDC.HFYU=huffyuv.dll</CODE></P> |
396 | |
5534 | 397 <P>So you need the <CODE>huffyuv.dll</CODE> file. Note that the audio codecs are |
6974 | 398 specified by the MSACM prefix:</P> |
1682 | 399 |
400 <P> <CODE>msacm.l3acm=L3codeca.acm</CODE></P> | |
1612 | 401 |
402 | |
6974 | 403 <P>This is the MP3 codec. Now that you have all the necessary information |
404 (fourcc, codec file, sample AVI), submit your codec support request by mail, | |
405 and upload these files to the FTP site:</P> | |
1612 | 406 |
1869 | 407 <P> <CODE>ftp://ftp.mplayerhq.hu/MPlayer/incoming/[codecname]/</CODE></P> |
1612 | 408 |
7305
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
409 <P><B>Note:</B> On Windows NT/2000/XP search for this info in the registry, e.g. search for |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
410 "VIDC.HFYU". To find out how to do this, look at the old DirectShow method below.</P> |
1612 | 411 |
7047 | 412 <H4><A NAME="importing_directshow">2.2.3.2 DirectShow codecs</A></H4> |
1612 | 413 |
1682 | 414 <P>DirectShow is the newer Video API, which is even worse than its predecessor. |
6974 | 415 Things are harder with DirectShow, since</P> |
416 | |
1682 | 417 <UL> |
6974 | 418 <LI><CODE>system.ini</CODE> does not contain the needed information, instead it |
419 is stored in the registry and | |
420 <LI>we need the GUID of the codec. | |
5534 | 421 </UL> |
1612 | 422 |
7305
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
423 <P><B>New Method:</B> Using Microsoft GraphEdit (fast)</P> |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
424 |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
425 <OL> |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
426 <LI>Get GraphEdit from either DirecX SDK or <A HREF="http://doom9.org">Doom9</A> |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
427 <LI>Start <CODE>graphedit.exe</CODE> |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
428 <LI>From the menue select Graph -> Insert Filters |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
429 <LI>Expand item <CODE>DirectShow Filters</CODE> |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
430 <LI>Select the right codec name and expand item |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
431 <LI>In the entry <CODE>DisplayName</CODE> look at the text in winged brackets |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
432 after the backslash and write it down (five dash-delimited blocks, the GUID) |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
433 <LI>The codec binary is the file specified in the <CODE>Filename</CODE> entry |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
434 </OL> |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
435 |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
436 <P><B>Note:</B> If there is no <CODE>Filename</CODE> entry and <CODE>DisplayName</CODE> |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
437 contains something like <CODE>device:dmo</CODE>, then it is a DMO-Codec, which are |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
438 currently not supported by MPlayer.</P> |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
439 |
d6b3e5dac5e8
Update with new method of finding DShow codecs and a small hint about VFW on WinNT.
atmos4
parents:
7270
diff
changeset
|
440 <P><B>Old Method:</B> Take a deep breath and start searching the registry...</P> |
6974 | 441 |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
442 <OL> |
6974 | 443 <LI>Start <CODE>regedit</CODE>. |
444 <LI>Press <CODE>Ctrl-f</CODE>, disable the first two checkboxes, and enable | |
445 the third. Type in the fourcc of the codec (e.g. TM20). | |
446 <LI>You should see a field which contains the path and the filename | |
447 (e.g. <CODE>C:\WINDOWS\SYSTEM\TM20DEC.AX</CODE>). | |
448 <LI>Now that you have the file, we need the GUID. Try searching again, but | |
449 now search for the codec's name, not the fourcc. Its name can be acquired | |
450 when Media Player is playing the file, by checking File -> Properties | |
451 -> Advanced. | |
452 If not, you are out of luck. Try guessing (e.g. search for TrueMotion). | |
453 <LI>If the GUID is found you should see a FriendlyName and a CLSID | |
454 field. Write down the 16 byte CLSID, this is the GUID we need. | |
7099
0b70f3dc34eb
Applied patch by Andras Mohari <mayday@varoshaza.nagyatad.hu>, with some
diego
parents:
7076
diff
changeset
|
455 </OL> |
1682 | 456 |
6775
7a41ce77089f
Moved RealPlayer libs installation to codecs.html where all the other
diego
parents:
6596
diff
changeset
|
457 <P><B>Note:</B> If searching fails, try enabling all the checkboxes. You may have |
6974 | 458 false hits, but you may get lucky...</P> |
1612 | 459 |
5534 | 460 <P>Now that you have all the necessary information (fourcc, GUID, codec file, |
6974 | 461 sample AVI), submit your codec support request by mail, and upload these files |
462 to the FTP site:</P> | |
1612 | 463 |
5534 | 464 <P> <CODE>ftp://ftp.mplayerhq.hu/MPlayer/incoming/[codecname]/</CODE></P> |
1612 | 465 |
466 </BODY> | |
467 </HTML> |