summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJean-Louis Biasini <jlbiasini@gmail.com>2012-02-25 21:29:01 +0100
committerThomas Martitz <kugel@rockbox.org>2012-03-03 12:05:58 +0100
commit10c566ed94189141ba5aca287c74cd984a2010f5 (patch)
tree0cd17a732365486170521fc6c8a56dc6bc5753da
parentf1e1ab8d416058692281ed7442485ed6037f7afb (diff)
downloadrockbox-10c566ed94189141ba5aca287c74cd984a2010f5.zip
rockbox-10c566ed94189141ba5aca287c74cd984a2010f5.tar.gz
rockbox-10c566ed94189141ba5aca287c74cd984a2010f5.tar.bz2
rockbox-10c566ed94189141ba5aca287c74cd984a2010f5.tar.xz
Plugin logo PLA integration (code + manual)
This commit changes: 1) replace all keymaps with PLA ones. 2) do the required change to the manual in order to match code's changes. 3) add an alternative exit button (PLA_EXIT or PLA_CANCEL) 4) add the possibility to change values repeatily by holding key pressed. Change-Id: Ie68fd4e94830bba8a592941ee4e8b10aeacda923 Reviewed-on: http://gerrit.rockbox.org/127 Reviewed-by: Thomas Martitz <kugel@rockbox.org> Tested-by: Thomas Martitz <kugel@rockbox.org>
-rw-r--r--apps/plugins/logo.c266
-rw-r--r--manual/plugins/logo.tex29
2 files changed, 34 insertions, 261 deletions
diff --git a/apps/plugins/logo.c b/apps/plugins/logo.c
index 14360b4..aae9e54 100644
--- a/apps/plugins/logo.c
+++ b/apps/plugins/logo.c
@@ -20,8 +20,15 @@
**************************************************************************/
#include "plugin.h"
#include "lib/playergfx.h"
+#include "lib/pluginlib_actions.h"
-
+/* this set the context to use with PLA */
+static const struct button_mapping *plugin_contexts[]
+ = { pla_main_ctx,
+#ifdef HAVE_REMOTE_LCD
+ pla_remote_ctx,
+#endif
+ };
#ifdef HAVE_LCD_BITMAP
#define DISPLAY_WIDTH LCD_WIDTH
@@ -57,223 +64,17 @@ const unsigned char rockbox16x7[] = {
};
#endif /* !LCD_BITMAP */
-/* variable button definitions */
-#if CONFIG_KEYPAD == PLAYER_PAD
-#define LP_QUIT BUTTON_STOP
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y (BUTTON_ON | BUTTON_LEFT)
-#define LP_INC_Y (BUTTON_ON | BUTTON_RIGHT)
-
-#elif (CONFIG_KEYPAD == IPOD_4G_PAD) || \
- (CONFIG_KEYPAD == IPOD_3G_PAD) || \
- (CONFIG_KEYPAD == IPOD_1G2G_PAD)
-#define LP_QUIT BUTTON_MENU
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_SCROLL_BACK
-#define LP_INC_Y BUTTON_SCROLL_FWD
-
-#elif CONFIG_KEYPAD == IRIVER_IFP7XX_PAD
-#define LP_QUIT BUTTON_PLAY
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == IAUDIO_X5M5_PAD
-#define LP_QUIT BUTTON_POWER
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == GIGABEAT_PAD
-#define LP_QUIT BUTTON_POWER
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif (CONFIG_KEYPAD == SANSA_E200_PAD) || \
- (CONFIG_KEYPAD == SANSA_C200_PAD) || \
- (CONFIG_KEYPAD == SANSA_CLIP_PAD) || \
- (CONFIG_KEYPAD == SANSA_M200_PAD) || \
- (CONFIG_KEYPAD == SANSA_CONNECT_PAD)
-#define LP_QUIT BUTTON_POWER
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif (CONFIG_KEYPAD == SANSA_FUZE_PAD)
-#define LP_QUIT (BUTTON_HOME|BUTTON_REPEAT)
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == IRIVER_H10_PAD
-#define LP_QUIT BUTTON_POWER
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_SCROLL_DOWN
-#define LP_INC_Y BUTTON_SCROLL_UP
-
-#elif CONFIG_KEYPAD == MROBE500_PAD
-#define LP_QUIT BUTTON_POWER
-
-#elif CONFIG_KEYPAD == GIGABEAT_S_PAD || \
- CONFIG_KEYPAD == SAMSUNG_YPR0_PAD
-#define LP_QUIT BUTTON_BACK
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == MROBE100_PAD
-#define LP_QUIT BUTTON_POWER
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == IAUDIO_M3_PAD
-#define LP_QUIT BUTTON_RC_REC
-#define LP_DEC_X BUTTON_RC_REW
-#define LP_INC_X BUTTON_RC_FF
-#define LP_DEC_Y BUTTON_RC_VOL_DOWN
-#define LP_INC_Y BUTTON_RC_VOL_UP
-
-#elif CONFIG_KEYPAD == COWON_D2_PAD
-#define LP_QUIT BUTTON_POWER
-
-#elif CONFIG_KEYPAD == IAUDIO67_PAD
-#define LP_QUIT BUTTON_POWER
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_PLAY
-#define LP_INC_Y BUTTON_STOP
-
-#elif CONFIG_KEYPAD == CREATIVEZVM_PAD
-#define LP_QUIT BUTTON_BACK
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == PHILIPS_HDD1630_PAD
-#define LP_QUIT BUTTON_POWER
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == PHILIPS_HDD6330_PAD
-#define LP_QUIT BUTTON_POWER
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == PHILIPS_SA9200_PAD
-#define LP_QUIT BUTTON_POWER
-#define LP_DEC_X BUTTON_PREV
-#define LP_INC_X BUTTON_NEXT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == ONDAVX747_PAD
-#define LP_QUIT BUTTON_POWER
-#elif CONFIG_KEYPAD == ONDAVX777_PAD
-#define LP_QUIT BUTTON_POWER
-
-#elif CONFIG_KEYPAD == SAMSUNG_YH_PAD
-#define LP_QUIT BUTTON_PLAY
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == PBELL_VIBE500_PAD
-#define LP_QUIT BUTTON_REC
-#define LP_DEC_X BUTTON_PREV
-#define LP_INC_X BUTTON_NEXT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == MPIO_HD200_PAD
-#define LP_QUIT (BUTTON_REC|BUTTON_PLAY)
-#define LP_DEC_X BUTTON_VOL_DOWN
-#define LP_INC_X BUTTON_VOL_UP
-#define LP_DEC_Y BUTTON_REW
-#define LP_INC_Y BUTTON_FF
-
-#elif CONFIG_KEYPAD == MPIO_HD300_PAD
-#define LP_QUIT (BUTTON_MENU|BUTTON_REPEAT)
-#define LP_DEC_X BUTTON_REW
-#define LP_INC_X BUTTON_FF
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#elif CONFIG_KEYPAD == SANSA_FUZEPLUS_PAD
-#define LP_QUIT BUTTON_POWER
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-
-#else
-#define LP_QUIT BUTTON_OFF
-#define LP_DEC_X BUTTON_LEFT
-#define LP_INC_X BUTTON_RIGHT
-#define LP_DEC_Y BUTTON_DOWN
-#define LP_INC_Y BUTTON_UP
-#endif
-
-#ifdef CONFIG_REMOTE_KEYPAD
-#if (CONFIG_REMOTE_KEYPAD == H100_REMOTE) || \
- (CONFIG_REMOTE_KEYPAD == H300_REMOTE)
-#define LP_R_QUIT BUTTON_RC_STOP
-#define LP_R_DEC_X BUTTON_RC_REW
-#define LP_R_INC_X BUTTON_RC_FF
-#define LP_R_DEC_Y BUTTON_RC_SOURCE
-#define LP_R_INC_Y BUTTON_RC_BITRATE
-
-#elif CONFIG_REMOTE_KEYPAD == IAUDIO_REMOTE
-#define LP_R_QUIT BUTTON_RC_REC
-#define LP_R_DEC_X BUTTON_RC_REW
-#define LP_R_INC_X BUTTON_RC_FF
-#define LP_R_DEC_Y BUTTON_RC_VOL_DOWN
-#define LP_R_INC_Y BUTTON_RC_VOL_UP
-
-#elif (CONFIG_REMOTE_KEYPAD == MROBE_REMOTE)
-#define LP_R_QUIT BUTTON_RC_HEART
-#define LP_R_DEC_X BUTTON_RC_REW
-#define LP_R_INC_X BUTTON_RC_FF
-#define LP_R_DEC_Y BUTTON_RC_DOWN
-#define LP_R_INC_Y BUTTON_RC_PLAY
-#endif
-
-#endif /* CONFIG_REMOTE_KEYPAD */
-
-#ifdef HAVE_TOUCHSCREEN
-#ifndef LP_QUIT
-#define LP_QUIT BUTTON_TOPLEFT
-#endif
-#ifndef LP_DEC_X
-#define LP_DEC_X BUTTON_MIDLEFT
-#endif
-#ifndef LP_INC_X
-#define LP_INC_X BUTTON_MIDRIGHT
-#endif
-#ifndef LP_DEC_Y
-#define LP_DEC_Y BUTTON_TOPMIDDLE
-#endif
-#ifndef LP_INC_Y
-#define LP_INC_Y BUTTON_BOTTOMMIDDLE
-#endif
-#endif
+/* We use PLA */
+#define LP_QUIT PLA_EXIT
+#define LP_QUIT2 PLA_CANCEL
+#define LP_DEC_X PLA_LEFT
+#define LP_DEC_X_REPEAT PLA_LEFT_REPEAT
+#define LP_INC_X PLA_RIGHT
+#define LP_INC_X_REPEAT PLA_RIGHT_REPEAT
+#define LP_DEC_Y PLA_DOWN
+#define LP_DEC_Y_REPEAT PLA_DOWN_REPEAT
+#define LP_INC_Y PLA_UP
+#define LP_INC_Y_REPEAT PLA_UP_REPEAT
enum plugin_status plugin_start(const void* parameter) {
int button;
@@ -350,41 +151,36 @@ enum plugin_status plugin_start(const void* parameter) {
pgfx_update();
#endif
rb->sleep(HZ/timer);
-
- button = rb->button_get(false);
+
+
+
+ /*We get button from PLA this way */
+ button = pluginlib_getaction(TIMEOUT_NOBLOCK, plugin_contexts,
+ ARRAYLEN(plugin_contexts));
+
switch (button) {
case LP_QUIT:
-#ifdef CONFIG_REMOTE_KEYPAD
- case LP_R_QUIT:
-#endif
+ case LP_QUIT2:
#ifdef HAVE_LCD_CHARCELLS
pgfx_release();
#endif
return PLUGIN_OK;
case LP_DEC_X:
-#ifdef CONFIG_REMOTE_KEYPAD
- case LP_R_DEC_X:
-#endif
+ case LP_DEC_X_REPEAT:
if (dx)
dx += (dx < 0) ? 1 : -1;
break;
case LP_INC_X:
-#ifdef CONFIG_REMOTE_KEYPAD
- case LP_R_INC_X:
-#endif
+ case LP_INC_X_REPEAT:
dx += (dx < 0) ? -1 : 1;
break;
case LP_DEC_Y:
-#ifdef CONFIG_REMOTE_KEYPAD
- case LP_R_DEC_Y:
-#endif
+ case LP_DEC_Y_REPEAT:
if (dy)
dy += (dy < 0) ? 1 : -1;
break;
case LP_INC_Y:
-#ifdef CONFIG_REMOTE_KEYPAD
- case LP_R_INC_Y:
-#endif
+ case LP_INC_Y_REPEAT:
dy += (dy < 0) ? -1 : 1;
break;
diff --git a/manual/plugins/logo.tex b/manual/plugins/logo.tex
index 776f274..7239d42 100644
--- a/manual/plugins/logo.tex
+++ b/manual/plugins/logo.tex
@@ -2,46 +2,23 @@
\subsection{Logo}
Demo showing the Rockbox logo bouncing around the screen.
\begin{btnmap}
- \nopt{touchscreen,IAUDIO_M3_PAD,MPIO_HD200_PAD,MPIO_HD300_PAD}%
- {\ButtonRight / \ButtonLeft}%
- \opt{MPIO_HD200_PAD}{\ButtonVolUp / \ButtonVolDown}
- \opt{MPIO_HD300_PAD}{\ButtonFF / \ButtonRew}
- \opt{touchscreen}{\TouchMidRight / \TouchMidLeft}
+ \PluginRight{} / \PluginLeft
&
\opt{HAVEREMOTEKEYMAP}{
- \opt{IRIVER_RC_H100_PAD}{\ButtonRCRew\ / \ButtonRCFF}
&}
Increase / decrease speed on the x-axis
\\
- \nopt{PLAYER_PAD,IPOD_4G_PAD,IPOD_3G_PAD,IRIVER_H10_PAD,touchscreen%
- ,IAUDIO_M3_PAD,MPIO_HD200_PAD,MPIO_HD300_PAD}%
- {\ButtonUp\ / \ButtonDown}%
- \opt{PLAYER_PAD}{\ButtonOn+\ButtonRight\ / \ButtonOn+\ButtonLeft}
- \opt{IPOD_4G_PAD,IPOD_3G_PAD}{\ButtonScrollFwd\ / \ButtonScrollBack}
- \opt{IRIVER_H10_PAD,MPIO_HD300_PAD}{\ButtonScrollUp\ / \ButtonScrollDown}
- \opt{MPIO_HD200_PAD}{\ButtonFF / \ButtonRew}
- \opt{touchscreen}{\TouchBottomMiddle\ / \TouchTopMiddle}
+ \PluginUp{} / \PluginDown
&
\opt{HAVEREMOTEKEYMAP}{
- \opt{IRIVER_RC_H100_PAD}{\ButtonRCSource\ / \ButtonRCBitrate}
&}
Increase / decrease speed on the y-axis
\\
- \opt{PLAYER_PAD}{\ButtonStop}
- \opt{RECORDER_PAD,ONDIO_PAD,IRIVER_H100_PAD,IRIVER_H300_PAD}{\ButtonOff}
- \opt{IPOD_4G_PAD,IPOD_3G_PAD}{\ButtonMenu}
- \opt{IAUDIO_X5_PAD,IRIVER_H10_PAD,SANSA_E200_PAD,SANSA_C200_PAD%
- ,GIGABEAT_PAD,MROBE100_PAD,COWON_D2_PAD}{\ButtonPower}
- \opt{SANSA_FUZE_PAD}{Long \ButtonHome}
- \opt{GIGABEAT_S_PAD}{\ButtonBack}
- \opt{PBELL_VIBE500_PAD}{\ButtonRec}
- \opt{MPIO_HD200_PAD}{\ButtonRec + \ButtonPlay}
- \opt{MPIO_HD300_PAD}{Long \ButtonMenu}
+ \PluginCancel{} or \PluginExit
&
\opt{HAVEREMOTEKEYMAP}{
- \opt{IRIVER_RC_H100_PAD}{\ButtonRCStop}
&}
Quit
\\