Added all typical keys from a 104-key keyboard to the StellaEvent class.

Updated the SDL port to bind to those keys.

Cleaned up the SDL port event handling method a bit.  By the time I'm
finished, I hope that almost all event mapping/lookups will be constant
time by using simple array lookup.

Next thing to do is to add all possible remappings to the UserInterface,
get the joystick remapping working, and then get to the Windows port.


git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@194 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
stephena 2003-09-29 18:10:56 +00:00
parent 4b7a2c475c
commit bbd7a69179
3 changed files with 140 additions and 106 deletions

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of // See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES. // this file, and for a DISCLAIMER OF ALL WARRANTIES.
// //
// $Id: StellaEvent.hxx,v 1.5 2003-09-28 21:59:24 stephena Exp $ // $Id: StellaEvent.hxx,v 1.6 2003-09-29 18:10:56 stephena Exp $
//============================================================================ //============================================================================
#ifndef STELLAEVENT_HXX #ifndef STELLAEVENT_HXX
@ -28,7 +28,7 @@
by the frontends directly. by the frontends directly.
@author Stephen Anthony @author Stephen Anthony
@version $Id: StellaEvent.hxx,v 1.5 2003-09-28 21:59:24 stephena Exp $ @version $Id: StellaEvent.hxx,v 1.6 2003-09-29 18:10:56 stephena Exp $
*/ */
class StellaEvent class StellaEvent
{ {
@ -55,15 +55,21 @@ class StellaEvent
KCODE_KP_MULTIPLY, KCODE_KP_MINUS, KCODE_KP_PLUS, KCODE_KP_ENTER, KCODE_KP_MULTIPLY, KCODE_KP_MINUS, KCODE_KP_PLUS, KCODE_KP_ENTER,
KCODE_KP_EQUALS, KCODE_KP_EQUALS,
KCODE_BACKSPACE, KCODE_TAB, KCODE_RETURN, KCODE_PAUSE, KCODE_ESCAPE, KCODE_BACKSPACE, KCODE_TAB, KCODE_CLEAR, KCODE_RETURN,
KCODE_COMMA, KCODE_PERIOD, KCODE_SLASH, KCODE_SEMICOLON, KCODE_BACKSLASH, KCODE_ESCAPE, KCODE_SPACE, KCODE_COMMA, KCODE_MINUS, KCODE_PERIOD,
KCODE_QUOTE, KCODE_LEFTBRACKET, KCODE_RIGHTBRACKET, KCODE_BACKQUOTE, KCODE_SLASH, KCODE_BACKSLASH, KCODE_SEMICOLON, KCODE_EQUALS,
KCODE_QUOTE, KCODE_BACKQUOTE, KCODE_LEFTBRACKET, KCODE_RIGHTBRACKET,
KCODE_CTRL, KCODE_ALT, KCODE_UP, KCODE_DOWN, KCODE_LEFT, KCODE_RIGHT, KCODE_PRTSCREEN, KCODE_SCRLOCK, KCODE_PAUSE,
KCODE_SPACE, KCODE_INSERT, KCODE_HOME, KCODE_PAGEUP,
KCODE_DELETE, KCODE_END, KCODE_PAGEDOWN,
KCODE_LCTRL, KCODE_RCTRL, KCODE_LALT, KCODE_RALT, KCODE_LWIN,
KCODE_RWIN, KCODE_MENU, KCODE_UP, KCODE_DOWN, KCODE_LEFT, KCODE_RIGHT,
KCODE_F1, KCODE_F2, KCODE_F3, KCODE_F4, KCODE_F5, KCODE_F6, KCODE_F7, KCODE_F1, KCODE_F2, KCODE_F3, KCODE_F4, KCODE_F5, KCODE_F6, KCODE_F7,
KCODE_F8, KCODE_F9, KCODE_F10, KCODE_F11, KCODE_F12, KCODE_F8, KCODE_F9, KCODE_F10, KCODE_F11, KCODE_F12, KCODE_F13,
KCODE_F14, KCODE_F15,
LastKCODE LastKCODE
}; };

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of // See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES. // this file, and for a DISCLAIMER OF ALL WARRANTIES.
// //
// $Id: UserInterface.cxx,v 1.5 2003-09-28 21:59:24 stephena Exp $ // $Id: UserInterface.cxx,v 1.6 2003-09-29 18:10:56 stephena Exp $
//============================================================================ //============================================================================
#include "bspf.hxx" #include "bspf.hxx"
@ -510,11 +510,15 @@ const char* UserInterface::ourEventName[StellaEvent::LastKCODE] = {
"KP 0", "KP 1", "KP 2", "KP 3", "KP 4", "KP 5", "KP 6", "KP 7", "KP 8", "KP 0", "KP 1", "KP 2", "KP 3", "KP 4", "KP 5", "KP 6", "KP 7", "KP 8",
"KP 9", "KP .", "KP /", "KP *", "KP -", "KP +", "KP ENTER", "KP =", "KP 9", "KP .", "KP /", "KP *", "KP -", "KP +", "KP ENTER", "KP =",
"BACKSP", "TAB", "ENTER", "PAUSE", "ESC", ",", ".", "/", ";", "\\", "\"", "BACKSP", "TAB", "CLEAR", "ENTER", "ESC", "SPACE", ",", "-", ".",
"[", "]", "`", "/", "\\", ";", "=", "\"", "`", "[", "]",
"CTRL", "ALT", "UP", "DOWN", "LEFT", "RIGHT", "SPACE", "PRT SCRN", "SCR LOCK", "PAUSE", "INS", "HOME", "PGUP",
"DEL", "END", "PGDN",
"F1", "F2", "F3", "F4", "F5", "F6", "F7", "F8", "F9", "F10", "F11", "F12" "LCTRL", "RCTRL", "LALT", "RALT", "LWIN", "RWIN", "MENU",
"UP", "DOWN", "LEFT", "RIGHT",
"F1", "F2", "F3", "F4", "F5", "F6", "F7", "F8", "F9", "F10",
"F11", "F12", "F13", "F14", "F15",
}; };

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of // See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES. // this file, and for a DISCLAIMER OF ALL WARRANTIES.
// //
// $Id: mainSDL.cxx,v 1.53 2003-09-23 17:27:11 stephena Exp $ // $Id: mainSDL.cxx,v 1.54 2003-09-29 18:10:56 stephena Exp $
//============================================================================ //============================================================================
#include <fstream> #include <fstream>
@ -147,6 +147,8 @@ struct Switches
}; };
// Place the most used keys first to speed up access // Place the most used keys first to speed up access
// Todo - initialize this array in the same order as the SDLK
// keys are defined, so it can be a constant-time LUT
static Switches keyList[] = { static Switches keyList[] = {
{ SDLK_F1, StellaEvent::KCODE_F1 }, { SDLK_F1, StellaEvent::KCODE_F1 },
{ SDLK_F2, StellaEvent::KCODE_F2 }, { SDLK_F2, StellaEvent::KCODE_F2 },
@ -160,16 +162,22 @@ static Switches keyList[] = {
{ SDLK_F10, StellaEvent::KCODE_F10 }, { SDLK_F10, StellaEvent::KCODE_F10 },
{ SDLK_F11, StellaEvent::KCODE_F11 }, { SDLK_F11, StellaEvent::KCODE_F11 },
{ SDLK_F12, StellaEvent::KCODE_F12 }, { SDLK_F12, StellaEvent::KCODE_F12 },
{ SDLK_F13, StellaEvent::KCODE_F13 },
{ SDLK_F14, StellaEvent::KCODE_F14 },
{ SDLK_F15, StellaEvent::KCODE_F15 },
{ SDLK_UP, StellaEvent::KCODE_UP }, { SDLK_UP, StellaEvent::KCODE_UP },
{ SDLK_DOWN, StellaEvent::KCODE_DOWN }, { SDLK_DOWN, StellaEvent::KCODE_DOWN },
{ SDLK_LEFT, StellaEvent::KCODE_LEFT }, { SDLK_LEFT, StellaEvent::KCODE_LEFT },
{ SDLK_RIGHT, StellaEvent::KCODE_RIGHT }, { SDLK_RIGHT, StellaEvent::KCODE_RIGHT },
{ SDLK_SPACE, StellaEvent::KCODE_SPACE }, { SDLK_SPACE, StellaEvent::KCODE_SPACE },
{ SDLK_LCTRL, StellaEvent::KCODE_CTRL }, { SDLK_LCTRL, StellaEvent::KCODE_LCTRL },
{ SDLK_RCTRL, StellaEvent::KCODE_CTRL }, { SDLK_RCTRL, StellaEvent::KCODE_RCTRL },
{ SDLK_LALT, StellaEvent::KCODE_ALT }, { SDLK_LALT, StellaEvent::KCODE_LALT },
{ SDLK_RALT, StellaEvent::KCODE_ALT }, { SDLK_RALT, StellaEvent::KCODE_RALT },
{ SDLK_LSUPER, StellaEvent::KCODE_LWIN },
{ SDLK_RSUPER, StellaEvent::KCODE_RWIN },
{ SDLK_MENU, StellaEvent::KCODE_MENU },
{ SDLK_a, StellaEvent::KCODE_a }, { SDLK_a, StellaEvent::KCODE_a },
{ SDLK_b, StellaEvent::KCODE_b }, { SDLK_b, StellaEvent::KCODE_b },
@ -229,18 +237,31 @@ static Switches keyList[] = {
{ SDLK_BACKSPACE, StellaEvent::KCODE_BACKSPACE }, { SDLK_BACKSPACE, StellaEvent::KCODE_BACKSPACE },
{ SDLK_TAB, StellaEvent::KCODE_TAB }, { SDLK_TAB, StellaEvent::KCODE_TAB },
{ SDLK_CLEAR, StellaEvent::KCODE_CLEAR },
{ SDLK_RETURN, StellaEvent::KCODE_RETURN }, { SDLK_RETURN, StellaEvent::KCODE_RETURN },
{ SDLK_PAUSE, StellaEvent::KCODE_PAUSE },
{ SDLK_ESCAPE, StellaEvent::KCODE_ESCAPE }, { SDLK_ESCAPE, StellaEvent::KCODE_ESCAPE },
{ SDLK_SPACE, StellaEvent::KCODE_SPACE },
{ SDLK_COMMA, StellaEvent::KCODE_COMMA }, { SDLK_COMMA, StellaEvent::KCODE_COMMA },
{ SDLK_MINUS, StellaEvent::KCODE_MINUS },
{ SDLK_PERIOD, StellaEvent::KCODE_PERIOD }, { SDLK_PERIOD, StellaEvent::KCODE_PERIOD },
{ SDLK_SLASH, StellaEvent::KCODE_SLASH }, { SDLK_SLASH, StellaEvent::KCODE_SLASH },
{ SDLK_BACKSLASH, StellaEvent::KCODE_BACKSLASH }, { SDLK_BACKSLASH, StellaEvent::KCODE_BACKSLASH },
{ SDLK_SEMICOLON, StellaEvent::KCODE_SEMICOLON }, { SDLK_SEMICOLON, StellaEvent::KCODE_SEMICOLON },
{ SDLK_EQUALS, StellaEvent::KCODE_EQUALS },
{ SDLK_QUOTE, StellaEvent::KCODE_QUOTE }, { SDLK_QUOTE, StellaEvent::KCODE_QUOTE },
{ SDLK_BACKQUOTE, StellaEvent::KCODE_BACKQUOTE }, { SDLK_BACKQUOTE, StellaEvent::KCODE_BACKQUOTE },
{ SDLK_LEFTBRACKET, StellaEvent::KCODE_LEFTBRACKET}, { SDLK_LEFTBRACKET, StellaEvent::KCODE_LEFTBRACKET},
{ SDLK_RIGHTBRACKET,StellaEvent::KCODE_RIGHTBRACKET} { SDLK_RIGHTBRACKET,StellaEvent::KCODE_RIGHTBRACKET},
{ SDLK_PRINT, StellaEvent::KCODE_PRTSCREEN },
{ SDLK_MODE, StellaEvent::KCODE_SCRLOCK },
{ SDLK_PAUSE, StellaEvent::KCODE_PAUSE },
{ SDLK_INSERT, StellaEvent::KCODE_INSERT },
{ SDLK_HOME, StellaEvent::KCODE_HOME },
{ SDLK_PAGEUP, StellaEvent::KCODE_PAGEUP },
{ SDLK_DELETE, StellaEvent::KCODE_DELETE },
{ SDLK_END, StellaEvent::KCODE_END },
{ SDLK_PAGEDOWN, StellaEvent::KCODE_PAGEDOWN }
}; };
// Lookup table for joystick numbers and events // Lookup table for joystick numbers and events
@ -841,19 +862,43 @@ void handleEvents()
mod = event.key.keysym.mod; mod = event.key.keysym.mod;
type = event.type; type = event.type;
// An attempt to speed up event processing
// All SDL-specific event actions are accessed by either
// Control or Alt keys. So we quickly check for those.
if(mod & KMOD_ALT)
{
if(key == SDLK_EQUALS) if(key == SDLK_EQUALS)
{
resizeWindow(1); resizeWindow(1);
}
else if(key == SDLK_MINUS) else if(key == SDLK_MINUS)
{
resizeWindow(0); resizeWindow(0);
} else if(key == SDLK_RETURN)
else if((mod & KMOD_ALT) && key == SDLK_RETURN)
{
toggleFullscreen(); toggleFullscreen();
#ifdef DEVELOPER_SUPPORT
else if(key == SDLK_END) // Alt-End increases XStart
{
theConsole->changeXStart(1);
resizeWindow(-1);
} }
else if((mod & KMOD_CTRL) && key == SDLK_g) else if(key == SDLK_HOME) // Alt-Home decreases XStart
{
theConsole->changeXStart(0);
resizeWindow(-1);
}
else if(key == SDLK_PAGEUP) // Alt-PageUp increases YStart
{
theConsole->changeYStart(1);
resizeWindow(-1);
}
else if(key == SDLK_PAGEDOWN) // Alt-PageDown decreases YStart
{
theConsole->changeYStart(0);
resizeWindow(-1);
}
#endif
}
else if(mod & KMOD_CTRL)
{
if(key == SDLK_g)
{ {
// don't change grabmouse in fullscreen mode // don't change grabmouse in fullscreen mode
if(!isFullscreen) if(!isFullscreen)
@ -862,7 +907,7 @@ void handleEvents()
grabMouse(theGrabMouseIndicator); grabMouse(theGrabMouseIndicator);
} }
} }
else if((mod & KMOD_CTRL) && key == SDLK_h) else if(key == SDLK_h)
{ {
// don't change hidecursor in fullscreen mode // don't change hidecursor in fullscreen mode
if(!isFullscreen) if(!isFullscreen)
@ -872,54 +917,32 @@ void handleEvents()
} }
} }
#ifdef DEVELOPER_SUPPORT #ifdef DEVELOPER_SUPPORT
else if((mod & KMOD_ALT) && key == SDLK_f) // Alt-f switches between NTSC and PAL else if(key == SDLK_f) // Ctrl-f toggles NTSC/PAL mode
{ {
theConsole->toggleFormat(); theConsole->toggleFormat();
// update the palette
setupPalette(); setupPalette();
} }
else if(key == SDLK_END) // End decreases XStart else if(key == SDLK_END) // Ctrl-End increases Width
{ // Alt-End decreases Width {
if(mod & KMOD_ALT)
theConsole->changeWidth(0);
else
theConsole->changeXStart(0);
// Make sure changes to the properties are reflected onscreen
resizeWindow(-1);
}
else if(key == SDLK_HOME) // Home increases XStart
{ // Alt-Home increases Width
if(mod & KMOD_ALT)
theConsole->changeWidth(1); theConsole->changeWidth(1);
else
theConsole->changeXStart(1);
// Make sure changes to the properties are reflected onscreen
resizeWindow(-1); resizeWindow(-1);
} }
else if(key == SDLK_PAGEDOWN) // PageDown decreases YStart else if(key == SDLK_HOME) // Ctrl-Home decreases Width
{ // Alt-PageDown decreases Height {
if(mod & KMOD_ALT) theConsole->changeWidth(0);
theConsole->changeHeight(0);
else
theConsole->changeYStart(0);
// Make sure changes to the properties are reflected onscreen
resizeWindow(-1); resizeWindow(-1);
} }
else if(key == SDLK_PAGEUP) // PageUp increases YStart else if(key == SDLK_PAGEUP) // Ctrl-PageUp increases Height
{ // Alt-PageUp increases Height {
if(mod & KMOD_ALT)
theConsole->changeHeight(1); theConsole->changeHeight(1);
else
theConsole->changeYStart(1);
// Make sure changes to the properties are reflected onscreen
resizeWindow(-1); resizeWindow(-1);
} }
else if((mod & KMOD_ALT) && key == SDLK_s) // Alt-s saves properties to a file else if(key == SDLK_PAGEDOWN) // Ctrl-PageDown decreases Height
{
theConsole->changeHeight(0);
resizeWindow(-1);
}
else if(key == SDLK_s) // Ctrl-s saves properties to a file
{ {
if(theConsole->settings().getBool("mergeprops")) // Attempt to merge with propertiesSet if(theConsole->settings().getBool("mergeprops")) // Attempt to merge with propertiesSet
{ {
@ -934,6 +957,7 @@ void handleEvents()
} }
} }
#endif #endif
}
else // check all the other keys else // check all the other keys
{ {
for(unsigned int i = 0; i < sizeof(keyList) / sizeof(Switches); ++i) for(unsigned int i = 0; i < sizeof(keyList) / sizeof(Switches); ++i)