L'objectif de ce document est de décrire le format de skins de MPlayer.
Les informations présentées ici peuvent s'avérer fausses, du fait que <em>a)</em> ce n'est pas moi qui ait écrit la GUI, <em>b)</em> cette GUI n'est pas terminée, <em>c)</em> je peux me tromper. Ne soyez donc pas surpris si quelque chose ne correspond pas à cette description.
<p>
Merci à<em>Zoltán Ponekker</em> pour son aide.
Ce n'est pas en rapport direct avec le format des skins, mais vous devez savoir que <em>MPlayer n'a <b>pas</b> de skin par défaut, donc <b>une skin au moins doit être installée pour pouvoir utiliser la GUI.</b></em>
MPlayer cherche des skins dans ces répertoires (dans cet ordre):
<pre>
/usr/local/share/mplayer/Skin/
~/.mplayer/Skin/
</pre>
<p>
Notez que le premier répertoire peut varier suivant la façon dont MPlayer a été configuré
(c.f. l'argument <code>--datadir</code> du script <code>configure</code>).
<p>
Chaque skin est installée dans son propre répertoire sous l'un des répertoires listés ci-dessus, par exemple:
<pre>
/usr/local/share/mplayer/Skin/default/
</pre>
<h3><aname="images">2.2 Format d'images</a></h3>
Les images doivent être en truecolor (24 ou 32 bpp) et enregistrées au format
BMP, PNG ou TGA (sans compression pour les images TGA).
<em>le format par excellence reste le PNG, qui assure un très bon taux de compression.</em>
<p>
Dans la fenêtre principale (c.f. ci-dessous) vous pouvez utiliser des images dotées de régions "transparentes" :
les régions remplies avec la couleur #FF00FF (<fontcolor="#FF00FF">magenta</font>)
deviennent transparentes dans MPlayer. De même, vous pouvez obtenir des formes particulières pour vos fenêtres si votre serveur X possède l'extension XShape.
<h3><aname="parts">2.3 Parties d'une skin</a></h3>
Les skins sont d'un format plutôt libre (contrairement aux formats fixes de
Winamp/XMMS, par exemple), donc il ne tient qu'a vous de créer quelque chose de bien.
<p>
Actuellement, trois fenêtres doivent être décorées : la
<ahref="#mainwin">fenêtre principale</a>, la <ahref="#subwindow">sous-fenêtre</a> et
le <ahref="#skinmenu">menu</a> (activable par un clic droit).
<ul>
<li>
Vous controlez MPlayer par la <b>fenêtre principale</b>. L'arrière plan en est une image.
Divers objets doivent venir se placer dans cette fenêtre : <em>boutons</em>, <em>podomètres</em> (ou des sliders si vous préferez) et des <em>labels</em>. Pour chaque objet, vous devez spécifier sa taille et sa position.
<p>
Un <b>bouton</b> comprend trois états (pressé, relaché,
désactivé), donc l'image doit se diviser en trois parties, verticalement.
c.f. l'objet <ahref="#main.button">bouton</a> pour plus de détails.
<p>
Un <b>podomètre</b> (principalement utilisé pour la barre d'avancement et le contrôle du volume/balance) peut posséder n'importe quel nombre d'états en empilant ces images, verticalement.
C.f. <ahref="#main.hpotmeter">hpotmeter</a> et
<ahref="#main.potmeter">potmeter</a> pour plus de détails.
<p>
Les <b>labels</b> sont un peut particuliers : les caractères nécessaires pour les dessiner sont récupérés depuis un fichier image, décrit par un <ahref="#fonts">fichier de description de polices</a>.
Ce dernier est un fichier texte brut spécifiant la position x,y ainsi que la taille de chaque caractère dans l'image. (donc le fichier image et son descripteur forment une police <em>ensemble</em>.)
C.f. <ahref="#main.dlabel">dlabel</a> et <ahref="#main.slabel">slabel</a>
pour plus de détails.
<p>
<emclass=note>
<b>Note:</b> toutes les images diposent de la couleur de transparence décrite dans
la section <ahref="#images">formats d'images</a>.
</em>
</li>
<li>
La <b>sous-fenêtre</b> contient la vidéo en elle même. Elle peut affichier une image si aucun film n'est chargé (ce n'est jamais plaisant d'avoir une fenêtre vide :-))
<emclass=note><b>Note:</b> la couleur de transparence n'est <b>pas</b> autorisée ici</em>
</li>
<li>
Le <b>menu</b> est simplement un moyen de controler MPlayer par des entrées graphiques.
Deux images sont nécessaires pour le menu : l'une d'elle, l'image de base, affiche le menu dans son été normal, l'autre est utilisée pour afficher les entrées sélectionnées.
Quand vous faites apparaitre le menu, la première image s'affiche.
Si vous passez la souris sur les entrées du menu, l'entrée sélectionnée est copiée depuis la seconde image, et uniquement la partie concernée par cette sélection
(Donc la seconde image ne s'affiche jamais complètement.)
<p>
Une entrée de menu se définit par sa position et sa taille dans l'image (c.f. la section
<ahref="#skinmenu">menu</a> pour plus de détails).
</li>
</ul>
<p>
Une chose essentielle n'a pas encore été mentionnée : pour que les boutons podomètres et entrées du menu fonctionnent, MPlayer doit savoir quoi en faire. Ceci dépend des
<ahref="#guimsg">messages</a> (events) envoyés. Pour chaque objet vous devez définir une action a réaliser.
Vous aurez besoin des fichiers suivants pour construire une skin.
<ul>
<li>
Le fichier de configuration nommé<ahref="#skin">skin</a> indique à MPlayer comment assembler les différentes images et comment interpréter les clics de souris sur l'interface.
</li>
<li>L'image de fond de la fenêtre principale.</li>
<li>Les images correspondant aux objets de la fenêtre principale (y compris une ou plusieurs polices et descripteurs nécessaires à l'affichage des textes).</li>
<li>L'image affichée dans la sous-fenêtre (optionnel).</li>
<li>Deux images pour le menu (nécessaires uniquement si vous voulez créer un menu).
</ul>
A l'exception du fichier de configuration, vous pouvez nommer les fichiers comme bon vous semble (mais notez que les descripteurs de polices doivent avoir une extension .fnt)
<h2><aname="skin">3 Le fichier <code><b>skin</b></code></a></h2>
<p>
Il est lu ligne par ligne; les lignes de commentaire démarrent par le caractère '<code>;</code>' en début de ligne (seuls les espace et tabulations sont autorisées avant ce signe).
<p>
Les fichiers se composent de sections. Chaque section décrit la skin pour une application et s'écrit sous la forme :
Quelques précisions sur l'appel des images dans la configuration.
<br>
Le nom d'un fichier image doit être donné sans distinction de répertoire ---
les images seront cherchées dans le même répertoire que le fichier de configuration. Vous pouvez (mais ce n'est pas obligatoire)
spécifier l'extension du fichier. Si le fichier n'existe pas, MPlayer essaie de charger le fichier <i><filename>.<ext></i>, ou <i><ext></i> sera respectivement <i>tga</i>,<i>TGA</i>, <i>bmp</i>, <i>BMP</i>, <i>png</i> et <i>PNG</i> dans cet ordre. La première correspondance trouvée sera utilisée.
Vous spécifiez ici l'image de fond utilisée dans la fenêtre principale.
La fenêtre apparaitra a la position <i>x</i>,<i>y</i>
sur l'ecran (0,0 est le coin supérieur gauche). Vous pouvez spécifier -1 pour le centre
et -2 pour droite (x) et bas (y). La fenêtre prendra la taille de l'image.
<p>
<emclass=warn>
<b>Attention :</b> les régions transparentes (couleur #FF00FF) apparaitront en noir
sur les serveurs X n'ayant pas l'extension XShape.
</em>
</dd>
</dl>
<dl>
<dt><aname="main.button">
<b>button = <i>image, x, y, largeur, hauteur, message</i></b></a></dt>
<dd>
Place un bouton de taille <i>largeur</i> * <i>hauteur</i> a la position
<i>x</i>,<i>y</i>. Le message sera généré au clic sur ce bouton.
L'image appellée par <i>image</i> doit avoir trois états empilés verticalement
(pour les trois états du bouton), comme ceci:
<divalign=center><table><tr><td><pre><small>
+--------+
| pressé |
+--------+
| relaché |
+--------+
| désactivé |
+--------+
</small></pre></td></tr></table></div>
</dd>
</dl>
<dl>
<dt><aname="main.decoration">
<b>decoration = enable|disable</b>
</a></dt>
<dd>
Active ou désactive la décoration du gestionnaire de fenêtre pour la fenêtre principale. <b>Désactivé</b> par défaut.
Place un podomètre horizontal de taille <i>w</i> * <i>h</i> a la position
<i>x</i>,<i>y</i>. L'image peut être divisée en différentes parties pour les différentes phases du podomètre (par exemple,
vous pouvez en avoir un pour le contrôle du volume qui passe du vert au rouge
quand sa valeur passe du minimum au maximum.)
hpotmeter peut posséder un bouton qui sera glissé horizontalement.
Les paramètres sont :
<ul>
<li><i>butt</i> - l'image utilisée pour le bouton
(doit avoir trois états superposés, comme pour les
<ahref="#main.button">boutons</a>)</li>
<li><i>bw</i>, <i>bh</i> - taille du bouton</li>
<li><i>phases</i> - L'image utilisée pour les différentes phases du podomètre.
L'image doit être divisée en <i>numphases</i> parties verticalement
(c.f. ci-dessous). Une valeur <kbd>NULL</kbd> spéciale peut-être utilisée si vous ne voulez pas d'image.
</li>
<li><i>numphases</i> - nombre d'états placés dans l'image.</li>
<li><i>default</i> - valeur par défaut du podomètre (dans un intervalle de 0 a
100)</li>
<li><i>x</i>, <i>y</i> - position pour le podomètre</li>
<li><i>w</i>, <i>h</i> - largeur et hauteur du podomètre</li>
<li><i>msg</i> - le message généré lors des changements d'état du podomètre</li>
</ul>
L'image utilisée pour les différents états doit correspondre a ceci :
<td>numéro de piste (dans la playlist)</td></tr>
<tr><tdalign=center><kbd>$o</kbd></td>
<td>nom du fichier</td></tr>
<tr><tdalign=center><kbd>$f</kbd></td>
<td>nom du fichier en minuscule</td></tr>
<tr><tdalign=center><kbd>$F</kbd></td>
<td>nom du fichier en majuscule</td></tr>
<tr><tdalign=center><kbd>$T</kbd></td>
<td>un caractère dépendant du type de flux (fichier: <code>f</code>,
video CD: <code>v</code>, DVD: <code>d</code>, URL: <code>u</code>)
</td></tr>
<tr><tdalign=center><kbd>$p</kbd></td>
<td>le caractère "p" (si une vidéo est en lecture et que la police a le caractère "p")
</td></tr>
<tr><tdalign=center><kbd>$s</kbd></td>
<td>le caractère "s" (si une vidéo est stoppée et que la police a le caractère "s")
</td></tr>
<tr><tdalign=center><kbd>$e</kbd></td>
<td>le caractère "e" (si une vidéo est en pause et que la police a le caractère "e")
</td></tr>
</table></div>
<p>
<b>Note:</b> les variables <kbd>$a</kbd>, <kbd>$T</kbd>, <kbd>$p</kbd>, <kbd>$s</kbd>
et <kbd>$e</kbd>retournent toutres des caractères pouvant s'afficher comme des symboles spéciaux (par exemple, "e" est le symbole de pause qui ressemble généralement à<code>||</code>). Vous pouvez avoir une police pour les saractères normaux et une autre pour les symboles.
Lisez la section sur les <ahref="#symbols">symboles</a> pour plus d'informations.
</dd>
</dl>
<dl>
<dt><aname="main.slabel">
<b>slabel = <i>x, y, fontid, text</i></b>
</a></dt>
<dd>
Place un label statique à la position <i>x</i>,<i>y</i>.
<i>text</i> s'affiche en utilisant la police spécifiée par <i>fontid</i>.
Le texte est seulement du texte brut (les variables $x ne fonctionnent pas) et doit être enfermé entre des guillements doubles (le caractère <code>"</code> ne doit pas faire partie du texte).
<b>base = <i>image, x, y, largeur, hauteur</i></b>
</a></dt>
<dd>
L'image qui s'affichera dans la fenêtre.
La fenêtre apparaîtra à la position <i>x</i>,<i>y</i>
sur l'écran (0,0 est le coin supérieur gauche). Vous pouvez spécifier -1 pour centre
et -2 pour droite. La fenêtre prendra la taille de l'image.
<i>largeur</i> et <i>hauteur</i> donnent la taille de la fenêtre; ces paramètres sont optionnels (si ils sont absents, le fenêtre prend la taille de l'image).
</dd>
</dl>
<dl>
<dt><aname="sub.background">
<b>background = <i>r, g, b</i></b>
</a></dt>
<dd>
Vous permet de définir la couleur de fond. Utile si l'image est plus petite que la fenêtre.
<i>r</i>, <i>g</i> et <i>b</i> spécifient les composantes rouge, verte et bleue de la couleur (d'une intervalle entre 0 et 255).
</dd>
</dl>
<h3><aname="skinmenu">3.3 Menu</a></h3>
Comme mentionné précédemment, le menu s'affiche en utilisant deux images.
Les entrées normales du menu sont extraitres de l'image spécifiée par l'objet <i>base</i>,
tandis que l'entrée actuellement sélectionnée est extraite de l'image spécifiée par l'objet <i>selected</i>.
Vous devez définir la taille et la position de chaque entrée du menu par l'objet <i>menu</i>.
<p>
Ils correspondent aux objets utilisés dans le bloc '<code>window = menu</code>'
. . . '<code>end</code>'.
<dl>
<dt><aname="menu.base">
<b>base = <i>image</i></b>
</a></dt>
<dd>
L'image utilisée pour les entrées normales.
</dl>
</dd>
<dl>
<dt><aname="menu.selected">
<b>selected = <i>image</i></b>
</a></dt>
<dd>
L'image utilisée pour les entrées selectionnées.
</dd>
</dl>
<dl>
<dt><aname="menu.menu">
<b>menu = <i>x, y, largeur, hauteur, message</i></b>
</a></dt>
<dd>
Définit la position <i>x</i>,<i>y</i> et la taille des entrées du menu dans les images. <i>message</i> est le message généré quand le bouton de la souris est relaché sur l'entrée..
</dd>
</dl>
<h2><aname="fonts">4 Polices</a></h2>
Comme mentionné dans la section sur les parties de la skin, une police est définie par une image et un fichier de description.
Vous pouvez placer les caractères n'importe ou sur l'image, mais vous devez vous assurer que leur position et taille correspondent précisément au fichier de description..
<p>
Les fichier descriptif des polices (avec l'extension .fnt) peut avoir des lignes de commentaires commençant par '<code>;</code>'.
Le fichier doit avoir une ligne du type
<blockquote>
<pre>
image = <i>image</i>
</pre>
</blockquote>
<p>
où<i>image</i> est le nom de l'image qui sera utilisée pour la police
(vous n'avez pas à définir d'extension).
Cette ligne est suivie par une définition de caractère du type :
<blockquote>
<pre>
"<i>char</i>" = <i>x, y, w, h</i>
</pre>
</blockquote>
<p>
Ici <i>x</i> et <i>y</i> précisent la position du caractère
<i>char</i> dans l'image (0,0 est le coin supérieur gauche).
<i>w</i> et <i>h</i> sont la largeur et la hauteur du caractère
(en pixels, bien sûr).
<p>
Voici un exemple définissant les caractères A, B, C utilisant la police font.png.
<tdalign=left>lecture depuis un video CD</td></tr>
<tr><tdalign=center><kbd>d</kbd></td>
<tdalign=left>lecture depuis un DVD</td></tr>
<tr><tdalign=center><kbd>u</kbd></td>
<tdalign=left>lecture depuis une URL</td></tr>
</table>
</div>
<p>
<b>Note:</b> actuellement uniquement 'p', 's', 'e', 'n', 'm' et 't' sont utilisables.
</p>
<h2><aname="guimsg">Appendice A: messages de la GUI</a></h2>
Ce sont les messages qui peuvent être générés par les boutons, podomètres et
entrées du menu.
<p>
<emclass=note>
<b>Note:</b> certains messages peuvent ne pas fonctionner comme prévu (ou ne pas fonctionner du tout). Comme vous le savez, la GUI est en cours de développement.</em>
<p>
<i>Contrôle de lecture :</i>
<blockquote>
<dl>
<dt><b>evNext</b>
<dd>Saute à la prochaine piste dans la playlist.
<dt><b>evPause</b>
<dd>Pause.
<dt><b>evPauseSwitchToPlay</b>
<dd>Associéà la commande <i>evPlaySwitchToPause</i>. Ils s'utilisent pour avoir un bouton play/pause commun. Les deux messages peuvent être assignés
aux boutons affiches exactement à la même position dans la fenêtre. Ces
message mettent la lecture en pause et le bouton <i>evPlaySwitchToPause</i> s'affiche (pour indiquer que le bouton peut être pressé pour continuer la lecture).
<dt><b>evPlay</b>
<dd>Commence la lecture.
<dt><b>evPlaySwitchToPause</b>
<dd>Le contraire de <i>evPauseSwitchToPlay</i>. Ce message démarre la lecture
et l'image associée au bouton <i>evPauseSwitchToPlay</i> s'affiche (pour indiquer que le bouton peut être pressé pour mettre en pause la lecture).
<dt><b>evPrev</b>
<dd>Saute à la piste précedente dans la playlist.
<dt><b>evStop</b>
<dd>Stoppe la lecture.
</dl>
</blockquote>
<p>
<i>Avancée dans le flux:</i>
<blockquote>
<dl>
<dt><b>evBackward10sec</b>
<dt><b>evBackward1min</b>
<dt><b>evBackward10min</b>
<dd>Recule de 10 secondes / 1 minute / 10 minutes.
<dt><b>evForward10sec</b>
<dt><b>evForward1min</b>
<dt><b>evForward10min</b>
<dd>Avance de 10 secondes / 1 minute / 10 minutes.
<dt><b>evSetMoviePosition</b>
<dd>Se place à la position (utilisable avec un podomètre; utilise la valeur relative (0-100%) du podomètre).
</dl>
</blockquote>
<p>
<i>Contrôle vidéo :</i>
<blockquote>
<dl>
<dt><b>evDoubleSize</b>
<dd>Double la taille de la fenêtre vidéo.
<dt><b>evFullScreen</b>
<dd>Passe en mode plein écran.
<dt><b>evNormalSize</b>
<dd>Met la vidéo à sa taille réelle.
</dl>
</blockquote>
<p>
<i>Contôle audio :</i>
<blockquote>
<dl>
<dt><b>evDecAudioBufDelay</b>
<dd>Diminue le délai du buffer audio.
<dt><b>evDecBalance</b>
<dd>Diminue la balance.
<dt><b>evDecVolume</b>
<dd>Diminue le volume.
<dt><b>evIncAudioBufDelay</b>
<dd>Augmente le délai du buffer audio.
<dt><b>evIncBalance</b>
<dd>Augmente la balance.
<dt><b>evIncVolume</b>
<dd>Augmente le volume.
<dt><b>evMute</b>
<dd>Active/désactive le son.
<dt><b>evSetBalance</b>
<dd>Fixe la balance (utilisable avec un podomètre; utilise la valeur relative (0-100%) du podomètre).
<dt><b>evSetVolume</b>
<dd>Fixe le volume (utilisable avec un podomètre; utilise la valeur relative (0-100%) du podomètre).