summaryrefslogtreecommitdiff
path: root/apps/sound_menu.c
diff options
context:
space:
mode:
authorBjörn Stenberg <bjorn@haxx.se>2002-06-27 01:08:11 +0000
committerBjörn Stenberg <bjorn@haxx.se>2002-06-27 01:08:11 +0000
commit60b356ea25dca1b103eec7a59ace90a710db31fe (patch)
tree042bf8e9e7ee698287fa36f85855c9db861d3e49 /apps/sound_menu.c
parentb45491df8fd4093eb79235cffb2f68c2e2228bfd (diff)
downloadrockbox-60b356ea25dca1b103eec7a59ace90a710db31fe.zip
rockbox-60b356ea25dca1b103eec7a59ace90a710db31fe.tar.gz
rockbox-60b356ea25dca1b103eec7a59ace90a710db31fe.tar.bz2
rockbox-60b356ea25dca1b103eec7a59ace90a710db31fe.tar.xz
Abstracted settings user interface into set_bool, set_int and set_option.
Removed the unnecessary menu entry ids. Made playlist_shuffle and scroll_speed proper global settings. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@1220 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'apps/sound_menu.c')
-rw-r--r--apps/sound_menu.c72
1 files changed, 6 insertions, 66 deletions
diff --git a/apps/sound_menu.c b/apps/sound_menu.c
index 21b98ab..183c343 100644
--- a/apps/sound_menu.c
+++ b/apps/sound_menu.c
@@ -19,92 +19,32 @@
#include "config.h"
#include <stdio.h>
#include <stdbool.h>
-#include "lcd.h"
#include "menu.h"
-#include "sound_menu.h"
#include "mpeg.h"
-#include "button.h"
-#include "kernel.h"
-#include "sprintf.h"
#include "settings.h"
-typedef void (*settingfunc)(int);
-enum { Volume, Bass, Treble, numsettings };
-
-static const char* names[] = { "Volume", "Bass", "Treble" };
-static settingfunc funcs[] = { mpeg_volume, mpeg_bass, mpeg_treble };
-
-static void soundsetting(int setting, int *value)
-{
- char buf[32];
- bool done = false;
-
- lcd_clear_display();
- snprintf(buf,sizeof buf,"[%s]",names[setting]);
- lcd_puts(0,0,buf);
-
- while ( !done ) {
- snprintf(buf,sizeof buf,"%d %% ", *value);
- lcd_puts(0,1,buf);
- lcd_update();
-
- switch ( button_get(true) ) {
-#ifdef HAVE_RECORDER_KEYPAD
- case BUTTON_UP:
-#else
- case BUTTON_RIGHT:
-#endif
- *value += 2;
- if ( *value >= 100 )
- *value = 100;
- (funcs[setting])(*value);
- break;
-
-#ifdef HAVE_RECORDER_KEYPAD
- case BUTTON_DOWN:
-#else
- case BUTTON_LEFT:
-#endif
- *value -= 2;
- if ( *value <= 0 )
- *value = 0;
- (funcs[setting])(*value);
- break;
-
-#ifdef HAVE_RECORDER_KEYPAD
- case BUTTON_LEFT:
-#else
- case BUTTON_STOP:
- case BUTTON_MENU:
-#endif
- done = true;
- break;
- }
- }
-}
-
static void volume(void)
{
- soundsetting(Volume, &global_settings.volume);
+ set_int("Volume","%", &global_settings.volume, mpeg_volume, 2, 0, 100);
}
static void bass(void)
{
- soundsetting(Bass, &global_settings.bass);
+ set_int("Bass","%", &global_settings.bass, mpeg_bass, 2, 0, 100);
};
static void treble(void)
{
- soundsetting(Treble, &global_settings.treble);
+ set_int("Treble","%", &global_settings.treble, mpeg_treble, 2, 0, 100);
}
void sound_menu(void)
{
int m;
struct menu_items items[] = {
- { Volume, "Volume", volume },
- { Bass, "Bass", bass },
- { Treble, "Treble", treble }
+ { "Volume", volume },
+ { "Bass", bass },
+ { "Treble", treble }
};
m=menu_init( items, sizeof items / sizeof(struct menu_items) );