FS#9477 - new WPS tag (%mo) which lets the WPS have different "modes" which are changed with the usual "back to browser" button (This button is ONLY stolen if the WPS you use uses this tag.

an example use:
%?mo<one|two|three>
meaning that when the WPS is first opened "one" will be displayed, pressing select will change it to showing two, pressing it again will show three, and once more will go back to showing one. The text there could be any wps tags (conditional viewports for example...)
There is no real limit on the amount of modes, but remember that if you create a WPS which uses this tag more than once that every use HAS to have the same amount of choices or bad things will happen.



git-svn-id: svn://svn.rockbox.org/rockbox/trunk@19110 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Jonathan Gordon 2008-11-16 09:38:15 +00:00
parent db5965ff9e
commit 76d2dd9c0e
5 changed files with 53 additions and 8 deletions

View file

@ -1394,6 +1394,16 @@ static const char *get_token_value(struct gui_wps *gwps,
token->value.i))
return "v";
return NULL;
case WPS_TOKEN_VIEWMODE:
if (intval)
{
if (data->current_mode > limit)
data->current_mode = 1;
*intval = data->current_mode;
}
snprintf(buf, buf_size, "%d", data->current_mode);
return buf;
default:
return NULL;
}

View file

@ -136,7 +136,7 @@ long gui_wps_show(void)
bool update_track = false;
int i;
long last_left = 0, last_right = 0;
bool isremote = false;
wps_state_init();
#ifdef HAVE_LCD_CHARCELLS
@ -234,7 +234,10 @@ long gui_wps_show(void)
#else
button = get_action(CONTEXT_WPS|ALLOW_SOFTLOCK,HZ/5);
#endif
#if NB_SCREENS > 1
isremote = get_action_statuscode(NULL)&ACTION_REMOTE;
#endif
/* Exit if audio has stopped playing. This can happen if using the
sleep timer with the charger plugged or if starting a recording
from F1 */
@ -292,13 +295,23 @@ long gui_wps_show(void)
break;
case ACTION_WPS_BROWSE:
if (gui_wps[isremote?1:0].data->current_mode > -1)
{
/* will get set to 0 eventually again in wps_parser.c */
gui_wps[isremote?1:0].data->current_mode =
gui_wps[isremote?1:0].data->current_mode+1;
restore = true;
}
else
{
#ifdef HAVE_LCD_CHARCELLS
status_set_record(false);
status_set_audio(false);
status_set_record(false);
status_set_audio(false);
#endif
FOR_NB_SCREENS(i)
gui_wps[i].display->stop_scroll();
return GO_TO_PREVIOUS_BROWSER;
FOR_NB_SCREENS(i)
gui_wps[i].display->stop_scroll();
return GO_TO_PREVIOUS_BROWSER;
}
break;
/* play/pause */

View file

@ -295,7 +295,10 @@ enum wps_token_type {
WPS_VIEWPORT_ENABLE,
/* buttons */
WPS_TOKEN_BUTTON_VOLUME
WPS_TOKEN_BUTTON_VOLUME,
WPS_TOKEN_VIEWMODE
};
struct wps_token {
@ -429,6 +432,8 @@ struct wps_data
/* tick the volume button was last pressed */
unsigned int button_time_volume;
/* the current mode (used with %mo tag), -1 means modes not being used */
char current_mode;
};
/* initial setup of wps_data */

View file

@ -435,6 +435,9 @@ static char *get_token_desc(struct wps_token *token, struct wps_data *data,
snprintf(buf, bufsize, "Volume button timeout:%d",
token->value.i);
break;
case WPS_TOKEN_VIEWMODE:
snprintf(buf, bufsize, "viewmode");
break;
default:
snprintf(buf, bufsize, "FIXME (code: %d)",
token->type);

View file

@ -162,6 +162,8 @@ static int parse_albumart_load(const char *wps_bufptr,
static int parse_albumart_conditional(const char *wps_bufptr,
struct wps_token *token, struct wps_data *wps_data);
#endif /* HAVE_ALBUMART */
static int parse_viewmode(const char *wps_bufptr,
struct wps_token *token, struct wps_data *wps_data);
#ifdef CONFIG_RTC
#define WPS_RTC_REFRESH WPS_REFRESH_DYNAMIC
@ -281,6 +283,8 @@ static const struct wps_tag all_tags[] = {
{ WPS_TOKEN_PLAYBACK_STATUS, "mp", WPS_REFRESH_DYNAMIC, NULL },
{ WPS_TOKEN_BUTTON_VOLUME, "mv", WPS_REFRESH_DYNAMIC,
parse_timeout },
{ WPS_TOKEN_VIEWMODE, "mo", WPS_REFRESH_STATIC,
parse_viewmode },
#ifdef HAVE_LCD_BITMAP
{ WPS_TOKEN_PEAKMETER, "pm", WPS_REFRESH_PEAK_METER, NULL },
@ -1142,6 +1146,15 @@ static int parse_albumart_conditional(const char *wps_bufptr,
};
#endif /* HAVE_ALBUMART */
static int parse_viewmode(const char *wps_bufptr,
struct wps_token *token,
struct wps_data *wps_data)
{
(void)wps_bufptr; (void)token;
wps_data->current_mode = 1;
/* are we going to add parameters? */
return 0;
}
/* Parse a generic token from the given string. Return the length read */
static int parse_token(const char *wps_bufptr, struct wps_data *wps_data)
{
@ -1476,6 +1489,7 @@ void wps_data_init(struct wps_data *wps_data)
wps_data->full_line_progressbar = false;
#endif
wps_data->button_time_volume = 0;
wps_data->current_mode = -1;
wps_data->wps_loaded = false;
}