Some minor UI improvements to the InputSettings dialog; renamed the

'Virtual Devs' tab to 'Devices & Ports'.  Updated documentation and
snapshots for this change.

Added Halo 2600 ROM info to internal properties database.

Increased default setting for 'joydeadzone' from 0 to 13.  This means
the default deadzone is somewhere around half the axis range (~16500).

Fixed behaviour of hat events; events weren't actually being turned off
until the stick was centered.


git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@2108 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
stephena 2010-08-21 23:08:44 +00:00
parent 0fa706c558
commit 26b1654aa2
14 changed files with 59 additions and 58 deletions

View File

@ -12,6 +12,20 @@
Release History Release History
=========================================================================== ===========================================================================
3.2 to 3.2.1: (August x, 2010)
* Improved behaviour of joystick 'hat' movement. This should fix bugs
most visible in Yars' Revenge.
* Fixed bug in debugger rewind states; bankswitching wasn't being
performed during the rewind. Related to this, fixed a similar issue
with the debugger 'loadstate' and 'savestate' commands.
* Added game properties info for the newly released 'Halo 2600' ROM.
-Have fun!
3.1.2 to 3.2: (August 20, 2010) 3.1.2 to 3.2: (August 20, 2010)
* NOTE: because of the many event-related changes in this release, all * NOTE: because of the many event-related changes in this release, all
@ -111,8 +125,6 @@
* Updated included ZLib to latest release version (1.2.5). * Updated included ZLib to latest release version (1.2.5).
-Have fun!
3.1.1 to 3.1.2: (May 3, 2010) 3.1.1 to 3.1.2: (May 3, 2010)

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.1 KiB

After

Width:  |  Height:  |  Size: 6.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.8 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.0 KiB

After

Width:  |  Height:  |  Size: 6.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.1 KiB

After

Width:  |  Height:  |  Size: 6.2 KiB

View File

@ -10,7 +10,7 @@
<br><br> <br><br>
<center><h2><b>A multi-platform Atari 2600 VCS emulator</b></h2></center> <center><h2><b>A multi-platform Atari 2600 VCS emulator</b></h2></center>
<center><h4><b>Release 3.2</b></h4></center> <center><h4><b>Release 3.2.1</b></h4></center>
<br><br> <br><br>
<center><h2><b>User's Guide</b></h2></center> <center><h2><b>User's Guide</b></h2></center>
@ -2341,10 +2341,10 @@
</p> </p>
<p>Virtual devices can be configured under the 'Virtual Devs' tab, shown below:</p> <p>Device and port settings can be configured under the 'Devices & Ports' tab, shown below:</p>
<table border="5" cellpadding="2" frame="box" rules="none"> <table border="5" cellpadding="2" frame="box" rules="none">
<tr> <tr>
<td><img src="graphics/eventmapping_virtualdevs.png"></td> <td><img src="graphics/eventmapping_devsports.png"></td>
<td>&nbsp;&nbsp;&nbsp;&nbsp;</td> <td>&nbsp;&nbsp;&nbsp;&nbsp;</td>
<td valign="top"> <td valign="top">
<table border="1" cellpadding="4"> <table border="1" cellpadding="4">
@ -2541,7 +2541,7 @@
this is outside the scope of this document). Once your operating system this is outside the scope of this document). Once your operating system
properly detects the AtariVox, you will need to tell Stella which serial properly detects the AtariVox, you will need to tell Stella which serial
port it is connected to. This is done by using the '-avoxport' commandline port it is connected to. This is done by using the '-avoxport' commandline
argument, or by setting it in the UI under the 'Virtual Devs' tab in argument, or by setting it in the UI under the 'Devices & Ports' tab in
<b>Advanced Configuration - <a href="#Remapping">Input Devices</a></b>.</p> <b>Advanced Configuration - <a href="#Remapping">Input Devices</a></b>.</p>
<p>Note that you must use the entire name of the port as specified by <p>Note that you must use the entire name of the port as specified by

View File

@ -27,7 +27,7 @@
regenerated and the application recompiled. regenerated and the application recompiled.
*/ */
#define DEF_PROPS_SIZE 3240 #define DEF_PROPS_SIZE 3241
static const char* DefProps[DEF_PROPS_SIZE][20] = { static const char* DefProps[DEF_PROPS_SIZE][20] = {
{ "000509d1ed2b8d30a9d94be1b3b5febb", "Greg Zumwalt", "", "Jungle Jane (2003) (Greg Zumwalt) (Hack)", "Hack of Pitfall!", "Hack", "", "", "", "", "", "", "", "", "", "", "", "", "", "" }, { "000509d1ed2b8d30a9d94be1b3b5febb", "Greg Zumwalt", "", "Jungle Jane (2003) (Greg Zumwalt) (Hack)", "Hack of Pitfall!", "Hack", "", "", "", "", "", "", "", "", "", "", "", "", "", "" },
@ -983,6 +983,7 @@ static const char* DefProps[DEF_PROPS_SIZE][20] = {
{ "4ac9f40ddfcf194bd8732a75b3f2f214", "Atari, Stephen Keith, Preston Stuart", "CX26106", "Grover's Music Maker (12-29-1982) (Atari) (Prototype)", "Uses Kids/Keypad Controllers", "Prototype", "", "", "", "", "", "", "KEYBOARD", "KEYBOARD", "", "", "", "", "", "" }, { "4ac9f40ddfcf194bd8732a75b3f2f214", "Atari, Stephen Keith, Preston Stuart", "CX26106", "Grover's Music Maker (12-29-1982) (Atari) (Prototype)", "Uses Kids/Keypad Controllers", "Prototype", "", "", "", "", "", "", "KEYBOARD", "KEYBOARD", "", "", "", "", "", "" },
{ "4ae8c76cd6f24a2e181ae874d4d2aa3d", "", "", "Flash Gordon (Unknown) (PAL)", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "" }, { "4ae8c76cd6f24a2e181ae874d4d2aa3d", "", "", "Flash Gordon (Unknown) (PAL)", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "" },
{ "4af4103759d603c82b1c9c5acd2d8faf", "Imagic, Bob Smith", "720114-2A, 13207, EIZ-001-04I", "Moonsweeper (1983) (Imagic) (PAL)", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "YES", "" }, { "4af4103759d603c82b1c9c5acd2d8faf", "Imagic, Bob Smith", "720114-2A, 13207, EIZ-001-04I", "Moonsweeper (1983) (Imagic) (PAL)", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "YES", "" },
{ "4afa7f377eae1cafb4265c68f73f2718", "Ed Fries", "", "Halo 2600 (2010) (Ed Fries)", "", "Homebrew", "", "", "", "", "", "", "", "", "", "", "", "", "", "" },
{ "4afe528a082f0d008e7319ebd481248d", "", "", "Multi-Color Demo 1 (Bob Colbert) (PD)", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "" }, { "4afe528a082f0d008e7319ebd481248d", "", "", "Multi-Color Demo 1 (Bob Colbert) (PD)", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "" },
{ "4b143d7dcf6c96796c37090cba045f4f", "Atari, Jim Huether - Sears", "CX2644 - 6-99824", "Flag Capture (1978) (Atari) (4K)", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "" }, { "4b143d7dcf6c96796c37090cba045f4f", "Atari, Jim Huether - Sears", "CX2644 - 6-99824", "Flag Capture (1978) (Atari) (4K)", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "" },
{ "4b205ef73a5779acc5759bde3f6d33ed", "", "", "Berzerk (Unknown) (PAL)", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "" }, { "4b205ef73a5779acc5759bde3f6d33ed", "", "", "Berzerk (Unknown) (PAL)", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "" },

View File

@ -848,18 +848,32 @@ void EventHandler::poll(uInt64 time)
// Preprocess all hat events, converting to Stella JoyHat type // Preprocess all hat events, converting to Stella JoyHat type
// Generate multiple equivalent hat events representing combined direction // Generate multiple equivalent hat events representing combined direction
// when we get a diagonal hat event // when we get a diagonal hat event
if(myState == S_EMULATE)
{
handleEvent(myJoyHatTable[stick][hat][EVENT_HATUP][kEmulationMode],
value & SDL_HAT_UP);
handleEvent(myJoyHatTable[stick][hat][EVENT_HATRIGHT][kEmulationMode],
value & SDL_HAT_RIGHT);
handleEvent(myJoyHatTable[stick][hat][EVENT_HATDOWN][kEmulationMode],
value & SDL_HAT_DOWN);
handleEvent(myJoyHatTable[stick][hat][EVENT_HATLEFT][kEmulationMode],
value & SDL_HAT_LEFT);
}
else if(myOverlay != NULL)
{
if(value == SDL_HAT_CENTERED) if(value == SDL_HAT_CENTERED)
handleJoyHatEvent(stick, hat, EVENT_HATCENTER); myOverlay->handleJoyHatEvent(stick, hat, EVENT_HATCENTER);
else else
{ {
if(value & SDL_HAT_UP) if(value & SDL_HAT_UP)
handleJoyHatEvent(stick, hat, EVENT_HATUP); myOverlay->handleJoyHatEvent(stick, hat, EVENT_HATUP);
if(value & SDL_HAT_RIGHT) if(value & SDL_HAT_RIGHT)
handleJoyHatEvent(stick, hat, EVENT_HATRIGHT); myOverlay->handleJoyHatEvent(stick, hat, EVENT_HATRIGHT);
if(value & SDL_HAT_DOWN) if(value & SDL_HAT_DOWN)
handleJoyHatEvent(stick, hat, EVENT_HATDOWN); myOverlay->handleJoyHatEvent(stick, hat, EVENT_HATDOWN);
if(value & SDL_HAT_LEFT) if(value & SDL_HAT_LEFT)
handleJoyHatEvent(stick, hat, EVENT_HATLEFT); myOverlay->handleJoyHatEvent(stick, hat, EVENT_HATLEFT);
}
} }
break; // SDL_JOYHATMOTION break; // SDL_JOYHATMOTION
} }
@ -911,29 +925,6 @@ void EventHandler::poll(uInt64 time)
myEvent->set(Event::MouseAxisYValue, 0); myEvent->set(Event::MouseAxisYValue, 0);
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void EventHandler::handleJoyHatEvent(int stick, int hat, JoyHat value)
{
#ifdef JOYSTICK_SUPPORT
if(myState == S_EMULATE)
{
if(value == EVENT_HATCENTER)
{
// Turn off all associated events, since we don't know exactly
// which one was previously activated.
handleEvent(myJoyHatTable[stick][hat][EVENT_HATUP] [kEmulationMode], 0);
handleEvent(myJoyHatTable[stick][hat][EVENT_HATDOWN] [kEmulationMode], 0);
handleEvent(myJoyHatTable[stick][hat][EVENT_HATLEFT] [kEmulationMode], 0);
handleEvent(myJoyHatTable[stick][hat][EVENT_HATRIGHT][kEmulationMode], 0);
}
else
handleEvent(myJoyHatTable[stick][hat][value][kEmulationMode], 1);
}
else if(myOverlay != NULL)
myOverlay->handleJoyHatEvent(stick, hat, value);
#endif
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void EventHandler::handleEvent(Event::Type event, int state) void EventHandler::handleEvent(Event::Type event, int state)
{ {

View File

@ -336,15 +336,6 @@ class EventHandler
void allowAllDirections(bool allow) { myAllowAllDirectionsFlag = allow; } void allowAllDirections(bool allow) { myAllowAllDirectionsFlag = allow; }
private: private:
/**
Send a joystick hat event to the handler
@param stick The joystick number
@param hat The joystick hat
@param value The value on the given hat
*/
void handleJoyHatEvent(int stick, int hat, JoyHat value);
/** /**
Detects and changes the eventhandler state Detects and changes the eventhandler state

View File

@ -81,7 +81,7 @@ Settings::Settings(OSystem* osystem)
setInternal("joyaxismap", ""); setInternal("joyaxismap", "");
setInternal("joyhatmap", ""); setInternal("joyhatmap", "");
setInternal("combomap", ""); setInternal("combomap", "");
setInternal("joydeadzone", "0"); setInternal("joydeadzone", "13");
setInternal("joyallow4", "false"); setInternal("joyallow4", "false");
setInternal("usemouse", "true"); setInternal("usemouse", "true");
setInternal("pspeed", "6"); setInternal("pspeed", "6");

View File

@ -19607,3 +19607,9 @@
"Cartridge.Rarity" "Homebrew" "Cartridge.Rarity" "Homebrew"
"Display.Phosphor" "YES" "Display.Phosphor" "YES"
"" ""
"Cartridge.MD5" "4afa7f377eae1cafb4265c68f73f2718"
"Cartridge.Manufacturer" "Ed Fries"
"Cartridge.Name" "Halo 2600 (2010) (Ed Fries)"
"Cartridge.Rarity" "Homebrew"
""

View File

@ -48,7 +48,7 @@ InputDialog::InputDialog(OSystem* osystem, DialogContainer* parent,
WidgetArray wid; WidgetArray wid;
// Set real dimensions // Set real dimensions
_w = BSPF_min(48 * fontWidth + 10, max_w); _w = BSPF_min(49 * fontWidth + 10, max_w);
_h = BSPF_min(12 * (lineHeight + 4) + 10, max_h); _h = BSPF_min(12 * (lineHeight + 4) + 10, max_h);
// The tab widget // The tab widget
@ -78,8 +78,8 @@ InputDialog::InputDialog(OSystem* osystem, DialogContainer* parent,
myTab->setParentWidget(tabID, myMenuEventMapper); myTab->setParentWidget(tabID, myMenuEventMapper);
addToFocusList(myMenuEventMapper->getFocusList(), tabID); addToFocusList(myMenuEventMapper->getFocusList(), tabID);
// 3) Virtual device support // 3) Devices & ports
addVDeviceTab(font); addDevicePortTab(font);
// Finalize the tabs, and activate the first tab // Finalize the tabs, and activate the first tab
myTab->activateTabs(); myTab->activateTabs();
@ -101,7 +101,7 @@ InputDialog::~InputDialog()
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void InputDialog::addVDeviceTab(const GUI::Font& font) void InputDialog::addDevicePortTab(const GUI::Font& font)
{ {
const int lineHeight = font.getLineHeight(), const int lineHeight = font.getLineHeight(),
fontWidth = font.getMaxCharWidth(), fontWidth = font.getMaxCharWidth(),
@ -110,8 +110,8 @@ void InputDialog::addVDeviceTab(const GUI::Font& font)
WidgetArray wid; WidgetArray wid;
StringMap items; StringMap items;
// Virtual device/ports // Devices/ports
tabID = myTab->addTab("Virtual Devs"); tabID = myTab->addTab("Devices & Ports");
// Stelladaptor mappings // Stelladaptor mappings
xpos = 5; ypos = 5; xpos = 5; ypos = 5;

View File

@ -52,7 +52,7 @@ class InputDialog : public Dialog
void setDefaults(); void setDefaults();
private: private:
void addVDeviceTab(const GUI::Font& font); void addDevicePortTab(const GUI::Font& font);
private: private:
enum { enum {