2002-06-24 21:39:48 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright (C) 2002 Robert Hak
|
|
|
|
*
|
|
|
|
* All files in this archive are subject to the GNU General Public License.
|
|
|
|
* See the file COPYING in the source tree root for full license agreement.
|
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdbool.h>
|
2004-04-20 10:23:57 +00:00
|
|
|
#include <string.h>
|
2002-08-31 04:58:35 +00:00
|
|
|
|
2002-06-24 21:39:48 +00:00
|
|
|
#include "lcd.h"
|
|
|
|
#include "menu.h"
|
|
|
|
#include "mpeg.h"
|
2005-04-04 12:06:29 +00:00
|
|
|
#include "audio.h"
|
2002-06-24 21:39:48 +00:00
|
|
|
#include "button.h"
|
|
|
|
#include "kernel.h"
|
2003-02-14 09:44:34 +00:00
|
|
|
#include "thread.h"
|
2002-06-24 21:39:48 +00:00
|
|
|
#include "sprintf.h"
|
|
|
|
#include "settings.h"
|
|
|
|
#include "settings_menu.h"
|
|
|
|
#include "backlight.h"
|
2002-10-14 09:12:52 +00:00
|
|
|
#include "playlist.h" /* for playlist_shuffle */
|
2002-08-22 15:47:30 +00:00
|
|
|
#include "fat.h" /* For dotfile settings */
|
2004-01-14 14:42:31 +00:00
|
|
|
#include "sleeptimer.h"
|
2002-08-06 10:52:51 +00:00
|
|
|
#include "powermgmt.h"
|
2005-08-08 19:23:28 +00:00
|
|
|
#include "bidi.h"
|
2002-08-09 12:38:45 +00:00
|
|
|
#include "rtc.h"
|
2002-08-26 13:21:14 +00:00
|
|
|
#include "ata.h"
|
2003-09-29 21:26:53 +00:00
|
|
|
#include "tree.h"
|
2002-10-14 11:55:20 +00:00
|
|
|
#include "screens.h"
|
2004-03-19 22:15:53 +00:00
|
|
|
#include "talk.h"
|
2004-04-20 10:23:57 +00:00
|
|
|
#include "timefuncs.h"
|
2004-07-26 16:06:59 +00:00
|
|
|
#include "misc.h"
|
2005-08-21 23:01:12 +00:00
|
|
|
#include "abrepeat.h"
|
2005-07-01 09:42:39 +00:00
|
|
|
#include "power.h"
|
2005-07-02 10:50:42 +00:00
|
|
|
#include "database.h"
|
2005-10-07 17:38:05 +00:00
|
|
|
#include "dir.h"
|
|
|
|
#include "dircache.h"
|
2005-11-16 15:12:15 +00:00
|
|
|
#include "splash.h"
|
2005-11-18 02:07:02 +00:00
|
|
|
#include "yesno.h"
|
2005-07-01 09:42:39 +00:00
|
|
|
|
2002-09-27 10:18:48 +00:00
|
|
|
#ifdef HAVE_LCD_BITMAP
|
2002-09-27 09:31:31 +00:00
|
|
|
#include "peakmeter.h"
|
2002-09-27 10:18:48 +00:00
|
|
|
#endif
|
2002-09-18 14:08:05 +00:00
|
|
|
#include "lang.h"
|
2005-08-29 21:15:27 +00:00
|
|
|
#if CONFIG_CODEC == MAS3507D
|
2003-11-04 00:18:19 +00:00
|
|
|
void dac_line_in(bool enable);
|
2003-11-03 23:36:36 +00:00
|
|
|
#endif
|
2004-01-14 14:42:31 +00:00
|
|
|
#ifdef HAVE_ALARM_MOD
|
|
|
|
#include "alarm_menu.h"
|
|
|
|
#endif
|
2002-06-24 21:39:48 +00:00
|
|
|
|
2005-04-15 12:08:49 +00:00
|
|
|
#ifdef HAVE_REMOTE_LCD
|
|
|
|
#include "lcd-remote.h"
|
|
|
|
#endif
|
|
|
|
|
2005-08-29 21:15:27 +00:00
|
|
|
#if CONFIG_CODEC == SWCODEC
|
2005-07-13 12:48:22 +00:00
|
|
|
#include "pcmbuf.h"
|
2005-06-09 09:47:00 +00:00
|
|
|
#include "pcm_playback.h"
|
2005-07-24 15:32:28 +00:00
|
|
|
#include "dsp.h"
|
2005-06-09 09:47:00 +00:00
|
|
|
#endif
|
|
|
|
|
2004-10-10 01:25:32 +00:00
|
|
|
#ifdef HAVE_CHARGING
|
2003-10-17 14:49:00 +00:00
|
|
|
static bool car_adapter_mode(void)
|
|
|
|
{
|
2005-10-08 22:01:42 +00:00
|
|
|
return set_bool( str(LANG_CAR_ADAPTER_MODE),
|
|
|
|
&global_settings.car_adapter_mode );
|
2003-10-17 14:49:00 +00:00
|
|
|
}
|
2004-10-10 01:25:32 +00:00
|
|
|
#endif
|
2003-10-17 14:49:00 +00:00
|
|
|
|
2005-06-20 17:03:09 +00:00
|
|
|
/**
|
|
|
|
* Menu to set icon visibility
|
|
|
|
*/
|
|
|
|
static bool show_icons(void)
|
2002-08-13 11:10:11 +00:00
|
|
|
{
|
2005-06-20 17:03:09 +00:00
|
|
|
return set_bool( str(LANG_SHOW_ICONS), &global_settings.show_icons );
|
2002-08-13 11:10:11 +00:00
|
|
|
}
|
|
|
|
|
2005-04-15 12:08:49 +00:00
|
|
|
#ifdef HAVE_REMOTE_LCD
|
|
|
|
static bool remote_contrast(void)
|
|
|
|
{
|
|
|
|
return set_int( str(LANG_CONTRAST), "", UNIT_INT,
|
|
|
|
&global_settings.remote_contrast,
|
|
|
|
lcd_remote_set_contrast, 1, MIN_CONTRAST_SETTING,
|
2005-08-11 18:56:20 +00:00
|
|
|
MAX_CONTRAST_SETTING, NULL );
|
2005-04-15 12:08:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool remote_invert(void)
|
|
|
|
{
|
|
|
|
bool rc = set_bool_options(str(LANG_INVERT),
|
|
|
|
&global_settings.remote_invert,
|
|
|
|
STR(LANG_INVERT_LCD_INVERSE),
|
|
|
|
STR(LANG_INVERT_LCD_NORMAL),
|
|
|
|
lcd_remote_set_invert_display);
|
|
|
|
return rc;
|
|
|
|
}
|
2005-06-17 21:43:00 +00:00
|
|
|
|
|
|
|
static bool remote_flip_display(void)
|
|
|
|
{
|
|
|
|
bool rc = set_bool( str(LANG_FLIP_DISPLAY),
|
|
|
|
&global_settings.remote_flip_display);
|
|
|
|
|
|
|
|
lcd_remote_set_flip(global_settings.remote_flip_display);
|
|
|
|
lcd_remote_update();
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
2005-11-19 07:58:20 +00:00
|
|
|
|
2005-11-19 09:26:02 +00:00
|
|
|
#ifdef HAVE_REMOTE_LCD_TICKING
|
2005-11-19 07:58:20 +00:00
|
|
|
static bool remote_reduce_ticking(void)
|
|
|
|
{
|
|
|
|
bool rc = set_bool( str(LANG_REDUCE_TICKING),
|
|
|
|
&global_settings.remote_reduce_ticking);
|
|
|
|
|
|
|
|
lcd_remote_emireduce(global_settings.remote_reduce_ticking);
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
2005-04-15 12:08:49 +00:00
|
|
|
#endif
|
2005-11-19 09:26:02 +00:00
|
|
|
#endif
|
2005-04-15 12:08:49 +00:00
|
|
|
|
2004-12-18 10:29:47 +00:00
|
|
|
#ifdef CONFIG_BACKLIGHT
|
2005-11-23 20:12:33 +00:00
|
|
|
static const struct opt_items backlight_timeouts[] = {
|
|
|
|
{ STR(LANG_OFF) },
|
|
|
|
{ STR(LANG_ON) },
|
|
|
|
{ "1s ", TALK_ID(1, UNIT_SEC) },
|
|
|
|
{ "2s ", TALK_ID(2, UNIT_SEC) },
|
|
|
|
{ "3s ", TALK_ID(3, UNIT_SEC) },
|
|
|
|
{ "4s ", TALK_ID(4, UNIT_SEC) },
|
|
|
|
{ "5s ", TALK_ID(5, UNIT_SEC) },
|
|
|
|
{ "6s ", TALK_ID(6, UNIT_SEC) },
|
|
|
|
{ "7s ", TALK_ID(7, UNIT_SEC) },
|
|
|
|
{ "8s ", TALK_ID(8, UNIT_SEC) },
|
|
|
|
{ "9s ", TALK_ID(9, UNIT_SEC) },
|
|
|
|
{ "10s", TALK_ID(10, UNIT_SEC) },
|
|
|
|
{ "15s", TALK_ID(15, UNIT_SEC) },
|
|
|
|
{ "20s", TALK_ID(20, UNIT_SEC) },
|
|
|
|
{ "25s", TALK_ID(25, UNIT_SEC) },
|
|
|
|
{ "30s", TALK_ID(30, UNIT_SEC) },
|
|
|
|
{ "45s", TALK_ID(45, UNIT_SEC) },
|
|
|
|
{ "60s", TALK_ID(60, UNIT_SEC) },
|
|
|
|
{ "90s", TALK_ID(90, UNIT_SEC) }
|
|
|
|
};
|
|
|
|
|
2003-04-24 08:27:11 +00:00
|
|
|
static bool caption_backlight(void)
|
|
|
|
{
|
2005-11-21 23:55:39 +00:00
|
|
|
return set_bool( str(LANG_CAPTION_BACKLIGHT),
|
|
|
|
&global_settings.caption_backlight);
|
2003-04-24 08:27:11 +00:00
|
|
|
}
|
2005-06-20 17:03:09 +00:00
|
|
|
|
|
|
|
#ifdef HAVE_CHARGING
|
2005-11-23 20:12:33 +00:00
|
|
|
static bool backlight_timer_plugged(void)
|
2005-06-20 17:03:09 +00:00
|
|
|
{
|
2005-11-23 20:12:33 +00:00
|
|
|
return set_option(str(LANG_BACKLIGHT_ON_WHEN_CHARGING),
|
|
|
|
&global_settings.backlight_timeout_plugged,
|
|
|
|
INT, backlight_timeouts, 19,
|
|
|
|
backlight_set_timeout_plugged );
|
2005-06-20 17:03:09 +00:00
|
|
|
}
|
2004-10-09 19:56:27 +00:00
|
|
|
#endif
|
2003-04-24 08:27:11 +00:00
|
|
|
|
2005-06-20 17:03:09 +00:00
|
|
|
static bool backlight_timer(void)
|
2003-06-05 09:38:26 +00:00
|
|
|
{
|
2005-11-23 20:12:33 +00:00
|
|
|
return set_option(str(LANG_BACKLIGHT),
|
|
|
|
&global_settings.backlight_timeout,
|
|
|
|
INT, backlight_timeouts, 19,
|
|
|
|
backlight_set_timeout );
|
2005-06-20 17:03:09 +00:00
|
|
|
}
|
|
|
|
|
2005-11-21 23:55:39 +00:00
|
|
|
#if (CONFIG_BACKLIGHT == BL_IRIVER_H100) && !defined(SIMULATOR)
|
2005-06-20 17:03:09 +00:00
|
|
|
static bool backlight_fade_in(void)
|
|
|
|
{
|
|
|
|
static const struct opt_items names[] = {
|
|
|
|
{ STR(LANG_OFF) },
|
|
|
|
{ "500ms", TALK_ID(500, UNIT_MS) },
|
|
|
|
{ "1s", TALK_ID(1, UNIT_SEC) },
|
|
|
|
{ "2s", TALK_ID(2, UNIT_SEC) },
|
|
|
|
};
|
|
|
|
return set_option(str(LANG_BACKLIGHT_FADE_IN),
|
|
|
|
&global_settings.backlight_fade_in,
|
|
|
|
INT, names, 4, backlight_set_fade_in );
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool backlight_fade_out(void)
|
|
|
|
{
|
|
|
|
static const struct opt_items names[] = {
|
|
|
|
{ STR(LANG_OFF) },
|
|
|
|
{ "500ms", TALK_ID(500, UNIT_MS) },
|
|
|
|
{ "1s", TALK_ID(1, UNIT_SEC) },
|
|
|
|
{ "2s", TALK_ID(2, UNIT_SEC) },
|
|
|
|
{ "3s", TALK_ID(3, UNIT_SEC) },
|
|
|
|
{ "4s", TALK_ID(4, UNIT_SEC) },
|
|
|
|
{ "5s", TALK_ID(5, UNIT_SEC) },
|
|
|
|
{ "10s", TALK_ID(10, UNIT_SEC) },
|
|
|
|
};
|
|
|
|
return set_option(str(LANG_BACKLIGHT_FADE_OUT),
|
|
|
|
&global_settings.backlight_fade_out,
|
|
|
|
INT, names, 8, backlight_set_fade_out );
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* CONFIG_BACKLIGHT */
|
|
|
|
|
|
|
|
#ifdef HAVE_REMOTE_LCD
|
|
|
|
|
|
|
|
static bool remote_backlight_timer(void)
|
|
|
|
{
|
2005-11-23 20:12:33 +00:00
|
|
|
return set_option(str(LANG_BACKLIGHT),
|
|
|
|
&global_settings.remote_backlight_timeout,
|
|
|
|
INT, backlight_timeouts, 19,
|
|
|
|
remote_backlight_set_timeout );
|
2005-06-20 17:03:09 +00:00
|
|
|
}
|
|
|
|
|
2005-11-21 23:55:39 +00:00
|
|
|
#ifdef HAVE_CHARGING
|
2005-11-23 20:12:33 +00:00
|
|
|
static bool remote_backlight_timer_plugged(void)
|
2005-11-21 23:55:39 +00:00
|
|
|
{
|
2005-11-23 20:12:33 +00:00
|
|
|
return set_option(str(LANG_BACKLIGHT_ON_WHEN_CHARGING),
|
|
|
|
&global_settings.remote_backlight_timeout_plugged,
|
|
|
|
INT, backlight_timeouts, 19,
|
|
|
|
remote_backlight_set_timeout_plugged );
|
2005-11-21 23:55:39 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
static bool remote_caption_backlight(void)
|
|
|
|
{
|
|
|
|
return set_bool( str(LANG_CAPTION_BACKLIGHT),
|
|
|
|
&global_settings.remote_caption_backlight);
|
|
|
|
}
|
2005-06-20 17:03:09 +00:00
|
|
|
#endif /* HAVE_REMOTE_LCD */
|
|
|
|
|
|
|
|
static bool contrast(void)
|
|
|
|
{
|
|
|
|
return set_int( str(LANG_CONTRAST), "", UNIT_INT,
|
|
|
|
&global_settings.contrast,
|
|
|
|
lcd_set_contrast, 1, MIN_CONTRAST_SETTING,
|
2005-08-11 18:56:20 +00:00
|
|
|
MAX_CONTRAST_SETTING, NULL );
|
2003-06-05 09:38:26 +00:00
|
|
|
}
|
|
|
|
|
2002-09-27 09:31:31 +00:00
|
|
|
#ifdef HAVE_LCD_BITMAP
|
2002-10-26 05:46:53 +00:00
|
|
|
|
2003-06-05 09:38:26 +00:00
|
|
|
/**
|
|
|
|
* Menu to set LCD Mode (normal/inverse)
|
|
|
|
*/
|
2003-02-27 14:22:30 +00:00
|
|
|
static bool invert(void)
|
|
|
|
{
|
2003-04-24 13:13:16 +00:00
|
|
|
bool rc = set_bool_options(str(LANG_INVERT),
|
|
|
|
&global_settings.invert,
|
2004-03-15 08:27:51 +00:00
|
|
|
STR(LANG_INVERT_LCD_INVERSE),
|
|
|
|
STR(LANG_INVERT_LCD_NORMAL),
|
2003-06-05 11:11:10 +00:00
|
|
|
lcd_set_invert_display);
|
2003-04-24 13:13:16 +00:00
|
|
|
return rc;
|
2003-02-27 14:22:30 +00:00
|
|
|
}
|
|
|
|
|
2003-12-20 10:00:37 +00:00
|
|
|
/**
|
|
|
|
* Menu to turn the display+buttons by 180 degrees
|
|
|
|
*/
|
|
|
|
static bool flip_display(void)
|
|
|
|
{
|
|
|
|
bool rc = set_bool( str(LANG_FLIP_DISPLAY),
|
|
|
|
&global_settings.flip_display);
|
2005-06-20 17:03:09 +00:00
|
|
|
|
2003-12-20 10:00:37 +00:00
|
|
|
button_set_flip(global_settings.flip_display);
|
|
|
|
lcd_set_flip(global_settings.flip_display);
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2005-08-08 19:23:28 +00:00
|
|
|
/**
|
2005-09-01 20:23:16 +00:00
|
|
|
* Menu to set Line Selector Type (Pointer/Bar)
|
|
|
|
*/
|
|
|
|
static bool invert_cursor(void)
|
|
|
|
{
|
|
|
|
return set_bool_options(str(LANG_INVERT_CURSOR),
|
|
|
|
&global_settings.invert_cursor,
|
|
|
|
STR(LANG_INVERT_CURSOR_BAR),
|
|
|
|
STR(LANG_INVERT_CURSOR_POINTER),
|
|
|
|
NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2005-08-08 19:23:28 +00:00
|
|
|
* Menu to reverse Hebrew and Arabic text according to BiDi algorythm
|
|
|
|
*/
|
|
|
|
static bool bidi_support(void)
|
|
|
|
{
|
|
|
|
return set_bool_options( str(LANG_BIDI_SUPPORT),
|
|
|
|
&global_settings.bidi_support,
|
|
|
|
STR(LANG_SET_BOOL_YES),
|
|
|
|
STR(LANG_SET_BOOL_NO),
|
|
|
|
set_bidi_support);
|
|
|
|
}
|
|
|
|
|
2002-10-26 05:46:53 +00:00
|
|
|
/**
|
|
|
|
* Menu to configure the battery display on status bar
|
|
|
|
*/
|
2005-01-30 13:48:44 +00:00
|
|
|
static bool battery_display(void)
|
2002-10-26 05:46:53 +00:00
|
|
|
{
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_DISPLAY_GRAPHIC) },
|
|
|
|
{ STR(LANG_DISPLAY_NUMERIC) }
|
|
|
|
};
|
2002-10-26 05:46:53 +00:00
|
|
|
return set_option( str(LANG_BATTERY_DISPLAY),
|
2005-01-30 13:48:44 +00:00
|
|
|
&global_settings.battery_display, INT, names, 2, NULL);
|
2002-10-26 05:46:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Menu to configure the volume display on status bar
|
|
|
|
*/
|
|
|
|
static bool volume_type(void)
|
|
|
|
{
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_DISPLAY_GRAPHIC) },
|
|
|
|
{ STR(LANG_DISPLAY_NUMERIC) }
|
|
|
|
};
|
2002-10-26 05:46:53 +00:00
|
|
|
return set_option( str(LANG_VOLUME_DISPLAY), &global_settings.volume_type,
|
2003-06-05 11:11:10 +00:00
|
|
|
INT, names, 2, NULL);
|
2002-10-26 05:46:53 +00:00
|
|
|
}
|
|
|
|
|
2002-09-27 09:31:31 +00:00
|
|
|
/**
|
|
|
|
* Menu to set the hold time of normal peaks.
|
|
|
|
*/
|
2002-10-29 12:09:15 +00:00
|
|
|
static bool peak_meter_hold(void) {
|
|
|
|
bool retval = false;
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_OFF) },
|
2004-03-19 22:15:53 +00:00
|
|
|
{ "200 ms " , TALK_ID(200, UNIT_MS) },
|
|
|
|
{ "300 ms " , TALK_ID(300, UNIT_MS) },
|
|
|
|
{ "500 ms " , TALK_ID(500, UNIT_MS) },
|
|
|
|
{ "1 s" , TALK_ID(1, UNIT_SEC) },
|
|
|
|
{ "2 s" , TALK_ID(2, UNIT_SEC) },
|
|
|
|
{ "3 s" , TALK_ID(3, UNIT_SEC) },
|
|
|
|
{ "4 s" , TALK_ID(4, UNIT_SEC) },
|
|
|
|
{ "5 s" , TALK_ID(5, UNIT_SEC) },
|
|
|
|
{ "6 s" , TALK_ID(6, UNIT_SEC) },
|
|
|
|
{ "7 s" , TALK_ID(7, UNIT_SEC) },
|
|
|
|
{ "8 s" , TALK_ID(8, UNIT_SEC) },
|
|
|
|
{ "9 s" , TALK_ID(9, UNIT_SEC) },
|
|
|
|
{ "10 s" , TALK_ID(10, UNIT_SEC) },
|
|
|
|
{ "15 s" , TALK_ID(15, UNIT_SEC) },
|
|
|
|
{ "20 s" , TALK_ID(20, UNIT_SEC) },
|
|
|
|
{ "30 s" , TALK_ID(30, UNIT_SEC) },
|
|
|
|
{ "1 min" , TALK_ID(1, UNIT_MIN) }
|
2002-09-27 09:31:31 +00:00
|
|
|
};
|
2003-06-05 11:11:10 +00:00
|
|
|
retval = set_option( str(LANG_PM_PEAK_HOLD),
|
|
|
|
&global_settings.peak_meter_hold, INT, names,
|
|
|
|
18, NULL);
|
2002-10-29 12:09:15 +00:00
|
|
|
|
|
|
|
peak_meter_init_times(global_settings.peak_meter_release,
|
|
|
|
global_settings.peak_meter_hold,
|
|
|
|
global_settings.peak_meter_clip_hold);
|
|
|
|
|
|
|
|
return retval;
|
2002-09-27 09:31:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Menu to set the hold time of clips.
|
|
|
|
*/
|
2002-10-29 12:09:15 +00:00
|
|
|
static bool peak_meter_clip_hold(void) {
|
|
|
|
bool retval = false;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_PM_ETERNAL) },
|
2004-03-19 22:15:53 +00:00
|
|
|
{ "1s " , TALK_ID(1, UNIT_SEC) },
|
|
|
|
{ "2s " , TALK_ID(2, UNIT_SEC) },
|
|
|
|
{ "3s " , TALK_ID(3, UNIT_SEC) },
|
|
|
|
{ "4s " , TALK_ID(4, UNIT_SEC) },
|
|
|
|
{ "5s " , TALK_ID(5, UNIT_SEC) },
|
|
|
|
{ "6s " , TALK_ID(6, UNIT_SEC) },
|
|
|
|
{ "7s " , TALK_ID(7, UNIT_SEC) },
|
|
|
|
{ "8s " , TALK_ID(8, UNIT_SEC) },
|
|
|
|
{ "9s " , TALK_ID(9, UNIT_SEC) },
|
|
|
|
{ "10s" , TALK_ID(10, UNIT_SEC) },
|
|
|
|
{ "15s" , TALK_ID(15, UNIT_SEC) },
|
|
|
|
{ "20s" , TALK_ID(20, UNIT_SEC) },
|
|
|
|
{ "25s" , TALK_ID(25, UNIT_SEC) },
|
|
|
|
{ "30s" , TALK_ID(30, UNIT_SEC) },
|
|
|
|
{ "45s" , TALK_ID(45, UNIT_SEC) },
|
|
|
|
{ "60s" , TALK_ID(60, UNIT_SEC) },
|
|
|
|
{ "90s" , TALK_ID(90, UNIT_SEC) },
|
|
|
|
{ "2min" , TALK_ID(2, UNIT_MIN) },
|
|
|
|
{ "3min" , TALK_ID(3, UNIT_MIN) },
|
|
|
|
{ "5min" , TALK_ID(5, UNIT_MIN) },
|
|
|
|
{ "10min" , TALK_ID(10, UNIT_MIN) },
|
|
|
|
{ "20min" , TALK_ID(20, UNIT_MIN) },
|
|
|
|
{ "45min" , TALK_ID(45, UNIT_MIN) },
|
|
|
|
{ "90min" , TALK_ID(90, UNIT_MIN) }
|
2002-09-27 09:31:31 +00:00
|
|
|
};
|
2002-10-29 12:09:15 +00:00
|
|
|
retval = set_option( str(LANG_PM_CLIP_HOLD),
|
2003-06-05 11:11:10 +00:00
|
|
|
&global_settings.peak_meter_clip_hold, INT, names,
|
|
|
|
25, peak_meter_set_clip_hold);
|
2002-10-29 12:09:15 +00:00
|
|
|
|
|
|
|
peak_meter_init_times(global_settings.peak_meter_release,
|
|
|
|
global_settings.peak_meter_hold,
|
|
|
|
global_settings.peak_meter_clip_hold);
|
|
|
|
|
|
|
|
return retval;
|
2002-09-27 09:31:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Menu to set the release time of the peak meter.
|
|
|
|
*/
|
2002-10-29 12:09:15 +00:00
|
|
|
static bool peak_meter_release(void) {
|
|
|
|
bool retval = false;
|
|
|
|
|
|
|
|
/* The range of peak_meter_release is restricted so that it
|
|
|
|
fits into a 7 bit number. The 8th bit is used for storing
|
|
|
|
something else in the rtc ram.
|
|
|
|
Also, the max value is 0x7e, since the RTC value 0xff is reserved */
|
2004-11-19 01:13:33 +00:00
|
|
|
retval = set_int( str(LANG_PM_RELEASE), str(LANG_PM_UNITS_PER_READ),
|
|
|
|
LANG_PM_UNITS_PER_READ,
|
|
|
|
&global_settings.peak_meter_release,
|
2005-08-11 18:56:20 +00:00
|
|
|
NULL, 1, 1, 0x7e, NULL);
|
2002-10-29 12:09:15 +00:00
|
|
|
|
|
|
|
peak_meter_init_times(global_settings.peak_meter_release,
|
|
|
|
global_settings.peak_meter_hold,
|
|
|
|
global_settings.peak_meter_clip_hold);
|
|
|
|
|
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Menu to select wether the scale of the meter
|
|
|
|
* displays dBfs of linear values.
|
|
|
|
*/
|
|
|
|
static bool peak_meter_scale(void) {
|
|
|
|
bool retval = false;
|
|
|
|
bool use_dbfs = global_settings.peak_meter_dbfs;
|
|
|
|
retval = set_bool_options(str(LANG_PM_SCALE),
|
|
|
|
&use_dbfs,
|
2004-03-15 08:27:51 +00:00
|
|
|
STR(LANG_PM_DBFS), STR(LANG_PM_LINEAR),
|
2003-06-05 11:11:10 +00:00
|
|
|
NULL);
|
2002-10-29 12:09:15 +00:00
|
|
|
|
|
|
|
/* has the user really changed the scale? */
|
|
|
|
if (use_dbfs != global_settings.peak_meter_dbfs) {
|
|
|
|
|
|
|
|
/* store the change */
|
|
|
|
global_settings.peak_meter_dbfs = use_dbfs;
|
|
|
|
peak_meter_set_use_dbfs(use_dbfs);
|
|
|
|
|
|
|
|
/* If the user changed the scale mode the meaning of
|
|
|
|
peak_meter_min (peak_meter_max) has changed. Thus we have
|
|
|
|
to convert the values stored in global_settings. */
|
|
|
|
if (use_dbfs) {
|
|
|
|
|
|
|
|
/* we only store -dBfs */
|
|
|
|
global_settings.peak_meter_min = -peak_meter_get_min() / 100;
|
|
|
|
global_settings.peak_meter_max = -peak_meter_get_max() / 100;
|
|
|
|
} else {
|
|
|
|
int max;
|
|
|
|
|
|
|
|
/* linear percent */
|
|
|
|
global_settings.peak_meter_min = peak_meter_get_min();
|
|
|
|
|
|
|
|
/* converting dBfs -> percent results in a precision loss.
|
|
|
|
I assume that the user doesn't bother that conversion
|
|
|
|
dBfs <-> percent isn't symmetrical for odd values but that
|
|
|
|
he wants 0 dBfs == 100%. Thus I 'correct' the percent value
|
|
|
|
resulting from dBfs -> percent manually here */
|
|
|
|
max = peak_meter_get_max();
|
|
|
|
global_settings.peak_meter_max = max < 99 ? max : 100;
|
|
|
|
}
|
|
|
|
settings_apply_pm_range();
|
|
|
|
}
|
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adjust the min value of the value range that
|
|
|
|
* the peak meter shall visualize.
|
|
|
|
*/
|
|
|
|
static bool peak_meter_min(void) {
|
|
|
|
bool retval = false;
|
|
|
|
if (global_settings.peak_meter_dbfs) {
|
|
|
|
|
|
|
|
/* for dBfs scale */
|
|
|
|
int range_max = -global_settings.peak_meter_max;
|
|
|
|
int min = -global_settings.peak_meter_min;
|
|
|
|
|
2004-03-20 16:49:58 +00:00
|
|
|
retval = set_int(str(LANG_PM_MIN), str(LANG_PM_DBFS), UNIT_DB,
|
2005-08-11 18:56:20 +00:00
|
|
|
&min, NULL, 1, -89, range_max, NULL);
|
2002-10-29 12:09:15 +00:00
|
|
|
|
|
|
|
global_settings.peak_meter_min = - min;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* for linear scale */
|
|
|
|
else {
|
|
|
|
int min = global_settings.peak_meter_min;
|
|
|
|
|
2004-03-20 16:49:58 +00:00
|
|
|
retval = set_int(str(LANG_PM_MIN), "%", UNIT_PERCENT,
|
2002-10-29 12:09:15 +00:00
|
|
|
&min, NULL,
|
2005-08-11 18:56:20 +00:00
|
|
|
1, 0, global_settings.peak_meter_max - 1, NULL);
|
2002-10-29 12:09:15 +00:00
|
|
|
|
|
|
|
global_settings.peak_meter_min = (unsigned char)min;
|
|
|
|
}
|
|
|
|
|
|
|
|
settings_apply_pm_range();
|
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adjust the max value of the value range that
|
|
|
|
* the peak meter shall visualize.
|
|
|
|
*/
|
|
|
|
static bool peak_meter_max(void) {
|
|
|
|
bool retval = false;
|
|
|
|
if (global_settings.peak_meter_dbfs) {
|
|
|
|
|
|
|
|
/* for dBfs scale */
|
|
|
|
int range_min = -global_settings.peak_meter_min;
|
|
|
|
int max = -global_settings.peak_meter_max;;
|
|
|
|
|
2004-03-20 16:49:58 +00:00
|
|
|
retval = set_int(str(LANG_PM_MAX), str(LANG_PM_DBFS), UNIT_DB,
|
2005-08-11 18:56:20 +00:00
|
|
|
&max, NULL, 1, range_min, 0, NULL);
|
2002-10-29 12:09:15 +00:00
|
|
|
|
|
|
|
global_settings.peak_meter_max = - max;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/* for linear scale */
|
|
|
|
else {
|
|
|
|
int max = global_settings.peak_meter_max;
|
|
|
|
|
2004-03-20 16:49:58 +00:00
|
|
|
retval = set_int(str(LANG_PM_MAX), "%", UNIT_PERCENT,
|
2002-10-29 12:09:15 +00:00
|
|
|
&max, NULL,
|
2005-08-11 18:56:20 +00:00
|
|
|
1, global_settings.peak_meter_min + 1, 100, NULL);
|
2002-10-29 12:09:15 +00:00
|
|
|
|
|
|
|
global_settings.peak_meter_max = (unsigned char)max;
|
|
|
|
}
|
|
|
|
|
|
|
|
settings_apply_pm_range();
|
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
2002-09-27 09:31:31 +00:00
|
|
|
/**
|
|
|
|
* Menu to configure the peak meter
|
|
|
|
*/
|
|
|
|
static bool peak_meter_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_PM_RELEASE) , peak_meter_release },
|
|
|
|
{ ID2P(LANG_PM_PEAK_HOLD), peak_meter_hold },
|
|
|
|
{ ID2P(LANG_PM_CLIP_HOLD), peak_meter_clip_hold },
|
|
|
|
{ ID2P(LANG_PM_SCALE) , peak_meter_scale },
|
|
|
|
{ ID2P(LANG_PM_MIN) , peak_meter_min },
|
|
|
|
{ ID2P(LANG_PM_MAX) , peak_meter_max },
|
2002-09-27 09:31:31 +00:00
|
|
|
};
|
2004-03-16 13:44:56 +00:00
|
|
|
|
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL );
|
2002-09-27 09:31:31 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
2002-10-29 12:09:15 +00:00
|
|
|
#endif /* HAVE_LCD_BITMAP */
|
2002-09-27 09:31:31 +00:00
|
|
|
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool shuffle(void)
|
2002-06-24 21:39:48 +00:00
|
|
|
{
|
2002-09-24 17:22:12 +00:00
|
|
|
return set_bool( str(LANG_SHUFFLE), &global_settings.playlist_shuffle );
|
2002-06-27 01:08:11 +00:00
|
|
|
}
|
2002-10-04 08:48:20 +00:00
|
|
|
|
|
|
|
static bool repeat_mode(void)
|
|
|
|
{
|
|
|
|
bool result;
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_OFF) },
|
|
|
|
{ STR(LANG_REPEAT_ALL) },
|
2005-06-25 04:46:25 +00:00
|
|
|
{ STR(LANG_REPEAT_ONE) },
|
|
|
|
{ STR(LANG_SHUFFLE) },
|
2005-08-21 23:01:12 +00:00
|
|
|
#ifdef AB_REPEAT_ENABLE
|
|
|
|
{ STR(LANG_REPEAT_AB) }
|
|
|
|
#endif
|
2004-03-15 08:27:51 +00:00
|
|
|
};
|
2002-10-04 08:48:20 +00:00
|
|
|
int old_repeat = global_settings.repeat_mode;
|
|
|
|
|
|
|
|
result = set_option( str(LANG_REPEAT), &global_settings.repeat_mode,
|
2005-08-21 23:01:12 +00:00
|
|
|
INT, names, NUM_REPEAT_MODES, NULL );
|
2002-10-04 08:48:20 +00:00
|
|
|
|
2005-07-07 23:50:16 +00:00
|
|
|
if (old_repeat != global_settings.repeat_mode &&
|
|
|
|
(audio_status() & AUDIO_STATUS_PLAY))
|
2005-04-04 12:06:29 +00:00
|
|
|
audio_flush_and_reload_tracks();
|
2002-10-04 08:48:20 +00:00
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
2002-06-24 21:39:48 +00:00
|
|
|
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool play_selected(void)
|
2002-09-18 10:13:09 +00:00
|
|
|
{
|
2002-09-24 17:22:12 +00:00
|
|
|
return set_bool( str(LANG_PLAY_SELECTED), &global_settings.play_selected );
|
2002-09-18 10:13:09 +00:00
|
|
|
}
|
|
|
|
|
2002-09-24 19:12:09 +00:00
|
|
|
static bool dir_filter(void)
|
2002-06-27 01:08:11 +00:00
|
|
|
{
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_FILTER_ALL) },
|
|
|
|
{ STR(LANG_FILTER_SUPPORTED) },
|
|
|
|
{ STR(LANG_FILTER_MUSIC) },
|
2005-01-17 11:37:36 +00:00
|
|
|
{ STR(LANG_FILTER_PLAYLIST) },
|
|
|
|
{ STR(LANG_FILTER_ID3DB) }
|
2004-03-15 08:27:51 +00:00
|
|
|
};
|
2003-06-05 11:11:10 +00:00
|
|
|
return set_option( str(LANG_FILTER), &global_settings.dirfilter, INT,
|
2005-01-17 11:37:36 +00:00
|
|
|
names, 5, NULL );
|
2002-06-24 21:39:48 +00:00
|
|
|
}
|
|
|
|
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool sort_case(void)
|
2002-07-22 16:39:17 +00:00
|
|
|
{
|
2002-09-24 17:22:12 +00:00
|
|
|
return set_bool( str(LANG_SORT_CASE), &global_settings.sort_case );
|
2002-07-22 16:39:17 +00:00
|
|
|
}
|
|
|
|
|
2004-06-22 09:16:44 +00:00
|
|
|
static bool sort_file(void)
|
|
|
|
{
|
2004-06-23 07:28:35 +00:00
|
|
|
int oldval = global_settings.sort_file;
|
|
|
|
bool ret;
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-06-22 09:16:44 +00:00
|
|
|
{ STR(LANG_SORT_ALPHA) },
|
|
|
|
{ STR(LANG_SORT_DATE) },
|
|
|
|
{ STR(LANG_SORT_DATE_REVERSE) },
|
|
|
|
{ STR(LANG_SORT_TYPE) }
|
|
|
|
};
|
2004-06-23 07:28:35 +00:00
|
|
|
ret = set_option( str(LANG_SORT_FILE), &global_settings.sort_file, INT,
|
2004-06-22 09:16:44 +00:00
|
|
|
names, 4, NULL );
|
2004-06-23 07:28:35 +00:00
|
|
|
if (global_settings.sort_file != oldval)
|
|
|
|
reload_directory(); /* force reload if this has changed */
|
|
|
|
return ret;
|
2004-06-22 09:16:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool sort_dir(void)
|
|
|
|
{
|
2004-06-23 07:28:35 +00:00
|
|
|
int oldval = global_settings.sort_dir;
|
|
|
|
bool ret;
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-06-22 09:16:44 +00:00
|
|
|
{ STR(LANG_SORT_ALPHA) },
|
|
|
|
{ STR(LANG_SORT_DATE) },
|
|
|
|
{ STR(LANG_SORT_DATE_REVERSE) }
|
|
|
|
};
|
2004-06-23 07:28:35 +00:00
|
|
|
ret = set_option( str(LANG_SORT_DIR), &global_settings.sort_dir, INT,
|
2004-06-22 09:16:44 +00:00
|
|
|
names, 3, NULL );
|
2004-06-23 07:28:35 +00:00
|
|
|
if (global_settings.sort_dir != oldval)
|
|
|
|
reload_directory(); /* force reload if this has changed */
|
|
|
|
return ret;
|
2004-06-22 09:16:44 +00:00
|
|
|
}
|
|
|
|
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool resume(void)
|
2002-08-16 14:41:47 +00:00
|
|
|
{
|
2005-06-29 12:23:09 +00:00
|
|
|
return set_bool( str(LANG_RESUME), &global_settings.resume);
|
2002-08-16 14:41:47 +00:00
|
|
|
}
|
|
|
|
|
2005-07-01 09:42:39 +00:00
|
|
|
#ifdef HAVE_SPDIF_POWER
|
|
|
|
static bool spdif(void)
|
|
|
|
{
|
|
|
|
bool rc = set_bool_options(str(LANG_SPDIF_ENABLE),
|
|
|
|
&global_settings.spdif_enable,
|
|
|
|
STR(LANG_ON),
|
|
|
|
STR(LANG_OFF),
|
|
|
|
spdif_power_enable);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2004-01-14 00:13:04 +00:00
|
|
|
static bool autocreatebookmark(void)
|
|
|
|
{
|
2004-04-19 17:51:47 +00:00
|
|
|
bool retval = false;
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_SET_BOOL_NO) },
|
|
|
|
{ STR(LANG_SET_BOOL_YES) },
|
|
|
|
{ STR(LANG_RESUME_SETTING_ASK) },
|
|
|
|
{ STR(LANG_BOOKMARK_SETTINGS_RECENT_ONLY_YES) },
|
|
|
|
{ STR(LANG_BOOKMARK_SETTINGS_RECENT_ONLY_ASK) }
|
|
|
|
};
|
2004-04-19 17:51:47 +00:00
|
|
|
|
|
|
|
retval = set_option( str(LANG_BOOKMARK_SETTINGS_AUTOCREATE),
|
2004-01-14 00:13:04 +00:00
|
|
|
&global_settings.autocreatebookmark, INT,
|
|
|
|
names, 5, NULL );
|
2004-04-19 17:51:47 +00:00
|
|
|
if(global_settings.autocreatebookmark == BOOKMARK_RECENT_ONLY_YES ||
|
|
|
|
global_settings.autocreatebookmark == BOOKMARK_RECENT_ONLY_ASK)
|
|
|
|
{
|
|
|
|
if(global_settings.usemrb == BOOKMARK_NO)
|
|
|
|
global_settings.usemrb = BOOKMARK_YES;
|
|
|
|
|
|
|
|
}
|
|
|
|
return retval;
|
2004-01-14 00:13:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool autoloadbookmark(void)
|
|
|
|
{
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_SET_BOOL_NO) },
|
|
|
|
{ STR(LANG_SET_BOOL_YES) },
|
|
|
|
{ STR(LANG_RESUME_SETTING_ASK) }
|
|
|
|
};
|
2004-01-14 00:13:04 +00:00
|
|
|
return set_option( str(LANG_BOOKMARK_SETTINGS_AUTOLOAD),
|
|
|
|
&global_settings.autoloadbookmark, INT,
|
|
|
|
names, 3, NULL );
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool useMRB(void)
|
|
|
|
{
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_SET_BOOL_NO) },
|
|
|
|
{ STR(LANG_SET_BOOL_YES) },
|
|
|
|
{ STR(LANG_BOOKMARK_SETTINGS_UNIQUE_ONLY) }
|
|
|
|
};
|
2004-01-14 00:13:04 +00:00
|
|
|
return set_option( str(LANG_BOOKMARK_SETTINGS_MAINTAIN_RECENT_BOOKMARKS),
|
|
|
|
&global_settings.usemrb, INT,
|
|
|
|
names, 3, NULL );
|
|
|
|
}
|
2004-10-09 19:56:27 +00:00
|
|
|
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool poweroff_idle_timer(void)
|
2002-09-23 11:42:48 +00:00
|
|
|
{
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_OFF) },
|
2004-03-19 22:15:53 +00:00
|
|
|
{ "1m ", TALK_ID(1, UNIT_MIN) },
|
|
|
|
{ "2m ", TALK_ID(2, UNIT_MIN) },
|
|
|
|
{ "3m ", TALK_ID(3, UNIT_MIN) },
|
|
|
|
{ "4m ", TALK_ID(4, UNIT_MIN) },
|
|
|
|
{ "5m ", TALK_ID(5, UNIT_MIN) },
|
|
|
|
{ "6m ", TALK_ID(6, UNIT_MIN) },
|
|
|
|
{ "7m ", TALK_ID(7, UNIT_MIN) },
|
|
|
|
{ "8m ", TALK_ID(8, UNIT_MIN) },
|
|
|
|
{ "9m ", TALK_ID(9, UNIT_MIN) },
|
|
|
|
{ "10m", TALK_ID(10, UNIT_MIN) },
|
|
|
|
{ "15m", TALK_ID(15, UNIT_MIN) },
|
|
|
|
{ "30m", TALK_ID(30, UNIT_MIN) },
|
|
|
|
{ "45m", TALK_ID(45, UNIT_MIN) },
|
|
|
|
{ "60m", TALK_ID(60, UNIT_MIN) }
|
2004-03-15 08:27:51 +00:00
|
|
|
};
|
2002-09-24 17:22:12 +00:00
|
|
|
return set_option(str(LANG_POWEROFF_IDLE), &global_settings.poweroff,
|
2003-06-05 11:11:10 +00:00
|
|
|
INT, names, 15, set_poweroff_timeout);
|
2002-09-23 11:42:48 +00:00
|
|
|
}
|
|
|
|
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool scroll_speed(void)
|
2002-06-24 21:39:48 +00:00
|
|
|
{
|
2004-10-15 20:30:29 +00:00
|
|
|
return set_int(str(LANG_SCROLL), "", UNIT_INT,
|
|
|
|
&global_settings.scroll_speed,
|
2005-08-11 18:56:20 +00:00
|
|
|
&lcd_scroll_speed, 1, 0, 15, NULL );
|
2002-06-24 21:39:48 +00:00
|
|
|
}
|
|
|
|
|
2002-12-12 15:20:37 +00:00
|
|
|
|
|
|
|
static bool scroll_delay(void)
|
|
|
|
{
|
|
|
|
int dummy = global_settings.scroll_delay * (HZ/10);
|
2004-03-20 16:49:58 +00:00
|
|
|
int rc = set_int(str(LANG_SCROLL_DELAY), "ms", UNIT_MS,
|
|
|
|
&dummy,
|
2005-08-11 18:56:20 +00:00
|
|
|
&lcd_scroll_delay, 100, 0, 2500, NULL );
|
2002-12-12 15:20:37 +00:00
|
|
|
global_settings.scroll_delay = dummy / (HZ/10);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef HAVE_LCD_BITMAP
|
2002-12-12 17:20:37 +00:00
|
|
|
static bool scroll_step(void)
|
|
|
|
{
|
2004-03-20 16:49:58 +00:00
|
|
|
return set_int(str(LANG_SCROLL_STEP_EXAMPLE), "pixels", UNIT_PIXEL,
|
2002-12-12 17:20:37 +00:00
|
|
|
&global_settings.scroll_step,
|
2005-08-11 18:56:20 +00:00
|
|
|
&lcd_scroll_step, 1, 1, LCD_WIDTH, NULL );
|
2002-12-12 17:20:37 +00:00
|
|
|
}
|
2003-01-14 10:48:01 +00:00
|
|
|
#endif
|
2002-12-12 17:20:37 +00:00
|
|
|
|
2002-12-12 15:20:37 +00:00
|
|
|
static bool bidir_limit(void)
|
|
|
|
{
|
2004-03-20 16:49:58 +00:00
|
|
|
return set_int(str(LANG_BIDIR_SCROLL), "%", UNIT_PERCENT,
|
|
|
|
&global_settings.bidir_limit,
|
2005-08-11 18:56:20 +00:00
|
|
|
&lcd_bidir_scroll, 25, 0, 200, NULL );
|
2002-12-12 15:20:37 +00:00
|
|
|
}
|
|
|
|
|
2003-05-22 06:42:14 +00:00
|
|
|
#ifdef HAVE_LCD_CHARCELLS
|
|
|
|
static bool jump_scroll(void)
|
|
|
|
{
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_OFF) },
|
|
|
|
{ STR(LANG_ONE_TIME) },
|
2004-03-19 22:15:53 +00:00
|
|
|
{ "2", TALK_ID(2, UNIT_INT) },
|
|
|
|
{ "3", TALK_ID(3, UNIT_INT) },
|
|
|
|
{ "4", TALK_ID(4, UNIT_INT) },
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_ALWAYS) }
|
|
|
|
};
|
2003-05-27 12:54:11 +00:00
|
|
|
bool ret;
|
|
|
|
ret=set_option(str(LANG_JUMP_SCROLL), &global_settings.jump_scroll,
|
2003-06-05 11:11:10 +00:00
|
|
|
INT, names, 6, lcd_jump_scroll);
|
2003-05-27 12:54:11 +00:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
static bool jump_scroll_delay(void)
|
|
|
|
{
|
|
|
|
int dummy = global_settings.jump_scroll_delay * (HZ/10);
|
2004-03-20 16:49:58 +00:00
|
|
|
int rc = set_int(str(LANG_JUMP_SCROLL_DELAY), "ms", UNIT_MS,
|
|
|
|
&dummy,
|
2005-08-11 18:56:20 +00:00
|
|
|
&lcd_jump_scroll_delay, 100, 0, 2500, NULL );
|
2003-05-27 12:54:11 +00:00
|
|
|
global_settings.jump_scroll_delay = dummy / (HZ/10);
|
|
|
|
return rc;
|
2003-05-22 06:42:14 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2002-12-16 22:58:48 +00:00
|
|
|
#ifndef SIMULATOR
|
2002-12-15 18:12:00 +00:00
|
|
|
/**
|
|
|
|
* Menu to set the battery capacity
|
|
|
|
*/
|
2002-12-16 22:58:48 +00:00
|
|
|
static bool battery_capacity(void)
|
|
|
|
{
|
2004-03-20 16:49:58 +00:00
|
|
|
return set_int(str(LANG_BATTERY_CAPACITY), "mAh", UNIT_MAH,
|
|
|
|
&global_settings.battery_capacity,
|
2004-10-10 10:28:21 +00:00
|
|
|
&set_battery_capacity, 50, BATTERY_CAPACITY_MIN,
|
2005-08-11 18:56:20 +00:00
|
|
|
BATTERY_CAPACITY_MAX, NULL );
|
2002-12-15 18:12:00 +00:00
|
|
|
}
|
2005-01-30 16:25:46 +00:00
|
|
|
|
|
|
|
#if BATTERY_TYPES_COUNT > 1
|
|
|
|
static bool battery_type(void)
|
|
|
|
{
|
|
|
|
static const struct opt_items names[] = {
|
|
|
|
{ STR(LANG_BATTERY_TYPE_ALKALINE) },
|
|
|
|
{ STR(LANG_BATTERY_TYPE_NIMH) }
|
|
|
|
};
|
|
|
|
|
|
|
|
return set_option(str(LANG_BATTERY_TYPE), &global_settings.battery_type,
|
|
|
|
INT, names, 2, set_battery_type);
|
|
|
|
}
|
|
|
|
#endif
|
2002-12-16 22:58:48 +00:00
|
|
|
#endif
|
2002-12-15 18:12:00 +00:00
|
|
|
|
2004-01-14 14:42:31 +00:00
|
|
|
#ifdef HAVE_RTC
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool timedate_set(void)
|
2002-08-09 12:38:45 +00:00
|
|
|
{
|
2004-04-20 10:23:57 +00:00
|
|
|
struct tm tm;
|
2002-09-24 17:22:12 +00:00
|
|
|
bool result;
|
2002-08-09 12:38:45 +00:00
|
|
|
|
2004-04-20 10:23:57 +00:00
|
|
|
/* Make a local copy of the time struct */
|
|
|
|
memcpy(&tm, get_time(), sizeof(struct tm));
|
2003-05-27 14:28:08 +00:00
|
|
|
|
|
|
|
/* do some range checks */
|
|
|
|
/* This prevents problems with time/date setting after a power loss */
|
2004-04-20 10:23:57 +00:00
|
|
|
if (!valid_time(&tm))
|
2003-05-27 14:28:08 +00:00
|
|
|
{
|
|
|
|
/* hour */
|
2004-04-20 10:23:57 +00:00
|
|
|
tm.tm_hour = 0;
|
|
|
|
tm.tm_min = 0;
|
|
|
|
tm.tm_sec = 0;
|
|
|
|
tm.tm_mday = 1;
|
|
|
|
tm.tm_mon = 0;
|
|
|
|
tm.tm_wday = 1;
|
|
|
|
tm.tm_year = 100;
|
2003-05-27 14:28:08 +00:00
|
|
|
}
|
2002-08-09 12:38:45 +00:00
|
|
|
|
2004-04-20 10:23:57 +00:00
|
|
|
result = set_time_screen(str(LANG_TIME), &tm);
|
2002-08-09 12:38:45 +00:00
|
|
|
|
2004-04-20 10:23:57 +00:00
|
|
|
if(tm.tm_year != -1) {
|
|
|
|
set_time(&tm);
|
2002-08-09 12:38:45 +00:00
|
|
|
}
|
2002-09-24 17:22:12 +00:00
|
|
|
return result;
|
2002-08-09 12:38:45 +00:00
|
|
|
}
|
2002-10-14 12:50:20 +00:00
|
|
|
|
|
|
|
static bool timeformat_set(void)
|
|
|
|
{
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_24_HOUR_CLOCK) },
|
|
|
|
{ STR(LANG_12_HOUR_CLOCK) }
|
|
|
|
};
|
2003-06-05 11:11:10 +00:00
|
|
|
return set_option(str(LANG_TIMEFORMAT), &global_settings.timeformat,
|
|
|
|
INT, names, 2, NULL);
|
2002-10-14 12:50:20 +00:00
|
|
|
}
|
2002-08-09 12:38:45 +00:00
|
|
|
#endif
|
|
|
|
|
2004-10-09 22:04:47 +00:00
|
|
|
#ifndef HAVE_MMC
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool spindown(void)
|
2002-08-26 13:21:14 +00:00
|
|
|
{
|
2004-03-20 16:49:58 +00:00
|
|
|
return set_int(str(LANG_SPINDOWN), "s", UNIT_SEC,
|
|
|
|
&global_settings.disk_spindown,
|
2005-08-11 18:56:20 +00:00
|
|
|
ata_spindown, 1, 3, 254, NULL );
|
2002-08-14 19:23:34 +00:00
|
|
|
}
|
|
|
|
|
2002-11-29 07:05:46 +00:00
|
|
|
#ifdef HAVE_ATA_POWER_OFF
|
2002-11-28 22:46:19 +00:00
|
|
|
static bool poweroff(void)
|
|
|
|
{
|
|
|
|
bool rc = set_bool(str(LANG_POWEROFF), &global_settings.disk_poweroff);
|
|
|
|
ata_poweroff(global_settings.disk_poweroff);
|
|
|
|
return rc;
|
|
|
|
}
|
2004-10-09 22:04:47 +00:00
|
|
|
#endif /* HAVE_ATA_POWEROFF */
|
|
|
|
#endif /* !HAVE_MMC */
|
|
|
|
|
2005-08-29 21:15:27 +00:00
|
|
|
#if CONFIG_CODEC == MAS3507D
|
2004-10-09 22:04:47 +00:00
|
|
|
static bool line_in(void)
|
|
|
|
{
|
|
|
|
bool rc = set_bool(str(LANG_LINE_IN), &global_settings.line_in);
|
2005-11-06 23:12:11 +00:00
|
|
|
#ifndef SIMULATOR
|
2004-10-09 22:04:47 +00:00
|
|
|
dac_line_in(global_settings.line_in);
|
2005-11-06 23:12:11 +00:00
|
|
|
#endif
|
2004-10-09 22:04:47 +00:00
|
|
|
return rc;
|
|
|
|
}
|
2002-11-29 07:05:46 +00:00
|
|
|
#endif
|
2002-11-28 22:46:19 +00:00
|
|
|
|
2003-05-09 16:01:21 +00:00
|
|
|
static bool max_files_in_dir(void)
|
|
|
|
{
|
2004-03-20 16:49:58 +00:00
|
|
|
return set_int(str(LANG_MAX_FILES_IN_DIR), "", UNIT_INT,
|
2003-05-09 16:01:21 +00:00
|
|
|
&global_settings.max_files_in_dir,
|
2005-08-11 18:56:20 +00:00
|
|
|
NULL, 50, 50, 10000, NULL );
|
2003-05-09 16:01:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool max_files_in_playlist(void)
|
|
|
|
{
|
2004-03-20 16:49:58 +00:00
|
|
|
return set_int(str(LANG_MAX_FILES_IN_PLAYLIST), "", UNIT_INT,
|
2003-05-09 16:01:21 +00:00
|
|
|
&global_settings.max_files_in_playlist,
|
2005-08-11 18:56:20 +00:00
|
|
|
NULL, 1000, 1000, 20000, NULL );
|
2003-05-09 16:01:21 +00:00
|
|
|
}
|
|
|
|
|
2005-08-29 21:15:27 +00:00
|
|
|
#if CONFIG_CODEC == SWCODEC
|
2005-07-21 11:44:00 +00:00
|
|
|
static bool buffer_margin(void)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
static const struct opt_items names[] = {
|
|
|
|
{ "5s", TALK_ID(5, UNIT_SEC) },
|
|
|
|
{ "15s", TALK_ID(15, UNIT_SEC) },
|
|
|
|
{ "30s", TALK_ID(30, UNIT_SEC) },
|
|
|
|
{ "1min", TALK_ID(1, UNIT_MIN) },
|
|
|
|
{ "2min", TALK_ID(2, UNIT_MIN) },
|
|
|
|
{ "3min", TALK_ID(3, UNIT_MIN) },
|
|
|
|
{ "5min", TALK_ID(5, UNIT_MIN) },
|
|
|
|
{ "10min", TALK_ID(10, UNIT_MIN) }
|
|
|
|
};
|
|
|
|
|
|
|
|
ret = set_option(str(LANG_MP3BUFFER_MARGIN), &global_settings.buffer_margin,
|
2005-07-21 20:03:03 +00:00
|
|
|
INT, names, 8, NULL);
|
|
|
|
audio_set_buffer_margin(global_settings.buffer_margin);
|
|
|
|
|
2005-07-21 11:44:00 +00:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#else
|
2002-12-05 13:09:51 +00:00
|
|
|
static bool buffer_margin(void)
|
|
|
|
{
|
2004-03-20 16:49:58 +00:00
|
|
|
return set_int(str(LANG_MP3BUFFER_MARGIN), "s", UNIT_SEC,
|
2002-12-05 13:09:51 +00:00
|
|
|
&global_settings.buffer_margin,
|
2005-08-11 18:56:20 +00:00
|
|
|
audio_set_buffer_margin, 1, 0, 7, NULL );
|
2002-12-05 13:09:51 +00:00
|
|
|
}
|
2005-07-21 11:44:00 +00:00
|
|
|
#endif
|
2002-12-05 13:09:51 +00:00
|
|
|
|
2003-05-09 16:01:21 +00:00
|
|
|
static bool ff_rewind_min_step(void)
|
2002-09-04 03:38:37 +00:00
|
|
|
{
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-19 22:15:53 +00:00
|
|
|
{ "1s", TALK_ID(1, UNIT_SEC) },
|
|
|
|
{ "2s", TALK_ID(2, UNIT_SEC) },
|
|
|
|
{ "3s", TALK_ID(3, UNIT_SEC) },
|
|
|
|
{ "4s", TALK_ID(4, UNIT_SEC) },
|
|
|
|
{ "5s", TALK_ID(5, UNIT_SEC) },
|
|
|
|
{ "6s", TALK_ID(6, UNIT_SEC) },
|
|
|
|
{ "8s", TALK_ID(8, UNIT_SEC) },
|
|
|
|
{ "10s", TALK_ID(10, UNIT_SEC) },
|
|
|
|
{ "15s", TALK_ID(15, UNIT_SEC) },
|
|
|
|
{ "20s", TALK_ID(20, UNIT_SEC) },
|
|
|
|
{ "25s", TALK_ID(25, UNIT_SEC) },
|
|
|
|
{ "30s", TALK_ID(30, UNIT_SEC) },
|
|
|
|
{ "45s", TALK_ID(45, UNIT_SEC) },
|
|
|
|
{ "60s", TALK_ID(60, UNIT_SEC) }
|
2004-03-15 08:27:51 +00:00
|
|
|
};
|
2002-09-24 17:22:12 +00:00
|
|
|
return set_option(str(LANG_FFRW_STEP), &global_settings.ff_rewind_min_step,
|
2003-06-05 11:11:10 +00:00
|
|
|
INT, names, 14, NULL );
|
2002-09-04 03:38:37 +00:00
|
|
|
}
|
|
|
|
|
2003-02-14 15:54:52 +00:00
|
|
|
static bool set_fade_on_stop(void)
|
|
|
|
{
|
|
|
|
return set_bool( str(LANG_FADE_ON_STOP), &global_settings.fade_on_stop );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool ff_rewind_accel(void)
|
2002-08-29 05:41:35 +00:00
|
|
|
{
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct opt_items names[] = {
|
2004-03-15 08:27:51 +00:00
|
|
|
{ STR(LANG_OFF) },
|
2004-03-19 22:15:53 +00:00
|
|
|
{ "2x/1s", TALK_ID(1, UNIT_SEC) },
|
|
|
|
{ "2x/2s", TALK_ID(2, UNIT_SEC) },
|
|
|
|
{ "2x/3s", TALK_ID(3, UNIT_SEC) },
|
|
|
|
{ "2x/4s", TALK_ID(4, UNIT_SEC) },
|
|
|
|
{ "2x/5s", TALK_ID(5, UNIT_SEC) },
|
|
|
|
{ "2x/6s", TALK_ID(6, UNIT_SEC) },
|
|
|
|
{ "2x/7s", TALK_ID(7, UNIT_SEC) },
|
|
|
|
{ "2x/8s", TALK_ID(8, UNIT_SEC) },
|
|
|
|
{ "2x/9s", TALK_ID(9, UNIT_SEC) },
|
|
|
|
{ "2x/10s", TALK_ID(10, UNIT_SEC) },
|
|
|
|
{ "2x/11s", TALK_ID(11, UNIT_SEC) },
|
|
|
|
{ "2x/12s", TALK_ID(12, UNIT_SEC) },
|
|
|
|
{ "2x/13s", TALK_ID(13, UNIT_SEC) },
|
|
|
|
{ "2x/14s", TALK_ID(14, UNIT_SEC) },
|
|
|
|
{ "2x/15s", TALK_ID(15, UNIT_SEC) }
|
2004-03-15 08:27:51 +00:00
|
|
|
};
|
2002-09-24 17:22:12 +00:00
|
|
|
return set_option(str(LANG_FFRW_ACCEL), &global_settings.ff_rewind_accel,
|
2003-06-05 11:11:10 +00:00
|
|
|
INT, names, 16, NULL );
|
2002-08-29 05:41:35 +00:00
|
|
|
}
|
2002-08-28 19:34:07 +00:00
|
|
|
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool browse_current(void)
|
2002-09-09 14:25:39 +00:00
|
|
|
{
|
2002-09-24 17:22:12 +00:00
|
|
|
return set_bool( str(LANG_FOLLOW), &global_settings.browse_current );
|
2002-09-09 14:25:39 +00:00
|
|
|
}
|
|
|
|
|
2003-09-29 21:26:53 +00:00
|
|
|
static bool custom_wps_browse(void)
|
|
|
|
{
|
2005-11-12 21:48:06 +00:00
|
|
|
return rockbox_browse(WPS_DIR, SHOW_WPS);
|
2003-09-29 21:26:53 +00:00
|
|
|
}
|
|
|
|
|
2005-11-17 20:14:59 +00:00
|
|
|
#ifdef HAVE_REMOTE_LCD
|
|
|
|
static bool custom_remote_wps_browse(void)
|
|
|
|
{
|
|
|
|
return rockbox_browse(WPS_DIR, SHOW_RWPS);
|
|
|
|
}
|
|
|
|
#endif
|
2005-11-18 08:48:59 +00:00
|
|
|
|
2003-09-29 21:26:53 +00:00
|
|
|
static bool custom_cfg_browse(void)
|
|
|
|
{
|
2005-08-17 17:53:54 +00:00
|
|
|
return rockbox_browse(ROCKBOX_DIR, SHOW_CFG);
|
2003-09-29 21:26:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool language_browse(void)
|
|
|
|
{
|
2005-08-17 17:53:54 +00:00
|
|
|
return rockbox_browse(ROCKBOX_DIR LANG_DIR, SHOW_LNG);
|
2003-09-29 21:26:53 +00:00
|
|
|
}
|
|
|
|
|
2004-03-27 00:11:01 +00:00
|
|
|
static bool voice_menus(void)
|
|
|
|
{
|
|
|
|
bool ret;
|
|
|
|
bool temp = global_settings.talk_menu;
|
|
|
|
/* work on a temp variable first, avoid "life" disabling */
|
|
|
|
ret = set_bool( str(LANG_VOICE_MENU), &temp );
|
|
|
|
global_settings.talk_menu = temp;
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2004-10-06 21:37:46 +00:00
|
|
|
/* this is used 2 times below, so it saves memory to put it in global scope */
|
|
|
|
static const struct opt_items voice_names[] = {
|
|
|
|
{ STR(LANG_OFF) },
|
|
|
|
{ STR(LANG_VOICE_NUMBER) },
|
|
|
|
{ STR(LANG_VOICE_SPELL) },
|
|
|
|
{ STR(LANG_VOICE_DIR_HOVER) }
|
|
|
|
};
|
|
|
|
|
2004-03-27 00:11:01 +00:00
|
|
|
static bool voice_dirs(void)
|
|
|
|
{
|
|
|
|
return set_option( str(LANG_VOICE_DIR),
|
2004-10-06 21:37:46 +00:00
|
|
|
&global_settings.talk_dir, INT, voice_names, 4, NULL);
|
2004-03-27 00:11:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool voice_files(void)
|
|
|
|
{
|
2004-10-21 18:34:48 +00:00
|
|
|
int oldval = global_settings.talk_file;
|
|
|
|
bool ret;
|
|
|
|
ret = set_option( str(LANG_VOICE_FILE),
|
2004-10-06 21:37:46 +00:00
|
|
|
&global_settings.talk_file, INT, voice_names, 4, NULL);
|
2004-10-21 18:34:48 +00:00
|
|
|
if (oldval != 3 && global_settings.talk_file == 3)
|
|
|
|
{ /* force reload if newly talking thumbnails,
|
|
|
|
because the clip presence is cached only if enabled */
|
|
|
|
reload_directory();
|
|
|
|
}
|
|
|
|
return ret;
|
2004-03-27 00:11:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool voice_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_VOICE_MENU), voice_menus },
|
|
|
|
{ ID2P(LANG_VOICE_DIR), voice_dirs },
|
|
|
|
{ ID2P(LANG_VOICE_FILE), voice_files }
|
2004-03-27 00:11:01 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2004-01-14 14:42:31 +00:00
|
|
|
#ifdef HAVE_LCD_BITMAP
|
2003-09-29 21:26:53 +00:00
|
|
|
static bool font_browse(void)
|
|
|
|
{
|
2005-08-17 17:53:54 +00:00
|
|
|
return rockbox_browse(ROCKBOX_DIR FONT_DIR, SHOW_FONT);
|
2003-09-29 21:26:53 +00:00
|
|
|
}
|
|
|
|
|
2003-04-21 12:39:36 +00:00
|
|
|
static bool scroll_bar(void)
|
|
|
|
{
|
|
|
|
return set_bool( str(LANG_SCROLL_BAR), &global_settings.scrollbar );
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool status_bar(void)
|
|
|
|
{
|
|
|
|
return set_bool( str(LANG_STATUS_BAR), &global_settings.statusbar );
|
|
|
|
}
|
2004-03-16 13:44:56 +00:00
|
|
|
|
2004-10-09 20:54:15 +00:00
|
|
|
#if CONFIG_KEYPAD == RECORDER_PAD
|
2004-03-16 13:44:56 +00:00
|
|
|
static bool button_bar(void)
|
|
|
|
{
|
|
|
|
return set_bool( str(LANG_BUTTON_BAR), &global_settings.buttonbar );
|
|
|
|
}
|
2004-10-09 20:54:15 +00:00
|
|
|
#endif /* CONFIG_KEYPAD == RECORDER_PAD */
|
|
|
|
#endif /* HAVE_LCD_BITMAP */
|
2003-04-21 12:39:36 +00:00
|
|
|
|
2004-01-14 14:42:31 +00:00
|
|
|
static bool ff_rewind_settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_FFRW_STEP), ff_rewind_min_step },
|
|
|
|
{ ID2P(LANG_FFRW_ACCEL), ff_rewind_accel },
|
2004-01-14 14:42:31 +00:00
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2004-01-14 14:42:31 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2004-07-27 19:20:51 +00:00
|
|
|
static bool id3_order(void)
|
|
|
|
{
|
|
|
|
return set_bool_options( str(LANG_ID3_ORDER),
|
|
|
|
&global_settings.id3_v1_first,
|
|
|
|
STR(LANG_ID3_V1_FIRST),
|
|
|
|
STR(LANG_ID3_V2_FIRST),
|
|
|
|
mpeg_id3_options);
|
|
|
|
}
|
|
|
|
|
2005-07-01 11:25:16 +00:00
|
|
|
static bool next_folder(void)
|
|
|
|
{
|
|
|
|
return set_bool( str(LANG_NEXT_FOLDER), &global_settings.next_folder );
|
|
|
|
}
|
|
|
|
|
2005-07-02 10:50:42 +00:00
|
|
|
static bool runtimedb(void)
|
|
|
|
{
|
|
|
|
bool rc;
|
|
|
|
bool old = global_settings.runtimedb;
|
|
|
|
|
2005-10-08 22:01:42 +00:00
|
|
|
rc = set_bool( str(LANG_RUNTIMEDB_ACTIVE),
|
|
|
|
&global_settings.runtimedb );
|
2005-07-02 10:50:42 +00:00
|
|
|
if (old && !global_settings.runtimedb)
|
|
|
|
rundb_shutdown();
|
|
|
|
if (!old && global_settings.runtimedb)
|
|
|
|
rundb_init();
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2005-08-29 21:15:27 +00:00
|
|
|
#if CONFIG_CODEC == SWCODEC
|
2005-07-24 15:32:28 +00:00
|
|
|
static bool replaygain(void)
|
|
|
|
{
|
|
|
|
bool result = set_bool(str(LANG_REPLAYGAIN_ENABLE),
|
|
|
|
&global_settings.replaygain);
|
|
|
|
|
|
|
|
dsp_set_replaygain(true);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool replaygain_mode(void)
|
|
|
|
{
|
2005-09-24 15:22:48 +00:00
|
|
|
static const struct opt_items names[] = {
|
|
|
|
{ STR(LANG_TRACK_GAIN) },
|
|
|
|
{ STR(LANG_ALBUM_GAIN) },
|
|
|
|
{ STR(LANG_SHUFFLE_GAIN) },
|
|
|
|
};
|
|
|
|
bool result = set_option(str(LANG_REPLAYGAIN_MODE),
|
|
|
|
&global_settings.replaygain_type, INT, names, 3, NULL);
|
2005-07-24 15:32:28 +00:00
|
|
|
|
|
|
|
dsp_set_replaygain(true);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool replaygain_noclip(void)
|
|
|
|
{
|
|
|
|
bool result = set_bool(str(LANG_REPLAYGAIN_NOCLIP),
|
|
|
|
&global_settings.replaygain_noclip);
|
|
|
|
|
|
|
|
dsp_set_replaygain(true);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2005-08-11 18:56:20 +00:00
|
|
|
void replaygain_preamp_format(char* buffer, int buffer_size, int value,
|
|
|
|
const char* unit)
|
|
|
|
{
|
|
|
|
int v = abs(value);
|
|
|
|
|
|
|
|
snprintf(buffer, buffer_size, "%s%d.%d %s", value < 0 ? "-" : "",
|
|
|
|
v / 10, v % 10, unit);
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool replaygain_preamp(void)
|
|
|
|
{
|
|
|
|
bool result = set_int(str(LANG_REPLAYGAIN_PREAMP), str(LANG_UNIT_DB),
|
|
|
|
UNIT_DB, &global_settings.replaygain_preamp, NULL, 1, -120, 120,
|
|
|
|
replaygain_preamp_format);
|
|
|
|
|
|
|
|
dsp_set_replaygain(true);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2005-07-24 15:32:28 +00:00
|
|
|
static bool replaygain_settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_REPLAYGAIN_ENABLE), replaygain },
|
|
|
|
{ ID2P(LANG_REPLAYGAIN_NOCLIP), replaygain_noclip },
|
|
|
|
{ ID2P(LANG_REPLAYGAIN_MODE), replaygain_mode },
|
2005-08-11 18:56:20 +00:00
|
|
|
{ ID2P(LANG_REPLAYGAIN_PREAMP), replaygain_preamp },
|
2005-07-24 15:32:28 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
2005-08-20 21:17:41 +00:00
|
|
|
|
2005-11-14 21:56:56 +00:00
|
|
|
static bool crossfeed(void)
|
|
|
|
{
|
2005-11-23 21:06:57 +00:00
|
|
|
bool result = set_bool_options(str(LANG_CROSSFEED),
|
|
|
|
&global_settings.crossfeed,
|
|
|
|
STR(LANG_ON),
|
|
|
|
STR(LANG_OFF),
|
|
|
|
NULL);
|
2005-11-14 21:56:56 +00:00
|
|
|
|
|
|
|
dsp_set_crossfeed(global_settings.crossfeed);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2005-11-06 16:40:20 +00:00
|
|
|
static bool crossfade(void)
|
|
|
|
{
|
|
|
|
static const struct opt_items names[] = {
|
|
|
|
{ STR(LANG_OFF) },
|
|
|
|
{ STR(LANG_SHUFFLE) },
|
|
|
|
{ STR(LANG_ALWAYS) },
|
|
|
|
};
|
|
|
|
|
|
|
|
bool ret;
|
|
|
|
|
|
|
|
ret=set_option( str(LANG_CROSSFADE_ENABLE),
|
|
|
|
&global_settings.crossfade, INT, names, 3, NULL);
|
|
|
|
|
|
|
|
audio_set_crossfade(global_settings.crossfade);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool crossfade_fade_in_delay(void)
|
|
|
|
{
|
|
|
|
bool ret;
|
2005-11-07 20:14:39 +00:00
|
|
|
|
|
|
|
ret = set_int(str(LANG_CROSSFADE_FADE_IN_DELAY), "s", UNIT_SEC,
|
|
|
|
&global_settings.crossfade_fade_in_delay,
|
|
|
|
NULL, 1, 0, 7, NULL );
|
2005-11-06 16:40:20 +00:00
|
|
|
audio_set_crossfade(global_settings.crossfade);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool crossfade_fade_out_delay(void)
|
|
|
|
{
|
|
|
|
bool ret;
|
2005-11-07 20:14:39 +00:00
|
|
|
|
|
|
|
ret = set_int(str(LANG_CROSSFADE_FADE_OUT_DELAY), "s", UNIT_SEC,
|
|
|
|
&global_settings.crossfade_fade_out_delay,
|
|
|
|
NULL, 1, 0, 7, NULL );
|
2005-11-06 16:40:20 +00:00
|
|
|
audio_set_crossfade(global_settings.crossfade);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool crossfade_fade_in_duration(void)
|
|
|
|
{
|
|
|
|
bool ret;
|
2005-11-07 20:14:39 +00:00
|
|
|
|
|
|
|
ret = set_int(str(LANG_CROSSFADE_FADE_IN_DURATION), "s", UNIT_SEC,
|
|
|
|
&global_settings.crossfade_fade_in_duration,
|
|
|
|
NULL, 1, 0, 15, NULL );
|
2005-11-06 16:40:20 +00:00
|
|
|
audio_set_crossfade(global_settings.crossfade);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool crossfade_fade_out_duration(void)
|
|
|
|
{
|
|
|
|
bool ret;
|
2005-11-07 20:14:39 +00:00
|
|
|
|
|
|
|
ret = set_int(str(LANG_CROSSFADE_FADE_OUT_DURATION), "s", UNIT_SEC,
|
|
|
|
&global_settings.crossfade_fade_out_duration,
|
|
|
|
NULL, 1, 0, 15, NULL );
|
2005-11-06 16:40:20 +00:00
|
|
|
audio_set_crossfade(global_settings.crossfade);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool crossfade_fade_out_mixmode(void)
|
|
|
|
{
|
|
|
|
static const struct opt_items names[] = {
|
|
|
|
{ STR(LANG_CROSSFADE) },
|
|
|
|
{ STR(LANG_MIX) },
|
|
|
|
};
|
|
|
|
bool ret;
|
|
|
|
ret=set_option( str(LANG_CROSSFADE_FADE_OUT_MODE),
|
|
|
|
&global_settings.crossfade_fade_out_mixmode, INT, names, 2, NULL);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Menu to configure the crossfade settings.
|
|
|
|
*/
|
|
|
|
static bool crossfade_settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_CROSSFADE_ENABLE), crossfade },
|
|
|
|
{ ID2P(LANG_CROSSFADE_FADE_IN_DELAY), crossfade_fade_in_delay },
|
|
|
|
{ ID2P(LANG_CROSSFADE_FADE_IN_DURATION), crossfade_fade_in_duration },
|
|
|
|
{ ID2P(LANG_CROSSFADE_FADE_OUT_DELAY), crossfade_fade_out_delay },
|
|
|
|
{ ID2P(LANG_CROSSFADE_FADE_OUT_DURATION), crossfade_fade_out_duration },
|
|
|
|
{ ID2P(LANG_CROSSFADE_FADE_OUT_MODE), crossfade_fade_out_mixmode },
|
|
|
|
};
|
|
|
|
|
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2005-08-20 21:17:41 +00:00
|
|
|
static bool beep(void)
|
|
|
|
{
|
|
|
|
static const struct opt_items names[] = {
|
|
|
|
{ STR(LANG_OFF) },
|
|
|
|
{ STR(LANG_WEAK) },
|
|
|
|
{ STR(LANG_MODERATE) },
|
|
|
|
{ STR(LANG_STRONG) },
|
|
|
|
};
|
|
|
|
bool ret;
|
|
|
|
ret=set_option( str(LANG_BEEP),
|
|
|
|
&global_settings.beep, INT, names, 4, NULL);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
2005-07-24 15:32:28 +00:00
|
|
|
#endif
|
|
|
|
|
2005-10-07 17:38:05 +00:00
|
|
|
#ifdef HAVE_DIRCACHE
|
|
|
|
static bool dircache(void)
|
|
|
|
{
|
2005-10-08 22:01:42 +00:00
|
|
|
bool result = set_bool_options(str(LANG_DIRCACHE_ENABLE),
|
|
|
|
&global_settings.dircache,
|
|
|
|
STR(LANG_ON),
|
|
|
|
STR(LANG_OFF),
|
|
|
|
NULL);
|
2005-10-07 17:38:05 +00:00
|
|
|
|
|
|
|
if (!dircache_is_enabled() && global_settings.dircache)
|
2005-11-16 15:12:15 +00:00
|
|
|
gui_syncsplash(HZ*2, true, str(LANG_DIRCACHE_REBOOT));
|
2005-10-07 17:38:05 +00:00
|
|
|
|
|
|
|
if (!result)
|
|
|
|
dircache_disable();
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* HAVE_DIRCACHE */
|
|
|
|
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool playback_settings_menu(void)
|
2002-09-05 04:42:12 +00:00
|
|
|
{
|
|
|
|
int m;
|
2002-09-24 17:22:12 +00:00
|
|
|
bool result;
|
2002-09-05 04:42:12 +00:00
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_SHUFFLE), shuffle },
|
|
|
|
{ ID2P(LANG_REPEAT), repeat_mode },
|
|
|
|
{ ID2P(LANG_PLAY_SELECTED), play_selected },
|
|
|
|
{ ID2P(LANG_RESUME), resume },
|
|
|
|
{ ID2P(LANG_WIND_MENU), ff_rewind_settings_menu },
|
|
|
|
{ ID2P(LANG_MP3BUFFER_MARGIN), buffer_margin },
|
|
|
|
{ ID2P(LANG_FADE_ON_STOP), set_fade_on_stop },
|
2005-08-29 21:15:27 +00:00
|
|
|
#if CONFIG_CODEC == SWCODEC
|
2005-11-06 16:40:20 +00:00
|
|
|
{ ID2P(LANG_CROSSFADE), crossfade_settings_menu },
|
2005-07-24 15:32:28 +00:00
|
|
|
{ ID2P(LANG_REPLAYGAIN), replaygain_settings_menu },
|
2005-11-14 21:56:56 +00:00
|
|
|
{ ID2P(LANG_CROSSFEED), crossfeed },
|
2005-08-20 21:17:41 +00:00
|
|
|
{ ID2P(LANG_BEEP), beep },
|
2005-07-01 09:42:39 +00:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SPDIF_POWER
|
|
|
|
{ ID2P(LANG_SPDIF_ENABLE), spdif },
|
2005-06-09 09:47:00 +00:00
|
|
|
#endif
|
2004-07-27 19:20:51 +00:00
|
|
|
{ ID2P(LANG_ID3_ORDER), id3_order },
|
2005-07-01 11:25:16 +00:00
|
|
|
{ ID2P(LANG_NEXT_FOLDER), next_folder },
|
2005-07-02 10:50:42 +00:00
|
|
|
{ ID2P(LANG_RUNTIMEDB_ACTIVE), runtimedb },
|
2002-06-24 21:39:48 +00:00
|
|
|
};
|
2002-09-18 14:08:05 +00:00
|
|
|
|
2002-08-02 13:20:03 +00:00
|
|
|
bool old_shuffle = global_settings.playlist_shuffle;
|
2004-01-14 14:42:31 +00:00
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2002-08-23 12:32:52 +00:00
|
|
|
result = menu_run(m);
|
2002-06-24 21:39:48 +00:00
|
|
|
menu_exit(m);
|
2002-08-02 13:20:03 +00:00
|
|
|
|
2005-05-01 19:13:47 +00:00
|
|
|
if ((old_shuffle != global_settings.playlist_shuffle)
|
|
|
|
&& (audio_status() & AUDIO_STATUS_PLAY))
|
2002-08-02 13:20:03 +00:00
|
|
|
{
|
2005-09-24 15:56:33 +00:00
|
|
|
#if CONFIG_CODEC == SWCODEC
|
2005-09-24 15:22:48 +00:00
|
|
|
dsp_set_replaygain(true);
|
2005-09-24 15:56:33 +00:00
|
|
|
#endif
|
2005-09-24 15:22:48 +00:00
|
|
|
|
2002-08-02 13:20:03 +00:00
|
|
|
if (global_settings.playlist_shuffle)
|
|
|
|
{
|
2004-01-26 17:05:21 +00:00
|
|
|
playlist_randomise(NULL, current_tick, true);
|
2002-08-02 13:20:03 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2004-01-26 17:05:21 +00:00
|
|
|
playlist_sort(NULL, true);
|
2002-08-02 13:20:03 +00:00
|
|
|
}
|
|
|
|
}
|
2002-08-23 12:32:52 +00:00
|
|
|
return result;
|
2002-06-24 21:39:48 +00:00
|
|
|
}
|
2002-09-05 04:42:12 +00:00
|
|
|
|
2004-01-14 00:13:04 +00:00
|
|
|
static bool bookmark_settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_BOOKMARK_SETTINGS_AUTOCREATE), autocreatebookmark},
|
|
|
|
{ ID2P(LANG_BOOKMARK_SETTINGS_AUTOLOAD), autoloadbookmark},
|
|
|
|
{ ID2P(LANG_BOOKMARK_SETTINGS_MAINTAIN_RECENT_BOOKMARKS), useMRB},
|
2004-01-14 00:13:04 +00:00
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2004-01-14 00:13:04 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool reset_settings(void)
|
2002-09-06 07:00:20 +00:00
|
|
|
{
|
2005-11-18 02:07:02 +00:00
|
|
|
char *lines[]={str(LANG_RESET_ASK_RECORDER)};
|
|
|
|
char *yes_lines[]={str(LANG_RESET_DONE_SETTING), str(LANG_RESET_DONE_CLEAR)};
|
|
|
|
char *no_lines[]={yes_lines[0], str(LANG_RESET_DONE_CANCEL)};
|
|
|
|
struct text_message message={lines, 1};
|
|
|
|
struct text_message yes_message={yes_lines, 2};
|
|
|
|
struct text_message no_message={no_lines, 2};
|
2002-10-14 09:12:52 +00:00
|
|
|
|
2005-11-18 02:07:02 +00:00
|
|
|
switch(gui_syncyesno_run(&message, &yes_message, &no_message))
|
|
|
|
{
|
|
|
|
case YESNO_YES:
|
|
|
|
settings_reset();
|
|
|
|
settings_apply();
|
|
|
|
break;
|
|
|
|
case YESNO_NO:
|
|
|
|
break;
|
|
|
|
case YESNO_USB:
|
|
|
|
return true;
|
2002-09-06 07:00:20 +00:00
|
|
|
}
|
2002-10-14 09:12:52 +00:00
|
|
|
return false;
|
2002-09-06 07:00:20 +00:00
|
|
|
}
|
|
|
|
|
2002-09-24 17:22:12 +00:00
|
|
|
static bool fileview_settings_menu(void)
|
2002-09-05 04:42:12 +00:00
|
|
|
{
|
|
|
|
int m;
|
2002-09-24 17:22:12 +00:00
|
|
|
bool result;
|
2002-09-05 04:42:12 +00:00
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_SORT_CASE), sort_case },
|
|
|
|
{ ID2P(LANG_SORT_DIR), sort_dir },
|
|
|
|
{ ID2P(LANG_SORT_FILE), sort_file },
|
|
|
|
{ ID2P(LANG_FILTER), dir_filter },
|
|
|
|
{ ID2P(LANG_FOLLOW), browse_current },
|
|
|
|
{ ID2P(LANG_SHOW_ICONS), show_icons },
|
2002-09-05 04:42:12 +00:00
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2002-09-05 04:42:12 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2002-12-12 16:56:19 +00:00
|
|
|
|
|
|
|
static bool scroll_settings_menu(void)
|
2002-09-05 04:42:12 +00:00
|
|
|
{
|
|
|
|
int m;
|
2002-09-24 17:22:12 +00:00
|
|
|
bool result;
|
2002-09-05 04:42:12 +00:00
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_SCROLL_SPEED), scroll_speed },
|
|
|
|
{ ID2P(LANG_SCROLL_DELAY), scroll_delay },
|
2002-12-12 15:20:37 +00:00
|
|
|
#ifdef HAVE_LCD_BITMAP
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_SCROLL_STEP), scroll_step },
|
2002-12-12 15:20:37 +00:00
|
|
|
#endif
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_BIDIR_SCROLL), bidir_limit },
|
2003-05-22 06:42:14 +00:00
|
|
|
#ifdef HAVE_LCD_CHARCELLS
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_JUMP_SCROLL), jump_scroll },
|
|
|
|
{ ID2P(LANG_JUMP_SCROLL_DELAY), jump_scroll_delay },
|
2003-05-22 06:42:14 +00:00
|
|
|
#endif
|
2002-12-12 16:56:19 +00:00
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2002-12-12 16:56:19 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2004-01-14 14:42:31 +00:00
|
|
|
static bool lcd_settings_menu(void)
|
2002-12-12 16:56:19 +00:00
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
2004-12-18 10:29:47 +00:00
|
|
|
#ifdef CONFIG_BACKLIGHT
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_BACKLIGHT), backlight_timer },
|
2004-12-18 10:29:47 +00:00
|
|
|
#ifdef HAVE_CHARGING
|
2005-11-23 20:12:33 +00:00
|
|
|
{ ID2P(LANG_BACKLIGHT_ON_WHEN_CHARGING), backlight_timer_plugged },
|
2004-10-09 19:56:27 +00:00
|
|
|
#endif
|
2004-12-18 10:29:47 +00:00
|
|
|
{ ID2P(LANG_CAPTION_BACKLIGHT), caption_backlight },
|
2005-11-21 23:55:39 +00:00
|
|
|
#if (CONFIG_BACKLIGHT == BL_IRIVER_H100) && !defined(SIMULATOR)
|
2005-06-20 17:03:09 +00:00
|
|
|
{ ID2P(LANG_BACKLIGHT_FADE_IN), backlight_fade_in },
|
|
|
|
{ ID2P(LANG_BACKLIGHT_FADE_OUT), backlight_fade_out },
|
|
|
|
#endif
|
2004-12-18 10:29:47 +00:00
|
|
|
#endif /* CONFIG_BACKLIGHT */
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_CONTRAST), contrast },
|
2002-09-27 09:31:31 +00:00
|
|
|
#ifdef HAVE_LCD_BITMAP
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_INVERT), invert },
|
|
|
|
{ ID2P(LANG_FLIP_DISPLAY), flip_display },
|
2005-09-01 20:23:16 +00:00
|
|
|
{ ID2P(LANG_INVERT_CURSOR), invert_cursor },
|
2002-09-27 09:31:31 +00:00
|
|
|
#endif
|
2002-09-05 04:42:12 +00:00
|
|
|
};
|
2004-01-14 14:42:31 +00:00
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2002-09-05 04:42:12 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2005-04-15 12:08:49 +00:00
|
|
|
#ifdef HAVE_REMOTE_LCD
|
|
|
|
static bool lcd_remote_settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
|
|
|
static const struct menu_item items[] = {
|
2005-05-30 00:00:22 +00:00
|
|
|
{ ID2P(LANG_BACKLIGHT), remote_backlight_timer },
|
2005-11-21 23:55:39 +00:00
|
|
|
#ifdef HAVE_CHARGING
|
|
|
|
{ ID2P(LANG_BACKLIGHT_ON_WHEN_CHARGING),
|
2005-11-23 20:12:33 +00:00
|
|
|
remote_backlight_timer_plugged },
|
2005-11-21 23:55:39 +00:00
|
|
|
#endif
|
|
|
|
{ ID2P(LANG_CAPTION_BACKLIGHT), remote_caption_backlight },
|
2005-04-15 12:08:49 +00:00
|
|
|
{ ID2P(LANG_CONTRAST), remote_contrast },
|
|
|
|
{ ID2P(LANG_INVERT), remote_invert },
|
2005-06-17 21:43:00 +00:00
|
|
|
{ ID2P(LANG_FLIP_DISPLAY), remote_flip_display },
|
2005-11-19 09:26:02 +00:00
|
|
|
#ifdef HAVE_REMOTE_LCD_TICKING
|
2005-11-19 07:58:20 +00:00
|
|
|
{ ID2P(LANG_REDUCE_TICKING), remote_reduce_ticking },
|
2005-11-19 09:26:02 +00:00
|
|
|
#endif
|
2005-11-19 07:58:20 +00:00
|
|
|
};
|
2005-04-15 12:08:49 +00:00
|
|
|
|
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2004-01-14 14:42:31 +00:00
|
|
|
#ifdef HAVE_LCD_BITMAP
|
|
|
|
static bool bars_settings_menu(void)
|
2002-09-05 04:42:12 +00:00
|
|
|
{
|
|
|
|
int m;
|
2002-09-24 17:22:12 +00:00
|
|
|
bool result;
|
2002-09-05 04:42:12 +00:00
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_SCROLL_BAR), scroll_bar },
|
|
|
|
{ ID2P(LANG_STATUS_BAR), status_bar },
|
2004-10-09 20:54:15 +00:00
|
|
|
#if CONFIG_KEYPAD == RECORDER_PAD
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_BUTTON_BAR), button_bar },
|
2004-10-09 20:54:15 +00:00
|
|
|
#endif
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_VOLUME_DISPLAY), volume_type },
|
2005-01-30 13:48:44 +00:00
|
|
|
{ ID2P(LANG_BATTERY_DISPLAY), battery_display },
|
2004-01-14 14:42:31 +00:00
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2004-01-14 14:42:31 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
2003-11-03 23:36:36 +00:00
|
|
|
#endif
|
2004-01-14 14:42:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
static bool display_settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
2004-01-14 14:42:31 +00:00
|
|
|
#ifdef HAVE_LCD_BITMAP
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_CUSTOM_FONT), font_browse },
|
2002-11-29 07:05:46 +00:00
|
|
|
#endif
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_WHILE_PLAYING), custom_wps_browse },
|
2005-11-17 20:14:59 +00:00
|
|
|
#ifdef HAVE_REMOTE_LCD
|
|
|
|
{ ID2P(LANG_REMOTE_WHILE_PLAYING), custom_remote_wps_browse },
|
|
|
|
#endif
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_LCD_MENU), lcd_settings_menu },
|
2005-04-15 12:08:49 +00:00
|
|
|
#ifdef HAVE_REMOTE_LCD
|
|
|
|
{ ID2P(LANG_LCD_REMOTE_MENU), lcd_remote_settings_menu },
|
|
|
|
#endif
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_SCROLL_MENU), scroll_settings_menu },
|
2004-01-14 14:42:31 +00:00
|
|
|
#ifdef HAVE_LCD_BITMAP
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_BARS_MENU), bars_settings_menu },
|
|
|
|
{ ID2P(LANG_PM_MENU), peak_meter_menu },
|
2005-08-09 19:46:33 +00:00
|
|
|
{ ID2P(LANG_BIDI_SUPPORT), bidi_support },
|
2002-12-16 22:58:48 +00:00
|
|
|
#endif
|
2004-01-14 14:42:31 +00:00
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2004-01-14 14:42:31 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static bool firmware_browse(void)
|
|
|
|
{
|
2005-08-17 17:53:54 +00:00
|
|
|
return rockbox_browse(ROCKBOX_DIR, SHOW_MOD);
|
2004-01-14 14:42:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool battery_settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
2004-01-14 14:42:31 +00:00
|
|
|
#ifndef SIMULATOR
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_BATTERY_CAPACITY), battery_capacity },
|
2005-01-30 16:25:46 +00:00
|
|
|
#if BATTERY_TYPES_COUNT > 1
|
|
|
|
{ ID2P(LANG_BATTERY_TYPE), battery_type },
|
|
|
|
#endif
|
2004-06-14 07:23:48 +00:00
|
|
|
#else
|
|
|
|
#ifndef HAVE_CHARGE_CTRL
|
2004-07-23 23:01:20 +00:00
|
|
|
{ "Dummy", NULL }, /* to have an entry at all, in the simulator */
|
2004-06-14 07:23:48 +00:00
|
|
|
#endif
|
2004-01-14 14:42:31 +00:00
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2004-01-14 14:42:31 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2004-10-09 22:04:47 +00:00
|
|
|
#ifndef HAVE_MMC
|
2004-01-14 14:42:31 +00:00
|
|
|
static bool disk_settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_SPINDOWN), spindown },
|
2004-01-14 14:42:31 +00:00
|
|
|
#ifdef HAVE_ATA_POWER_OFF
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_POWEROFF), poweroff },
|
2005-10-07 17:38:05 +00:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_DIRCACHE
|
|
|
|
{ ID2P(LANG_DIRCACHE_ENABLE), dircache },
|
2004-01-14 14:42:31 +00:00
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2004-01-14 14:42:31 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
2004-10-09 22:04:47 +00:00
|
|
|
#endif /* !HAVE_MMC */
|
2004-01-14 14:42:31 +00:00
|
|
|
|
2004-09-10 10:51:54 +00:00
|
|
|
#ifdef HAVE_RTC
|
2004-01-14 14:42:31 +00:00
|
|
|
static bool time_settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_TIME), timedate_set },
|
|
|
|
{ ID2P(LANG_TIMEFORMAT), timeformat_set },
|
2004-01-14 14:42:31 +00:00
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2004-01-14 14:42:31 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
2002-09-05 04:42:12 +00:00
|
|
|
#endif
|
2004-01-14 14:42:31 +00:00
|
|
|
|
2005-07-04 09:24:31 +00:00
|
|
|
bool manage_settings_menu(void)
|
2004-01-14 14:42:31 +00:00
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_CUSTOM_CFG), custom_cfg_browse },
|
|
|
|
{ ID2P(LANG_FIRMWARE), firmware_browse },
|
|
|
|
{ ID2P(LANG_RESET), reset_settings },
|
|
|
|
{ ID2P(LANG_SAVE_SETTINGS), settings_save_config },
|
2002-09-05 04:42:12 +00:00
|
|
|
};
|
2004-01-14 14:42:31 +00:00
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2002-09-05 04:42:12 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
2002-09-07 12:28:46 +00:00
|
|
|
|
2004-01-14 14:42:31 +00:00
|
|
|
static bool limits_settings_menu(void)
|
2002-09-07 12:28:46 +00:00
|
|
|
{
|
|
|
|
int m;
|
2002-09-24 17:22:12 +00:00
|
|
|
bool result;
|
2002-09-07 12:28:46 +00:00
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_MAX_FILES_IN_DIR), max_files_in_dir },
|
|
|
|
{ ID2P(LANG_MAX_FILES_IN_PLAYLIST), max_files_in_playlist },
|
2004-01-14 14:42:31 +00:00
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2004-01-14 14:42:31 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static bool system_settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_BATTERY_MENU), battery_settings_menu },
|
2004-10-09 22:04:47 +00:00
|
|
|
#ifndef HAVE_MMC
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_DISK_MENU), disk_settings_menu },
|
2004-10-09 22:04:47 +00:00
|
|
|
#endif
|
2004-01-14 14:42:31 +00:00
|
|
|
#ifdef HAVE_RTC
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_TIME_MENU), time_settings_menu },
|
2003-09-29 21:26:53 +00:00
|
|
|
#endif
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_POWEROFF_IDLE), poweroff_idle_timer },
|
|
|
|
{ ID2P(LANG_SLEEP_TIMER), sleeptimer_screen },
|
2004-01-15 08:25:42 +00:00
|
|
|
#ifdef HAVE_ALARM_MOD
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_ALARM_MOD_ALARM_MENU), alarm_screen },
|
2004-01-15 08:25:42 +00:00
|
|
|
#endif
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_LIMITS_MENU), limits_settings_menu },
|
2005-08-29 21:15:27 +00:00
|
|
|
#if CONFIG_CODEC == MAS3507D
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_LINE_IN), line_in },
|
2004-01-14 14:42:31 +00:00
|
|
|
#endif
|
2004-10-10 01:25:32 +00:00
|
|
|
#ifdef HAVE_CHARGING
|
2004-07-23 23:01:20 +00:00
|
|
|
{ ID2P(LANG_CAR_ADAPTER_MODE), car_adapter_mode },
|
2004-10-10 01:25:32 +00:00
|
|
|
#endif
|
2004-01-14 14:42:31 +00:00
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2004-01-14 14:42:31 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool settings_menu(void)
|
|
|
|
{
|
|
|
|
int m;
|
|
|
|
bool result;
|
|
|
|
|
2004-07-23 23:01:20 +00:00
|
|
|
static const struct menu_item items[] = {
|
|
|
|
{ ID2P(LANG_PLAYBACK), playback_settings_menu },
|
|
|
|
{ ID2P(LANG_FILE), fileview_settings_menu },
|
|
|
|
{ ID2P(LANG_DISPLAY), display_settings_menu },
|
|
|
|
{ ID2P(LANG_SYSTEM), system_settings_menu },
|
|
|
|
{ ID2P(LANG_BOOKMARK_SETTINGS),bookmark_settings_menu },
|
|
|
|
{ ID2P(LANG_LANGUAGE), language_browse },
|
|
|
|
{ ID2P(LANG_VOICE), voice_menu },
|
2002-09-07 12:28:46 +00:00
|
|
|
};
|
|
|
|
|
2004-03-16 13:44:56 +00:00
|
|
|
m=menu_init( items, sizeof(items) / sizeof(*items), NULL,
|
|
|
|
NULL, NULL, NULL);
|
2002-09-07 12:28:46 +00:00
|
|
|
result = menu_run(m);
|
|
|
|
menu_exit(m);
|
|
|
|
return result;
|
|
|
|
}
|