1
0
Fork 0
dockapps/wmcdplay/ARTWORK

255 lines
8.6 KiB
Text

wmcdplay - A cd player designed for WindowMaker
Copyright (C) 1998 Sam Hawker <shawkie@geocities.com>
This software comes with ABSOLUTELY NO WARRANTY
This software is free software, and you are welcome to redistribute it
under certain conditions
See the README file for a more complete notice.
ARTWORK
=======
The artwork mechanism allows you to customise the appearance (and more) of
wmcdplay at run-time, by loading an artwork file with the "-f artwork_file"
command line argument - yes, THIS IS A CHANGE!!!!! IT USED TO BE "-a"
----------------------------------------
This file trys to explain how to create artwork files. Please feel free to send
me comments or improved versions.
BASICS
======
wmcdplay can be in any one of 6 states:
Data 0
Stopped 1
Playing 2
Paused 3
NoCD 4
TrayOpen 5
wmcdplay buttons can perform any of 10 actions, and the action can
depend on the current state of wmcdplay:
NOTHING 0
Stop 1
Play 2
Pause 3
Resume 4
Prev 5
Next 6
Rewd 7
FFwd 8
Eject 9
Close 10
PIXMAPS
=======
The following symbolic color names may be used in any pixmaps:
led_color_high
led_color_med
led_color_low
color_back
and should be used appropriately to ensure that the led and background
colors can be set at runtime with the "-l led_color" and "-back_color"
command line arguments
led.xpm
-------
This pixmap is used by wmcdplay to draw the digits of the time and
track displays
It represents the string of characters: "00112233445566778899 DDAATTNNOOCC--PPEE:;_"
"00" means the character "0" but states that it is double width (eg 7+1 pixels wide)
":" means the character ":" which is only single width (eg 3+1 pixels wide)
";" means an unlit ":" single width character
"_" means a single width "-" character
The digit size used does not matter, but ensure that 1 pixel spaces are left between
digits and that (double width + 1 space) = 2 * (single width + 1 space)
eg. ( 7 + 1 ) = 2 * ( 3 + 1 )
Transparency is _NOT_ interpreted
This file must begin with these 2 lines (character perfect):
/* XPM */
static const char * led_xpm[] = {
ledsym.xpm
----------
This pixmap is used by wmcdplay to draw the symbols illustrating the current status
It should contain symbols for the following (in sequence):
Data, Stopped, Playing, Paused, NoCD, TrayOpen
The symbol size used does not matter, but ensure that 1 pixel spaces are left between
symbols
Transparency is _NOT_ interpreted
This file must begin with these 2 lines (character perfect):
/* XPM */
static const char * ledsym_xpm[] = {
ledtsel.xpm
-----------
This pixmap is used by wmcdplay to draw the symbols illustrating the current track
selection mode
It should contain symbols for the following (in sequence):
None, Next, Repeat, RepeatCD, Random
The symbol size used does not matter, but ensure that 1 pixel spaces are left between
symbols
Transparency is _NOT_ interpreted
This file must begin with these 2 lines (character perfect):
/* XPM */
static const char * ledtsel_xpm[] = {
symbols.xpm
-----------
This pixmap contains the symbols to be drawn onto the buttons
It should contain symbols for the following (in sequence):
NOTHING, Stop, Play, Pause, Resume, Prev, Next, Rewd, FFwd, Eject, Close
The symbol size used does not matter, but ensure that 1 pixel spaces are left between
symbols
Transparency _IS_ interpreted
This file must begin with these 2 lines (character perfect):
/* XPM */
static const char * symbols_xpm[] = {
cdplayer.xpm
------------
This pixmap provides the basic background for wmcdplay
It _must_ be 64x64 pixels
It should provide solid areas (the size and color of which will depend on the
led.xpm, ledsym.xpm and ledtsel.xpm files used), for any required displays to
be drawn onto
These areas are usually bordered in some way
It can also be used to provide solid areas which can form buttons
(Although the button symbols can themselves form the buttons)
Transparency _IS_ interpreted
This file must begin with these 2 lines (character perfect):
/* XPM */
static const char * cdplayer_xpm[] = {
THE DATA FILE - artwork.dat
===========================
So far, all we have in our artwork file is a set of pixmaps. But we also
need a data file (artwork.dat), to answer the following questions:
How many buttons are there?
Where exactly is each button?
What does each button do?
Should do-NOTHING buttons be hidden?
Which led displays are there?
Where are they?
The formats of entries in this file must follow the examples given quite closely.
Basically, anything before an '=' must appear exactly as shown and at the
beginning of the line (not indented as here). Also, all entries must be on a single
line unless shown otherwise here.
Comments and blank lines are, however, perfectly legal (between entries).
How many buttons?
-----------------
eg.
int art_nbtns=5;
Where exactly is each button?
-----------------------------
Buttons must be shaped as convex polygons, so you give the position
(and shape) of each as a list of coordinates of its verticies.
The polygon defined by these points is used to interpret mouse clicks,
and also (optionally) to hide do-NOTHING buttons.
Also, tell wmcdplay where on the button to put the symbol. This is in the
form of the co-ordinates of the top-left corner of the symbol, relative
to the top-left corner of wmcdplay.
A single entry, defines all buttons.
eg.
int art_btns[]={ 8 , 38 , 5 , 5 , 27 , 7 , 27 , 20 , 40 , 7 , 54 , 5 , 54 ,
19 , 26 , 5 , 6 , 22 , 28 , 22 , 28 , 39 , 22 , 39 , 6 , 24 ,
19 , 50 , 5 , 6 , 57 , 21 , 42 , 28 , 42 , 28 , 59 , 6 , 59 ,
35 , 26 , 5 , 31 , 22 , 52 , 22 , 52 , 24 , 37 , 39 , 31 , 39 ,
51 , 31 , 5 , 42 , 36 , 56 , 22 , 59 , 22 , 59 , 39 , 42 , 39 };
Each line defines 1 button:
symbol_x , symbol_y , num_vertices , x1 , y1 , x2 , y2 , x3 , y3 , x4 , y4 , x5 , y5
Different buttons may have different numbers of vertices, so different numbers of fields.
The button must be a _convex_ polygon, and the vertices must be given in sequence, going
_clockwise_ around the button.
What does each button do?
-------------------------
This is answered with a set of integer actions (see list given earlier) for each button,
for each state (see list given earlier):
wmcdplay state: 0 1 2 3 4 5
D S P P N T
A T L A O R
T O A U A
A P Y S C Y
P I E D
T E N D O
R D G P
K E
N
eg.
int art_actions[]={ 0 , 2 , 3 , 4 , 0 , 0 ,
5 , 5 , 5 , 0 , 0 , 0 ,
6 , 6 , 6 , 0 , 0 , 0 ,
0 , 0 , 1 , 1 , 0 , 0 ,
9 , 9 , 9 , 9 , 9 , 10 };
Should do-NOTHING buttons be hidden?
------------------------------------
This can be set so that whenever a button has NOTHING assigned to it, it is hidden
(using the region defined by style_btns). Otherwise it is left and the symbol
representing NOTHING is drawn onto it.
eg.
bool art_hidebtns=false;
Which led displays are there?
-----------------------------
eg.
bool style_leds[4]={ true, true, false, false};
That's basically:
show_time=true , show_track=true , show_status=false , show_trksel=false
Where are they?
---------------
eg.
int art_ledpos[3][2]={ 8 , 7 , 37 , 45 , 0 , 0 , 0 , 0 };
That's basically:
time_x=8 , time_y=7 , track_x=37 , track_y=45 , status_x=0 , status_y=0 , trksel_x=0 , trksel_y=0
These are the co-ordinates of the top-left corner of each display
relative to the top-left corner of wmcdplay.
You should enter valid integers even for displays which you have
chosen not to use.
ARTWORK FILES
=============
All the above files should be placed in an appropriately named directory and the
"makeart" script (installed by default in /usr/local/share/wmcdplay) should be
executed in the parent directory. You should end up with a new .art file. You
should be able to load wmcdplay with this artwork using the "-f artwork_file"
command line argument.
You should also be able to make your new artwork the compile-time default by
using the "--with-art" option to the "configure" script.