diff options
| author | Michael Sevakis <jethead71@rockbox.org> | 2007-07-28 08:12:05 +0000 |
|---|---|---|
| committer | Michael Sevakis <jethead71@rockbox.org> | 2007-07-28 08:12:05 +0000 |
| commit | 58fc279d2674b5d56fed6772f82cdf1e431088f1 (patch) | |
| tree | 07a174bba7430b0ebc3c0f84d39ecb209eec1fc5 /firmware/export/scroll_engine.h | |
| parent | 885cdfdeb98d54b2597e65f1b9ae9ab98da8286f (diff) | |
| download | rockbox-58fc279d2674b5d56fed6772f82cdf1e431088f1.zip rockbox-58fc279d2674b5d56fed6772f82cdf1e431088f1.tar.gz rockbox-58fc279d2674b5d56fed6772f82cdf1e431088f1.tar.bz2 rockbox-58fc279d2674b5d56fed6772f82cdf1e431088f1.tar.xz | |
Scroll on main and remote with a single thread. Change the way system messages are defined before running out is an issue (which requires a full update of rockbox on the player).
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@14035 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware/export/scroll_engine.h')
| -rw-r--r-- | firmware/export/scroll_engine.h | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/firmware/export/scroll_engine.h b/firmware/export/scroll_engine.h new file mode 100644 index 0000000..aa11a9b --- /dev/null +++ b/firmware/export/scroll_engine.h @@ -0,0 +1,92 @@ +/*************************************************************************** + * __________ __ ___. + * Open \______ \ ____ ____ | | _\_ |__ _______ ___ + * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / + * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < + * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ + * \/ \/ \/ \/ \/ + * $Id$ + * + * Copyright (C) 2007 Michael Sevakis + * + * LCD scrolling driver and scheduler + * + * Much collected and combined from the various Rockbox LCD drivers. + * + * 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 __SCROLL_ENGINE_H__ +#define __SCROLL_ENGINE_H__ + +void scroll_init(void); +void lcd_scroll_fn(void); +void lcd_remote_scroll_fn(void); + +/* internal usage, but in multiple drivers */ +#define SCROLL_SPACING 3 +#ifdef HAVE_LCD_BITMAP +#define SCROLL_LINE_SIZE (MAX_PATH + SCROLL_SPACING + 3*LCD_WIDTH/2 + 2) +#else +#define SCROLL_LINE_SIZE (MAX_PATH + SCROLL_SPACING + 3*LCD_WIDTH + 2) +#endif + +struct scrollinfo +{ + char line[SCROLL_LINE_SIZE]; + int len; /* length of line in chars */ + int offset; + int startx; +#ifdef HAVE_LCD_BITMAP + int width; /* length of line in pixels */ + bool invert; /* invert the scrolled text */ +#endif + bool backward; /* scroll presently forward or backward? */ + bool bidir; + long start_tick; +#ifdef HAVE_LCD_COLOR + int line_color; +#endif +}; + +struct scroll_screen_info +{ + struct scrollinfo * const scroll; + const int num_scroll; /* number of scrollable lines (also number of scroll structs) */ + int lines; /* Bitpattern of which lines are scrolling */ + long ticks; /* # of ticks between updates*/ + long delay; /* ticks delay before start */ + int bidir_limit; /* percent */ +#ifdef HAVE_LCD_CHARCELLS + long jump_scroll_delay; /* delay between jump scroll jumps */ + int jump_scroll; /* 0=off, 1=once, ..., JUMP_SCROLL_ALWAYS */ +#endif +#if defined(HAVE_LCD_BITMAP) || defined(HAVE_REMOTE_LCD) + int step; /* pixels per scroll step */ +#endif +#if defined(HAVE_REMOTE_LCD) + long last_scroll; +#endif +}; + +/** main lcd **/ +#ifdef HAVE_LCD_BITMAP +#define LCD_SCROLLABLE_LINES ((LCD_HEIGHT+4)/5 < 32 ? (LCD_HEIGHT+4)/5 : 32) +#else +#define LCD_SCROLLABLE_LINES LCD_HEIGHT +#endif + +extern struct scroll_screen_info lcd_scroll_info; + +/** remote lcd **/ +#ifdef HAVE_REMOTE_LCD +#define LCD_REMOTE_SCROLLABLE_LINES \ + (((LCD_REMOTE_HEIGHT+4)/5 < 32) ? (LCD_REMOTE_HEIGHT+4)/5 : 32) +extern struct scroll_screen_info lcd_remote_scroll_info; +#endif + +#endif /* __SCROLL_ENGINE_H__ */ |