Index: tools/configure =================================================================== --- tools/configure (Revision 19084) +++ tools/configure (Arbeitskopie) @@ -1751,7 +1751,7 @@ output="rockbox.sansa" bootoutput="bootloader-fuze.sansa" appextra="recorder:gui" - plugins="yes" + plugins="" swcodec="yes" toolset=$scramblebitmaptools t_cpu="arm" Index: apps/lang/deutsch.lang =================================================================== --- apps/lang/deutsch.lang (Revision 19084) +++ apps/lang/deutsch.lang (Arbeitskopie) @@ -3850,17 +3850,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Tastenbeleuchtungsdauer" - e200*: "Scrollradbeleuchtungsdauer" + fuze,e200*: "Scrollradbeleuchtungsdauer" *: none button_light: "Tastenbeleuchtungsdauer" - e200*: "Scrollradbeleuchtungsdauer" + fuze,e200*: "Scrollradbeleuchtungsdauer" Index: apps/lang/dansk.lang =================================================================== --- apps/lang/dansk.lang (Revision 19084) +++ apps/lang/dansk.lang (Arbeitskopie) @@ -9933,17 +9933,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Knap-lys sluk" - e200*: "Hjul-lys sluk" + fuze,e200*: "Hjul-lys sluk" *: none button_light: "Knap-lys sluk" - e200*: "Hjul-lys sluk" + fuze,e200*: "Hjul-lys sluk" Index: apps/lang/polski.lang =================================================================== --- apps/lang/polski.lang (Revision 19084) +++ apps/lang/polski.lang (Arbeitskopie) @@ -3841,17 +3841,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Wygaszanie klawiszy" - e200*: "Wygaszanie koła sterującego" + fuze,e200*: "Wygaszanie koła sterującego" *: none button_light: "Wygaszanie klawiszy" - e200*: "Wygaszanie koła sterującego" + fuze,e200*: "Wygaszanie koła sterującego" Index: apps/lang/bulgarian.lang =================================================================== --- apps/lang/bulgarian.lang (Revision 19084) +++ apps/lang/bulgarian.lang (Arbeitskopie) @@ -10221,17 +10221,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Изключване на осветяването на бутоните" - e200*: "Изключване на осветяването на колелото" + fuze,e200*: "Изключване на осветяването на колелото" *: none button_light: "" - e200*: "" + fuze,e200*: "" Index: apps/lang/chinese-trad.lang =================================================================== --- apps/lang/chinese-trad.lang (Revision 19084) +++ apps/lang/chinese-trad.lang (Arbeitskopie) @@ -10704,15 +10704,15 @@ user: *: none - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none - e200*: "轉盤燈自動關時間" + fuze,e200*: "轉盤燈自動關時間" *: none - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" Index: apps/lang/svenska.lang =================================================================== --- apps/lang/svenska.lang (Revision 19084) +++ apps/lang/svenska.lang (Arbeitskopie) @@ -3852,17 +3852,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Knappbelysning" - e200*: "Hjulbelysning" + fuze,e200*: "Hjulbelysning" *: none button_light: "Knappbelysning" - e200*: "Hjulbelysning" + fuze,e200*: "Hjulbelysning" Index: apps/lang/hebrew.lang =================================================================== --- apps/lang/hebrew.lang (Revision 19084) +++ apps/lang/hebrew.lang (Arbeitskopie) @@ -3832,17 +3832,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "זמן תאורת כפתור" - e200*: "זמן תאורת הגלגל" + fuze,e200*: "זמן תאורת הגלגל" *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" Index: apps/lang/nederlands.lang =================================================================== --- apps/lang/nederlands.lang (Revision 19084) +++ apps/lang/nederlands.lang (Arbeitskopie) @@ -10276,17 +10276,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Knoppen Licht Vertraging" - e200*: "Wiel Licht Vertraging" + fuze,e200*: "Wiel Licht Vertraging" *: none button_light: "Knoppen Licht Vertraging" - e200*: "Wiel Licht Vertraging" + fuze,e200*: "Wiel Licht Vertraging" Index: apps/lang/magyar.lang =================================================================== --- apps/lang/magyar.lang (Revision 19084) +++ apps/lang/magyar.lang (Arbeitskopie) @@ -3826,18 +3826,18 @@ user: *: none - e200*: "Wheel Light Timeout" - clip,c200,gigabeatf,mrobe100: "Button Light Timeout" + button_light: "Button Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none - e200*: "Kerék világításának hossza" - clip,c200,gigabeatf,mrobe100: "Gomb világításának hossza" + button_light: "Gomb világításának hossza" + fuze,e200*: "Kerék világításának hossza" *: none - e200*: "Wheel Light Timeout" - clip,c200,gigabeatf,mrobe100: "Button Light Timeout" + button_light: "Button Light Timeout" + fuze,e200*: "Wheel Light Timeout" Index: apps/lang/russian.lang =================================================================== --- apps/lang/russian.lang (Revision 19084) +++ apps/lang/russian.lang (Arbeitskopie) @@ -10945,17 +10945,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Таймаут подсветки клавиш" - e200*: "Таймаут подсветки колёсика" + fuze,e200*: "Таймаут подсветки колёсика" *: none button_light: "Таймаут подсветки клавиш" - e200*: "Таймаут подсветки колёсика" + fuze,e200*: "Таймаут подсветки колёсика" Index: apps/lang/thai.lang =================================================================== --- apps/lang/thai.lang (Revision 19084) +++ apps/lang/thai.lang (Arbeitskopie) @@ -3834,15 +3834,15 @@ user: *: none - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none - e200*: "เวลาเปิดไฟล้อหมุน" + fuze,e200*: "เวลาเปิดไฟล้อหมุน" *: none - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" Index: apps/lang/catala.lang =================================================================== --- apps/lang/catala.lang (Revision 19084) +++ apps/lang/catala.lang (Arbeitskopie) @@ -3828,17 +3828,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Apagat de llum de botons" - e200*: "Apagat de llum de roda" + fuze,e200*: "Apagat de llum de roda" *: none button_light: "Apagat de llum de botons" - e200*: "Apagat de llum de roda" + fuze,e200*: "Apagat de llum de roda" Index: apps/lang/francais.lang =================================================================== --- apps/lang/francais.lang (Revision 19084) +++ apps/lang/francais.lang (Arbeitskopie) @@ -3880,17 +3880,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Durée de l'éclairage des touches" - e200*: "Durée de l'éclairage de la molette" + fuze,e200*: "Durée de l'éclairage de la molette" *: none button_light: "Durée de l'éclairage des touches" - e200*: "Durée de l'éclairage de la molette" + fuze,e200*: "Durée de l'éclairage de la molette" Index: apps/lang/japanese.lang =================================================================== --- apps/lang/japanese.lang (Revision 19084) +++ apps/lang/japanese.lang (Arbeitskopie) @@ -3834,17 +3834,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "ボタンライトのタイムアウト" - e200*: "ホイールライトのタイムアウト" + fuze,e200*: "ホイールライトのタイムアウト" *: none button_light: "ボタンライトのタイムアウト" - e200*: "ホイールライトのタイムアウト" + fuze,e200*: "ホイールライトのタイムアウト" Index: apps/lang/english.lang =================================================================== --- apps/lang/english.lang (Revision 19084) +++ apps/lang/english.lang (Arbeitskopie) @@ -3924,17 +3924,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" Index: apps/lang/czech.lang =================================================================== --- apps/lang/czech.lang (Revision 19084) +++ apps/lang/czech.lang (Arbeitskopie) @@ -3835,15 +3835,15 @@ user: *: none - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none - e200*: "Časový limit osvětlení kolečka" + fuze,e200*: "Časový limit osvětlení kolečka" *: none - e200*: "Časový limit osvětlení kolečka" + fuze,e200*: "Časový limit osvětlení kolečka" Index: apps/lang/norsk.lang =================================================================== --- apps/lang/norsk.lang (Revision 19084) +++ apps/lang/norsk.lang (Arbeitskopie) @@ -10023,17 +10023,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Slukketid for knapplys" - e200*: "Slukketid for hjullys" + fuze,e200*: "Slukketid for hjullys" *: none button_light: "Tid før lys på knapper slukker" - e200*: "Tid før lys på hjul slukker" + fuze,e200*: "Tid før lys på hjul slukker" Index: apps/lang/finnish.lang =================================================================== --- apps/lang/finnish.lang (Revision 19084) +++ apps/lang/finnish.lang (Arbeitskopie) @@ -9974,17 +9974,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Painikevalon aikakatkaisu" - e200*: "Rullavalon aikakatkaisu" + fuze,e200*: "Rullavalon aikakatkaisu" *: none button_light: "Painikevalon aikakatkaisu" - e200*: "Rullavalon aikakatkaisu" + fuze,e200*: "Rullavalon aikakatkaisu" Index: apps/lang/italiano.lang =================================================================== --- apps/lang/italiano.lang (Revision 19084) +++ apps/lang/italiano.lang (Arbeitskopie) @@ -3853,17 +3853,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Tempo di spegnimento illuminazione tasti" - e200*: "Tempo di spegnimento illuminazione rotella" + fuze,e200*: "Tempo di spegnimento illuminazione rotella" *: none button_light: "Tempo di spegnimento illuminazione tasti" - e200*: "Tempo di spegnimento illuminazione rotella" + fuze,e200*: "Tempo di spegnimento illuminazione rotella" Index: apps/lang/espanol.lang =================================================================== --- apps/lang/espanol.lang (Revision 19084) +++ apps/lang/espanol.lang (Arbeitskopie) @@ -11181,17 +11181,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Tiempo de espera en la luz del botón" - e200*: "Tiempo de espera en la luz de la rueda" + fuze,e200*: "Tiempo de espera en la luz de la rueda" *: none button_light: "Tiempo de espera en la luz del botón" - e200*: "Tiempo de espera en la luz de la rueda" + fuze,e200*: "Tiempo de espera en la luz de la rueda" Index: apps/lang/tagalog.lang =================================================================== --- apps/lang/tagalog.lang (Revision 19084) +++ apps/lang/tagalog.lang (Arbeitskopie) @@ -3841,17 +3841,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Pahintuin buttones sa ilaw" - e200*: "Pahintuin gulong sa ilaw" + fuze,e200*: "Pahintuin gulong sa ilaw" *: none button_light: "" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" Index: apps/lang/chinese-simp.lang =================================================================== --- apps/lang/chinese-simp.lang (Revision 19084) +++ apps/lang/chinese-simp.lang (Arbeitskopie) @@ -10687,17 +10687,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "按键背光自动关闭时滞" - e200*: "转盘背光自动关闭时滞" + fuze,e200*: "转盘背光自动关闭时滞" *: none button_light: "按键背光自动关闭时滞" - e200*: "转盘背光自动关闭时滞" + fuze,e200*: "转盘背光自动关闭时滞" Index: apps/lang/portugues-brasileiro.lang =================================================================== --- apps/lang/portugues-brasileiro.lang (Revision 19084) +++ apps/lang/portugues-brasileiro.lang (Arbeitskopie) @@ -3851,17 +3851,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Duração da Luz do Botão" - e200*: "Duração da Luz da Roda" + fuze,e200*: "Duração da Luz da Roda" *: none button_light: "Duração da Luz do Botão" - e200*: "Duração da Luz da Roda" + fuze,e200*: "Duração da Luz da Roda" Index: apps/lang/romaneste.lang =================================================================== --- apps/lang/romaneste.lang (Revision 19084) +++ apps/lang/romaneste.lang (Arbeitskopie) @@ -10303,17 +10303,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Timp iluminare butoane" - e200*: "Timp iluminare rotita" + fuze,e200*: "Timp iluminare rotita" *: none button_light: "Timp iluminare butoane" - e200*: "Timp iluminare rotita" + fuze,e200*: "Timp iluminare rotita" Index: apps/lang/norsk-nynorsk.lang =================================================================== --- apps/lang/norsk-nynorsk.lang (Revision 19084) +++ apps/lang/norsk-nynorsk.lang (Arbeitskopie) @@ -9871,17 +9871,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Avbrotstid for knappelys" - e200*: "Avbrotstid for hjullys" + fuze,e200*: "Avbrotstid for hjullys" *: none button_light: "Avbrotstid for knappelys" - e200*: "Avbrotstid for hjullys" + fuze,e200*: "Avbrotstid for hjullys" Index: apps/lang/greek.lang =================================================================== --- apps/lang/greek.lang (Revision 19084) +++ apps/lang/greek.lang (Arbeitskopie) @@ -3838,17 +3838,17 @@ *: none button_light: "Button Light Timeout" - e200*: "Wheel Light Timeout" + fuze,e200*: "Wheel Light Timeout" *: none button_light: "Χρόνος σβησίματος πλήκτρων" - e200*: "Χρόνος σβησίματος τροχού" + fuze,e200*: "Χρόνος σβησίματος τροχού" *: none button_light: "Χρόνος σβησίματος πλήκτρων" - e200*: "Χρόνος σβησίματος τροχού" + fuze,e200*: "Χρόνος σβησίματος τροχού" Index: apps/SOURCES =================================================================== --- apps/SOURCES (Revision 19084) +++ apps/SOURCES (Arbeitskopie) @@ -212,4 +212,6 @@ keymaps/keymap-iaudio67.c #elif CONFIG_KEYPAD == LOGIK_DAX_PAD keymaps/keymap-logikdax.c +#elif CONFIG_KEYPAD == SANSA_FUZE_PAD +keymaps/keymap-fuze.c #endif Index: apps/keymaps/keymap-fuze.c =================================================================== --- apps/keymaps/keymap-fuze.c (Revision 0) +++ apps/keymaps/keymap-fuze.c (Revision 0) @@ -0,0 +1,324 @@ +/*************************************************************************** + * __________ __ ___. + * Open \______ \ ____ ____ | | _\_ |__ _______ ___ + * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / + * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < + * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ + * \/ \/ \/ \/ \/ + * $Id: keymap-e200.c 18146 2008-07-29 11:47:40Z marcguay $ + * + * Copyright (C) Thomas Martitz 2008 + * Copyright (C) Barry Wardell 2006 + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY + * KIND, either express or implied. + * + ****************************************************************************/ +/* Button Code Definitions for Sandisk Sansa Fuze target, based on e200 keymap*/ + +#include "config.h" +#include "action.h" +#include "button.h" +#include "settings.h" + +/* {Action Code, Button code, Prereq button code } */ + +/* + * The format of the list is as follows + * { Action Code, Button code, Prereq button code } + * if there's no need to check the previous button's value, use BUTTON_NONE + * Insert LAST_ITEM_IN_LIST at the end of each mapping + */ +static const struct button_mapping button_context_standard[] = { + { ACTION_STD_PREV, BUTTON_SCROLL_BACK, BUTTON_NONE }, + { ACTION_STD_PREVREPEAT, BUTTON_SCROLL_BACK|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_STD_NEXT, BUTTON_SCROLL_FWD, BUTTON_NONE }, + { ACTION_STD_NEXTREPEAT, BUTTON_SCROLL_FWD|BUTTON_REPEAT, BUTTON_NONE }, + + { ACTION_STD_MENU, BUTTON_HOME|BUTTON_REL, BUTTON_DOWN }, + + { ACTION_STD_OK, BUTTON_SELECT|BUTTON_REL, BUTTON_SELECT }, + { ACTION_STD_OK, BUTTON_RIGHT, BUTTON_NONE }, + { ACTION_STD_CANCEL, BUTTON_LEFT, BUTTON_NONE }, + + { ACTION_STD_QUICKSCREEN, BUTTON_HOME|BUTTON_REPEAT, BUTTON_HOME }, + { ACTION_STD_CONTEXT, BUTTON_SELECT|BUTTON_REPEAT, BUTTON_SELECT }, + + LAST_ITEM_IN_LIST +}; /* button_context_standard */ + + +static const struct button_mapping button_context_wps[] = { + { ACTION_WPS_PLAY, BUTTON_UP|BUTTON_REL, BUTTON_UP }, + { ACTION_WPS_STOP, BUTTON_POWER|BUTTON_REL, BUTTON_POWER }, + + { ACTION_WPS_SKIPPREV, BUTTON_LEFT|BUTTON_REL, BUTTON_LEFT }, + { ACTION_WPS_SEEKBACK, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_WPS_STOPSEEK, BUTTON_LEFT|BUTTON_REL, BUTTON_LEFT|BUTTON_REPEAT }, + + { ACTION_WPS_SKIPNEXT, BUTTON_RIGHT|BUTTON_REL, BUTTON_RIGHT }, + { ACTION_WPS_SEEKFWD, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_WPS_STOPSEEK, BUTTON_RIGHT|BUTTON_REL, BUTTON_RIGHT|BUTTON_REPEAT }, + + { ACTION_WPS_ABSETB_NEXTDIR, BUTTON_HOME|BUTTON_RIGHT, BUTTON_HOME }, + { ACTION_WPS_ABSETA_PREVDIR, BUTTON_HOME|BUTTON_LEFT, BUTTON_HOME }, + { ACTION_WPS_ABRESET, BUTTON_HOME|BUTTON_UP, BUTTON_HOME }, + + { ACTION_WPS_VOLUP, BUTTON_SCROLL_FWD, BUTTON_NONE }, + { ACTION_WPS_VOLUP, BUTTON_SCROLL_FWD|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_WPS_VOLDOWN, BUTTON_SCROLL_BACK, BUTTON_NONE }, + { ACTION_WPS_VOLDOWN, BUTTON_SCROLL_BACK|BUTTON_REPEAT, BUTTON_NONE }, + + { ACTION_WPS_BROWSE, BUTTON_SELECT|BUTTON_REL, BUTTON_SELECT }, + + { ACTION_WPS_CONTEXT, BUTTON_SELECT|BUTTON_REPEAT, BUTTON_SELECT }, + { ACTION_WPS_QUICKSCREEN, BUTTON_HOME|BUTTON_REPEAT, BUTTON_HOME }, + + { ACTION_WPS_MENU, BUTTON_HOME|BUTTON_REL, BUTTON_HOME }, + + { ACTION_WPS_PITCHSCREEN, BUTTON_HOME|BUTTON_UP, BUTTON_HOME }, + { ACTION_WPS_ID3SCREEN, BUTTON_HOME|BUTTON_DOWN, BUTTON_HOME }, + + LAST_ITEM_IN_LIST +}; /* button_context_wps */ + +static const struct button_mapping button_context_settings[] = { + { ACTION_STD_CANCEL, BUTTON_HOME, BUTTON_NONE }, + { ACTION_SETTINGS_INC, BUTTON_SCROLL_FWD, BUTTON_NONE }, + { ACTION_SETTINGS_INCREPEAT,BUTTON_SCROLL_FWD|BUTTON_REPEAT,BUTTON_NONE }, + { ACTION_SETTINGS_DEC, BUTTON_SCROLL_BACK, BUTTON_NONE }, + { ACTION_SETTINGS_DECREPEAT,BUTTON_SCROLL_BACK|BUTTON_REPEAT,BUTTON_NONE }, + + { ACTION_STD_PREV, BUTTON_LEFT, BUTTON_NONE }, + { ACTION_STD_PREVREPEAT, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_STD_NEXT, BUTTON_RIGHT, BUTTON_NONE }, + { ACTION_STD_NEXTREPEAT, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_SETTINGS_RESET, BUTTON_SELECT, BUTTON_NONE }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD), +}; /* button_context_settings */ + +static const struct button_mapping button_context_list[] = { + { ACTION_LISTTREE_PGUP, BUTTON_HOME|BUTTON_SCROLL_BACK, BUTTON_HOME }, + { ACTION_LISTTREE_PGDOWN, BUTTON_HOME|BUTTON_SCROLL_FWD, BUTTON_HOME }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD) +}; /* button_context_list */ + +static const struct button_mapping button_context_tree[] = { + { ACTION_TREE_WPS, BUTTON_UP|BUTTON_REL, BUTTON_UP }, + { ACTION_TREE_STOP, BUTTON_POWER|BUTTON_REL, BUTTON_POWER }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_LIST), +}; /* button_context_tree */ + +static const struct button_mapping button_context_listtree_scroll_without_combo[] = { + { ACTION_NONE, BUTTON_LEFT, BUTTON_NONE }, + { ACTION_STD_CANCEL, BUTTON_LEFT|BUTTON_REL, BUTTON_LEFT }, + { ACTION_TREE_ROOT_INIT, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_LEFT }, + { ACTION_TREE_PGLEFT, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_TREE_PGLEFT, BUTTON_LEFT|BUTTON_REL, BUTTON_LEFT|BUTTON_REPEAT }, + { ACTION_NONE, BUTTON_RIGHT, BUTTON_NONE }, + { ACTION_STD_OK, BUTTON_RIGHT|BUTTON_REL, BUTTON_RIGHT }, + { ACTION_TREE_PGRIGHT, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_TREE_PGRIGHT, BUTTON_RIGHT|BUTTON_REL, BUTTON_RIGHT|BUTTON_REPEAT }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_CUSTOM|CONTEXT_TREE), +}; /* button_context_listtree_scroll_without_combo */ + +static const struct button_mapping button_context_listtree_scroll_with_combo[] = { + { ACTION_TREE_ROOT_INIT,BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_TREE_PGLEFT, BUTTON_HOME|BUTTON_LEFT, BUTTON_HOME }, + { ACTION_TREE_PGLEFT, BUTTON_HOME|BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_TREE_PGRIGHT, BUTTON_HOME|BUTTON_RIGHT, BUTTON_HOME }, + { ACTION_TREE_PGRIGHT, BUTTON_HOME|BUTTON_RIGHT|BUTTON_REPEAT,BUTTON_NONE }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_CUSTOM|CONTEXT_TREE), +}; /* button_context_listtree_scroll_with_combo */ + +static const struct button_mapping button_context_yesno[] = { + { ACTION_YESNO_ACCEPT, BUTTON_SELECT, BUTTON_NONE }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD), +}; /* button_context_settings_yesno */ + +static const struct button_mapping button_context_quickscreen[] = { + { ACTION_NONE, BUTTON_LEFT, BUTTON_NONE }, + { ACTION_STD_CANCEL, BUTTON_HOME|BUTTON_REL, BUTTON_NONE }, + { ACTION_QS_DOWNINV, BUTTON_UP|BUTTON_REL, BUTTON_NONE }, + { ACTION_QS_DOWNINV, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_QS_DOWN, BUTTON_DOWN|BUTTON_REL, BUTTON_NONE }, + { ACTION_QS_DOWN, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_QS_LEFT, BUTTON_LEFT|BUTTON_REL, BUTTON_NONE }, + { ACTION_QS_LEFT, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_QS_RIGHT, BUTTON_RIGHT|BUTTON_REL, BUTTON_NONE }, + { ACTION_QS_RIGHT, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD), +}; /* button_context_quickscreen */ + +static const struct button_mapping button_context_settings_right_is_inc[] = { + { ACTION_SETTINGS_INC, BUTTON_SCROLL_FWD, BUTTON_NONE }, + { ACTION_SETTINGS_INCREPEAT, BUTTON_SCROLL_FWD|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_SETTINGS_DEC, BUTTON_SCROLL_BACK, BUTTON_NONE }, + { ACTION_SETTINGS_DECREPEAT, BUTTON_SCROLL_BACK|BUTTON_REPEAT,BUTTON_NONE }, + + { ACTION_STD_PREV, BUTTON_UP|BUTTON_REL, BUTTON_NONE }, + { ACTION_STD_PREVREPEAT, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_STD_NEXT, BUTTON_DOWN|BUTTON_REL, BUTTON_NONE }, + { ACTION_STD_NEXTREPEAT, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_NONE, BUTTON_SELECT, BUTTON_NONE }, + { ACTION_STD_OK, BUTTON_SELECT|BUTTON_REL, BUTTON_NONE }, + { ACTION_NONE, BUTTON_LEFT|BUTTON_REL, BUTTON_LEFT }, + { ACTION_NONE, BUTTON_LEFT, BUTTON_NONE }, + { ACTION_STD_CANCEL, BUTTON_LEFT|BUTTON_REL, BUTTON_NONE }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD), +}; /* button_context_settings_right_is_inc */ + +static const struct button_mapping button_context_settings_time[] = { + { ACTION_STD_PREV, BUTTON_UP|BUTTON_REL, BUTTON_NONE }, + { ACTION_STD_PREVREPEAT, BUTTON_UP|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_STD_NEXT, BUTTON_DOWN|BUTTON_REL, BUTTON_NONE }, + { ACTION_STD_NEXTREPEAT, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_SETTINGS) +}; /* button_context_settings_time */ + +static const struct button_mapping button_context_pitchscreen[] = { + { ACTION_PS_INC_SMALL, BUTTON_SCROLL_FWD, BUTTON_NONE }, + { ACTION_PS_INC_BIG, BUTTON_SCROLL_FWD|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_PS_DEC_SMALL, BUTTON_SCROLL_BACK, BUTTON_NONE }, + { ACTION_PS_DEC_BIG, BUTTON_SCROLL_BACK|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_PS_NUDGE_LEFT, BUTTON_LEFT, BUTTON_NONE }, + { ACTION_PS_NUDGE_LEFTOFF, BUTTON_LEFT|BUTTON_REL, BUTTON_NONE }, + { ACTION_PS_NUDGE_RIGHT, BUTTON_RIGHT, BUTTON_NONE }, + { ACTION_PS_NUDGE_RIGHTOFF, BUTTON_RIGHT|BUTTON_REL, BUTTON_NONE }, + { ACTION_PS_TOGGLE_MODE, BUTTON_DOWN, BUTTON_NONE }, + { ACTION_PS_RESET, BUTTON_SELECT, BUTTON_NONE }, + { ACTION_PS_EXIT, BUTTON_HOME, BUTTON_NONE }, + { ACTION_PS_EXIT, BUTTON_UP, BUTTON_NONE }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD), +}; /* button_context_pitchscreen */ + +/** Recording Screen **/ +static const struct button_mapping button_context_recscreen[] = { + { ACTION_REC_PAUSE, BUTTON_UP|BUTTON_REL, BUTTON_UP }, + { ACTION_STD_CANCEL, BUTTON_HOME|BUTTON_REL, BUTTON_HOME }, + { ACTION_REC_NEWFILE, BUTTON_DOWN|BUTTON_REL, BUTTON_DOWN }, + { ACTION_STD_MENU, BUTTON_SELECT|BUTTON_REPEAT, BUTTON_SELECT}, + { ACTION_SETTINGS_INC, BUTTON_RIGHT, BUTTON_NONE }, + { ACTION_SETTINGS_INCREPEAT, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_SETTINGS_DEC, BUTTON_LEFT, BUTTON_NONE }, + { ACTION_SETTINGS_DECREPEAT, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_STD_PREV, BUTTON_SCROLL_BACK, BUTTON_NONE }, + { ACTION_STD_PREV, BUTTON_SCROLL_BACK|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_STD_NEXT, BUTTON_SCROLL_FWD, BUTTON_NONE }, + { ACTION_STD_NEXT, BUTTON_SCROLL_FWD|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_NONE, BUTTON_DOWN, BUTTON_DOWN }, + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_STD) +}; /* button_context_recscreen */ + +/** FM Radio Screen **/ +static const struct button_mapping button_context_radio[] = { + { ACTION_FM_MENU, BUTTON_SELECT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_FM_PRESET, BUTTON_SELECT|BUTTON_REL, BUTTON_NONE }, + { ACTION_FM_STOP, BUTTON_POWER|BUTTON_REL, BUTTON_NONE }, + { ACTION_FM_MODE, BUTTON_UP|BUTTON_REPEAT, BUTTON_UP }, + { ACTION_FM_EXIT, BUTTON_DOWN|BUTTON_REL, BUTTON_NONE }, + { ACTION_FM_PLAY, BUTTON_UP|BUTTON_REL, BUTTON_UP }, + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_SETTINGS) +}; /* button_context_radio */ + +static const struct button_mapping button_context_keyboard[] = { + { ACTION_KBD_LEFT, BUTTON_LEFT, BUTTON_NONE }, + { ACTION_KBD_LEFT, BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_KBD_RIGHT, BUTTON_RIGHT, BUTTON_NONE }, + { ACTION_KBD_RIGHT, BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE }, + +/* + { ACTION_KBD_CURSOR_LEFT, BUTTON_REC|BUTTON_LEFT, BUTTON_NONE }, + { ACTION_KBD_CURSOR_LEFT, BUTTON_REC|BUTTON_LEFT|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_KBD_CURSOR_RIGHT, BUTTON_REC|BUTTON_RIGHT, BUTTON_NONE }, + { ACTION_KBD_CURSOR_RIGHT, BUTTON_REC|BUTTON_RIGHT|BUTTON_REPEAT, BUTTON_NONE }, +*/ + + { ACTION_KBD_UP, BUTTON_SCROLL_BACK, BUTTON_NONE }, + { ACTION_KBD_UP, BUTTON_SCROLL_BACK|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_KBD_DOWN, BUTTON_SCROLL_FWD, BUTTON_NONE }, + { ACTION_KBD_DOWN, BUTTON_SCROLL_FWD|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_KBD_PAGE_FLIP, BUTTON_HOME|BUTTON_SELECT, BUTTON_HOME }, + { ACTION_KBD_BACKSPACE, BUTTON_DOWN, BUTTON_NONE }, + { ACTION_KBD_BACKSPACE, BUTTON_DOWN|BUTTON_REPEAT, BUTTON_NONE }, + { ACTION_KBD_SELECT, BUTTON_SELECT, BUTTON_NONE }, + { ACTION_KBD_DONE, BUTTON_UP, BUTTON_NONE }, + { ACTION_KBD_ABORT, BUTTON_HOME|BUTTON_REL, BUTTON_NONE }, + + LAST_ITEM_IN_LIST +}; /* button_context_keyboard */ + +static const struct button_mapping button_context_bmark[] = { + { ACTION_BMS_DELETE, BUTTON_HOME, BUTTON_NONE }, + + LAST_ITEM_IN_LIST__NEXTLIST(CONTEXT_LIST), +}; /* button_context_bmark */ + +/* get_context_mapping returns a pointer to one of the above defined arrays depending on the context */ +const struct button_mapping* get_context_mapping(int context) +{ + switch (context) + { + case CONTEXT_STD: + return button_context_standard; + + case CONTEXT_WPS: + return button_context_wps; + + case CONTEXT_LIST: + return button_context_list; + case CONTEXT_TREE: + case CONTEXT_MAINMENU: + if (global_settings.hold_lr_for_scroll_in_list) + return button_context_listtree_scroll_without_combo; + else + return button_context_listtree_scroll_with_combo; + case CONTEXT_CUSTOM|CONTEXT_TREE: + return button_context_tree; + + case CONTEXT_SETTINGS: + return button_context_settings; + case CONTEXT_CUSTOM|CONTEXT_SETTINGS: + case CONTEXT_SETTINGS_COLOURCHOOSER: + case CONTEXT_SETTINGS_EQ: + case CONTEXT_SETTINGS_RECTRIGGER: + return button_context_settings_right_is_inc; + + case CONTEXT_SETTINGS_TIME: + return button_context_settings_time; + + case CONTEXT_YESNOSCREEN: + return button_context_yesno; + case CONTEXT_FM: + return button_context_radio; + case CONTEXT_BOOKMARKSCREEN: + return button_context_bmark; + case CONTEXT_QUICKSCREEN: + return button_context_quickscreen; + case CONTEXT_PITCHSCREEN: + return button_context_pitchscreen; + case CONTEXT_RECSCREEN: + return button_context_recscreen; + case CONTEXT_KEYBOARD: + return button_context_keyboard; + + default: + return button_context_standard; + } + return button_context_standard; +} Index: firmware/target/arm/as3525/sansa-fuze/backlight-target.h =================================================================== --- firmware/target/arm/as3525/sansa-fuze/backlight-target.h (Revision 19084) +++ firmware/target/arm/as3525/sansa-fuze/backlight-target.h (Arbeitskopie) @@ -26,7 +26,8 @@ void _backlight_off(void); void _backlight_set_brightness(int brightness); int __backlight_is_on(void); - +#ifdef HAVE_BUTTON_LIGHT void _buttonlight_on(void); void _buttonlight_off(void); #endif +#endif Index: firmware/target/arm/as3525/sansa-fuze/button-target.h =================================================================== --- firmware/target/arm/as3525/sansa-fuze/button-target.h (Revision 19084) +++ firmware/target/arm/as3525/sansa-fuze/button-target.h (Arbeitskopie) @@ -37,12 +37,12 @@ /* Sandisk Sansa Fuze button codes */ -/* TODO: These are just a copy of the E200 */ +/* Main unit's buttons */ +#define BUTTON_HOME 0x00000001 -/* Main unit's buttons */ -#define BUTTON_REC 0x00000001 #define BUTTON_DOWN 0x00000002 #define BUTTON_RIGHT 0x00000004 + #define BUTTON_LEFT 0x00000008 #define BUTTON_SELECT 0x00000010 #define BUTTON_UP 0x00000020 @@ -51,8 +51,12 @@ #define BUTTON_SCROLL_BACK 0x00000080 #define BUTTON_SCROLL_FWD 0x00000100 -#define BUTTON_MAIN 0x00000fff +#define BUTTON_HOLD 0x00000200 +#define BUTTON_MAIN (BUTTON_HOME|BUTTON_DOWN|BUTTON_RIGHT|BUTTON_LEFT \ + |BUTTON_SELECT|BUTTON_UP|BUTTON_POWER \ + |BUTTON_SCROLLBACK|BUTTON_SCROLL_FWD|BUTTON_HOLD) + /* No Remote control */ #define BUTTON_REMOTE 0 Index: uisimulator/sdl/button.c =================================================================== --- uisimulator/sdl/button.c (Revision 19084) +++ uisimulator/sdl/button.c (Arbeitskopie) @@ -950,7 +950,43 @@ case SDLK_SPACE: new_btn = BUTTON_SELECT; break; - +#elif CONFIG_KEYPAD == SANSA_FUZE_PAD + case SDLK_KP4: + case SDLK_LEFT: + new_btn = BUTTON_LEFT; + break; + case SDLK_KP6: + case SDLK_RIGHT: + new_btn = BUTTON_RIGHT; + break; + case SDLK_KP8: + case SDLK_UP: + new_btn = BUTTON_SCROLL_BACK; + break; + case SDLK_KP2: + case SDLK_DOWN: + new_btn = BUTTON_SCROLL_FWD; + break; + case SDLK_PAGEUP: + case SDLK_KP9: + new_btn = BUTTON_UP; + break; + case SDLK_PAGEDOWN: + case SDLK_KP3: + new_btn = BUTTON_DOWN; + break; + case SDLK_KP_MINUS: + new_btn = BUTTON_POWER; + break; + case SDLK_KP_MULTIPLY: + new_btn = BUTTON_HOME; + break; + case SDLK_KP5: + case SDLK_SPACE: + case SDLK_KP_ENTER: + case SDLK_RETURN: + new_btn = BUTTON_SELECT; + break; #elif CONFIG_KEYPAD == SANSA_CLIP_PAD case SDLK_KP4: case SDLK_LEFT: Index: uisimulator/sdl/uisdl.h =================================================================== --- uisimulator/sdl/uisdl.h (Revision 19084) +++ uisimulator/sdl/uisdl.h (Arbeitskopie) @@ -436,6 +436,16 @@ #define UI_LCD_FGCOLOR 0, 0, 0 /* foreground color of LCD (no backlight) */ #define UI_LCD_FGCOLORLIGHT 0, 0, 0 /* foreground color of LCD (backlight) */ +#elif defined(SANSA_FUZE) +#define UI_TITLE "Sansa Fuze" +#define UI_WIDTH 279 /* width of GUI window */ +#define UI_HEIGHT 449 /* height of GUI window */ +/* high-colour */ +#define UI_LCD_POSX 30 /* x position of lcd */ +#define UI_LCD_POSY 31 /* y position of lcd */ +#define UI_LCD_WIDTH LCD_WIDTH +#define UI_LCD_HEIGHT LCD_HEIGHT + #elif defined(SANSA_CLIP) #define UI_TITLE "Sansa Clip" #define UI_WIDTH 205 /* width of GUI window */