intf-vcd.txt
上传用户:riyaled888
上传日期:2009-03-27
资源大小:7338k
文件大小:23k
源码类别:

多媒体

开发平台:

MultiPlatform

  1. This file documents the ``Extended'' VLC Video CD Plugin
  2. Copyright (C) 2003, 2004 Rocky Bernstein (rocky@panix.com)
  3. Permission is granted to copy, distribute and/or modify this document
  4. under the terms of the GNU Free Documentation License, Version 1.1 or
  5. any later version published by the Free Software Foundation; with the
  6. Invariant Sections being ``Free Software'' and ``Free Software Needs
  7. Free Documentation'', with the Front-Cover Texts being ``A GNU Manual,''
  8. and with the Back-Cover Texts as in (a) below.
  9. (a) The Free Software Foundation's Back-Cover Text is: ``You have
  10. freedom to copy and modify this GNU Manual, like GNU software.  Copies
  11. published by the Free Software Foundation raise funds for GNU
  12. development.''
  13. -----------------------------------------------------------------
  14. Quick start
  15. -----------------------------------------------------------------
  16. The newer Video CD plugin (using libcdio and vcdimager) has some
  17. navigation and playback capabilities. However full integration with
  18. into vlc is a bit lacking and will probably take some a bit of work
  19. and time.
  20. Although, this plugin replaces the older VCD plugin, the old plugin is
  21. still built and installed and used when the newer plugin is not found.
  22. This document describes only the newer VCD plugin.
  23. The next section is a general overview of Video CD's in general. If
  24. you are in a hurry to find out how to use this plugin or know this
  25. already, this section can be skipped. 
  26. After that we describe the terms and concepts used in the remainder
  27. Again, in a hurry, this section can be skipped or skimmed. If you come
  28. across a term like "segment," or "lid" that confuses you, look in
  29. this section.
  30. The next section describes the MRL format that this plugin uses. If
  31. you want to know how to control where to start playing, read this.
  32. Even if you are familiar with vlc MRL's, you probably want to look
  33. at this section. Some of the units in a VCD are a little different
  34. than those in a DVD or audio CD. 
  35. The next section gives key bindings that are used by this
  36. plugin. Again to be able to control the plugin, especially for
  37. playback control, you may need to read this section. 
  38. The next section describes the configuration parameters you can set
  39. for the plugin. Most of the default values I hope are what most
  40. people will want to start out with. But for fine control of the
  41. defaults, read this section.
  42. One configuration variable is the debug output. The next section
  43. describes the meaning of debug flags and how to troubleshoot the
  44. plugin.
  45. -----------------------------------------------------------------
  46. About VCDs, SVCDs, and XVCDs.
  47. -----------------------------------------------------------------
  48. From: http://www.vcdhelp.com/vcd
  49.  VCD stands for 'Video Compact Disc' and basically it is a CD that
  50.  contains moving pictures and sound. If you're familiar with regular
  51.  audio/music CDs, then you will know what a Video CD looks like. A VCD
  52.  has the capacity to hold up to 74/80 minutes on 650MB/700MB CDs
  53.  respectively of full-motion video along with quality stereo
  54.  sound. VCDs use a compression standard called MPEG to store the video
  55.  and audio. A VCD can be played on almost all standalone DVD Players
  56.  and of course on all computers with a DVD-ROM or CD-ROM drive with
  57.  the help of a software based decoder / player. It is also possible to
  58.  use menus and chapters, similar to DVDs, on a VCD and also simple
  59.  photo album/slide shows with background audio. The quality of a very
  60.  good VCD is about the same as a VHS tape based movie but VCD is
  61.  usually a bit more blurry. If you want better quality checkout
  62.  SVCD,CVD or DVD.
  63. From: http://www.vcdhelp.com/svcd.htm
  64.  SVCD stands for "Super VideoCD". A SVCD is very similar to a VCD, it
  65.  has the capacity to hold about 35-60 minutes on 74/80 min CDs of very
  66.  good quality full-motion video along with up to 2 stereo audio tracks
  67.  and also 4 selectable subtitles. A SVCD can be played on many
  68.  standalone DVD Players and of course on all computers with a DVD-ROM
  69.  or CD-ROM drive with the help of a software based decoder / player. It
  70.  is also possible to use menus and chapters, similar to DVDs, on a
  71.  SVCD and also simple photo album/slide shows with background
  72.  audio. The quality of a SVCD is much better than a VCD, especially
  73.  much more sharpen picture than a VCD because of the higher
  74.  resolution. But the quality depends how many minutes you choose to
  75.  store on a CD, less minutes/CD generally means higher quality.
  76. From: http://www.vcdhelp.com/xvcd.htm
  77.  XVCD stands for eXtendedVCD. XVCD has same features as VCD but it is
  78.  possible to use higher bitrates and higher resolution to get higher
  79.  video quality. XVCD is basicly everything that uses MPEG1 video, is
  80.  not within the VCD standard and burnt in "VCD"-Mode.
  81.  XSVCD stands for eXtendedSVCD. XSVCD has same features as SVCD but it
  82.  is possible to use higher bitrates and higher resolution to get
  83.  higher video quality. XSVCD is basicly everything that uses MPEG2
  84.  video, is not within the SVCD standard and burnt in "SVCD"-Mode.
  85. -----------------------------------------------------------------
  86. Concepts used by this plugin.
  87. -----------------------------------------------------------------
  88. The remote control of a Video CD players (or the front panel)
  89. generally has special keys or buttons. The author of a Video CD can
  90. assign what action to use when these buttons are pressed. They buttons
  91. are:
  92.  RETURN: Often used to return to the previous menu or previouly
  93.  interruped video segment. 
  94.  DEFAULT: Possibly take the default selection value. This function can
  95.  only be assigned when the LID refers to in a "Program Selection List"
  96.  or "Extended Program Selection List"
  97.  NEXT: Possibly the next entry, chapter, track, or menu.
  98.  PREVIOUS: Possibly the previous entry, chapter, track, or menu.
  99. Contiguous non-overlapping regions of a Compact Disc are called
  100. "Tracks".  The sum of the tracks forms the entire CD.  The CD
  101. specifications standards say that between tracks there is to be a
  102. 150-sector gap.
  103. In the MRL list described below, we generally don't list the first
  104. track which we would call call "Track 0", but other tools like
  105. VCDimager, cdinfo, and the CD-reading world in the general call this
  106. "Track 1".  This first track usually contains an ISO 9660-format
  107. filesystem with metadata describing what's on the CD. It may also
  108. contain "segments" or small MPEGs that generally make up still frames
  109. and menus.  Aside from the segments which are merely only parts of
  110. track 0, it doesn't make sense to try to "play" track 0 (or track 1
  111. depending on how you want to count), which is why we don't list it.
  112. It seems natural to call the first thing you would want to play "track
  113. 1" (which in fact is track 2 to everyone else).
  114. There are two other units that this plugin lists and are used
  115. internally. One we call an "entry". This is a starting point of a
  116. track which can include the beginning of the track, and when an entry
  117. points to the beginning of a track, it is equivalent to listing the
  118. track. However Video CD's often have multiple entry points into a
  119. track. Logically this corresponds to a "Chapter" or "Scene" of a
  120. larger uninterruptable unit. One might think a CD "track" could serve
  121. this purpose with a collection of tracks making up a work or
  122. movie. Alas, there is "track pregap" space between tracks which appear
  123. as a time gaps when hardware players go between tracks - something
  124. that doesn't have to happen switching between entries because there in
  125. fact is no gap.
  126. Another unit we use is a called a "segment." These are just the
  127. playable units in track 0. Segments come in fixed-length units so
  128. several may be combined to form a single logical playable unit.  Still
  129. frames for menus are segments. A menu doesn't have to have a
  130. still-frame associated with it; a menu might be implemented as a short
  131. looped movie clip.  But all still frames are segments. Also, Video CD
  132. specifications allow still frames to have higher resolution than
  133. motion clips. All segments reside in track 0.
  134. A "list ID" (also called a LID and and is one greater than a Play
  135. Sequence descripter or "PSD" number) combines "entries" and "segments"
  136. and "tracks" together with some navigation logic. "Playback Control"
  137. (acronym PBC) is simply starting playback at a particular LID, and
  138. unless otherwise specified you'd start with the first playback item
  139. which we call P1.
  140. Below we will refer to an "item" as combination of a unit name (track,
  141. entry, segment, playback) and a whole number.
  142. -----------------------------------------------------------------
  143. MRLS:
  144. -----------------------------------------------------------------
  145. This vlc Video CD plugin, identifies itself in the vlc GUI preferences
  146. vcdx. It also registers itelf to handle a class of MRL's that start
  147. with vcdx://.
  148. The VCDX MRL takes the following form:
  149.   vcdx://[path to file or vcd device][@[letter]number]]
  150. (Note: eventually the trailing "x" will be dropped. In MRL's "vcd"
  151. works as well as "vcdx".
  152. A simple vcdx:// runs the default item (e.g. perhaps track 1 or the
  153. playback control) the default VCD device (perhaps /dev/cdrom). Whether
  154. to use playback control and the default device are user-configurable.
  155. It is however also possible to specify both Video CD device/filename
  156. and the kind of item explicitly in the MRL.
  157. For example vcdx:/dev/dvd specifies the default entry using device
  158. /dev/dvd which might useful if this is your DVD which is different
  159. than your CD-ROM device and your DVD drive can play CD's. And
  160. vcdx://test_svcd_ntsc.cue specifies the cue file for CD image on disk.
  161. (test_svcd_ntsc.bin is the corresponding bin file, but using that
  162. won't work.)
  163. After the optional device name or file name, you can name the kind of
  164. unit which preceded by an '@'. An MRL which ends in an @ is like
  165. not adding it at all: the default entry type and number is used. Items
  166. come in 4 flavors: "Track," "Entry," "Playback," and "Segment." See
  167. the preceding section for an explaination of these terms. These units
  168. are indicated with the capital first letter of each type: T, E, P, S,
  169. s. 
  170. --- In the future when we are able to control MRL display: 
  171. An uppercase S in the MRL display indicates a NTS segment while a
  172. lowercase S indicates a PAL segment. 
  173. ----
  174. However when you enter a MRL, the case of these letters is
  175. insignificant.
  176. You can configure various things that affect MRLs are selected when
  177. there is some ambiguity in the MRL name. vcdx-PBC sets whether to 
  178. to use PBC in a MRL is none is given.  Another configuration
  179. setting, vcdx-device, determines what device to use if that part is
  180. not given. 
  181. Some examples of MRLS are given below. In the examples, we assume the
  182. following configuration settings:
  183.   vcdx-PBC=1
  184.   vcdx-device=/dev/cdrom
  185. vcdx://                   - Play (navigate) default item (in this
  186.                             case Entry ID 0) from the default device (in this
  187.                             case set to /dev/cdrom)
  188. vcdx://@                  - same as above
  189. vcdx:///dev/cdrom@        - same effect as above since the default device
  190.                             is set to /dev/cdrom. 
  191. vcdx:///dev/cdrom@E0      - same as above. But note that this is
  192.                             because we have autoplay:entry which is
  193.                             no longer the default value
  194. vcdx:///dev/cdrom2@       - Play (navigate) the default item of /dev/cdrom2
  195. vcdx:///dev/cdrom2        - should be same as above but is currently broken?
  196. vcdx:///dev/cdrom2@T1     - Play Track 1 from /dev/cdrom2
  197. vcdx:///dev/cdrom@S1      - Play segment 1 from /dev/cdrom. This
  198.                             assumes there *is* a segment 1. Check
  199.                             the MRL list to see if that is the case.
  200. vcdx://@P1                - Play LID item 1 from default device
  201.                             If there is no playback control, MRL will
  202.     get converted into vcdx://@E0. Again
  203.                             check the MRL list to see if there is a P1.
  204. vcdx://@P1*               - probably same as above.
  205. vcdx:///dev/cdrom@E1      - Play Entry id 1 from default device
  206. vcdx://@S0                - Play segment 0 from default device
  207. vcdx://@3                 - Play track 3 from default device
  208. vcdx:///dev/cdrom2:1      - Play track 1 from /dev/cdrom2
  209. vcdx:///tmp/ntsc.cue@     - Play default item (E0) of /tmp/ntsc.bin. Note
  210.                             trailing @
  211. vcdx://ntsc.cue/@E0       - Play entry 0 of ntsc.bin
  212. vcdx:///tmp/ntsc.nrg/@E0  - Play entry 0 of /tmp/ntsc.nrg (Nero
  213.                             file) Works for some simple Nero images.
  214. -----------------------------------------------------------------
  215. Key bindings and non-PBC navigation.
  216. -----------------------------------------------------------------
  217. At present vlc doesn't have special hot-keys for "NEXT", "PREVIOUS",
  218. "RETURN" or "DEFAULT". So we use some of other hot-key names that
  219. don't seem to correspond to anything for a VCD. The key mapping names
  220. are:
  221. VLC NAME         VCD NAME
  222. --------------------------
  223. NAVIGATE UP      RETURN
  224. NAVIGATE DOWN    DEFAULT
  225. NAVIGATE LEFT    PREVIOUS
  226. NAVIGATE RIGHT   NEXT
  227. Also this plugin understand numeric input. Since the hot-keys don't
  228. have assignments for numbers, the digits on the keyboard (also
  229. available from the keypad if num-lock is on) are hard-coded. Even
  230. though this isn't customizable, it's probably what most people would
  231. expect and want.
  232. The enter a number just type the digits of the number. To finish
  233. specifying a number use the whatever key is bound to vlc's
  234. "ACTIVATE" hot key - the default value is the "Enter" key.
  235. However the next/previous/return buttons can be prefaced with a number
  236. and that has the effect of hitting that button that many times. So
  237. let's say you want to go forward 5 "Chapters" and hitting the "Next"
  238. key 5 times would do that Instead, you could just enter the digit 5
  239. followed by the key that is assigned to "NAVIGATE RIGHT", probably the
  240. right-arrow key.
  241. If you have better suggestions as to what functions the VCD buttons
  242. would be better bound to how what fixed algorithm to use when not in
  243. PBC, let me know.
  244. -----------------------------------------------------------------
  245. Configuration settings:
  246. -----------------------------------------------------------------
  247. Configuration settings in xine are generally put in ~/.vlc/vlcrc, but
  248. can be configured via a vlc GUI. A description of the ones specific to
  249. VCDX are listed below.
  250. - -
  251. vcdx-device
  252. This specifies the name of the video device that will be used by default.
  253. If you don't specify anything, the plugin scan for a suitable CD-ROM
  254. device containing a Video CD in it.
  255. The default device in a MRL when none is listed. The default is
  256. determined by the appropriate name for the OS that you are running.
  257. - - 
  258. vcd-debug
  259. An integer (interpreted as a bit mask) which shows additional
  260. debugging information see the Debugging Section below for more
  261. information about the bits that can be set.
  262. -----------------------------------------------------------------
  263. Troubleshooting Guide
  264. -----------------------------------------------------------------
  265. The VCD plugin leaves a bit to be desired and has many bugs. I expect
  266. that there will not be covered below. But the below is a start.
  267. This gives higher-level troubleshooting. More detailed and
  268. lower-level information is given in the next section DEBUGGING. 
  269. Problem: something doesn't work. Start at step -1.
  270. Problem: The program gets a SEGFAULT or gives core dump. Start at step
  271. 0.
  272. Problem: I don't get anything playing. I can't even get information 
  273. listed in "Media and Stream Information" or the playlist.
  274. Determination: start at step 1.
  275. Problem: Okay, I something plays menu now. But I don't see information
  276. about the CD in the playlist.
  277. Determination: start at step 5.
  278. -1. (Something doesn't work.)
  279.    A lot of what is put here really is applicable to reporting
  280.    problems and troubleshooting in vlc and the concepts really
  281.    apply to any sort of bug reporting. 
  282.    When reporting a problem it's helpful to have facts:
  283.      a) the version of vlc) you are using
  284.      b) the OS you are running on 
  285.      c) the version of libcdio and/or libcddb you are using 
  286.         versions of libcdio and libcddb can be obtained by running 
  287.           pkg-config --modversion libcdio
  288.           pkg-config --modversion libvcdinfo
  289.      d) what you input or requested (e.g. the full command line entered -
  290.         if it is possible to reproduce the problem by giving a
  291.         commandline that is desirable since it is probably the simplest
  292.         way to convey exactly what was requested)
  293.    
  294.         People often give (some part) of an error message neglecting
  295.         to also include what was requested or entered that led to the
  296.         output.
  297.   
  298.      e) The setting for this plugin. That is the values of the
  299.         variables that start cddax- listed above. On Unix this can
  300. generally be found in ~/.vlc/vlcrc
  301.   
  302.   
  303.      f) Exactly the messages that were what given. You can turn
  304.         increase the verbosity level by setting "verbosity=2" in the
  305.         vlc preferences files. On Unix the preferences file is
  306.         generally in ~/vlc/.vlcrc but there are GUI ways to set this
  307.         too. Give everything that is in the message log.
  308. 0. (The program gets a SEGFAULT or gives core dump.)
  309.    Get and send a stack trace. 
  310.    In addition to -1. Make sure the program has been compiled with
  311.    debugging symbols put into the code. This is usually done by having
  312.    the "-g" flag set when compiling the program.
  313.    You can get a strack trace the GNU debugger using the "where"
  314.    command. For example on this might work:
  315.      gdb vlc *name-of-corefile*
  316.      where
  317. 1. (I don't get anything playing. I can't even get information 
  318.     listed in "Media and Stream Information" or the playlist)
  319.    Do you even have the plugin loaded? 
  320.    When you run the vlc GUI, under Settings/Preferences you should see
  321.    a "plugins" expandable list and under that another "access" list do
  322.    you see a expandalbe entry under "access" labeled "vcdx"? If so,
  323.    skip on to step 2.
  324.    a) If no "vcdx" expandable list, thent the VCDX plugin isn't
  325.    loaded. Does a shared object exist?  The plugin shared object is
  326.    called "libvcdx_plugin.so" It should be in the directory that has
  327.    ...vlc/access. If this isn't around you need to build and install
  328.    the VCDX plugin.
  329.    b) if libvcdx_plugin.so is in the fileystem, there might be a
  330.    loader error; perhaps libcdio or libvcdinfo are not installed or
  331.    are the wrong version. Use ldd on the file to see that it has all
  332.    of the libraries dependencies satisfied. Also you might be able
  333.    check if there was an attempt to load it by tracking system
  334.    calls. On Linux and other OS's) "strace" can be used to see if the
  335.    file gets accessed. On Solaris use "truss". 
  336.    For example on Linux, amonst the many line of output when I run
  337.    "strace -e trace=file vlc" I see this amongst lots of other
  338.    output:
  339.    ...
  340.    stat64("/usr/local/lib/vlc/access/libvcdx_plugin.so", {st_mode=S_IFREG|0755, st_size=302990, ...}) = 0
  341.   open("/usr/local/lib/vlc/access/libvcdx_plugin.so", O_RDONLY) = 5
  342.    The parameters inside the calls may be different depending on where
  343.    vlc is installed and what release is installed. If the the file is
  344.    found and "opened", 
  345.   
  346.    There may also be a message may under "setup/logs".
  347. 2. (There plugin was loaded and preferences found).  In the "vcdx" tab
  348.    of preference. An important selection is "vcdx-device."  If this is
  349.    set to the empty string, VCDX will try to scan your drives for a
  350.    suitable device if the driver has the capability to scan for
  351.    drives. However you can set the device to something of your
  352.    choosing. On GNU/Linux, this may be "/dev/cdrom" and on Solaris it
  353.    may be "/vol/dev/aliases/cdrom0".  If you set this field, make sure
  354.    these are correct for your particular setup. For example, I
  355.    generally play out of the DVD device and this is called /dev/dvd
  356.    rather than /dev/cdrom.
  357. 3. (Video CD Setup devices seems correct and there is a CD in the
  358.    drive).  
  359.    
  360.    when you run
  361.       vlc vcdx://
  362.    you should see your CD disk light go on if you have one. And the CD
  363.    should be read. 
  364.    
  365.    a. If not something's wrong like step 2. Another tack may be to try
  366.    to read a disk image of a Video CD and thus elimate any problems
  367.    with hardware. You can get a test Video CD disk image to test here:
  368.    http://www.vcdimager.org/pub/vcdimager/examples/test_svcd/test_svcd_pal.zip
  369.  
  370.    After unzipping this run there should be files test_svcd_pal.cue 
  371.    and test_svcd_pal.bin. Get out of xine and run from the directory
  372.    that contains those files: 
  373.      vcdx://test_svcd_pal.cue@E0
  374.    
  375.    If you see something playing then this is a hardware problem. 
  376. -----------------------------------------------------------------
  377. Debugging
  378. -----------------------------------------------------------------
  379. **General vlc debugging...
  380. Before delving to things specific to this plugin, some preparation may
  381. be in order. You'll probably want to configure vlc with "--enable-debug".
  382. plugin with debug information. Instead of "make'ing" with "make", use
  383. "make debug" and instead of installing using "make install" use "make
  384. install-debug". 
  385. I use gdb to debug. Debugging vlc with the entire suite of plugins
  386. under gdb is slow because it has to read in symbol tables from all the
  387. plugins. There are two ways to make loading faster when debugging. The
  388. simplest is just to go to the plugin directory and remove unused
  389. plugins. Another approach is create a new directory and make
  390. (symbolic) links into the complete plugin directory. Another way to
  391. speed up gdb loading is to attach the debugger after vlc has started up
  392. via a command like:
  393.   gdb -p *pid-of-vlc-process*
  394. **vcdx debugging...
  395. It's a fact of life that this plugin is in an incomplete state and has
  396. bugs. So to facilitate tracking down problems we let you see what's
  397. going on dynamically. Various debugging settings will cause output to
  398. appear on vlc plugin log and/or "standard error" (assuming you've run
  399. xine in a way that you can capture this).
  400. You think of debug switches as a bit mask, that you specifiy as an
  401. integers the various "bit" values (given in decimal) are listed below.
  402.    name        value       description
  403.    ------      ----------  -----------
  404.    meta info            1  Trace Meta information
  405.    event info           2  Trace keyboard events
  406.    MRL                  4  Things involved getting lists of what's in the VCD
  407.    ext call             8  Trace vlc calls to the plugin routines
  408.    all calls   (10)    16  Trace all calls
  409.    LSN         (20)    32  Trace updates to the Logical sector number
  410.                            (basically reads)
  411.    PBC         (40)    64  Trace things involved with playback control
  412.    libcdio     (80)   128  Turn on CDIO debugging
  413.    seek-set    (100)  256  Trace "seek set" calls
  414.    seek-cur    (200)  512  Trace "seek cur" calls
  415.    still       (400) 1024  Trace Still-frames
  416.    vcdinfo     (800) 2048  Turn on VCDINFO debugging
  417. **Video CD debugging...
  418. The tool vcd-info from the cdio branch of vcdimager can be used to
  419. show the entire contents of a Video CD or selected portions of
  420. that. Until the cdio branch of vcdimager is completely merged with
  421. vcdimager, the cd-info branch vresion has a few more
  422. features. (However consult vcdimager for complete of the program).
  423. vcdxrip can be used to extract portions of a Video CD and or create an
  424. XML description file of the Video CD. This XML file and the extracted
  425. files can be used by vcdxbuild to recreate another Video CD.
  426. And finally see also tools cd-info an cd-read from libcdio.
  427. -----------------------------------------------------------------
  428. Other references
  429. -----------------------------------------------------------------
  430. http://www.vcdhelp.com/
  431. http://www.vcdimager.org/
  432. http://www.vcdimager.org/guides/#guides
  433. $Id: intf-vcd.txt 6961 2004-03-05 17:34:23Z sam $