Mercurial > mplayer.hg
annotate gui/win32/skinload.c @ 32173:2a28dda68bbc
swscale: factorize plane copying code out of 2 functions
author | ramiro |
---|---|
date | Thu, 16 Sep 2010 01:07:55 +0000 |
parents | 9e6fdede8ece |
children | 8fa2f43cb760 |
rev | line source |
---|---|
23077 | 1 /* |
23079 | 2 * MPlayer GUI for Win32 |
3 * Copyright (C) 2003 Sascha Sommer <saschasommer@freenet.de> | |
4 * Copyright (C) 2006 Erik Augustson <erik_27can@yahoo.com> | |
5 * Copyright (C) 2006 Gianluigi Tiesi <sherpya@netfarm.it> | |
6 * | |
7 * This file is part of MPlayer. | |
8 * | |
9 * MPlayer is free software; you can redistribute it and/or modify | |
10 * it under the terms of the GNU General Public License as published by | |
11 * the Free Software Foundation; either version 2 of the License, or | |
12 * (at your option) any later version. | |
13 * | |
14 * MPlayer is distributed in the hope that it will be useful, | |
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
17 * GNU General Public License for more details. | |
18 * | |
26457 | 19 * You should have received a copy of the GNU General Public License along |
20 * with MPlayer; if not, write to the Free Software Foundation, Inc., | |
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |
23079 | 22 */ |
23077 | 23 |
24 #include <stdlib.h> | |
23796 | 25 #include <stdio.h> |
23077 | 26 #include <inttypes.h> |
27 #include <windows.h> | |
28 | |
23091
52488bb09d90
Consistently use quotes instead of angled brackets in #include
diego
parents:
23079
diff
changeset
|
29 #include "mp_msg.h" |
52488bb09d90
Consistently use quotes instead of angled brackets in #include
diego
parents:
23079
diff
changeset
|
30 #include "cpudetect.h" |
52488bb09d90
Consistently use quotes instead of angled brackets in #include
diego
parents:
23079
diff
changeset
|
31 #include "libswscale/swscale.h" |
32028
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
32 #include "libavcore/imgutils.h" |
23077 | 33 #include "gui.h" |
26372
76413880bfad
Update include paths to account for build system changes.
diego
parents:
23796
diff
changeset
|
34 #include "gui/bitmap.h" |
23077 | 35 |
36 #define MAX_LINESIZE 256 | |
37 | |
38 typedef struct | |
39 { | |
40 int msg; | |
41 char *name; | |
42 } evName; | |
43 | |
44 static const evName evNames[] = | |
45 { | |
46 { evNone, "evNone" }, | |
47 { evPlay, "evPlay" }, | |
48 { evDropFile, "evDropFile" }, | |
49 { evStop, "evStop" }, | |
50 { evPause, "evPause" }, | |
51 { evPrev, "evPrev" }, | |
52 { evNext, "evNext" }, | |
53 { evLoad, "evLoad" }, | |
54 { evEqualizer, "evEqualizer" }, | |
55 { evEqualizer, "evEqualeaser" }, | |
56 { evPlayList, "evPlaylist" }, | |
57 { evExit, "evExit" }, | |
58 { evIconify, "evIconify" }, | |
59 { evIncBalance, "evIncBalance" }, | |
60 { evDecBalance, "evDecBalance" }, | |
61 { evFullScreen, "evFullScreen" }, | |
62 { evFName, "evFName" }, | |
63 { evMovieTime, "evMovieTime" }, | |
64 { evAbout, "evAbout" }, | |
65 { evLoadPlay, "evLoadPlay" }, | |
66 { evPreferences, "evPreferences" }, | |
67 { evSkinBrowser, "evSkinBrowser" }, | |
68 { evBackward10sec, "evBackward10sec" }, | |
69 { evForward10sec, "evForward10sec" }, | |
70 { evBackward1min, "evBackward1min" }, | |
71 { evForward1min, "evForward1min" }, | |
72 { evBackward10min, "evBackward10min" }, | |
73 { evForward10min, "evForward10min" }, | |
74 { evIncVolume, "evIncVolume" }, | |
75 { evDecVolume, "evDecVolume" }, | |
76 { evMute, "evMute" }, | |
77 { evIncAudioBufDelay, "evIncAudioBufDelay" }, | |
78 { evDecAudioBufDelay, "evDecAudioBufDelay" }, | |
79 { evPlaySwitchToPause, "evPlaySwitchToPause" }, | |
80 { evPauseSwitchToPlay, "evPauseSwitchToPlay" }, | |
81 { evNormalSize, "evNormalSize" }, | |
82 { evDoubleSize, "evDoubleSize" }, | |
83 { evSetMoviePosition, "evSetMoviePosition" }, | |
84 { evSetVolume, "evSetVolume" }, | |
85 { evSetBalance, "evSetBalance" }, | |
86 { evHelp, "evHelp" }, | |
87 { evLoadSubtitle, "evLoadSubtitle" }, | |
88 { evPlayDVD, "evPlayDVD" }, | |
89 { evPlayVCD, "evPlayVCD" }, | |
90 { evSetURL, "evSetURL" }, | |
91 { evLoadAudioFile, "evLoadAudioFile" }, | |
92 { evDropSubtitle, "evDropSubtitle" }, | |
93 { evSetAspect, "evSetAspect" } | |
94 }; | |
95 | |
96 static const int evBoxs = sizeof(evNames) / sizeof(evName); | |
97 | |
98 static char *geteventname(int event) | |
99 { | |
100 int i; | |
101 for(i=0; i<evBoxs; i++) | |
102 if(evNames[i].msg == event) | |
103 return evNames[i].name; | |
104 return NULL; | |
105 } | |
106 | |
107 /* reads a complete image as is into image buffer */ | |
108 static image *pngRead(skin_t *skin, unsigned char *fname) | |
109 { | |
23266
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
110 int i; |
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
111 txSample bmp; |
23077 | 112 image *bf; |
23266
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
113 char *filename = NULL; |
23077 | 114 FILE *fp; |
115 | |
116 if(!stricmp(fname, "NULL")) return 0; | |
117 | |
118 /* find filename in order file file.png */ | |
119 if(!(fp = fopen(fname, "rb"))) | |
120 { | |
121 filename = calloc(1, strlen(skin->skindir) + strlen(fname) + 6); | |
122 sprintf(filename, "%s\\%s.png", skin->skindir, fname); | |
123 if(!(fp = fopen(filename, "rb"))) | |
124 { | |
125 mp_msg(MSGT_GPLAYER, MSGL_ERR, "[png] cannot find image %s\n", filename); | |
126 free(filename); | |
127 return 0; | |
128 } | |
129 } | |
23266
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
130 fclose(fp); |
23077 | 131 |
132 for (i=0; i < skin->imagecount; i++) | |
133 if(!strcmp(fname, skin->images[i]->name)) | |
134 { | |
135 #ifdef DEBUG | |
136 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[png] skinfile %s already exists\n", fname); | |
137 #endif | |
23266
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
138 free(filename); |
23077 | 139 return skin->images[i]; |
140 } | |
141 (skin->imagecount)++; | |
142 skin->images = realloc(skin->images, sizeof(image *) * skin->imagecount); | |
143 bf = skin->images[(skin->imagecount) - 1] = calloc(1, sizeof(image)); | |
144 bf->name = strdup(fname); | |
23266
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
145 bpRead(filename ? filename : fname, &bmp); |
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
146 free(filename); |
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
147 bf->width = bmp.Width; bf->height = bmp.Height; |
23077 | 148 |
149 #ifdef DEBUG | |
150 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[png] loaded image %s\n", fname); | |
151 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[png] size: %dx%d bits: %d\n", bf->width, bf->height, BPP); | |
152 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[png] imagesize: %u\n", imgsize); | |
153 #endif | |
154 | |
155 bf->size = bf->width * bf->height * skin->desktopbpp / 8; | |
23266
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
156 if (skin->desktopbpp == 32) |
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
157 bf->data = bmp.Image; |
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
158 else { |
32028
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
159 const uint8_t *src[4] = { bmp.Image, NULL, NULL, NULL}; |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
160 int src_stride[4] = { 4 * bmp.Width, 0, 0, 0 }; |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
161 uint8_t *dst[4] = { NULL, NULL, NULL, NULL }; |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
162 int dst_stride[4]; |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
163 enum PixelFormat out_pix_fmt; |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
164 struct SwsContext *sws; |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
165 if (skin->desktopbpp == 16) out_pix_fmt = PIX_FMT_RGB555; |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
166 else if (skin->desktopbpp == 24) out_pix_fmt = PIX_FMT_RGB24; |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
167 av_image_fill_linesizes(dst_stride, out_pix_fmt, bmp.Width); |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
168 sws = sws_getContext(bmp.Width, bmp.Height, PIX_FMT_RGB32, |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
169 bmp.Width, bmp.Height, out_pix_fmt, |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
170 SWS_POINT, NULL, NULL, NULL); |
23266
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
171 bf->data = malloc(bf->size); |
32028
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
172 dst[0] = bf->data; |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
173 sws_scale(sws, src, src_stride, 0, bmp.Height, dst, dst_stride); |
9e6fdede8ece
gui: remove direct usage of rgb2rgb interface, use swscale instead
ramiro
parents:
26457
diff
changeset
|
174 sws_freeContext(sws); |
23266
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
175 free(bmp.Image); |
6cd7f1c23d90
Reuse linux code for reading png images for windows Gui,
reimar
parents:
23091
diff
changeset
|
176 } |
23077 | 177 return bf; |
178 } | |
179 | |
180 /* frees all skin images */ | |
181 static void freeimages(skin_t *skin) | |
182 { | |
183 unsigned int i; | |
184 for (i=0; i<skin->imagecount; i++) | |
185 { | |
186 if(skin->images && skin->images[i]) | |
187 { | |
188 if(skin->images[i]->data) free(skin->images[i]->data); | |
189 if(skin->images[i]->name) free(skin->images[i]->name); | |
190 free(skin->images[i]); | |
191 } | |
192 } | |
193 free(skin->images); | |
194 } | |
195 | |
196 #ifdef DEBUG | |
197 void dumpwidgets(skin_t *skin) | |
198 { | |
199 unsigned int i; | |
200 for (i=0; i<skin->widgetcount; i++) | |
201 mp_msg(MSGT_GPLAYER, MSGL_V, "widget %p id %i\n", skin->widgets[i], skin->widgets[i]->id); | |
202 } | |
203 #endif | |
204 | |
205 static int counttonextchar(const char *s1, char c) | |
206 { | |
207 unsigned int i; | |
208 for (i=0; i<strlen(s1); i++) | |
209 if(s1[i] == c) return i; | |
210 return 0; | |
211 } | |
212 | |
213 static char *findnextstring(char *temp, const char *desc, int *base) | |
214 { | |
215 int len = counttonextchar(*base + desc, ','); | |
216 memset(temp, 0, strlen(desc) + 1); | |
217 if(!len) len = strlen(desc); | |
218 memcpy(temp, *base + desc, len); | |
219 *base += (len+1); | |
220 return temp; | |
221 } | |
222 | |
223 static void freeskin(skin_t *skin) | |
224 { | |
225 unsigned int i; | |
226 if(skin->skindir) | |
227 { | |
228 free(skin->skindir); | |
229 skin->skindir = NULL; | |
230 } | |
231 | |
232 for (i=1; i<=skin->lastusedid; i++) | |
233 skin->removewidget(skin, i); | |
234 | |
235 if(skin->widgets) | |
236 { | |
237 free(skin->widgets); | |
238 skin->widgets = NULL; | |
239 } | |
240 | |
241 freeimages(skin); | |
242 for(i=0; i<skin->windowcount; i++) | |
243 { | |
244 if(skin->windows[i]->name) | |
245 { | |
246 free(skin->windows[i]->name); | |
247 skin->windows[i]->name = NULL; | |
248 } | |
249 free(skin->windows[i]); | |
250 } | |
251 | |
252 free(skin->windows); | |
253 skin->windows = NULL; | |
254 | |
255 for (i=0; i<skin->fontcount; i++) | |
256 { | |
257 unsigned int x; | |
258 if(skin->fonts[i]->name) | |
259 { | |
260 free(skin->fonts[i]->name); | |
261 skin->fonts[i]->name = NULL; | |
262 } | |
263 | |
264 if(skin->fonts[i]->id) | |
265 { | |
266 free(skin->fonts[i]->id); | |
267 skin->fonts[i]->id = NULL; | |
268 } | |
269 | |
270 for (x=0; x<skin->fonts[i]->charcount; x++) | |
271 { | |
272 free(skin->fonts[i]->chars[x]); | |
273 skin->fonts[i]->chars[x] = NULL; | |
274 } | |
275 | |
276 if(skin->fonts[i]->chars) | |
277 { | |
278 free(skin->fonts[i]->chars); | |
279 skin->fonts[i]->chars = NULL; | |
280 } | |
281 | |
282 free(skin->fonts[i]); | |
283 skin->fonts[i] = NULL; | |
284 } | |
285 free(skin->fonts); | |
286 skin->fonts = NULL; | |
287 #ifdef DEBUG | |
288 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN FREE] skin freed\n"); | |
289 #endif | |
290 free(skin); | |
291 skin = NULL; | |
292 } | |
293 | |
294 static void removewidget(skin_t *skin, int id) | |
295 { | |
296 unsigned int i; | |
297 unsigned int pos=0; | |
298 widget **temp = calloc(skin->widgetcount - 1, sizeof(widget *)); | |
299 | |
300 for (i=0; i<skin->widgetcount; i++) | |
301 { | |
302 if(skin->widgets[i]->id == id) | |
303 { | |
304 if(skin->widgets[i]->label) | |
305 free(skin->widgets[i]->label); | |
306 free(skin->widgets[i]); | |
307 skin->widgets[i] = NULL; | |
308 } | |
309 else | |
310 { | |
311 temp[pos] = skin->widgets[i]; | |
312 pos++; | |
313 } | |
314 } | |
315 if (pos != i) | |
316 { | |
317 (skin->widgetcount)--; | |
318 free(skin->widgets); | |
319 skin->widgets = temp; | |
320 #ifdef DEBUG | |
321 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "removed widget %i\n", id); | |
322 #endif | |
323 return; | |
324 } | |
325 free(temp); | |
326 mp_msg(MSGT_GPLAYER, MSGL_ERR, "widget %i not found\n", id); | |
327 } | |
328 | |
329 static void addwidget(skin_t *skin, window *win, const char *desc) | |
330 { | |
331 widget *mywidget; | |
332 char *temp = calloc(1, strlen(desc) + 1); | |
333 (skin->widgetcount)++; | |
334 (skin->lastusedid)++; | |
335 skin->widgets = realloc(skin->widgets, sizeof(widget *) * skin->widgetcount); | |
336 mywidget = skin->widgets[(skin->widgetcount) - 1] = calloc(1, sizeof(widget)); | |
337 mywidget->id = skin->lastusedid; | |
338 mywidget->window = win->type; | |
339 /* parse and fill widget specific info */ | |
340 if(!strncmp(desc, "base", 4)) | |
341 { | |
342 int base = counttonextchar(desc, '=') + 1; | |
343 mywidget->type = tyBase; | |
344 mywidget->bitmap[0] = pngRead(skin, findnextstring(temp, desc, &base)); | |
345 mywidget->wx = mywidget->x = atoi(findnextstring(temp, desc, &base)); | |
346 mywidget->wy = mywidget->y = atoi(findnextstring(temp, desc, &base)); | |
347 mywidget->wwidth = mywidget->width = atoi(findnextstring(temp, desc, &base)); | |
348 mywidget->wheight = mywidget->height = atoi(findnextstring(temp, desc, &base)); | |
349 win->base = mywidget; | |
350 #ifdef DEBUG | |
351 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [ITEM] [BASE] %s %i %i %i %i\n", | |
352 (mywidget->bitmap[0]) ? mywidget->bitmap[0]->name : NULL, | |
353 mywidget->x, mywidget->y, mywidget->width, mywidget->height); | |
354 #endif | |
355 } | |
356 else if(!strncmp(desc, "button", 6)) | |
357 { | |
358 int base = counttonextchar(desc, '=') + 1; | |
359 int i; | |
360 mywidget->type = tyButton; | |
361 mywidget->bitmap[0] = pngRead(skin, findnextstring(temp, desc, &base)); | |
362 mywidget->wx = mywidget->x = atoi(findnextstring(temp, desc, &base)); | |
363 mywidget->wy = mywidget->y = atoi(findnextstring(temp, desc, &base)); | |
364 mywidget->wwidth = mywidget->width = atoi(findnextstring(temp, desc, &base)); | |
365 mywidget->wheight = mywidget->height = atoi(findnextstring(temp, desc, &base)); | |
366 findnextstring(temp, desc, &base); | |
367 | |
368 /* Assign corresponding event to the widget */ | |
369 mywidget->msg = evNone; | |
370 for (i=0; i<evBoxs; i++) | |
371 { | |
372 if(!strcmp(temp, evNames[i].name)) | |
373 { | |
374 mywidget->msg = evNames[i].msg; | |
375 break; | |
376 } | |
377 } | |
378 | |
379 #ifdef DEBUG | |
380 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [ITEM] [BUTTON] %s %i %i %i %i msg %i\n", | |
381 (mywidget->bitmap[0]) ? mywidget->bitmap[0]->name : NULL, | |
382 mywidget->x, mywidget->y, mywidget->width, mywidget->height, mywidget->msg); | |
383 #endif | |
384 } | |
385 else if(!strncmp(desc, "hpotmeter", 9) || !strncmp(desc, "vpotmeter", 9)) | |
386 { | |
387 int base = counttonextchar(desc, '=') + 1; | |
388 int i; | |
389 /* hpotmeter = button, bwidth, bheight, phases, numphases, default, X, Y, width, height, message */ | |
390 if(!strncmp(desc, "hpotmeter", 9)) mywidget->type = tyHpotmeter; | |
391 else mywidget->type = tyVpotmeter; | |
392 mywidget->bitmap[0] = pngRead(skin, findnextstring(temp, desc, &base)); | |
393 mywidget->width = atoi(findnextstring(temp, desc, &base)); | |
394 mywidget->height = atoi(findnextstring(temp, desc, &base)); | |
395 mywidget->bitmap[1] = pngRead(skin, findnextstring(temp, desc, &base)); | |
396 mywidget->phases = atoi(findnextstring(temp, desc, &base)); | |
397 mywidget->value = atof(findnextstring(temp, desc, &base)); | |
398 mywidget->x = mywidget->wx = atoi(findnextstring(temp, desc, &base)); | |
399 mywidget->y = mywidget->wy = atoi(findnextstring(temp, desc, &base)); | |
400 mywidget->wwidth = atoi(findnextstring(temp, desc, &base)); | |
401 mywidget->wheight = atoi(findnextstring(temp, desc, &base)); | |
402 findnextstring(temp, desc, &base); | |
403 mywidget->msg = evNone; | |
404 for (i=0; i<evBoxs; i++) | |
405 { | |
406 if(!strcmp(temp, evNames[i].name)) | |
407 { | |
408 mywidget->msg = evNames[i].msg; | |
409 break; | |
410 } | |
411 } | |
412 #ifdef DEBUG | |
413 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [ITEM] %s %s %i %i %s %i %f %i %i %i %i msg %i\n", | |
414 (mywidget->type == tyHpotmeter) ? "[HPOTMETER]" : "[VPOTMETER]", | |
415 (mywidget->bitmap[0]) ? mywidget->bitmap[0]->name : NULL, | |
416 mywidget->width, mywidget->height, | |
417 (mywidget->bitmap[1]) ? mywidget->bitmap[1]->name : NULL, | |
418 mywidget->phases, mywidget->value, | |
419 mywidget->wx, mywidget->wy, mywidget->wwidth, mywidget->wwidth, | |
420 mywidget->msg); | |
421 #endif | |
422 } | |
423 else if(!strncmp(desc, "potmeter", 8)) | |
424 { | |
425 int base = counttonextchar(desc, '=') + 1; | |
426 int i; | |
427 /* potmeter = phases, numphases, default, X, Y, width, height, message */ | |
428 mywidget->type = tyPotmeter; | |
429 mywidget->bitmap[0] = pngRead(skin, findnextstring(temp, desc, &base)); | |
430 mywidget->phases = atoi(findnextstring(temp, desc, &base)); | |
431 mywidget->value = atof(findnextstring(temp, desc, &base)); | |
432 mywidget->wx = mywidget->x = atoi(findnextstring(temp, desc, &base)); | |
433 mywidget->wy = mywidget->y = atoi(findnextstring(temp, desc, &base)); | |
434 mywidget->wwidth = mywidget->width = atoi(findnextstring(temp, desc, &base)); | |
435 mywidget->wheight = mywidget->height = atoi(findnextstring(temp, desc, &base)); | |
436 findnextstring(temp, desc, &base); | |
437 mywidget->msg = evNone; | |
438 for (i=0; i<evBoxs; i++) | |
439 { | |
440 if(!strcmp(temp, evNames[i].name)) | |
441 { | |
442 mywidget->msg=evNames[i].msg; | |
443 break; | |
444 } | |
445 } | |
446 #ifdef DEBUG | |
447 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [ITEM] [POTMETER] %s %i %i %i %f %i %i msg %i\n", | |
448 (mywidget->bitmap[0]) ? mywidget->bitmap[0]->name : NULL, | |
449 mywidget->width, mywidget->height, | |
450 mywidget->phases, mywidget->value, | |
451 mywidget->x, mywidget->y, | |
452 mywidget->msg); | |
453 #endif | |
454 } | |
455 else if(!strncmp(desc, "menu", 4)) | |
456 { | |
457 int base = counttonextchar(desc, '=') + 1; | |
458 int i; | |
459 mywidget->type = tyMenu; | |
460 mywidget->wx=atoi(findnextstring(temp, desc, &base)); | |
461 mywidget->x=0; | |
462 mywidget->wy=mywidget->y=atoi(findnextstring(temp, desc, &base)); | |
463 mywidget->wwidth=mywidget->width=atoi(findnextstring(temp, desc, &base)); | |
464 mywidget->wheight=mywidget->height=atoi(findnextstring(temp, desc, &base)); | |
465 findnextstring(temp, desc, &base); | |
466 mywidget->msg = evNone; | |
467 for (i=0; i<evBoxs; i++) | |
468 { | |
469 if(!strcmp(temp, evNames[i].name)) | |
470 { | |
471 mywidget->msg = evNames[i].msg; | |
472 break; | |
473 } | |
474 } | |
475 #ifdef DEBUG | |
476 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [ITEM] [MENU] %i %i %i %i msg %i\n", | |
477 mywidget->x, mywidget->y, mywidget->width, mywidget->height, mywidget->msg); | |
478 #endif | |
479 } | |
480 else if(!strncmp(desc, "selected", 8)) | |
481 { | |
482 win->base->bitmap[1] = pngRead(skin, (char *) desc + 9); | |
483 #ifdef DEBUG | |
484 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [ITEM] [BASE] added image %s\n", win->base->bitmap[1]->name); | |
485 #endif | |
486 } | |
487 else if(!strncmp(desc, "slabel",6)) | |
488 { | |
489 int base = counttonextchar(desc, '=') + 1; | |
490 unsigned int i; | |
491 mywidget->type = tySlabel; | |
492 mywidget->wx = mywidget->x = atoi(findnextstring(temp, desc, &base)); | |
493 mywidget->wy = mywidget->y = atoi(findnextstring(temp, desc, &base)); | |
494 findnextstring(temp, desc, &base); | |
495 mywidget->font = NULL; | |
496 for (i=0; i<skin->fontcount; i++) | |
497 { | |
498 if(!strcmp(temp, skin->fonts[i]->name)) | |
499 { | |
500 mywidget->font = skin->fonts[i]; | |
501 break; | |
502 } | |
503 } | |
504 mywidget->label = strdup(findnextstring(temp, desc, &base)); | |
505 #ifdef DEBUG | |
506 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [ITEM] [SLABEL] %i %i %s %s\n", | |
507 mywidget->x, mywidget->y, mywidget->font->name, mywidget->label); | |
508 #endif | |
509 } | |
510 else if(!strncmp(desc, "dlabel", 6)) | |
511 { | |
512 int base = counttonextchar(desc, '=') + 1; | |
513 unsigned int i; | |
514 mywidget->type = tyDlabel; | |
515 mywidget->wx = mywidget->x = atoi(findnextstring(temp, desc, &base)); | |
516 mywidget->wy = mywidget->y = atoi(findnextstring(temp, desc, &base)); | |
517 mywidget->length = atoi(findnextstring(temp, desc, &base)); | |
518 mywidget->align = atoi(findnextstring(temp, desc, &base)); | |
519 findnextstring(temp, desc, &base); | |
520 mywidget->font = NULL; | |
521 for (i=0; i<skin->fontcount; i++) | |
522 { | |
523 if(!strcmp(temp, skin->fonts[i]->name)) | |
524 { | |
525 mywidget->font=skin->fonts[i]; | |
526 break; | |
527 } | |
528 } | |
529 mywidget->label=strdup(findnextstring(temp, desc, &base)); | |
530 #ifdef DEBUG | |
531 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [ITEM] [DLABEL] %i %i %i %i %s \"%s\"\n", | |
532 mywidget->x, mywidget->y, mywidget->length, mywidget->align, mywidget->font->name, mywidget->label); | |
533 #endif | |
534 } | |
535 free(temp); | |
536 } | |
537 | |
538 static void loadfonts(skin_t* skin) | |
539 { | |
540 unsigned int x; | |
541 for (x=0; x<skin->fontcount; x++) | |
542 { | |
543 FILE *fp; | |
544 int linenumber=0; | |
545 char *filename; | |
546 char *tmp = calloc(1, MAX_LINESIZE); | |
547 char *desc = calloc(1, MAX_LINESIZE); | |
548 filename = calloc(1, strlen(skin->skindir) + strlen(skin->fonts[x]->name) + 6); | |
549 sprintf(filename, "%s\\%s.fnt", skin->skindir, skin->fonts[x]->name); | |
550 if(!(fp = fopen(filename,"rb"))) | |
551 { | |
552 mp_msg(MSGT_GPLAYER, MSGL_ERR, "[FONT LOAD] Font not found \"%s\"\n", skin->fonts[x]->name); | |
553 return; | |
554 } | |
555 while(!feof(fp)) | |
556 { | |
557 int pos = 0; | |
558 unsigned int i; | |
559 fgets(tmp, MAX_LINESIZE, fp); | |
560 linenumber++; | |
561 memset(desc, 0, MAX_LINESIZE); | |
562 for (i=0; i<strlen(tmp); i++) | |
563 { | |
564 /* remove spaces and linebreaks */ | |
565 if((tmp[i] == ' ') || (tmp[i] == '\n') || (tmp[i] == '\r')) continue; | |
566 /* remove comments */ | |
567 if((tmp[i] == ';') && ((i < 1) || (tmp[i-1] != '\"'))) | |
568 { | |
569 #ifdef DEBUG | |
570 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[FONT LOAD] Comment: %s", tmp + i + 1); | |
571 #endif | |
572 break; | |
573 } | |
574 desc[pos] = tmp[i]; | |
575 pos++; | |
576 } | |
577 if(!strlen(desc)) continue; | |
578 /* now we have "readable" output -> parse it */ | |
579 if(!strncmp(desc, "image", 5)) | |
580 { | |
581 skin->fonts[x]->image = pngRead(skin, desc + 6); | |
582 #ifdef DEBUG | |
583 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[FONT] [IMAGE] \"%s\"\n", desc + 6); | |
584 #endif | |
585 } | |
586 else | |
587 { | |
588 int base = 4; | |
589 if(*desc != '"') break; | |
590 if(*(desc + 1) == 0) break; | |
591 (skin->fonts[x]->charcount)++; | |
592 skin->fonts[x]->chars = realloc(skin->fonts[x]->chars, sizeof(char_t *) *skin->fonts[x]->charcount); | |
593 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]=calloc(1, sizeof(char_t)); | |
594 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]->c = ((*(desc + 1) == '"') && (*(desc + 2) != '"')) ? ' ': *(desc + 1); | |
595 if((*(desc + 1) == '"') && (*(desc + 2) != '"')) base = 3; | |
596 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]->x = atoi(findnextstring(tmp, desc, &base)); | |
597 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]->y = atoi(findnextstring(tmp, desc, &base)); | |
598 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]->width = atoi(findnextstring(tmp, desc, &base)); | |
599 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]->height = atoi(findnextstring(tmp, desc, &base)); | |
600 #ifdef DEBUG | |
601 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[FONT] [CHAR] %c %i %i %i %i\n", | |
602 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]->c, | |
603 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]->x, | |
604 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]->y, | |
605 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]->width, | |
606 skin->fonts[x]->chars[skin->fonts[x]->charcount - 1]->height); | |
607 #endif | |
608 } | |
609 } | |
610 free(desc); | |
611 free(filename); | |
612 free(tmp); | |
613 fclose(fp); | |
614 } | |
615 } | |
616 | |
617 skin_t* loadskin(char* skindir, int desktopbpp) | |
618 { | |
619 FILE *fp; | |
620 int reachedendofwindow = 0; | |
621 int linenumber = 0; | |
622 skin_t *skin = calloc(1, sizeof(skin_t)); | |
623 char *filename; | |
624 char *tmp = calloc(1, MAX_LINESIZE); | |
625 char *desc = calloc(1, MAX_LINESIZE); | |
626 window* mywindow = NULL; | |
627 | |
628 /* setup funcs */ | |
629 skin->freeskin = freeskin; | |
630 skin->pngRead = pngRead; | |
631 skin->addwidget = addwidget; | |
632 skin->removewidget = removewidget; | |
633 skin->geteventname = geteventname; | |
634 skin->desktopbpp = desktopbpp; | |
635 skin->skindir = strdup(skindir); | |
636 | |
637 filename = calloc(1, strlen(skin->skindir) + strlen("skin") + 2); | |
638 sprintf(filename, "%s\\skin", skin->skindir); | |
639 if(!(fp = fopen(filename, "rb"))) | |
640 { | |
641 mp_msg(MSGT_GPLAYER, MSGL_FATAL, "[SKIN LOAD] Skin \"%s\" not found\n", skindir); | |
642 skin->freeskin(skin); | |
643 return NULL; | |
644 } | |
645 | |
646 while(!feof(fp)) | |
647 { | |
648 int pos = 0; | |
649 unsigned int i; | |
650 int insidequote = 0; | |
651 fgets(tmp, MAX_LINESIZE, fp); | |
652 linenumber++; | |
653 memset(desc, 0, MAX_LINESIZE); | |
654 for (i=0; i<strlen(tmp); i++) | |
655 { | |
656 if((tmp[i] == '"') && !insidequote) { insidequote=1; continue; } | |
657 else if((tmp[i] == '"') && insidequote) { insidequote=0 ; continue; } | |
658 /* remove spaces and linebreaks */ | |
659 if((!insidequote && (tmp[i] == ' ')) || (tmp[i] == '\n') || (tmp[i] == '\r')) continue; | |
660 /* remove comments */ | |
661 else if(tmp[i] == ';') | |
662 { | |
663 #ifdef DEBUG | |
664 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN LOAD] Comment: %s", tmp + i + 1); | |
665 #endif | |
666 break; | |
667 } | |
668 desc[pos] = tmp[i]; | |
669 pos++; | |
670 } | |
671 | |
672 if(!strlen(desc)) continue; | |
673 /* now we have "readable" output -> parse it */ | |
674 /* parse window specific info */ | |
675 if(!strncmp(desc, "section", 7)) | |
676 { | |
677 #ifdef DEBUG | |
678 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [SECTION] \"%s\"\n", desc + 8); | |
679 #endif | |
680 } | |
681 else if(!strncmp(desc, "window", 6)) | |
682 { | |
683 #ifdef DEBUG | |
684 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [WINDOW] \"%s\"\n", desc + 7); | |
685 #endif | |
686 reachedendofwindow = 0; | |
687 (skin->windowcount)++; | |
688 skin->windows = realloc(skin->windows, sizeof(window *) * skin->windowcount); | |
689 mywindow = skin->windows[(skin->windowcount) - 1] = calloc(1, sizeof(window)); | |
690 mywindow->name = strdup(desc + 7); | |
691 if(!strncmp(desc + 7, "main", 4)) mywindow->type = wiMain; | |
692 else if(!strncmp(desc+7, "sub", 3)) | |
693 { | |
694 mywindow->type = wiSub; | |
695 mywindow->decoration = 1; | |
696 } | |
697 else if(!strncmp(desc + 7, "menu", 4)) mywindow->type = wiMenu; | |
698 else if(!strncmp(desc + 7, "playbar", 7)) mywindow->type = wiPlaybar; | |
699 else mp_msg(MSGT_GPLAYER, MSGL_V, "[SKIN] warning found unknown windowtype"); | |
700 } | |
701 else if(!strncmp(desc, "decoration", 10) && !strncmp(desc + 11, "enable", 6)) | |
702 { | |
703 mywindow->decoration = 1; | |
704 #ifdef DEBUG | |
705 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [DECORATION] enabled decoration for window \"%s\"\n", mywindow->name); | |
706 #endif | |
707 } | |
708 else if(!strncmp(desc, "background", 10)) | |
709 { | |
710 int base = counttonextchar(desc, '=') + 1; | |
711 char temp[MAX_LINESIZE]; | |
712 mywindow->backgroundcolor[0] = atoi(findnextstring(temp, desc, &base)); | |
713 mywindow->backgroundcolor[1] = atoi(findnextstring(temp, desc, &base)); | |
714 mywindow->backgroundcolor[2] = atoi(findnextstring(temp, desc, &base)); | |
715 #ifdef DEBUG | |
716 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [BACKGROUND] window \"%s\" has backgroundcolor (%i,%i,%i)\n", mywindow->name, | |
717 mywindow->backgroundcolor[0], | |
718 mywindow->backgroundcolor[1], | |
719 mywindow->backgroundcolor[2]); | |
720 #endif | |
721 } | |
722 else if(!strncmp(desc, "end", 3)) | |
723 { | |
724 if(reachedendofwindow) | |
725 { | |
726 #ifdef DEBUG | |
727 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [END] of section\n"); | |
728 #endif | |
729 } | |
730 else | |
731 { | |
732 reachedendofwindow = 1; | |
733 #ifdef DEBUG | |
734 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [END] of window \"%s\"\n", mywindow->name); | |
735 #endif | |
736 } | |
737 } | |
738 else if(!strncmp(desc, "font", 4)) | |
739 { | |
740 unsigned int i; | |
741 int id = 0; | |
742 char temp[MAX_LINESIZE]; | |
743 int base = counttonextchar(desc, '=')+1; | |
744 findnextstring(temp, desc, &base); | |
745 findnextstring(temp, desc, &base); | |
746 for (i=0; i<skin->fontcount; i++) | |
747 if(!strcmp(skin->fonts[i]->id, temp)) | |
748 { | |
749 id = i; | |
750 break; | |
751 } | |
752 if(!id) | |
753 { | |
754 int base = counttonextchar(desc, '=') + 1; | |
755 findnextstring(temp, desc, &base); | |
756 id = skin->fontcount; | |
757 (skin->fontcount)++; | |
758 skin->fonts = realloc(skin->fonts, sizeof(font_t *) * skin->fontcount); | |
759 skin->fonts[id]=calloc(1, sizeof(font_t)); | |
760 skin->fonts[id]->name = strdup(temp); | |
761 skin->fonts[id]->id = strdup(findnextstring(temp, desc, &base)); | |
762 } | |
763 #ifdef DEBUG | |
764 mp_msg(MSGT_GPLAYER, MSGL_DBG4, "[SKIN] [FONT] id \"%s\" name \"%s\"\n", skin->fonts[id]->name, skin->fonts[id]->id); | |
765 #endif | |
766 } | |
767 else | |
768 skin->addwidget(skin, mywindow, desc); | |
769 } | |
770 | |
771 free(desc); | |
772 free(filename); | |
773 free(tmp); | |
774 fclose(fp); | |
775 loadfonts(skin); | |
776 mp_msg(MSGT_GPLAYER, MSGL_V, "[SKIN LOAD] loaded skin \"%s\"\n", skin->skindir); | |
777 /* dumpwidgets(skin); */ | |
778 return skin; | |
779 } |