2 * $Id: display.c,v 1.11 2007-10-21 05:15:56 nkeynes Exp $
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 typedef struct keymap_entry {
29 input_key_callback_t callback;
35 * Colour format information
37 struct colour_format colour_formats[] = {
38 { GL_UNSIGNED_SHORT_1_5_5_5_REV, GL_BGRA, GL_RGB5_A1, 2 },
39 { GL_UNSIGNED_SHORT_5_6_5, GL_RGB, GL_RGB5, 2 },
40 { GL_UNSIGNED_SHORT_4_4_4_4_REV, GL_BGRA, GL_RGBA4, 2 },
41 { GL_UNSIGNED_BYTE, GL_BGRA, GL_RGBA8, 4 }, /* YUV decoded to ARGB8888 */
42 { GL_UNSIGNED_BYTE, GL_BGR, GL_RGB, 3 },
43 { GL_UNSIGNED_BYTE, GL_BGRA, GL_RGBA8, 4 },
48 * FIXME: make this more memory efficient
50 struct keymap_entry *keymap[65536];
53 static struct keymap_entry *input_create_key( uint16_t keycode )
55 struct keymap_entry *key = keymap[ keycode ];
57 key = malloc( sizeof( struct keymap_entry ) );
58 assert( key != NULL );
59 keymap[ keycode ] = key;
60 key->keycode = keycode;
65 static void input_delete_key( uint16_t keycode, input_key_callback_t callback, void *data,
68 struct keymap_entry *key = keymap[keycode];
69 if( key != NULL && key->callback == callback && key->data == data && key->value == value ) {
71 keymap[keycode] = NULL;
75 static struct keymap_entry *input_get_key( uint16_t keycode )
77 return keymap[ keycode ];
80 gboolean input_register_key( const gchar *keysym, input_key_callback_t callback,
81 void *data, uint32_t value )
83 if( display_driver == NULL || keysym == NULL || display_driver->resolve_keysym == NULL )
84 return FALSE; /* No display driver */
85 gchar **strv = g_strsplit(keysym, ",", 16);
88 uint16_t keycode = display_driver->resolve_keysym(g_strstrip(*s));
90 return FALSE; /* Invalid keysym */
92 struct keymap_entry *key = input_create_key( keycode );
93 key->callback = callback;
102 void input_unregister_key( const gchar *keysym, input_key_callback_t callback,
103 void *data, uint32_t value )
105 if( display_driver == NULL || keysym == NULL )
107 uint16_t keycode = display_driver->resolve_keysym(keysym);
110 input_delete_key( keycode, callback, data, value );
114 gboolean input_is_key_valid( const gchar *keysym )
116 if( display_driver == NULL )
117 return FALSE; /* No display driver */
118 return display_driver->resolve_keysym(keysym) != 0;
121 gboolean input_is_key_registered( const gchar *keysym )
123 if( display_driver == NULL )
125 uint16_t keycode = display_driver->resolve_keysym(keysym);
128 return input_get_key( keycode ) != NULL;
131 void input_event_keydown( uint16_t keycode )
133 struct keymap_entry *key = input_get_key(keycode);
135 key->callback( key->data, key->value, TRUE );
139 void input_event_keyup( uint16_t keycode )
141 struct keymap_entry *key = input_get_key(keycode);
143 key->callback( key->data, key->value, FALSE );
149 gboolean display_set_driver( display_driver_t driver )
152 if( display_driver != NULL && display_driver->shutdown_driver != NULL )
153 display_driver->shutdown_driver();
155 display_driver = driver;
156 if( driver->init_driver != NULL )
157 rv = driver->init_driver();
.