diff options
| author | Michael Sevakis <jethead71@rockbox.org> | 2007-07-22 21:02:24 +0000 |
|---|---|---|
| committer | Michael Sevakis <jethead71@rockbox.org> | 2007-07-22 21:02:24 +0000 |
| commit | 873e0fd1ef2ad0e8e1d74a9c9a3b0ed0cdfee35e (patch) | |
| tree | 29ca956fb87b7f8c17cb5061d3afcfda70c44e4c /firmware/drivers/button.c | |
| parent | 3213d4a0f5d3aea725bb9ddf34ae0ec38ca4b097 (diff) | |
| download | rockbox-873e0fd1ef2ad0e8e1d74a9c9a3b0ed0cdfee35e.zip rockbox-873e0fd1ef2ad0e8e1d74a9c9a3b0ed0cdfee35e.tar.gz rockbox-873e0fd1ef2ad0e8e1d74a9c9a3b0ed0cdfee35e.tar.bz2 rockbox-873e0fd1ef2ad0e8e1d74a9c9a3b0ed0cdfee35e.tar.xz | |
Wheel acceleration for e200. A general acceleration interface intended for use on any scroll target and by any code. A general interface to obtain data associated with most recently dequeued button presses and actions. Use #define HAVE_SCROLLWHEEL and set appropriate constants, values in the scroller driver that feel right.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@13959 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware/drivers/button.c')
| -rw-r--r-- | firmware/drivers/button.c | 45 |
1 files changed, 43 insertions, 2 deletions
diff --git a/firmware/drivers/button.c b/firmware/drivers/button.c index f9f355c..715d4d3 100644 --- a/firmware/drivers/button.c +++ b/firmware/drivers/button.c @@ -49,6 +49,7 @@ struct event_queue button_queue; static long lastbtn; /* Last valid button status */ static long last_read; /* Last button status, for debouncing/filtering */ +static intptr_t button_data; /* data value from last message dequeued */ #ifdef HAVE_LCD_BITMAP static bool flipped; /* buttons can be flipped to match the LCD flip */ #endif @@ -309,7 +310,7 @@ long button_get(bool block) if (current_tick - ev.tick > MAX_EVENT_AGE) return BUTTON_NONE; #endif - + button_data = ev.data; return ev.id; } @@ -329,7 +330,17 @@ long button_get_w_tmo(int ticks) #endif queue_wait_w_tmo(&button_queue, &ev, ticks); - return (ev.id != SYS_TIMEOUT)? ev.id: BUTTON_NONE; + if (ev.id == SYS_TIMEOUT) + ev.id = BUTTON_NONE; + else + button_data = ev.data; + + return ev.id; +} + +intptr_t button_get_data(void) +{ + return button_data; } void button_init(void) @@ -470,3 +481,33 @@ void button_clear_queue(void) { queue_clear(&button_queue); } + +#ifdef HAVE_SCROLLWHEEL +/** + * data: + * [31] Use acceleration + * [30:24] Message post count (skipped + 1) (1-127) + * [23:0] Velocity - clicks/uS - 0.24 fixed point + * + * factor: + * Wheel acceleration scaling factor - x.24 fixed point - + * no greater than what will not overflow 64 bits when multiplied + * by the driver's maximum velocity in (clicks/usec)^2 in 0.24 + */ +int button_apply_acceleration(unsigned int data, unsigned int factor) +{ + int delta = (data >> 24) & 0x7f; + + if ((data & (1 << 31)) != 0) + { + unsigned int v = data & 0xffffff; + + v = factor * (unsigned long long)v*v / 0xffffffffffffull; + + if (v > 1) + delta *= v; + } + + return delta; +} +#endif /* HAVE_SCROLLWHEEL */ |