/*************************************************************************** * __________ __ ___. * Open \______ \ ____ ____ | | _\_ |__ _______ ___ * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ * \/ \/ \/ \/ \/ * $Id$ * * Copyright (C) 2005 by Kevin Ferrare * * 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 "quickscreen.h" #ifdef HAS_QUICKSCREEN #include #include "system.h" #include "icons.h" #include "textarea.h" #include "font.h" #include "kernel.h" #include "misc.h" #include "statusbar.h" void gui_quickscreen_init(struct gui_quickscreen * qs, struct option_select *left_option, struct option_select *bottom_option, struct option_select *right_option, char * left_right_title, quickscreen_callback callback) { qs->left_option=left_option; qs->bottom_option=bottom_option; qs->right_option=right_option; qs->left_right_title=left_right_title; qs->callback=callback; } void gui_quickscreen_draw(struct gui_quickscreen * qs, struct screen * display) { char buffer[30]; const unsigned char *option; const unsigned char *title; const unsigned char *left_right_title; char line_text[40]; #ifdef HAS_BUTTONBAR display->has_buttonbar=false; #endif gui_textarea_clear(display); display->setfont(FONT_SYSFIXED); left_right_title=(unsigned char *)qs->left_right_title; /* Displays the icons */ display->mono_bitmap(bitmap_icons_7x8[Icon_FastBackward], 1, 8, 7, 8); display->mono_bitmap(bitmap_icons_7x8[Icon_DownArrow], 1, 24, 7, 8); display->mono_bitmap(bitmap_icons_7x8[Icon_FastForward], 1, 40, 7, 8); /* Displays the first line of text */ option=(unsigned char *)option_select_get_text(qs->left_option, buffer, sizeof buffer); title=(unsigned char *)qs->left_option->title; snprintf(line_text, sizeof(line_text), "%s %s", title, left_right_title); display->puts_scroll(0, 0+!(global_settings.statusbar), line_text); display->puts_scroll(3, 1+!(global_settings.statusbar), option); /* Displays the second line of text */ option=(unsigned char *)option_select_get_text(qs->bottom_option, buffer, sizeof buffer); title=(unsigned char *)qs->bottom_option->title; display->puts_scroll(0, 2+!(global_settings.statusbar), title); display->puts_scroll(3, 3+!(global_settings.statusbar), option); /* Displays the third line of text */ option=(unsigned char *)option_select_get_text(qs->right_option, buffer, sizeof buffer); title=(unsigned char *)qs->right_option->title; snprintf(line_text, sizeof(line_text), "%s %s", title, left_right_title); display->puts_scroll(0, 4+!(global_settings.statusbar), line_text); display->puts_scroll(3, 5+!(global_settings.statusbar), option); gui_textarea_update(display); display->setfont(FONT_UI); } void gui_syncquickscreen_draw(struct gui_quickscreen * qs) { int i; FOR_NB_SCREENS(i) gui_quickscreen_draw(qs, &screens[i]); } bool gui_quickscreen_do_button(struct gui_quickscreen * qs, int button) { switch(button) { case QUICKSCREEN_LEFT : case QUICKSCREEN_LEFT | BUTTON_REPEAT : #ifdef QUICKSCREEN_RC_LEFT case QUICKSCREEN_RC_LEFT : case QUICKSCREEN_RC_LEFT | BUTTON_REPEAT : #endif option_select_next(qs->left_option); return(true); case QUICKSCREEN_BOTTOM : case QUICKSCREEN_BOTTOM | BUTTON_REPEAT : #ifdef QUICKSCREEN_RC_BOTTOM case QUICKSCREEN_RC_BOTTOM : case QUICKSCREEN_RC_BOTTOM | BUTTON_REPEAT : #endif option_select_next(qs->bottom_option); return(true); case QUICKSCREEN_RIGHT : case QUICKSCREEN_RIGHT | BUTTON_REPEAT : #ifdef QUICKSCREEN_RC_RIGHT case QUICKSCREEN_RC_RIGHT : case QUICKSCREEN_RC_RIGHT | BUTTON_REPEAT : #endif option_select_next(qs->right_option); return(true); case QUICKSCREEN_BOTTOM_INV : case QUICKSCREEN_BOTTOM_INV | BUTTON_REPEAT : #ifdef QUICKSCREEN_RC_BOTTOM_INV case QUICKSCREEN_RC_BOTTOM_INV : case QUICKSCREEN_RC_BOTTOM_INV | BUTTON_REPEAT : #endif option_select_prev(qs->bottom_option); return(true); } return(false); } #ifdef BUTTON_REMOTE #define uncombine_button(key_read, combined_button) \ key_read & ~(combined_button & ~BUTTON_REMOTE) #else #define uncombine_button(key_read, combined_button) \ key_read & ~combined_button #endif bool gui_syncquickscreen_run(struct gui_quickscreen * qs, int button_enter) { int raw_key, button; /* To quit we need either : * - a second press on the button that made us enter * - an action taken while pressing the enter button, * then release the enter button*/ bool can_quit=false; gui_syncquickscreen_draw(qs); gui_syncstatusbar_draw(&statusbars, true); while (true) { raw_key = button_get(true); button=uncombine_button(raw_key, button_enter); if(default_event_handler(button) == SYS_USB_CONNECTED) return(true); if(gui_quickscreen_do_button(qs, button)) { can_quit=true; if(qs->callback) qs->callback(qs); gui_syncquickscreen_draw(qs); } else if(raw_key==button_enter) can_quit=true; if(raw_key==(button_enter | BUTTON_REL) && can_quit) return(false); #ifdef QUICKSCREEN_QUIT if(raw_key==QUICKSCREEN_QUIT #ifdef QUICKSCREEN_QUIT2 || raw_key==QUICKSCREEN_QUIT2 #endif #if QUICKSCREEN_RC_QUIT || raw_key==QUICKSCREEN_RC_QUIT #endif ) return(false); #endif /* QUICKSCREEN_QUIT */ gui_syncstatusbar_draw(&statusbars, false); } } #endif /* HAS_QUICKSCREEN */