Added a commandmenu, currently tied to the '\' key. Eventually,

this will also be tied to a joystick button, so common operations
will be selectable by two buttons (one to enter the menu, another
to select an item).

The commandmenu is a set of buttons for the most common operations
in Stella (specifically, those assigned to the F1 .. F12 keys).
Due to the way Stella is designed, pressing one of these buttons
immediately exits the commandmenu and proceeds with emulation.
Sorry if this causes anyone problems, but it's too difficult to
work around.

Still TODO is add joystick emulates mouse code (movement is done
and will be committed soon, still working on joystick button to mouse
button).


git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@749 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
stephena 2005-08-29 18:36:42 +00:00
parent 787fe3eebc
commit f4590830d4
14 changed files with 479 additions and 56 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: Console.cxx,v 1.66 2005-08-24 22:54:30 stephena Exp $ // $Id: Console.cxx,v 1.67 2005-08-29 18:36:41 stephena Exp $
//============================================================================ //============================================================================
#include <assert.h> #include <assert.h>
@ -45,6 +45,7 @@
#include "FrameBuffer.hxx" #include "FrameBuffer.hxx"
#include "OSystem.hxx" #include "OSystem.hxx"
#include "Menu.hxx" #include "Menu.hxx"
#include "CommandMenu.hxx"
#include "Version.hxx" #include "Version.hxx"
#ifdef SNAPSHOT_SUPPORT #ifdef SNAPSHOT_SUPPORT
@ -186,10 +187,13 @@ Console::Console(const uInt8* image, uInt32 size, OSystem* osystem)
myOSystem->sound().setFrameRate(framerate); myOSystem->sound().setFrameRate(framerate);
myOSystem->sound().initialize(); myOSystem->sound().initialize();
// Initialize the menuing system with updated values from the framebuffer // Initialize the options menu system with updated values from the framebuffer
myOSystem->menu().initialize(); myOSystem->menu().initialize();
myOSystem->menu().setGameProfile(myProperties); myOSystem->menu().setGameProfile(myProperties);
// Initialize the command menu system with updated values from the framebuffer
myOSystem->commandMenu().initialize();
#ifdef DEVELOPER_SUPPORT #ifdef DEVELOPER_SUPPORT
// Finally, initialize the debugging system, since it depends on the current ROM // Finally, initialize the debugging system, since it depends on the current ROM
myOSystem->debugger().setConsole(this); myOSystem->debugger().setConsole(this);

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: Event.hxx,v 1.12 2005-06-28 03:34:41 urchlay Exp $ // $Id: Event.hxx,v 1.13 2005-08-29 18:36:41 stephena Exp $
//============================================================================ //============================================================================
#ifndef EVENT_HXX #ifndef EVENT_HXX
@ -25,7 +25,7 @@ class Event;
/** /**
@author Bradford W. Mott @author Bradford W. Mott
@version $Id: Event.hxx,v 1.12 2005-06-28 03:34:41 urchlay Exp $ @version $Id: Event.hxx,v 1.13 2005-08-29 18:36:41 stephena Exp $
*/ */
class Event class Event
{ {
@ -72,7 +72,7 @@ class Event
DrivingOneFire, DrivingOneFire,
ChangeState, LoadState, SaveState, TakeSnapshot, Pause, Quit, ChangeState, LoadState, SaveState, TakeSnapshot, Pause, Quit,
MenuMode, DebuggerMode, LauncherMode, Fry, MenuMode, CmdMenuMode, DebuggerMode, LauncherMode, Fry,
LastType LastType
}; };

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: EventHandler.cxx,v 1.88 2005-08-25 16:29:52 stephena Exp $ // $Id: EventHandler.cxx,v 1.89 2005-08-29 18:36:41 stephena Exp $
//============================================================================ //============================================================================
#include <algorithm> #include <algorithm>
@ -29,6 +29,7 @@
#include "Sound.hxx" #include "Sound.hxx"
#include "OSystem.hxx" #include "OSystem.hxx"
#include "Menu.hxx" #include "Menu.hxx"
#include "CommandMenu.hxx"
#include "Launcher.hxx" #include "Launcher.hxx"
#include "GuiUtils.hxx" #include "GuiUtils.hxx"
#include "bspf.hxx" #include "bspf.hxx"
@ -143,19 +144,10 @@ void EventHandler::reset(State state)
switch(myState) switch(myState)
{ {
case S_EMULATE:
break;
case S_MENU:
break;
case S_LAUNCHER: case S_LAUNCHER:
myUseLauncherFlag = true; myUseLauncherFlag = true;
break; break;
case S_DEBUGGER:
break;
default: default:
break; break;
} }
@ -175,6 +167,11 @@ void EventHandler::refreshDisplay()
myOSystem->menu().refresh(); myOSystem->menu().refresh();
break; break;
case S_CMDMENU:
myOSystem->frameBuffer().refresh();
myOSystem->commandMenu().refresh();
break;
case S_LAUNCHER: case S_LAUNCHER:
myOSystem->launcher().refresh(); myOSystem->launcher().refresh();
break; break;
@ -642,6 +639,10 @@ void EventHandler::poll(uInt32 time)
myOSystem->menu().updateTime(time); myOSystem->menu().updateTime(time);
break; break;
case S_CMDMENU:
myOSystem->commandMenu().updateTime(time);
break;
case S_LAUNCHER: case S_LAUNCHER:
myOSystem->launcher().updateTime(time); myOSystem->launcher().updateTime(time);
break; break;
@ -670,6 +671,11 @@ void EventHandler::handleKeyEvent(int unicode, SDLKey key, SDLMod mod, uInt8 sta
enterMenuMode(); enterMenuMode();
return; return;
} }
else if(myKeyTable[key] == Event::CmdMenuMode && state == 1 && !myPauseFlag)
{
enterCmdMenuMode();
return;
}
else if(myKeyTable[key] == Event::DebuggerMode && state == 1 && !myPauseFlag) else if(myKeyTable[key] == Event::DebuggerMode && state == 1 && !myPauseFlag)
{ {
enterDebugMode(); enterDebugMode();
@ -693,6 +699,15 @@ void EventHandler::handleKeyEvent(int unicode, SDLKey key, SDLMod mod, uInt8 sta
myOSystem->menu().handleKeyEvent(unicode, key, mod, state); myOSystem->menu().handleKeyEvent(unicode, key, mod, state);
break; break;
case S_CMDMENU:
if(myKeyTable[key] == Event::CmdMenuMode && state == 1)
{
leaveCmdMenuMode();
return;
}
myOSystem->commandMenu().handleKeyEvent(unicode, key, mod, state);
break;
case S_LAUNCHER: case S_LAUNCHER:
myOSystem->launcher().handleKeyEvent(unicode, key, mod, state); myOSystem->launcher().handleKeyEvent(unicode, key, mod, state);
break; break;
@ -742,6 +757,10 @@ void EventHandler::handleMouseMotionEvent(SDL_Event& event)
myOSystem->menu().handleMouseMotionEvent(x, y, 0); myOSystem->menu().handleMouseMotionEvent(x, y, 0);
break; break;
case S_CMDMENU:
myOSystem->commandMenu().handleMouseMotionEvent(x, y, 0);
break;
case S_LAUNCHER: case S_LAUNCHER:
myOSystem->launcher().handleMouseMotionEvent(x, y, 0); myOSystem->launcher().handleMouseMotionEvent(x, y, 0);
break; break;
@ -769,6 +788,7 @@ void EventHandler::handleMouseButtonEvent(SDL_Event& event, uInt8 state)
break; break;
case S_MENU: case S_MENU:
case S_CMDMENU:
case S_LAUNCHER: case S_LAUNCHER:
case S_DEBUGGER: case S_DEBUGGER:
{ {
@ -804,6 +824,8 @@ void EventHandler::handleMouseButtonEvent(SDL_Event& event, uInt8 state)
if(myState == S_MENU) if(myState == S_MENU)
myOSystem->menu().handleMouseButtonEvent(button, x, y, state); myOSystem->menu().handleMouseButtonEvent(button, x, y, state);
else if(myState == S_CMDMENU)
myOSystem->commandMenu().handleMouseButtonEvent(button, x, y, state);
else if(myState == S_LAUNCHER) else if(myState == S_LAUNCHER)
myOSystem->launcher().handleMouseButtonEvent(button, x, y, state); myOSystem->launcher().handleMouseButtonEvent(button, x, y, state);
#ifdef DEVELOPER_SUPPORT #ifdef DEVELOPER_SUPPORT
@ -949,6 +971,8 @@ void EventHandler::handleJoyEvent(uInt8 stick, uInt32 code, uInt8 state)
handleEvent(myJoyTable[stick*kNumJoyButtons + code], state); handleEvent(myJoyTable[stick*kNumJoyButtons + code], state);
break; break;
// FIXME - remove handleJoyEvent from DialogContainer, have it pass
// mouse events instead
case S_MENU: case S_MENU:
myOSystem->menu().handleJoyEvent(stick, code, state); myOSystem->menu().handleJoyEvent(stick, code, state);
break; break;
@ -1036,7 +1060,7 @@ void EventHandler::handleEvent(Event::Type event, Int32 state)
void EventHandler::setActionMappings() void EventHandler::setActionMappings()
{ {
// Fill the ActionList with the current key and joystick mappings // Fill the ActionList with the current key and joystick mappings
for(Int32 i = 0; i < 61; ++i) for(Int32 i = 0; i < 62; ++i)
{ {
Event::Type event = ourActionList[i].event; Event::Type event = ourActionList[i].event;
ourActionList[i].key = "None"; ourActionList[i].key = "None";
@ -1277,6 +1301,7 @@ void EventHandler::setDefaultKeymap()
myKeyTable[ SDLK_F12 ] = Event::TakeSnapshot; myKeyTable[ SDLK_F12 ] = Event::TakeSnapshot;
myKeyTable[ SDLK_PAUSE ] = Event::Pause; myKeyTable[ SDLK_PAUSE ] = Event::Pause;
myKeyTable[ SDLK_TAB ] = Event::MenuMode; myKeyTable[ SDLK_TAB ] = Event::MenuMode;
myKeyTable[ SDLK_BACKSLASH ] = Event::CmdMenuMode;
myKeyTable[ SDLK_BACKQUOTE ] = Event::DebuggerMode; myKeyTable[ SDLK_BACKQUOTE ] = Event::DebuggerMode;
myKeyTable[ SDLK_ESCAPE ] = Event::LauncherMode; myKeyTable[ SDLK_ESCAPE ] = Event::LauncherMode;
myKeyTable[ SDLK_BACKSPACE ] = Event::Fry; myKeyTable[ SDLK_BACKSPACE ] = Event::Fry;
@ -1517,6 +1542,31 @@ void EventHandler::leaveMenuMode()
myEvent->clear(); myEvent->clear();
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void EventHandler::enterCmdMenuMode()
{
myState = S_CMDMENU;
myOSystem->commandMenu().reStack();
refreshDisplay();
myOSystem->frameBuffer().setCursorState();
myOSystem->sound().mute(true);
myEvent->clear();
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void EventHandler::leaveCmdMenuMode()
{
myState = S_EMULATE;
refreshDisplay();
myOSystem->frameBuffer().setCursorState();
myOSystem->sound().mute(false);
myEvent->clear();
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
bool EventHandler::enterDebugMode() bool EventHandler::enterDebugMode()
{ {
@ -1803,7 +1853,7 @@ void EventHandler::setSDLMappings()
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
ActionList EventHandler::ourActionList[61] = { ActionList EventHandler::ourActionList[62] = {
{ Event::ConsoleSelect, "Select", "" }, { Event::ConsoleSelect, "Select", "" },
{ Event::ConsoleReset, "Reset", "" }, { Event::ConsoleReset, "Reset", "" },
{ Event::ConsoleColor, "Color TV", "" }, { Event::ConsoleColor, "Color TV", "" },
@ -1817,7 +1867,8 @@ ActionList EventHandler::ourActionList[61] = {
{ Event::LoadState, "Load State", "" }, { Event::LoadState, "Load State", "" },
{ Event::TakeSnapshot, "Snapshot", "" }, { Event::TakeSnapshot, "Snapshot", "" },
{ Event::Pause, "Pause", "" }, { Event::Pause, "Pause", "" },
{ Event::MenuMode, "Toggle menu/options mode", "" }, { Event::MenuMode, "Toggle options menu mode", "" },
{ Event::CmdMenuMode, "Toggle command menu mode", "" },
{ Event::DebuggerMode, "Toggle debugger mode", "" }, { Event::DebuggerMode, "Toggle debugger mode", "" },
{ Event::LauncherMode, "Enter ROM launcher", "" }, { Event::LauncherMode, "Enter ROM launcher", "" },
{ Event::Quit, "Quit", "" }, { Event::Quit, "Quit", "" },

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: EventHandler.hxx,v 1.46 2005-08-25 15:19:17 stephena Exp $ // $Id: EventHandler.hxx,v 1.47 2005-08-29 18:36:41 stephena Exp $
//============================================================================ //============================================================================
#ifndef EVENTHANDLER_HXX #ifndef EVENTHANDLER_HXX
@ -74,7 +74,7 @@ struct Stella_Joystick {
mapping can take place. mapping can take place.
@author Stephen Anthony @author Stephen Anthony
@version $Id: EventHandler.hxx,v 1.46 2005-08-25 15:19:17 stephena Exp $ @version $Id: EventHandler.hxx,v 1.47 2005-08-29 18:36:41 stephena Exp $
*/ */
class EventHandler class EventHandler
{ {
@ -90,7 +90,7 @@ class EventHandler
virtual ~EventHandler(); virtual ~EventHandler();
// Enumeration representing the different states of operation // Enumeration representing the different states of operation
enum State { S_NONE, S_EMULATE, S_LAUNCHER, S_MENU, S_DEBUGGER }; enum State { S_NONE, S_EMULATE, S_LAUNCHER, S_MENU, S_CMDMENU, S_DEBUGGER };
/** /**
Returns the event object associated with this handler class. Returns the event object associated with this handler class.
@ -220,11 +220,13 @@ class EventHandler
void enterMenuMode(); void enterMenuMode();
void leaveMenuMode(); void leaveMenuMode();
void enterCmdMenuMode();
void leaveCmdMenuMode();
bool enterDebugMode(); bool enterDebugMode();
void leaveDebugMode(); void leaveDebugMode();
// Holds static strings for the remap menu // Holds static strings for the remap menu
static ActionList ourActionList[61]; static ActionList ourActionList[62];
// Lookup table for paddle resistance events // Lookup table for paddle resistance events
static const Event::Type Paddle_Resistance[4]; static const Event::Type Paddle_Resistance[4];

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: FrameBuffer.cxx,v 1.65 2005-08-25 15:19:17 stephena Exp $ // $Id: FrameBuffer.cxx,v 1.66 2005-08-29 18:36:41 stephena Exp $
//============================================================================ //============================================================================
#include <sstream> #include <sstream>
@ -28,6 +28,7 @@
#include "Font.hxx" #include "Font.hxx"
#include "GuiUtils.hxx" #include "GuiUtils.hxx"
#include "Menu.hxx" #include "Menu.hxx"
#include "CommandMenu.hxx"
#include "Launcher.hxx" #include "Launcher.hxx"
#include "OSystem.hxx" #include "OSystem.hxx"
@ -173,28 +174,7 @@ void FrameBuffer::update()
// Draw any pending messages // Draw any pending messages
if(myMessageTime > 0 && !myPauseStatus) if(myMessageTime > 0 && !myPauseStatus)
{ drawMessage();
int w = myOSystem->font().getStringWidth(myMessageText) + 10;
int h = myOSystem->font().getFontHeight() + 8;
int x = (myBaseDim.w >> 1) - (w >> 1);
int y = myBaseDim.h - h - 10/2;
// Draw the bounded box and text
fillRect(x+1, y+2, w-2, h-4, kBGColor);
box(x, y+1, w, h-2, kColor, kColor);
drawString(&myOSystem->font(), myMessageText, x+1, y+4, w, kTextColor, kTextAlignCenter);
myMessageTime--;
// Either erase the entire message (when time is reached),
// or show again this frame
if(myMessageTime == 0)
{
theRedrawTIAIndicator = true;
drawMediaSource();
}
else
addDirtyRect(x, y, w, h);
}
break; // S_EMULATE break; // S_EMULATE
} }
@ -208,6 +188,20 @@ void FrameBuffer::update()
break; // S_MENU break; // S_MENU
} }
case EventHandler::S_CMDMENU:
{
// Only update the screen if it's been invalidated
if(theRedrawTIAIndicator)
drawMediaSource();
myOSystem->commandMenu().draw();
// Draw any pending messages
if(myMessageTime > 0 && !myPauseStatus)
drawMessage();
break; // S_CMDMENU
}
case EventHandler::S_LAUNCHER: case EventHandler::S_LAUNCHER:
{ {
myOSystem->launcher().draw(); myOSystem->launcher().draw();
@ -260,6 +254,14 @@ void FrameBuffer::showMessage(const string& message)
myMessageTime = myFrameRate << 1; // Show message for 2 seconds myMessageTime = myFrameRate << 1; // Show message for 2 seconds
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void FrameBuffer::hideMessage()
{
// Erase old messages on the screen
if(myMessageTime > 0)
refresh(true);
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void FrameBuffer::pause(bool status) void FrameBuffer::pause(bool status)
{ {
@ -487,6 +489,31 @@ void FrameBuffer::setWindowIcon()
#endif #endif
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
inline void FrameBuffer::drawMessage()
{
int w = myOSystem->font().getStringWidth(myMessageText) + 10;
int h = myOSystem->font().getFontHeight() + 8;
int x = (myBaseDim.w >> 1) - (w >> 1);
int y = myBaseDim.h - h - 10/2;
// Draw the bounded box and text
fillRect(x+1, y+2, w-2, h-4, kBGColor);
box(x, y+1, w, h-2, kColor, kColor);
drawString(&myOSystem->font(), myMessageText, x+1, y+4, w, kTextColor, kTextAlignCenter);
myMessageTime--;
// Either erase the entire message (when time is reached),
// or show again this frame
if(myMessageTime == 0)
{
theRedrawTIAIndicator = true;
drawMediaSource();
}
else
addDirtyRect(x, y, w, h);
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void FrameBuffer::box(uInt32 x, uInt32 y, uInt32 w, uInt32 h, void FrameBuffer::box(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
OverlayColor colorA, OverlayColor colorB) OverlayColor colorA, OverlayColor colorB)

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: FrameBuffer.hxx,v 1.54 2005-08-11 19:12:38 stephena Exp $ // $Id: FrameBuffer.hxx,v 1.55 2005-08-29 18:36:41 stephena Exp $
//============================================================================ //============================================================================
#ifndef FRAMEBUFFER_HXX #ifndef FRAMEBUFFER_HXX
@ -52,7 +52,7 @@ enum FrameStyle {
All GUI elements (ala ScummVM) are drawn here as well. All GUI elements (ala ScummVM) are drawn here as well.
@author Stephen Anthony @author Stephen Anthony
@version $Id: FrameBuffer.hxx,v 1.54 2005-08-11 19:12:38 stephena Exp $ @version $Id: FrameBuffer.hxx,v 1.55 2005-08-29 18:36:41 stephena Exp $
*/ */
class FrameBuffer class FrameBuffer
{ {
@ -92,6 +92,11 @@ class FrameBuffer
*/ */
void showMessage(const string& message); void showMessage(const string& message);
/**
Hides any onscreen messages.
*/
void hideMessage();
/** /**
Returns the current width of the framebuffer *before* any scaling. Returns the current width of the framebuffer *before* any scaling.
@ -441,6 +446,11 @@ class FrameBuffer
*/ */
void setWindowIcon(); void setWindowIcon();
/**
Set the icon for the main SDL window.
*/
void drawMessage();
private: private:
// Indicates the current framerate of the system // Indicates the current framerate of the system
uInt32 myFrameRate; uInt32 myFrameRate;

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: OSystem.cxx,v 1.33 2005-08-25 15:19:17 stephena Exp $ // $Id: OSystem.cxx,v 1.34 2005-08-29 18:36:41 stephena Exp $
//============================================================================ //============================================================================
#include <cassert> #include <cassert>
@ -43,6 +43,7 @@
#include "PropsSet.hxx" #include "PropsSet.hxx"
#include "EventHandler.hxx" #include "EventHandler.hxx"
#include "Menu.hxx" #include "Menu.hxx"
#include "CommandMenu.hxx"
#include "Launcher.hxx" #include "Launcher.hxx"
#include "Font.hxx" #include "Font.hxx"
#include "StellaFont.hxx" #include "StellaFont.hxx"
@ -59,6 +60,7 @@ OSystem::OSystem()
myPropSet(NULL), myPropSet(NULL),
myConsole(NULL), myConsole(NULL),
myMenu(NULL), myMenu(NULL),
myCommandMenu(NULL),
myLauncher(NULL), myLauncher(NULL),
myDebugger(NULL), myDebugger(NULL),
myRomFile(""), myRomFile(""),
@ -68,6 +70,7 @@ OSystem::OSystem()
{ {
// Create menu and launcher GUI objects // Create menu and launcher GUI objects
myMenu = new Menu(this); myMenu = new Menu(this);
myCommandMenu = new CommandMenu(this);
myLauncher = new Launcher(this); myLauncher = new Launcher(this);
#ifdef DEVELOPER_SUPPORT #ifdef DEVELOPER_SUPPORT
myDebugger = new Debugger(this); myDebugger = new Debugger(this);
@ -101,6 +104,7 @@ OSystem::~OSystem()
myDriverList.clear(); myDriverList.clear();
delete myMenu; delete myMenu;
delete myCommandMenu;
delete myLauncher; delete myLauncher;
delete myFont; delete myFont;
delete myConsoleFont; delete myConsoleFont;
@ -207,6 +211,7 @@ bool OSystem::createFrameBuffer(bool showmessage)
{ {
case EventHandler::S_EMULATE: case EventHandler::S_EMULATE:
case EventHandler::S_MENU: case EventHandler::S_MENU:
case EventHandler::S_CMDMENU:
myConsole->initializeVideo(); myConsole->initializeVideo();
if(showmessage) if(showmessage)
{ {
@ -221,7 +226,7 @@ bool OSystem::createFrameBuffer(bool showmessage)
else // a driver that doesn't exist was requested, so use software mode else // a driver that doesn't exist was requested, so use software mode
myFrameBuffer->showMessage("Software mode"); myFrameBuffer->showMessage("Software mode");
} }
break; // S_EMULATE, S_MENU break; // S_EMULATE, S_MENU, S_CMDMENU
case EventHandler::S_LAUNCHER: case EventHandler::S_LAUNCHER:
myLauncher->initializeVideo(); myLauncher->initializeVideo();
@ -278,14 +283,12 @@ void OSystem::createSound()
{ {
case EventHandler::S_EMULATE: case EventHandler::S_EMULATE:
case EventHandler::S_MENU: case EventHandler::S_MENU:
case EventHandler::S_CMDMENU:
case EventHandler::S_DEBUGGER: case EventHandler::S_DEBUGGER:
myConsole->initializeAudio(); myConsole->initializeAudio();
break; // S_EMULATE, S_MENU, S_DEBUGGER break; // S_EMULATE, S_MENU, S_DEBUGGER
case EventHandler::S_LAUNCHER: default:
break; // S_LAUNCHER
case EventHandler::S_NONE:
break; break;
} }
} }

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: OSystem.hxx,v 1.27 2005-08-24 22:54:30 stephena Exp $ // $Id: OSystem.hxx,v 1.28 2005-08-29 18:36:41 stephena Exp $
//============================================================================ //============================================================================
#ifndef OSYSTEM_HXX #ifndef OSYSTEM_HXX
@ -22,6 +22,7 @@
class PropertiesSet; class PropertiesSet;
class Menu; class Menu;
class CommandMenu;
class Launcher; class Launcher;
class Debugger; class Debugger;
@ -42,7 +43,7 @@ class Debugger;
other objects belong. other objects belong.
@author Stephen Anthony @author Stephen Anthony
@version $Id: OSystem.hxx,v 1.27 2005-08-24 22:54:30 stephena Exp $ @version $Id: OSystem.hxx,v 1.28 2005-08-29 18:36:41 stephena Exp $
*/ */
class OSystem class OSystem
{ {
@ -128,6 +129,13 @@ class OSystem
*/ */
Menu& menu(void) const { return *myMenu; } Menu& menu(void) const { return *myMenu; }
/**
Get the command menu of the system.
@return The command menu object
*/
CommandMenu& commandMenu(void) const { return *myCommandMenu; }
/** /**
Get the ROM launcher of the system. Get the ROM launcher of the system.
@ -351,6 +359,9 @@ class OSystem
// Pointer to the Menu object // Pointer to the Menu object
Menu* myMenu; Menu* myMenu;
// Pointer to the CommandMenu object
CommandMenu* myCommandMenu;
// Pointer to the Launcher object // Pointer to the Launcher object
Launcher* myLauncher; Launcher* myLauncher;

View File

@ -0,0 +1,177 @@
//============================================================================
//
// SSSS tt lll lll
// SS SS tt ll ll
// SS tttttt eeee ll ll aaaa
// SSSS tt ee ee ll ll aa
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
// SS SS tt ee ll ll aa aa
// SSSS ttt eeeee llll llll aaaaa
//
// Copyright (c) 1995-2005 by Bradford W. Mott and the Stella team
//
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: CommandDialog.cxx,v 1.1 2005-08-29 18:36:42 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
//============================================================================
#include "OSystem.hxx"
#include "Dialog.hxx"
#include "DialogContainer.hxx"
#include "Widget.hxx"
#include "CommandDialog.hxx"
#include "EventHandler.hxx"
enum {
kSelectCmd = 'Csel',
kResetCmd = 'Cres',
kColorCmd = 'Ccol',
kBWCmd = 'Cbwt',
kLeftDiffACmd = 'Clda',
kLeftDiffBCmd = 'Cldb',
kRightDiffACmd = 'Crda',
kRightDiffBCmd = 'Crdb',
kSaveStateCmd = 'Csst',
kStateSlotCmd = 'Ccst',
kLoadStateCmd = 'Clst',
kSnapshotCmd = 'Csnp'
};
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CommandDialog::CommandDialog(OSystem* osystem, DialogContainer* parent)
: Dialog(osystem, parent, 0, 0, 16, 16)
{
int lineHeight = osystem->font().getLineHeight(),
buttonWidth = 60,
buttonHeight = lineHeight + 2,
xoffset = 5,
yoffset = 5,
lwidth = buttonWidth + 5;
// Set real dimensions
_w = 4 * (lwidth) + 5;
_h = 3 * (buttonHeight+5) + 5;
_x = (osystem->frameBuffer().baseWidth() - _w) / 2;
_y = (osystem->frameBuffer().baseHeight() - _h) / 2;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"Select", kSelectCmd, 0);
xoffset += lwidth;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"Reset", kResetCmd, 0);
xoffset += lwidth;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"Color TV", kColorCmd, 0);
xoffset += lwidth;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"B/W TV", kBWCmd, 0);
xoffset = 5; yoffset += buttonHeight + 5;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"Left Diff A", kLeftDiffACmd, 0);
xoffset += lwidth;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"Left Diff B", kLeftDiffBCmd, 0);
xoffset += lwidth;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"Right Diff A", kRightDiffACmd, 0);
xoffset += lwidth;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"Right Diff B", kRightDiffBCmd, 0);
xoffset = 5; yoffset += buttonHeight + 5;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"Save State", kSaveStateCmd, 0);
xoffset += lwidth;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"State Slot", kStateSlotCmd, 0);
xoffset += lwidth;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"Load State", kLoadStateCmd, 0);
xoffset += lwidth;
new ButtonWidget(this, xoffset, yoffset, buttonWidth, buttonHeight,
"Snapshot", kSnapshotCmd, 0);
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CommandDialog::~CommandDialog()
{
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void CommandDialog::handleCommand(CommandSender* sender, int cmd,
int data, int id)
{
bool execute = true;
Event::Type event = Event::NoType;
switch(cmd)
{
case kSelectCmd:
event = Event::ConsoleSelect;
break;
case kResetCmd:
event = Event::ConsoleReset;
break;
case kColorCmd:
event = Event::ConsoleColor;
break;
case kBWCmd:
event = Event::ConsoleBlackWhite;
break;
case kLeftDiffACmd:
event = Event::ConsoleLeftDifficultyA;
break;
case kLeftDiffBCmd:
event = Event::ConsoleLeftDifficultyB;
break;
case kRightDiffACmd:
event = Event::ConsoleRightDifficultyA;
break;
case kRightDiffBCmd:
event = Event::ConsoleRightDifficultyB;
break;
case kSaveStateCmd:
event = Event::SaveState;
break;
case kStateSlotCmd:
event = Event::ChangeState;
break;
case kLoadStateCmd:
event = Event::LoadState;
break;
case kSnapshotCmd:
event = Event::TakeSnapshot;
break;
default:
execute = false;
}
// Show changes onscreen
if(execute)
{
instance()->eventHandler().leaveCmdMenuMode();
instance()->eventHandler().handleEvent(event, 1);
instance()->console().mediaSource().update();
instance()->eventHandler().handleEvent(event, 0);
}
}

View File

@ -0,0 +1,41 @@
//============================================================================
//
// SSSS tt lll lll
// SS SS tt ll ll
// SS tttttt eeee ll ll aaaa
// SSSS tt ee ee ll ll aa
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
// SS SS tt ee ll ll aa aa
// SSSS ttt eeeee llll llll aaaaa
//
// Copyright (c) 1995-2005 by Bradford W. Mott and the Stella team
//
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: CommandDialog.hxx,v 1.1 2005-08-29 18:36:42 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
//============================================================================
#ifndef COMMAND_DIALOG_HXX
#define COMMAND_DIALOG_HXX
class Properties;
class CommandSender;
class DialogContainer;
#include "OSystem.hxx"
#include "Dialog.hxx"
class CommandDialog : public Dialog
{
public:
CommandDialog(OSystem* osystem, DialogContainer* parent);
~CommandDialog();
virtual void handleCommand(CommandSender* sender, int cmd, int data, int id);
};
#endif

View File

@ -0,0 +1,39 @@
//============================================================================
//
// SSSS tt lll lll
// SS SS tt ll ll
// SS tttttt eeee ll ll aaaa
// SSSS tt ee ee ll ll aa
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
// SS SS tt ee ll ll aa aa
// SSSS ttt eeeee llll llll aaaaa
//
// Copyright (c) 1995-2005 by Bradford W. Mott and the Stella team
//
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: CommandMenu.cxx,v 1.1 2005-08-29 18:36:42 stephena Exp $
//============================================================================
#include "Dialog.hxx"
#include "CommandDialog.hxx"
#include "CommandMenu.hxx"
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CommandMenu::CommandMenu(OSystem* osystem)
: DialogContainer(osystem)
{
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CommandMenu::~CommandMenu()
{
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void CommandMenu::initialize()
{
delete myBaseDialog;
myBaseDialog = new CommandDialog(myOSystem, this);
}

View File

@ -0,0 +1,53 @@
//============================================================================
//
// SSSS tt lll lll
// SS SS tt ll ll
// SS tttttt eeee ll ll aaaa
// SSSS tt ee ee ll ll aa
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
// SS SS tt ee ll ll aa aa
// SSSS ttt eeeee llll llll aaaaa
//
// Copyright (c) 1995-2005 by Bradford W. Mott and the Stella team
//
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: CommandMenu.hxx,v 1.1 2005-08-29 18:36:42 stephena Exp $
//============================================================================
#ifndef COMMAND_MENU_HXX
#define COMMAND_MENU_HXX
class Properties;
class OSystem;
#include "DialogContainer.hxx"
/**
The base dialog for common commands in Stella.
@author Stephen Anthony
@version $Id: CommandMenu.hxx,v 1.1 2005-08-29 18:36:42 stephena Exp $
*/
class CommandMenu : public DialogContainer
{
public:
/**
Create a new menu stack
*/
CommandMenu(OSystem* osystem);
/**
Destructor
*/
virtual ~CommandMenu();
public:
/**
Updates the basedialog to be of the type defined for this derived class.
*/
void initialize();
};
#endif

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: DialogContainer.cxx,v 1.16 2005-08-11 19:12:39 stephena Exp $ // $Id: DialogContainer.cxx,v 1.17 2005-08-29 18:36:42 stephena Exp $
//============================================================================ //============================================================================
#include "OSystem.hxx" #include "OSystem.hxx"
@ -121,6 +121,9 @@ void DialogContainer::reStack()
myDialogStack.pop(); myDialogStack.pop();
addDialog(myBaseDialog); addDialog(myBaseDialog);
// Erase any previous messages
myOSystem->frameBuffer().hideMessage();
// Reset all continuous events // Reset all continuous events
myCurrentKeyDown.keycode = 0; myCurrentKeyDown.keycode = 0;
myCurrentMouseDown.button = -1; myCurrentMouseDown.button = -1;

View File

@ -6,6 +6,8 @@ MODULE_OBJS := \
src/gui/BrowserDialog.o \ src/gui/BrowserDialog.o \
src/gui/ColorWidget.o \ src/gui/ColorWidget.o \
src/gui/CheatCodeDialog.o \ src/gui/CheatCodeDialog.o \
src/gui/CommandDialog.o \
src/gui/CommandMenu.o \
src/gui/DataGridWidget.o \ src/gui/DataGridWidget.o \
src/gui/DataGridOpsWidget.o \ src/gui/DataGridOpsWidget.o \
src/gui/DebuggerDialog.o \ src/gui/DebuggerDialog.o \