/*************************************************************************** * __________ __ ___. * Open \______ \ ____ ____ | | _\_ |__ _______ ___ * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ * \/ \/ \/ \/ \/ * $Id$ * * Copyright (C) 2002 Björn Stenberg * * All files in this archive are subject to the GNU General Public License. * See the file COPYING in the source tree root for full license agreement. * * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY * KIND, either express or implied. * ****************************************************************************/ #include "menu.h" #include "tree.h" #include "credits.h" #include "lcd.h" #include "button.h" #include "kernel.h" #include "main_menu.h" #include "sound_menu.h" #include "version.h" #include "debug.h" #include "sprintf.h" #include #include "playlist.h" #ifdef HAVE_LCD_BITMAP #include "games_menu.h" #include "screensavers_menu.h" #include "bmp.h" #include "icons.h" #endif int show_logo( void ) { #ifdef HAVE_LCD_BITMAP char version[32]; unsigned char *ptr=rockbox112x37; int height, i, font_h, font_w; lcd_clear_display(); for(i=0; i < 37; i+=8) { /* the bitmap function doesn't work with full-height bitmaps so we "stripe" the logo output */ lcd_bitmap(ptr, 0, 10+i, 112, (37-i)>8?8:37-i, false); ptr += 112; } height = 37; #if 0 /* * This code is not used anymore, but I kept it here since it shows * one way of using the BMP reader function to display an externally * providing logo. */ unsigned char buffer[112 * 8]; int width; int i; int eline; int failure; failure = read_bmp_file("/rockbox112.bmp", &width, &height, buffer); debugf("read_bmp_file() returned %d, width %d height %d\n", failure, width, height); for(i=0, eline=0; i < height; i+=8, eline++) { /* the bitmap function doesn't work with full-height bitmaps so we "stripe" the logo output */ lcd_bitmap(&buffer[eline*width], 0, 10+i, width, (height-i)>8?8:height-i, false); } } #endif snprintf(version, sizeof(version), "Ver. %s", appsversion); lcd_getfontsize(0, &font_w, &font_h); lcd_putsxy((LCD_WIDTH/2) - ((strlen(version)*font_w)/2), height+10+font_h, version, 0); lcd_update(); #else char *rockbox = "ROCKbox!"; lcd_clear_display(); #ifdef HAVE_NEW_CHARCELL_LCD lcd_double_height(true); #endif lcd_puts(0, 0, rockbox); lcd_puts(0, 1, appsversion); #endif return 0; } void show_credits(void) { int j = 0; show_logo(); #ifdef HAVE_NEW_CHARCELL_LCD lcd_double_height(false); #endif for (j = 0; j < 10; j++) { sleep((HZ*2)/10); if (button_get(false)) return; } roll_credits(); } void scroll_speed(void) { bool done=false; int speed=10; char str[16]; lcd_clear_display(); lcd_puts_scroll(0,0,"Scroll speed indicator"); while (!done) { snprintf(str,sizeof str,"Speed: %d ",speed); lcd_puts(0,1,str); lcd_update(); lcd_scroll_speed(speed); switch( button_get(true) ) { #ifdef HAVE_RECORDER_KEYPAD case BUTTON_UP: #else case BUTTON_RIGHT: #endif speed++; break; #ifdef HAVE_RECORDER_KEYPAD case BUTTON_DOWN: #else case BUTTON_LEFT: #endif speed--; if ( speed < 1 ) speed = 1; break; #ifdef HAVE_RECORDER_KEYPAD case BUTTON_LEFT: #else case BUTTON_STOP: case BUTTON_MENU: #endif done = true; lcd_stop_scroll(); break; } } } void shuffle(void) { bool done = false; lcd_clear_display(); lcd_puts(0,0,"[Shuffle]"); while ( !done ) { lcd_puts(0,1,playlist_shuffle ? "on " : "off"); lcd_update(); switch ( button_get(true) ) { #ifdef HAVE_RECORDER_KEYPAD case BUTTON_LEFT: #else case BUTTON_STOP: #endif done = true; break; default: playlist_shuffle = !playlist_shuffle; break; } } } void main_menu(void) { int m; enum { Games, Screensavers, Version, Sound, Scroll, Shuffle }; /* main menu */ struct menu_items items[] = { { Shuffle, "Shuffle", shuffle }, { Sound, "Sound", sound_menu }, { Scroll, "Scroll speed", scroll_speed }, #ifdef HAVE_LCD_BITMAP { Games, "Games", games_menu }, { Screensavers, "Screensavers", screensavers_menu }, #endif { Version, "Version", show_credits }, }; m=menu_init( items, sizeof items / sizeof(struct menu_items) ); menu_run(m); menu_exit(m); }