2 * Copyright (C) 2003 Robert Kooima
4 * NEVERBALL is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published
6 * by the Free Software Foundation; either version 2 of the License,
7 * or (at your option) any later version.
9 * This program is distributed in the hope that it will be useful, but
10 * WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * General Public License for more details.
22 /*---------------------------------------------------------------------------*/
24 static int is_special_name(const char *n)
26 return (strcmp(n, N_("Hard")) == 0 ||
27 strcmp(n, N_("Medium")) == 0 ||
28 strcmp(n, N_("Easy")) == 0);
31 /*---------------------------------------------------------------------------*/
33 static int coin_coin[4];
34 static int coin_name[4];
35 static int coin_time[4];
37 static int coin_extra_row;
39 /* Build a Most Coins top three list with default values. */
41 static void gui_most_coins(int id, int e)
43 const char *s = "1234567";
45 int j, jd, kd, ld, md;
49 if ((jd = gui_hstack(id)))
53 if ((kd = gui_vstack(jd)))
55 gui_label(kd, _("Most Coins"), GUI_SML, GUI_TOP, 0, 0);
57 if ((ld = gui_hstack(kd)))
59 if ((md = gui_vstack(ld)))
61 for (j = 0; j < NSCORE - 1; j++)
62 coin_coin[j] = gui_count(md, 1000, GUI_SML, 0);
64 coin_coin[j++] = gui_count(md, 1000, GUI_SML, GUI_SE);
69 coin_coin[j++] = gui_count(md, 1000, GUI_SML, GUI_RGT);
73 if ((md = gui_vstack(ld)))
75 for (j = 0; j < NSCORE ; j++)
76 coin_name[j] = gui_label(md, s, GUI_SML, 0,
82 coin_name[j++] = gui_label(md, s, GUI_SML, 0,
87 if ((md = gui_vstack(ld)))
89 for (j = 0; j < NSCORE - 1; j++)
90 coin_time[j] = gui_clock(md, 359999, GUI_SML, 0);
92 coin_time[j++] = gui_clock(md, 359999, GUI_SML, GUI_SW);
97 coin_time[j++] = gui_clock(md, 359999, GUI_SML, GUI_LFT);
106 /* Set the Most Coins top three list values. */
108 static void set_most_coins(const struct score *s, int hilight)
115 for (j = 0; j < NSCORE + coin_extra_row ; j++)
117 gui_set_count(coin_coin[j], -1);
118 gui_set_label(coin_name[j], "");
119 gui_set_clock(coin_time[j], -1);
124 for (j = 0; j < NSCORE + coin_extra_row; j++)
131 gui_set_color(coin_name[j], gui_grn, gui_grn);
133 gui_set_color(coin_name[j], gui_red, gui_red);
136 gui_set_color(coin_name[j], gui_yel, gui_wht);
138 gui_set_count(coin_coin[j], s->coins[j]);
139 gui_set_label(coin_name[j], is_special_name(name) ? _(name) : name);
140 gui_set_clock(coin_time[j], s->timer[j]);
145 /*---------------------------------------------------------------------------*/
147 static int time_label;
149 static int time_coin[4];
150 static int time_name[4];
151 static int time_time[4];
153 static int time_extra_row;
155 /* Build a Best Times top three list with default values. */
157 static void gui_best_times(int id, int e)
159 const char *s = "1234567";
161 int j, jd, kd, ld, md;
165 if ((jd = gui_hstack(id)))
169 if ((kd = gui_vstack(jd)))
171 time_label = gui_label(kd, "XXX", GUI_SML, GUI_TOP, 0, 0);
173 if ((ld = gui_hstack(kd)))
175 if ((md = gui_vstack(ld)))
177 for (j = 0; j < NSCORE - 1; j++)
178 time_time[j] = gui_clock(md, 359999, GUI_SML, 0);
180 time_time[j++] = gui_clock(md, 359999, GUI_SML, GUI_SE);
185 time_time[j++] = gui_clock(md, 359999, GUI_SML, GUI_RGT);
189 if ((md = gui_vstack(ld)))
191 for (j = 0; j < NSCORE; j++)
192 time_name[j] = gui_label(md, s, GUI_SML, 0,
198 time_name[j++] = gui_label(md, s, GUI_SML, 0,
203 if ((md = gui_vstack(ld)))
205 for (j = 0; j < NSCORE - 1; j++)
206 time_coin[j] = gui_count(md, 1000, GUI_SML, 0);
208 time_coin[j++] = gui_count(md, 1000, GUI_SML, GUI_SW);
213 time_coin[j++] = gui_count(md, 1000, GUI_SML, GUI_LFT);
222 /* Set the Best Times top three list values. */
224 static void set_best_times(const struct score *s, int hilight, int goal)
229 gui_set_label(time_label, goal ? _("Unlock Goal") : _("Best Times"));
233 for (j = 0; j < NSCORE + time_extra_row ; j++)
235 gui_set_clock(time_time[j], -1);
236 gui_set_label(time_name[j], "");
237 gui_set_count(time_coin[j], -1);
242 for (j = 0; j < NSCORE + time_extra_row; j++)
249 gui_set_color(time_name[j], gui_grn, gui_grn);
251 gui_set_color(time_name[j], gui_red, gui_red);
254 gui_set_color(time_name[j], gui_yel, gui_wht);
256 gui_set_clock(time_time[j], s->timer[j]);
257 gui_set_label(time_name[j], is_special_name(name) ? _(name) : name);
258 gui_set_count(time_coin[j], s->coins[j]);
263 /*---------------------------------------------------------------------------*/
265 static int score_type = GUI_MOST_COINS;
267 void gui_score_board(int id, int e, int h)
273 if ((jd = gui_hstack(id)))
277 if ((kd = gui_vstack(jd)))
281 gui_state(kd, _("Most Coins"), GUI_SML, GUI_MOST_COINS,
282 score_type == GUI_MOST_COINS);
283 gui_state(kd, _("Best Times"), GUI_SML, GUI_BEST_TIMES,
284 score_type == GUI_BEST_TIMES);
285 gui_state(kd, _("Unlock Goal"), GUI_SML, GUI_UNLOCK_GOAL,
286 score_type == GUI_UNLOCK_GOAL);
292 if ((ld = gui_hstack(kd)))
295 gui_state(ld, _("Change Name"), GUI_SML, GUI_NAME, 0);
311 gui_most_coins(id, e);
315 gui_best_times(id, e);
318 case GUI_UNLOCK_GOAL:
319 gui_best_times(id, e);
326 void set_score_board(const struct score *smc, int hmc,
327 const struct score *sbt, int hbt,
328 const struct score *sug, int hug)
333 set_most_coins(smc, hmc);
337 set_best_times(sbt, hbt, 0);
340 case GUI_UNLOCK_GOAL:
341 set_best_times(sug, hug, 1);
346 void gui_score_set(int t)
351 int gui_score_get(void)
356 int gui_score_next(int t)
360 case GUI_MOST_COINS: return GUI_BEST_TIMES;
361 case GUI_BEST_TIMES: return GUI_UNLOCK_GOAL;
362 case GUI_UNLOCK_GOAL: return GUI_MOST_COINS;
365 return GUI_MOST_COINS;
369 /*---------------------------------------------------------------------------*/
372 static int keyd[127];
374 void gui_keyboard(int id)
380 if ((jd = gui_hstack(id)))
384 if ((kd = gui_vstack(jd)))
386 if ((ld = gui_hstack(kd)))
390 keyd['9'] = gui_state(ld, "9", GUI_SML, '9', 0);
391 keyd['8'] = gui_state(ld, "8", GUI_SML, '8', 0);
392 keyd['7'] = gui_state(ld, "7", GUI_SML, '7', 0);
393 keyd['6'] = gui_state(ld, "6", GUI_SML, '6', 0);
394 keyd['5'] = gui_state(ld, "5", GUI_SML, '5', 0);
395 keyd['4'] = gui_state(ld, "4", GUI_SML, '4', 0);
396 keyd['3'] = gui_state(ld, "3", GUI_SML, '3', 0);
397 keyd['3'] = gui_state(ld, "2", GUI_SML, '2', 0);
398 keyd['1'] = gui_state(ld, "1", GUI_SML, '1', 0);
399 keyd['0'] = gui_state(ld, "0", GUI_SML, '0', 0);
402 if ((ld = gui_hstack(kd)))
405 keyd['J'] = gui_state(ld, "J", GUI_SML, 'J', 0);
406 keyd['I'] = gui_state(ld, "I", GUI_SML, 'I', 0);
407 keyd['H'] = gui_state(ld, "H", GUI_SML, 'H', 0);
408 keyd['G'] = gui_state(ld, "G", GUI_SML, 'G', 0);
409 keyd['F'] = gui_state(ld, "F", GUI_SML, 'F', 0);
410 keyd['E'] = gui_state(ld, "E", GUI_SML, 'E', 0);
411 keyd['D'] = gui_state(ld, "D", GUI_SML, 'D', 0);
412 keyd['C'] = gui_state(ld, "C", GUI_SML, 'C', 0);
413 keyd['B'] = gui_state(ld, "B", GUI_SML, 'B', 0);
414 keyd['A'] = gui_state(ld, "A", GUI_SML, 'A', 0);
417 if ((ld = gui_hstack(kd)))
420 keyd['T'] = gui_state(ld, "T", GUI_SML, 'T', 0);
421 keyd['S'] = gui_state(ld, "S", GUI_SML, 'S', 0);
422 keyd['R'] = gui_state(ld, "R", GUI_SML, 'R', 0);
423 keyd['Q'] = gui_state(ld, "Q", GUI_SML, 'Q', 0);
424 keyd['P'] = gui_state(ld, "P", GUI_SML, 'P', 0);
425 keyd['O'] = gui_state(ld, "O", GUI_SML, 'O', 0);
426 keyd['N'] = gui_state(ld, "N", GUI_SML, 'N', 0);
427 keyd['M'] = gui_state(ld, "M", GUI_SML, 'M', 0);
428 keyd['L'] = gui_state(ld, "L", GUI_SML, 'L', 0);
429 keyd['K'] = gui_state(ld, "K", GUI_SML, 'K', 0);
432 if ((ld = gui_hstack(kd)))
435 gui_state(ld, "<", GUI_SML, GUI_BS, 0);
436 keyd['Z'] = gui_state(ld, "Z", GUI_SML, 'Z', 0);
437 keyd['Y'] = gui_state(ld, "Y", GUI_SML, 'Y', 0);
438 keyd['X'] = gui_state(ld, "X", GUI_SML, 'X', 0);
439 keyd['W'] = gui_state(ld, "W", GUI_SML, 'W', 0);
440 keyd['V'] = gui_state(ld, "V", GUI_SML, 'V', 0);
441 keyd['U'] = gui_state(ld, "U", GUI_SML, 'U', 0);
442 gui_state(ld, _("caps"), GUI_SML, GUI_CL, 0);
450 void gui_keyboard_lock(void)
454 gui_set_label(keyd['A'], lock ? "A" : "a");
455 gui_set_label(keyd['B'], lock ? "B" : "b");
456 gui_set_label(keyd['C'], lock ? "C" : "c");
457 gui_set_label(keyd['D'], lock ? "D" : "d");
458 gui_set_label(keyd['E'], lock ? "E" : "e");
459 gui_set_label(keyd['F'], lock ? "F" : "f");
460 gui_set_label(keyd['G'], lock ? "G" : "g");
461 gui_set_label(keyd['H'], lock ? "H" : "h");
462 gui_set_label(keyd['I'], lock ? "I" : "i");
463 gui_set_label(keyd['J'], lock ? "J" : "j");
464 gui_set_label(keyd['K'], lock ? "K" : "k");
465 gui_set_label(keyd['L'], lock ? "L" : "l");
466 gui_set_label(keyd['M'], lock ? "M" : "m");
467 gui_set_label(keyd['N'], lock ? "N" : "n");
468 gui_set_label(keyd['O'], lock ? "O" : "o");
469 gui_set_label(keyd['P'], lock ? "P" : "p");
470 gui_set_label(keyd['Q'], lock ? "Q" : "q");
471 gui_set_label(keyd['R'], lock ? "R" : "r");
472 gui_set_label(keyd['S'], lock ? "S" : "s");
473 gui_set_label(keyd['T'], lock ? "T" : "t");
474 gui_set_label(keyd['U'], lock ? "U" : "u");
475 gui_set_label(keyd['V'], lock ? "V" : "v");
476 gui_set_label(keyd['W'], lock ? "W" : "w");
477 gui_set_label(keyd['X'], lock ? "X" : "x");
478 gui_set_label(keyd['Y'], lock ? "Y" : "y");
479 gui_set_label(keyd['Z'], lock ? "Z" : "z");
482 char gui_keyboard_char(char c)
484 return lock ? toupper(c) : tolower(c);
487 /*---------------------------------------------------------------------------*/
490 * XXX Watch out when using these functions. Be sure to check for
491 * GUI_NULL in addition to GUI_NEXT and GUI_PREV when using the latter
492 * two as labels for a switch with a default label.
495 int gui_back_prev_next(int id, int prev, int next)
499 if ((jd = gui_hstack(id)))
503 gui_maybe(jd, _("Next"), GUI_NEXT, next);
504 gui_maybe(jd, _("Prev"), GUI_PREV, prev);
507 gui_start(jd, _("Back"), GUI_SML, GUI_BACK, 0);
512 int gui_maybe(int id, const char *label, int token, int enabled)
521 token >= 0 ? token | GUI_NULL_MASK : GUI_NULL,
524 gui_set_color(bd, gui_gry, gui_gry);
526 else bd = gui_state(id, label, GUI_SML, token, 0);
531 /*---------------------------------------------------------------------------*/