4 * Generic support for keyboard and other input sources. The active display
5 * driver is expected to deliver events here, where they're translated and
6 * passed to the appropriate dreamcast controllers (if any).
8 * Copyright (c) 2005 Nathan Keynes.
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
25 #include "pvr2/pvr2.h"
27 display_driver_t display_driver_list[] = {
34 typedef struct keymap_entry {
36 input_key_callback_t callback;
39 struct keymap_entry *next; // allow chaining
42 typedef struct mouse_entry {
44 input_mouse_callback_t callback;
46 struct mouse_entry *next;
50 * Colour format information
52 struct colour_format colour_formats[] = {
53 { GL_UNSIGNED_SHORT_1_5_5_5_REV, GL_BGRA, GL_RGB5_A1, 2 },
54 { GL_UNSIGNED_SHORT_5_6_5, GL_RGB, GL_RGB5, 2 },
55 { GL_UNSIGNED_SHORT_4_4_4_4_REV, GL_BGRA, GL_RGBA4, 2 },
56 { GL_UNSIGNED_BYTE, GL_BGRA, GL_RGBA8, 4 }, /* YUV decoded to ARGB8888 */
57 { GL_UNSIGNED_BYTE, GL_BGR, GL_RGB, 3 },
58 { GL_UNSIGNED_BYTE, GL_BGRA, GL_RGBA8, 4 },
59 { GL_UNSIGNED_BYTE, GL_BGRA, GL_RGBA8, 4 }, /* Index4 decoded */
60 { GL_UNSIGNED_BYTE, GL_BGRA, GL_RGBA8, 4 }, /* Index8 decoded */
61 { GL_UNSIGNED_BYTE, GL_BGRA, GL_RGBA8, 4 },
62 { GL_UNSIGNED_BYTE, GL_RGB, GL_RGB, 3 },
67 * FIXME: make this more memory efficient
69 struct keymap_entry *keymap[65536];
70 struct keymap_entry *keyhooks = NULL;
71 struct mouse_entry *mousehooks = NULL;
73 static struct keymap_entry *input_create_key( uint16_t keycode )
75 struct keymap_entry *key = keymap[ keycode ];
77 key = malloc( sizeof( struct keymap_entry ) );
78 assert( key != NULL );
79 keymap[ keycode ] = key;
80 key->keycode = keycode;
85 static void input_delete_key( uint16_t keycode, input_key_callback_t callback, void *data,
88 struct keymap_entry *key = keymap[keycode];
89 if( key != NULL && key->callback == callback && key->data == data && key->value == value ) {
91 keymap[keycode] = NULL;
95 static struct keymap_entry *input_get_key( uint16_t keycode )
97 return keymap[ keycode ];
100 gboolean input_register_key( const gchar *keysym, input_key_callback_t callback,
101 void *data, uint32_t value )
103 if( display_driver == NULL || keysym == NULL || display_driver->resolve_keysym == NULL )
104 return FALSE; /* No display driver */
105 gchar **strv = g_strsplit(keysym, ",", 16);
107 while( *s != NULL ) {
108 uint16_t keycode = display_driver->resolve_keysym(g_strstrip(*s));
110 return FALSE; /* Invalid keysym */
112 struct keymap_entry *key = input_create_key( keycode );
113 key->callback = callback;
122 void input_unregister_key( const gchar *keysym, input_key_callback_t callback,
123 void *data, uint32_t value )
125 if( display_driver == NULL || keysym == NULL || display_driver->resolve_keysym == NULL )
127 uint16_t keycode = display_driver->resolve_keysym(keysym);
130 input_delete_key( keycode, callback, data, value );
133 gboolean input_register_hook( input_key_callback_t callback,
136 keymap_entry_t key = malloc( sizeof( struct keymap_entry ) );
137 assert( key != NULL );
138 key->callback = callback;
140 key->next = keyhooks;
145 void input_unregister_hook( input_key_callback_t callback,
148 keymap_entry_t key = keyhooks;
150 keymap_entry_t next = key->next;
151 if( key->callback == callback && key->data == data ) {
156 while( next != NULL ) {
157 if( next->callback == callback && next->data == data ) {
158 key->next = next->next;
165 gboolean input_register_mouse_hook( gboolean relative, input_mouse_callback_t callback,
168 mouse_entry_t ent = malloc( sizeof( struct mouse_entry ) );
169 assert( ent != NULL );
170 ent->callback = callback;
172 ent->next = mousehooks;
177 void input_unregister_mouse_hook( input_mouse_callback_t callback, void *data )
179 mouse_entry_t ent = mousehooks;
181 mouse_entry_t next = ent->next;
182 if( ent->callback == callback && ent->data == data ) {
187 while( next != NULL ) {
188 if( next->callback == callback && next->data == data ) {
189 ent->next = next->next;
196 void input_event_mouse( uint32_t buttons, int32_t x, int32_t y )
198 mouse_entry_t ent = mousehooks;
199 while( ent != NULL ) {
200 ent->callback(ent->data, buttons, x, y);
205 gboolean input_is_key_valid( const gchar *keysym )
207 if( display_driver == NULL )
208 return FALSE; /* No display driver */
209 return display_driver->resolve_keysym(keysym) != 0;
212 gboolean input_is_key_registered( const gchar *keysym )
214 if( display_driver == NULL )
216 uint16_t keycode = display_driver->resolve_keysym(keysym);
219 return input_get_key( keycode ) != NULL;
222 void input_event_keydown( uint16_t keycode )
224 struct keymap_entry *key = input_get_key(keycode);
226 key->callback( key->data, key->value, TRUE );
229 while( key != NULL ) {
230 key->callback( key->data, keycode, TRUE );
235 void input_event_keyup( uint16_t keycode )
237 struct keymap_entry *key = input_get_key(keycode);
239 key->callback( key->data, key->value, FALSE );
242 while( key != NULL ) {
243 key->callback( key->data, keycode, FALSE );
248 uint16_t input_keycode_to_dckeysym( uint16_t keycode )
250 return display_driver->convert_to_dckeysym(keycode);
253 display_driver_t get_display_driver_by_name( const char *name )
257 return display_driver_list[0];
259 for( i=0; display_driver_list[i] != NULL; i++ ) {
260 if( strcasecmp( display_driver_list[i]->name, name ) == 0 ) {
261 return display_driver_list[i];
269 gboolean display_set_driver( display_driver_t driver )
272 if( display_driver != NULL && display_driver->shutdown_driver != NULL )
273 display_driver->shutdown_driver();
275 display_driver = driver;
276 if( driver->init_driver != NULL )
277 rv = driver->init_driver();
279 display_driver = NULL;
.