summaryrefslogtreecommitdiffstats
path: root/apps/gui
diff options
context:
space:
mode:
Diffstat (limited to 'apps/gui')
-rw-r--r--apps/gui/backdrop.c155
-rw-r--r--apps/gui/backdrop.h46
-rw-r--r--apps/gui/gwps-common.c7
-rw-r--r--apps/gui/gwps.c7
-rw-r--r--apps/gui/wps_parser.c5
5 files changed, 212 insertions, 8 deletions
diff --git a/apps/gui/backdrop.c b/apps/gui/backdrop.c
new file mode 100644
index 0000000000..0d023602be
--- /dev/null
+++ b/apps/gui/backdrop.c
@@ -0,0 +1,155 @@
+/***************************************************************************
+ * __________ __ ___.
+ * Open \______ \ ____ ____ | | _\_ |__ _______ ___
+ * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
+ * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
+ * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
+ * \/ \/ \/ \/ \/
+ * $Id$
+ *
+ * Copyright (C) 2006 Dave Chapman
+ *
+ * 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 <stdio.h>
+#include "config.h"
+#include "lcd.h"
+#ifdef HAVE_REMOTE_LCD
+#include "lcd-remote.h"
+#endif
+#include "backdrop.h"
+
+#if LCD_DEPTH >= 8
+static fb_data main_backdrop[LCD_HEIGHT][LCD_WIDTH] __attribute__ ((aligned (16)));
+static fb_data wps_backdrop[LCD_HEIGHT][LCD_WIDTH] __attribute__ ((aligned (16)));
+#elif LCD_DEPTH == 2
+static fb_data main_backdrop[LCD_FBHEIGHT][LCD_FBWIDTH];
+static fb_data wps_backdrop[LCD_FBHEIGHT][LCD_FBWIDTH];
+#endif
+
+#if defined(HAVE_REMOTE_LCD) && LCD_REMOTE_DEPTH > 1
+static fb_remote_data remote_wps_backdrop[LCD_REMOTE_FBHEIGHT][LCD_REMOTE_FBWIDTH];
+static bool remote_wps_backdrop_valid = false;
+#endif
+
+static bool main_backdrop_valid = false;
+static bool wps_backdrop_valid = false;
+
+/* load a backdrop into a buffer */
+static bool load_backdrop(char* filename, fb_data* backdrop_buffer)
+{
+ struct bitmap bm;
+ int ret;
+
+ /* load the image */
+ bm.data=(char*)backdrop_buffer;
+ ret = read_bmp_file(filename, &bm, sizeof(main_backdrop),
+ FORMAT_NATIVE | FORMAT_DITHER);
+
+ if ((ret > 0) && (bm.width == LCD_WIDTH) && (bm.height == LCD_HEIGHT))
+ {
+ return true;
+ }
+ else
+ {
+ return false;
+ }
+}
+
+bool load_main_backdrop(char* filename)
+{
+ main_backdrop_valid = load_backdrop(filename, &main_backdrop[0][0]);
+ return main_backdrop_valid;
+}
+
+bool load_wps_backdrop(char* filename)
+{
+ wps_backdrop_valid = load_backdrop(filename, &wps_backdrop[0][0]);
+ return wps_backdrop_valid;
+}
+
+void unload_main_backdrop(void)
+{
+ main_backdrop_valid = false;
+}
+
+void unload_wps_backdrop(void)
+{
+ wps_backdrop_valid = false;
+}
+
+void show_main_backdrop(void)
+{
+ lcd_set_backdrop(main_backdrop_valid ? &main_backdrop[0][0] : NULL);
+}
+
+void show_wps_backdrop(void)
+{
+ /* if no wps backdrop, fall back to main backdrop */
+ if(wps_backdrop_valid)
+ {
+ lcd_set_backdrop(&wps_backdrop[0][0]);
+ }
+ else
+ {
+ show_main_backdrop();
+ }
+}
+
+#if defined(HAVE_REMOTE_LCD) && LCD_REMOTE_DEPTH > 1
+
+static bool load_remote_backdrop(char* filename, fb_remote_data* backdrop_buffer)
+{
+ struct bitmap bm;
+ int ret;
+
+ /* load the image */
+ bm.data=(char*)backdrop_buffer;
+ ret = read_bmp_file(filename, &bm, sizeof(main_backdrop),
+ FORMAT_NATIVE | FORMAT_DITHER | FORMAT_REMOTE);
+
+ if ((ret > 0) && (bm.width == LCD_REMOTE_WIDTH) && (bm.height == LCD_REMOTE_HEIGHT))
+ {
+ return true;
+ }
+ else
+ {
+ return false;
+ }
+}
+
+bool load_remote_wps_backdrop(char* filename)
+{
+ remote_wps_backdrop_valid = load_remote_backdrop(filename, &remote_wps_backdrop[0][0]);
+ return remote_wps_backdrop_valid;
+}
+
+void unload_remote_wps_backdrop(void)
+{
+ remote_wps_backdrop_valid = false;
+}
+
+void show_remote_wps_backdrop(void)
+{
+ /* if no wps backdrop, fall back to main backdrop */
+ if(remote_wps_backdrop_valid)
+ {
+ lcd_remote_set_backdrop(&remote_wps_backdrop[0][0]);
+ }
+ else
+ {
+ show_remote_main_backdrop();
+ }
+}
+
+void show_remote_main_backdrop(void)
+{
+ lcd_remote_set_backdrop(NULL);
+}
+#endif
diff --git a/apps/gui/backdrop.h b/apps/gui/backdrop.h
new file mode 100644
index 0000000000..c930a87433
--- /dev/null
+++ b/apps/gui/backdrop.h
@@ -0,0 +1,46 @@
+/***************************************************************************
+ * __________ __ ___.
+ * Open \______ \ ____ ____ | | _\_ |__ _______ ___
+ * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
+ * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
+ * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
+ * \/ \/ \/ \/ \/
+ * $Id$
+ *
+ * Copyright (C) 2006 Dave Chapman
+ *
+ * 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.
+ *
+ ****************************************************************************/
+
+#ifndef _BACKDROP_H
+#define _BACKDROP_H
+
+#if LCD_DEPTH > 1
+
+#include "lcd.h"
+#include "bmp.h"
+
+bool load_main_backdrop(char* filename);
+bool load_wps_backdrop(char* filename);
+
+void unload_main_backdrop(void);
+void unload_wps_backdrop(void);
+
+void show_main_backdrop(void);
+void show_wps_backdrop(void);
+
+#endif /* LCD_DEPTH > 1 */
+
+#if defined(HAVE_REMOTE_LCD) && LCD_REMOTE_DEPTH > 1
+bool load_remote_wps_backdrop(char* filename);
+void unload_remote_wps_backdrop(void);
+void show_remote_wps_backdrop(void);
+void show_remote_main_backdrop(void); /* only clears the wps backdrop */
+#endif
+
+#endif /* _BACKDROP_H */
diff --git a/apps/gui/gwps-common.c b/apps/gui/gwps-common.c
index 7f84be613b..5043b33ec0 100644
--- a/apps/gui/gwps-common.c
+++ b/apps/gui/gwps-common.c
@@ -49,13 +49,14 @@
#include "bmp.h"
#include "atoi.h"
#endif
-#if LCD_DEPTH > 1
-#include "backdrop.h"
-#endif
#include "dsp.h"
#include "action.h"
#include "cuesheet.h"
+#if (LCD_DEPTH > 1) || (defined(HAVE_LCD_REMOTE) && (LCD_REMOTE_DEPTH > 1))
+#include "backdrop.h"
+#endif
+
#define FF_REWIND_MAX_PERCENT 3 /* cap ff/rewind step size at max % of file */
/* 3% of 30min file == 54s step size */
#define MIN_FF_REWIND_STEP 500
diff --git a/apps/gui/gwps.c b/apps/gui/gwps.c
index 97f3b4dbbc..d8b2751847 100644
--- a/apps/gui/gwps.c
+++ b/apps/gui/gwps.c
@@ -55,12 +55,13 @@
#include "playback.h"
#include "splash.h"
#include "cuesheet.h"
-#if LCD_DEPTH > 1
-#include "backdrop.h"
-#endif
#include "ata_idle_notify.h"
#include "root_menu.h"
+#if (LCD_DEPTH > 1) || (defined(HAVE_LCD_REMOTE) && (LCD_REMOTE_DEPTH > 1))
+#include "backdrop.h"
+#endif
+
/* currently only on wps_state is needed */
struct wps_state wps_state;
struct gui_wps gui_wps[NB_SCREENS];
diff --git a/apps/gui/wps_parser.c b/apps/gui/wps_parser.c
index 2b5d1bb321..6d8078aab9 100644
--- a/apps/gui/wps_parser.c
+++ b/apps/gui/wps_parser.c
@@ -30,9 +30,10 @@
#ifdef HAVE_LCD_BITMAP
#include "bmp.h"
-#if LCD_DEPTH > 1
-#include "backdrop.h"
#endif
+
+#if (LCD_DEPTH > 1) || (defined(HAVE_LCD_REMOTE) && (LCD_REMOTE_DEPTH > 1))
+#include "backdrop.h"
#endif
#define WPS_DEFAULTCFG WPS_DIR "/rockbox_default.wps"