1 /***************************************************************************
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
10 * Copyright (C) 2002 Itai Shaked
12 * All files in this archive are subject to the GNU General Public License.
13 * See the file COPYING in the source tree root for full license agreement.
15 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
16 * KIND, either express or implied.
18 ****************************************************************************/
25 ok, a little explanation -
26 board holds the snake and apple position - 1+ - snake body (the number
27 represents the age [1 is the snake's head]).
28 -1 is an apple, and 0 is a clear spot.
29 dir is the current direction of the snake - 0=up, 1=right, 2=down, 3=left;
34 #ifdef HAVE_LCD_BITMAP
38 /* variable button definitions */
39 #if CONFIG_KEYPAD == RECORDER_PAD
40 #define SNAKE_QUIT BUTTON_OFF
41 #define SNAKE_UP BUTTON_UP
42 #define SNAKE_DOWN BUTTON_DOWN
43 #define SNAKE_PLAYPAUSE BUTTON_PLAY
45 #elif CONFIG_KEYPAD == ARCHOS_AV300_PAD
46 #define SNAKE_QUIT BUTTON_OFF
47 #define SNAKE_UP BUTTON_UP
48 #define SNAKE_DOWN BUTTON_DOWN
49 #define SNAKE_PLAYPAUSE BUTTON_SELECT
51 #elif CONFIG_KEYPAD == ONDIO_PAD
52 #define SNAKE_QUIT BUTTON_OFF
53 #define SNAKE_UP BUTTON_UP
54 #define SNAKE_DOWN BUTTON_DOWN
55 #define SNAKE_PLAYPAUSE BUTTON_MENU
57 #elif (CONFIG_KEYPAD == IRIVER_H100_PAD) || \
58 (CONFIG_KEYPAD == IRIVER_H300_PAD)
59 #define SNAKE_QUIT BUTTON_OFF
60 #define SNAKE_UP BUTTON_UP
61 #define SNAKE_DOWN BUTTON_DOWN
62 #define SNAKE_PLAYPAUSE BUTTON_ON
64 #define SNAKE_RC_QUIT BUTTON_RC_STOP
66 #elif (CONFIG_KEYPAD == IPOD_4G_PAD) || \
67 (CONFIG_KEYPAD == IPOD_3G_PAD) || \
68 (CONFIG_KEYPAD == IPOD_1G2G_PAD)
69 #define SNAKE_QUIT (BUTTON_SELECT|BUTTON_MENU)
70 #define SNAKE_UP BUTTON_MENU
71 #define SNAKE_DOWN BUTTON_PLAY
72 #define SNAKE_PLAYPAUSE BUTTON_SELECT
74 #elif (CONFIG_KEYPAD == IAUDIO_X5M5_PAD)
75 #define SNAKE_QUIT BUTTON_POWER
76 #define SNAKE_UP BUTTON_UP
77 #define SNAKE_DOWN BUTTON_DOWN
78 #define SNAKE_PLAYPAUSE BUTTON_PLAY
80 #elif (CONFIG_KEYPAD == GIGABEAT_PAD)
81 #define SNAKE_QUIT BUTTON_POWER
82 #define SNAKE_UP BUTTON_UP
83 #define SNAKE_DOWN BUTTON_DOWN
84 #define SNAKE_PLAYPAUSE BUTTON_SELECT
86 #elif (CONFIG_KEYPAD == SANSA_E200_PAD) || \
87 (CONFIG_KEYPAD == SANSA_C200_PAD)
88 #define SNAKE_QUIT BUTTON_POWER
89 #define SNAKE_UP BUTTON_UP
90 #define SNAKE_DOWN BUTTON_DOWN
91 #define SNAKE_PLAYPAUSE BUTTON_SELECT
93 #elif (CONFIG_KEYPAD == IRIVER_H10_PAD)
94 #define SNAKE_QUIT BUTTON_POWER
95 #define SNAKE_UP BUTTON_SCROLL_UP
96 #define SNAKE_DOWN BUTTON_SCROLL_DOWN
97 #define SNAKE_PLAYPAUSE BUTTON_PLAY
99 #elif (CONFIG_KEYPAD == GIGABEAT_S_PAD)
100 #define SNAKE_QUIT BUTTON_BACK
101 #define SNAKE_UP BUTTON_UP
102 #define SNAKE_DOWN BUTTON_DOWN
103 #define SNAKE_PLAYPAUSE BUTTON_SELECT
105 #elif (CONFIG_KEYPAD == MROBE100_PAD)
106 #define SNAKE_QUIT BUTTON_POWER
107 #define SNAKE_UP BUTTON_UP
108 #define SNAKE_DOWN BUTTON_DOWN
109 #define SNAKE_PLAYPAUSE BUTTON_SELECT
112 #error No keymap defined!
115 #define BOARD_WIDTH (LCD_WIDTH/4)
116 #define BOARD_HEIGHT (LCD_HEIGHT/4)
118 static int board
[BOARD_WIDTH
][BOARD_HEIGHT
],snakelength
;
119 static unsigned int score
,hiscore
=0,level
=1;
120 static short dir
,frames
,apple
,dead
=0;
121 static struct plugin_api
* rb
;
126 rb
->lcd_clear_display();
127 rb
->snprintf(pscore
,sizeof(pscore
),"Your score: %d",score
);
128 rb
->lcd_puts(0,0,"Oops...");
129 rb
->lcd_puts(0,1, pscore
);
132 rb
->lcd_puts(0,2,"New High Score!");
135 rb
->snprintf(pscore
,sizeof(pscore
),"High Score: %d",hiscore
);
136 rb
->lcd_puts(0,2,pscore
);
143 void colission (short x
, short y
)
145 switch (board
[x
][y
]) {
157 if (x
==BOARD_WIDTH
|| x
<0 || y
==BOARD_HEIGHT
|| y
<0)
161 void move_head (short x
, short y
)
181 rb
->lcd_fillrect(x
*4,y
*4,4,4);
187 for (x
=0; x
<BOARD_WIDTH
; x
++) {
188 for (y
=0; y
<BOARD_HEIGHT
; y
++) {
189 switch (board
[x
][y
]) {
204 if (board
[x
][y
]==snakelength
) {
206 rb
->lcd_set_drawmode(DRMODE_SOLID
|DRMODE_INVERSEVID
);
207 rb
->lcd_fillrect(x
*4,y
*4,4,4);
208 rb
->lcd_set_drawmode(DRMODE_SOLID
);
222 rb
->lcd_clear_display();
223 for (x
=0; x
<BOARD_WIDTH
; x
++) {
224 for (y
=0; y
<BOARD_HEIGHT
; y
++) {
225 switch (board
[x
][y
]) {
227 rb
->lcd_fillrect((x
*4)+1,y
*4,2,4);
228 rb
->lcd_fillrect(x
*4,(y
*4)+1,4,2);
233 rb
->lcd_fillrect(x
*4,y
*4,4,4);
241 void game_pause (void) {
243 rb
->lcd_clear_display();
244 rb
->lcd_putsxy(3,12,"Game Paused");
245 #if CONFIG_KEYPAD == RECORDER_PAD
246 rb
->lcd_putsxy(3,22,"[Play] to resume");
247 #elif CONFIG_KEYPAD == ONDIO_PAD
248 rb
->lcd_putsxy(3,22,"[Mode] to resume");
250 rb
->lcd_putsxy(3,32,"[Off] to quit");
253 button
=rb
->button_get(true);
261 case SNAKE_PLAYPAUSE
:
266 if (rb
->default_event_handler(button
)==SYS_USB_CONNECTED
) {
288 x
=rb
->rand() % BOARD_WIDTH
;
289 y
=rb
->rand() % BOARD_HEIGHT
;
290 } while (board
[x
][y
]);
293 rb
->lcd_fillrect((x
*4)+1,y
*4,2,4);
294 rb
->lcd_fillrect(x
*4,(y
*4)+1,4,2);
300 button
=rb
->button_get(false);
302 #ifdef HAS_BUTTON_HOLD
303 if (rb
->button_hold())
304 button
= SNAKE_PLAYPAUSE
;
326 case SNAKE_PLAYPAUSE
:
330 if (rb
->default_event_handler(button
)==SYS_USB_CONNECTED
) {
339 void game_init(void) {
342 bool menu_quit
= false;
344 for (x
=0; x
<BOARD_WIDTH
; x
++) {
345 for (y
=0; y
<BOARD_HEIGHT
; y
++) {
355 MENUITEM_STRINGLIST(menu
,"Snake Menu",NULL
,"Start New Game","Starting Level",
359 switch(rb
->do_menu(&menu
, &selection
))
362 menu_quit
= true; /* start playing */
366 rb
->set_int("Starting Level", "", UNIT_INT
, &level
, NULL
,
371 dead
=1; /* quit program */
379 enum plugin_status
plugin_start(struct plugin_api
* api
, void* parameter
)
385 rb
->lcd_clear_display();
387 return (dead
==1)?PLUGIN_OK
:PLUGIN_USB_CONNECTED
;