Contents
- Dependencies
- Installation
- Usage
- Configuration
- Skins
- Removable Media
- Remote Control
- Main Menu
- Mediamarks
- Shutdown Dialog
- Thumbnail Images
- Video Disc Recorder
- Apple Airport Express
- Password protection
- Extractor
- Controls
- Menu Navigation
- Direct Menu Access
- Miscellaneous
- Playback Control
- Playlist
- Images
- DVD
- Television
- Video Disc Recorder
- Problems
Dependencies
oxine depends on a number of external libraries to support it in some of the more complicated tasks it has to perform. Please make sure to install the following libraries before you start compiling oxine.
Libraries marked as mandatory must be installed. It is suggested that you also install libraries marked as optional to improve oxine's overall experience.
Depending on the distribution you are using it may be necessary to not only install the library, but to also install the associated development packages. For Ubuntu this would mean that you would need to install liblircclient0 and liblircclient-dev.
Library | Description | Status |
---|---|---|
X.org | You will need to install the X or X.org development files. | mandatory |
xine-lib | This library provides the core functionality of oxine. Everything that has to do with video and audio playback depends on this piece of software. | mandatory |
gettext | This library is used to provide internationalization. Without it translating oxine to your favorite language cannot work. | mandatory |
LIRC | This library is necessary if you wish to use a remote control with oxine. | optional |
gdk-pixbuf |
This library is necessary if you wish to display thumbnail or cover images. Although it is also possible to use ImageMagick for this purpose the higher speed of gdk-pixbuf (around factor 10 compared to ImageMagick) makes it the better choic. Because gdk-puxbuf does not provide a method for reducing the number of colors in an image and because the OSD of xine-lib only support 256 colors oxine has to do the color reduction. This leads to a slightly worse image-quality than when using ImageMagick. If image quality is important to you and the time needed to display an image is not relevant, please run ./configure --disable-gdkpixbuf <other options> |
optional |
ImageMagick | This library is necessary if you wish to display thumbnail or cover images and do not have gdk-pixbuf installed. If you wish to rotate images this library must be installed. | optional |
libcurl | This library is necessary if you wish to enable oxine to download files via a network. This is needed e.g. for shoutcast support. | optional |
libcdio | This library is used to identify ISO image files. Without it oxine will not know what to do with these files as it cannot know if it's looking at a DVD image, a VCD image or something else. | optional |
libiso9660 | This library is actually a part of libcdio. Some distributions (e.g. Debian, Ubuntu) distribute it as a separate package. | optional |
libmetar | This library is necessary if you wish to use the weather functionality. If you wish to use the weather functionality you will also have to install libcurl. | optional |
libjsw |
This library is recommended if you wish to use a joystick to control oxine. It makes the job of reading input from the joystick much easier and gives better results than when using the raw joystick interface. There is a bug in versions of libjsw ≤ 1.5.5 that may cause oxine to crash if no joystick is attached. This bug has been fixed in 1.5.6 and may be fixed in earlier versions by some distributions (e.g. Ubuntu) as well. If oxine crashes when starting up please either disable libjsw by running ./configure --without-jsw <other options> or install version 1.5.6 of the library. |
optional |
HAL DBUS DBUS-GLib GLib |
These libraries are used to provide support for automatically detecting when new media such as CDROMs, DVDs or external harddrives are inserted. | optional |
libavahi-client | Avahi is a system which facilitates service discovery on a local network. This means that you can plug your laptop or computer into a network and instantly be able to view other people who you can chat with, find printers to print to or find files being shared. oxine uses this library to find available Apple Airport Express in the local network. | optional |
libexif | The Exchangeable image file format (EXIF) specifies a number of metadata tags for digital images. This library is used to read this metadata information from image files. oxine currently only displays the date and time an image was created but this could easily be changed to include more information. | optional |
Apart from the libraries oxine also depends on a number of command line programs.
Program | Description | Status |
---|---|---|
mount umount |
These tools are used by oxine to mount and unmount volumes. These tools are available on all linux base systems. | mandatory |
pmount-hal pumount |
These tools are necessary if you want to mount and unmount volumes recognized by HAL. If these tools are available mount and umount will not be used. | optional |
eject | This tool is necessary if you wish to eject drives (e.g. CDROM-drives). If this tool is not available oxine will try to eject the drives using the ioctl command. | optional |
cdparanoia | This tool is necessary if you wish to extract audio CDs. | optional |
flac oggenc lame |
At least one of these tools is necessary to compress the extracted audio files. It is possible to choose what encoder to use in oxine's configuration menu. | optional |
dd | This is needed if you wish to create DVD and VCD images. This tool is available on most linux base systems. | optional |
Installation
The installation is quite straight forward. Make sure that you have installed the latest version of xine-lib. At least version 1.0 is required. Then download and unpack oxine source tarball, change to the directory created and type
./configure --prefix=/some/path make make install
If you checked oxine out of SVN you must first create the configure script yourself. The tools autoconf and automake are needed for this to work. To run type
./autogen.sh --prefix=/some/path make make install
When building oxine a number of it's feature may be enabled or disabled. Most features are enabled by default. Only a small subset of features is not enabled by default. This is because these features (e.g. support for VDR or Apple Airport Express) are only interesting to a few users.
The following parameters may be used to configure oxine at build time. They may be passed to the scripts configure or autogen.sh:
./configure --help . --disable-hal do not activate HAL support --disable-extractor do not activate ripping support --disable-exif do not activate EXIF support --disable-gdkpixbuf do not activate gdk-pixbuf support --disable-lirc do not activate LIRC support --disable-joystick do not activate joystick support --disable-weather do not activate weather support --disable-shoutcast do not activate SHOUTcast support --disable-youtube do not activate YouTube support . --enable-vdr enable support for Video Disc Recorder (VDR) --enable-aex enable support for Apple Airport Express (AEX) --enable-debug enable support for debugging . --without-curl Turn off CURL support. --without-imagemagick Turn off ImageMagick support. --without-jsw Turn off libjsw support.
Users who want to help debug oxine should add --enable-debug to the options they pass to configure or autogen.sh. This enables debug messages that often make it easier to find out what goes wrong.
Usage
There exist a number of command line options oxine accepts. These can be used to change the standard behaviour of oxine (e.g. what configuration file or what log file to use).
It is also possible to deactivate certain features that were enabled at build time but are not needed by the user.
The following command line options are known to oxine:
Usage: oxine [OPTIONS] [MRL] OPTIONS are: -c, --config <filename> Use non-standard configuration file. -v, --version Display version. --verbose=<level> Set verbosity level. Default is 0. -l, --logfile <filename> Set the log filename. -V, --video-driver <drv> Select video driver by ID. Available drivers: auto xv xshm sdl -A, --audio-driver <drv> Select audio driver by ID. Available drivers: alsa esd file none -X, --xineramascreen=<num> Sets the screen on which the fullscreen window will be shown. -F, --no-fullscreen Do no start in fullscreen mode. -L, --no-lirc Do not use remote control (LIRC). -J, --no-joystick Do not use joystick support. -W, --no-weather Do not automaticaly retrieve weather information. -H, --no-hal-dbus Do not use HAL/ DBUS to monitor removable drives.
Depending on how you configured oxine at build time some of the above options may not be available. If you for example configured oxine without weather support the command line option --no-weather will not be available.
Configuration
There are two location where oxine keeps it's configuration files. One is in $PREFIX/share/oxine/ ($PREFIX is the installation prefix where you installed oxine. This will usually be /usr/ or /usr/local/) and the other is $HOME/.oxine/ ($HOME is your home directory).
Especially the file $HOME/.oxine/config is important. This is where all configuration values are saved by oxine. This file will be created the first time you run oxine.
oxine's configuration can be changed by editing the configuration file directly or by selecting "Edit Settings" from the oxine main menu.
The following sections describe various issues that need to be addressed before oxine is fully functional.
Please read the ChangeLog when updating oxine. As the program is still alpha configuration and feature may change between releases.
Skins
oxine comes with one standard skin. This skin (oxinetic) is in english and for 4:3 monitors only.
Skins in your favorite language and skins for 16:9 monitors can be downloaded from the oxine subversion repository by running
svn co https://oxine.svn.sourceforge.net/svnroot/oxine/trunk/oxine-skins
The skins in that directory can be installed by running
./install.sh <skinname>
If a skin is missing in your favorite language or resolution please file a support request telling us what language and resolution (4:3 or 16:9) you need.
Once you've installed other skins the skin to use can be selected via the 'User Interface' section of the configuration menu or by changing the following configuration key:
# Skin to use # { oxinetic default oxinetic-de oxinetic-de-hdtv }, default: 1 #gui.skin:default
Removable Media
If you wish to use a CDROM or DVD drive please make sure the correct devices are set in the configuration file. The following configuration keys are relevant:
# device used for DVD playback # string, default: /dev/dvd #media.dvd.device:/dev/dvd # device used for CD audio # string, default: /dev/cdrom #media.audio_cd.device:/dev/cdrom # CD-ROM drive used for VCD when none given # string, default: #media.vcd.device:/dev/cdrom
Remote Control
To control oxine with a remote control the library LIRC must be installed and correctly configured.
The names of the oxine LIRC commands were choosen to be descriptive rather than to fit to a specific remote control. This means that nearly all remote controls will not work out of the box.
There are two options to fix this:
- either you change the entries in the systemwide LIRC configuration file /etc/lirc/lircd.conf to fit the names of the oxine LIRC commands (see $PREFIX/share/oxine/lircrc)
- or you copy the the file $PREFIX/share/oxine/lircrc to $HOME/.oxine/lircrc and modify that so the names of the commands fit the entries in the file /etc/lirc/lircd.conf.
What you should not do is modify $PREFIX/share/oxine/lircrc directly, as this will be overwritten whenever oxine is reinstalled.
If you use LIRC, make sure that you don't have the irxevent daemon running. Otherwise oxine may get all LIRC events twice which is quite annoying.
Main Menu
Starting with version 0.6 it is possible to configure oxine's main menu.
The default menu file is located in $PREFIX/share/oxine/mainmenu.xml. This file should not be changed as it will be overwritten whenever oxine is reinstalled. Instead you should copy this file to $HOME/.oxine/mainmenu.xml and modify it there. The file must follow the syntax as described in $PREFIX/share/oxine/DTD/menu.dtd
The default menu file contains a complete set of permitted parameters and some examples.
Mediamarks
When selecting "Listen to Music", "Watch Films" or "View Images" the user enters the file selection dialogs. The main difference between the three is what files are displayed. When selecting "Listen to Music" only audio files are displayed while selecting "Watch Films" will only display video files and "View Images" will only display image files.
To customize the entries the user sees when first entering these dialogs mediamarks files may be created in $HOME/.oxine/ called:
mediamarks_music.xml mediamarks_video.xml mediamarks_image.xml
For an example of how these files might look please have a look at $PREFIX/share/oxine/mediamarks_example.xml. These files must follow the syntax defined in the mediamarks document type definition.
Shutdown Dialog
When pressing the "Shutdown" button in the main menu oxine displays a dialog asking the user what he wishes to do. If the user specifies the necessary commands
# shell command (reboot) # string, default: /sbin/reboot #shutdown.reboot_command:/sbin/reboot # shell command (power off) # string, default: /sbin/poweroff #shutdown.shutdown_command:/sbin/poweroff # shell command (standby) # string, default: #shutdown.standby_command:
in the configuration file, the user can also choose to shutdown or reboot the computer or to switch the computer to standby mode.
If the configuration key
# ask before leaving oxine # bool, default: 1 #shutdown.ask:1
is set to 0 this dialog will not be displayed.
Thumbnail Images
There are three ways to make oxine display thumbnail images in the filelist and the playback menu:
- If you place an image in a directory oxine will show that image whenever that directory is opened in the filelist menu or a file from that directory is being played in the playback menu. The image may have any name. If a file called title.jpg, title.png or title.gif exists oxine will display that.
- You may also add a thumbnail link to an entry in a mediamarks file:
<entry> <mrl href="dvd:/home/public/lotr.iso" /> <title>[Lord Of The Rings (ISO)]</title> <thumbnail href="/home/public/lotr.png" /> </entry>
- You may add a '.directory' file to a directory that contains an entry
'Icon':
[Desktop Entry] Version=1.0 Icon=/home/public/lotr.png
For thumbnails to work you must have ImageMagick installed on your computer.
Video Disc Recorder
Starting with version 0.6 oxine can be used with Klaus Schmidinger's Video Disc Recorder via the vdr-plugin-xine.
Support for VDR is not enabled by default. To enable it you must run
./configure --enable-vdr <other options>
As soon as you've got VDR and vdr-plugin-xine up and running, oxine should work with it without any further problems. To use VDR please change the configuration key
# type of television # { Analogue Television Digital Television Video Disc Recorder }, default: 1 television.type:Video Disc Recorder
to 'Video Disc Recorder'.
Apple Airport Express
Using the xine-lib audio output plugin for the Apple Airport Express which can be downloaded from the oxine subversion repository by running
svn co https://oxine.svn.sourceforge.net/svnroot/oxine/trunk/xine-aex
it is possible to output audio on any Apple Airport Express available on the local network.
If you have the AVAHI client library installed (see above) oxine will automatically find any available Apple Airport Express and make them available in the settings menu.
At the moment it is only possible to output audio via one Apple Airport Express or via the normal sound card.
Password protection
Directories on local discs can be password protected by placing a file .password inside that directory.
The .password file must contain exactly one password. The password may be in clear text or (as in /etc/shadow/) encrypted.
Due to some limitations of oxine's widget toolset the directory is not entered at once after providing the password. The user must double click on the directory again to enter.
Please note, that this does not protect the directory in any meaningful way. Anyone with direct access to the filesystem will not care at all about the .password file. This is only good enough to keep kids (depending on the kids) out of some directories.
Audio CD extractor
The audio CD extractor support three different output format:
- Lossless (FLAC)
- Lossy (OGG)
- Lossy (MP3)
By setting the following configuration keys it is possible to pass extra parameters to the programs doing the actual encoding:
# FLAC encoder (flac) parameters # string, default: #extractor.cdda.encoder.flac.parameters: # MP3 encoder (lame) parameters # string, default: #extractor.cdda.encoder.mp3.parameters: # OGG encoder (oggenc) parameters # string, default: #extractor.cdda.encoder.ogg.parameters:
Another configuration key does the same thing for the program doing the ripping (cdparanoia):
# CD extractor (cdparanoia) parameters # string, default: #extractor.cdda.parameters:
If for example you want the FLAC encoder (flac) to use the higest level of compression you might want to set:
# FLAC encoder (flac) parameters # string, default: extractor.cdda.encoder.flac.parameters:--compression-level-8
DVD and video CD extractor
By default the command dd is used to copy complete images of DVD's and video CD's to disc. As this may not work for all discs other programs can be specified by changing the following configuration keys:
# DVD extractor command # string, default: /bin/dd if=%s of=%s #extractor.dvd.command:/bin/dd if=%s of=%s # VCD extractor command # string, default: /bin/dd if=%s of=%s #extractor.vcd.command:/bin/dd if=%s of=%s
If for example you wish to use mplayer to extract DVD's you might want to set:
# DVD extractor command # string, default: /bin/dd if=%s of=%s extractor.dvd.command:mplayer dvd:// -dvd-device %s -dumpstream -dumpfile %s
The first %s of the commands is replaced with the device name (e.g. /dev/dvd). The second %s is replaced with the output filename. Please note, that it is not possible to change the order of device name and filename in the command.
Controls
oxine can be controlled using a keyboard, a mouse or a remote control (using LIRC).
The names of the LIRC commands were choosen to be descriptive rather than to fit to a specific remote control. On most systems it will be necessary to change these names to the command names of the remote control used (see remote control).
Menu Navigation
Action | Keyboard | Remote control |
---|---|---|
navigate the menus | arrow keys | up, down, left, right |
next widget | Tab | next_widget |
previous widget | Shift-Tab | prev_widget |
(de)select items in a list | Space | select |
activate items or buttons | Enter | activate |
go back/ up one level | Esc, Backspace | back |
Direct Menu Access
Action | Keyboard | Remote control |
---|---|---|
show the help menu | F1 | menu_help |
show the settings menu | F2 | menu_settings |
show the playback menu | F3 | menu_playback |
start television playback | F4 | television |
show the main menu | F5 | menu_main |
show the music menu | F6 | menu_music |
show the video menu | F7 | menu_video |
show the image menu | F8 | menu_image |
show the playlist menu | F9 | menu_playlist |
show the weather menu | F10 | menu_weather |
Miscellaneous
Action | Keyboard | Remote control |
---|---|---|
leave the program | Ctrl + q | quit |
show the shutdown dialog | q | shutdown |
eject a removable volume | e | eject |
save configuration/ playlist | Ctrl + s | save |
toggle fullscreen mode | f | toggle_fullscreen |
show/ hide onscreen display | o | show_osd |
Playback Control
Action | Keyboard | Remote control |
---|---|---|
adjust volume | v / V, + / - | volume [+/-] |
seek in stream | Ctrl + Alt + arrow right/ left |
skip [+/-] |
adjust speed | Ctrl + arrow up/ down |
speed [+/-] |
fast forward/ rewind | Ctrl + arrow right/ left |
fast_forward/ fast_rewind |
stop | s | stop |
toggle mute/ unmute | m | toggle_mute |
toggle pause/ play | Space | toggle_pause_play |
toggle playmode | M | toggle_playmode |
toggle aspect ratio | a | toggle_aspect_ratio |
toggle deinterlace | i | toggle_deinterlace |
change audio channel | x / X | audio_channel [+/-] |
adjust audio offset | c / C | audio_offset [+/-] |
change subtitle channel | r / R | spu_channel [+/-] |
adjust subtitle offset | t / T | spu_offset [+/-] |
adjust zoom factor | Z / z | zoom [+/-] |
adjust x-zoom factor | Ctrl + Z / z | zoom_x [+/-] |
adjust y-zoom factor | Alt + Z / z | zoom_y [+/-] |
reset zoom factor | Ctrl + Alt + Z / z | zoom_reset |
Playlist
Action | Keyboard | Remote control |
---|---|---|
previous entry | Ctrl + page up | prev |
next entry | Ctrl + page down | next |
Images
Action | Keyboard | Remote control |
---|---|---|
previous image | Ctrl + page up | prev |
next image | Ctrl + page down | next |
rotate clockwise | Ctrl + r | rotate_right |
rotate clockwise | Ctrl + F5 | red |
rotate counter-clockwise | Ctrl + l | rotate_left |
rotate counter-clockwise | Ctrl + F8 | blue |
DVD
Action | Keyboard | Remote control |
---|---|---|
previous chapter | Ctrl + page up | prev |
next chapter | Ctrl + page down | next |
escape from the menu | Ctrl + F1 | menu1 |
go to the title menu | Ctrl + F2 | menu2 |
go to the root menu | Ctrl + F3 | menu3 |
go to the subtitle menu | Ctrl + F4 | menu4 |
go to the audio menu | Ctrl + F5 | menu5 |
go to the angle menu | Ctrl + F6 | menu6 |
go to the chapter menu | Ctrl + F7 | menu7 |
Television
Action | Keyboard | Remote control |
---|---|---|
previous channel | Ctrl + page up | prev |
next channel | Ctrl + page down | next |
Video Disc Recorder
Action | Keyboard | Remote control |
---|---|---|
previous channel | Ctrl + page up | prev |
next channel | Ctrl + page down | next |
show main menu | Ctrl + F1 | menu1 |
show channel menu | Ctrl + F2 | menu2 |
show schedule menu | Ctrl + F3 | menu3 |
show recordings menu | Ctrl + F4 | menu4 |
depends on the location (see OSD) | Ctrl + F5 | red |
depends on the location (see OSD) | Ctrl + F6 | green |
depends on the location (see OSD) | Ctrl + F7 | yellow |
depends on the location (see OSD) | Ctrl + F8 | blue |
Problems
If you have trouble doing something with oxine please try to do the same thing with xine before reporting it as a bug. If it doesn't work in xine it will normally not work in oxine. This is not true the other way around as many things implemented in xine have not been added to oxine yet.
If you do find a bug please report it to the issue tracker, send a mail to the oxine-devel mailing list or directly to one of the developers. Good patches are very welcome.