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 */