eliminating some magic numbers in joystick handlers

This commit is contained in:
thrust26 2019-06-19 21:58:39 +02:00
parent 77c2824d4a
commit d7e9c95fb0
5 changed files with 79 additions and 66 deletions

View File

@ -127,13 +127,13 @@ int PhysicalJoystickHandler::add(PhysicalJoystickPtr stick)
// We're potentially swapping out an input device behind the back of // We're potentially swapping out an input device behind the back of
// the Event system, so we make sure all Stelladaptor-generated events // the Event system, so we make sure all Stelladaptor-generated events
// are reset // are reset
for(int i = 0; i < 2; ++i) for(int i = 0; i < NUM_PORTS; ++i)
{ {
for(int j = 0; j < 2; ++j) for(int j = 0; j < NUM_JOY_AXIS; ++j)
myEvent.set(SA_Axis[i][j], 0); myEvent.set(SA_Axis[i][j], 0);
for(int j = 0; j < 4; ++j) for(int j = 0; j < NUM_JOY_BTN; ++j)
myEvent.set(SA_Button[i][j], 0); myEvent.set(SA_Button[i][j], 0);
for(int j = 0; j < 12; ++j) for(int j = 0; j < NUM_KEY_BTN; ++j)
myEvent.set(SA_Key[i][j], 0); myEvent.set(SA_Key[i][j], 0);
} }
@ -197,7 +197,7 @@ void PhysicalJoystickHandler::mapStelladaptors(const string& saport)
// We know there will be only two such devices (at most), since the logic // We know there will be only two such devices (at most), since the logic
// in setupJoysticks take care of that // in setupJoysticks take care of that
int saCount = 0; int saCount = 0;
int saOrder[2] = { 1, 2 }; int saOrder[NUM_PORTS] = { 1, 2 };
if(BSPF::equalsIgnoreCase(saport, "rl")) if(BSPF::equalsIgnoreCase(saport, "rl"))
{ {
saOrder[0] = 2; saOrder[1] = 1; saOrder[0] = 2; saOrder[1] = 1;
@ -414,7 +414,7 @@ string PhysicalJoystickHandler::getMappingDesc(Event::Type event, EventMode mode
// Joystick axis mapping/labeling // Joystick axis mapping/labeling
for(int axis = 0; axis < j->numAxes; ++axis) for(int axis = 0; axis < j->numAxes; ++axis)
{ {
for(int dir = 0; dir < 2; ++dir) for(int dir = 0; dir < NUM_JOY_DIRS; ++dir)
{ {
if(j->axisTable[axis][dir][mode] == event) if(j->axisTable[axis][dir][mode] == event)
{ {
@ -423,7 +423,7 @@ string PhysicalJoystickHandler::getMappingDesc(Event::Type event, EventMode mode
buf << "J" << stick << "/A" << axis; buf << "J" << stick << "/A" << axis;
if(Event::isAnalog(event)) if(Event::isAnalog(event))
{ {
dir = 2; // Immediately exit the inner loop after this iteration dir = NUM_JOY_DIRS; // Immediately exit the inner loop after this iteration
buf << "/+|-"; buf << "/+|-";
} }
else if(dir == 0) else if(dir == 0)
@ -437,7 +437,7 @@ string PhysicalJoystickHandler::getMappingDesc(Event::Type event, EventMode mode
// Joystick hat mapping/labeling // Joystick hat mapping/labeling
for(int hat = 0; hat < j->numHats; ++hat) for(int hat = 0; hat < j->numHats; ++hat)
{ {
for(int dir = 0; dir < 4; ++dir) for(int dir = 0; dir < NUM_JOY_HAT_DIRS; ++dir)
{ {
if(j->hatTable[hat][dir][mode] == event) if(j->hatTable[hat][dir][mode] == event)
{ {
@ -471,16 +471,16 @@ bool PhysicalJoystickHandler::addAxisMapping(Event::Type event, EventMode mode,
// This confusing code is because each axis has two associated values, // This confusing code is because each axis has two associated values,
// but analog events only affect one of the axis. // but analog events only affect one of the axis.
if(Event::isAnalog(event)) if(Event::isAnalog(event))
j->axisTable[axis][0][mode] = j->axisTable[axis][1][mode] = event; j->axisTable[axis][int(JoyDir::NEG)][mode] = j->axisTable[axis][int(JoyDir::POS)][mode] = event;
else else
{ {
// Otherwise, turn off the analog event(s) for this axis // Otherwise, turn off the analog event(s) for this axis
if(Event::isAnalog(j->axisTable[axis][0][mode])) if(Event::isAnalog(j->axisTable[axis][int(JoyDir::NEG)][mode]))
j->axisTable[axis][0][mode] = Event::NoType; j->axisTable[axis][int(JoyDir::NEG)][mode] = Event::NoType;
if(Event::isAnalog(j->axisTable[axis][1][mode])) if(Event::isAnalog(j->axisTable[axis][int(JoyDir::POS)][mode]))
j->axisTable[axis][1][mode] = Event::NoType; j->axisTable[axis][int(JoyDir::POS)][mode] = Event::NoType;
j->axisTable[axis][(value > 0)][mode] = event; j->axisTable[axis][(value > int(JoyDir::NEG))][mode] = event;
} }
return true; return true;
} }
@ -534,8 +534,8 @@ void PhysicalJoystickHandler::handleAxisEvent(int stick, int axis, int value)
if(myHandler.state() == EventHandlerState::EMULATION) if(myHandler.state() == EventHandlerState::EMULATION)
{ {
// Every axis event has two associated values, negative and positive // Every axis event has two associated values, negative and positive
Event::Type eventAxisNeg = j->axisTable[axis][0][kEmulationMode]; Event::Type eventAxisNeg = j->axisTable[axis][int(JoyDir::NEG)][kEmulationMode];
Event::Type eventAxisPos = j->axisTable[axis][1][kEmulationMode]; Event::Type eventAxisPos = j->axisTable[axis][int(JoyDir::POS)][kEmulationMode];
// Check for analog events, which are handled differently // Check for analog events, which are handled differently
// We'll pass them off as Stelladaptor events, and let the controllers // We'll pass them off as Stelladaptor events, and let the controllers
@ -611,13 +611,13 @@ void PhysicalJoystickHandler::handleAxisEvent(int stick, int axis, int value)
// they can never be remapped // they can never be remapped
case PhysicalJoystick::JT_STELLADAPTOR_LEFT: case PhysicalJoystick::JT_STELLADAPTOR_LEFT:
case PhysicalJoystick::JT_2600DAPTOR_LEFT: case PhysicalJoystick::JT_2600DAPTOR_LEFT:
if(axis < 2) if(axis < NUM_JOY_AXIS)
myEvent.set(SA_Axis[0][axis], value); myEvent.set(SA_Axis[int(Controller::Jack::Left)][axis], value);
break; // axis on left controller (0) break; // axis on left controller (0)
case PhysicalJoystick::JT_STELLADAPTOR_RIGHT: case PhysicalJoystick::JT_STELLADAPTOR_RIGHT:
case PhysicalJoystick::JT_2600DAPTOR_RIGHT: case PhysicalJoystick::JT_2600DAPTOR_RIGHT:
if(axis < 2) if(axis < NUM_JOY_AXIS)
myEvent.set(SA_Axis[1][axis], value); myEvent.set(SA_Axis[int(Controller::Jack::Right)][axis], value);
break; // axis on right controller (1) break; // axis on right controller (1)
default: default:
break; break;
@ -654,7 +654,8 @@ void PhysicalJoystickHandler::handleBtnEvent(int stick, int button, bool pressed
// The 'type-2' here refers to the fact that 'PhysicalJoystick::JT_STELLADAPTOR_LEFT' // The 'type-2' here refers to the fact that 'PhysicalJoystick::JT_STELLADAPTOR_LEFT'
// and 'PhysicalJoystick::JT_STELLADAPTOR_RIGHT' are at index 2 and 3 in the JoyType // and 'PhysicalJoystick::JT_STELLADAPTOR_RIGHT' are at index 2 and 3 in the JoyType
// enum; subtracting two gives us Controller 0 and 1 // enum; subtracting two gives us Controller 0 and 1
if(button < 2) myEvent.set(SA_Button[j->type-2][button], pressed ? 1 : 0); if(button < 2)
myEvent.set(SA_Button[j->type-PhysicalJoystick::JT_STELLADAPTOR_LEFT][button], pressed ? 1 : 0);
break; // Stelladaptor button break; // Stelladaptor button
case PhysicalJoystick::JT_2600DAPTOR_LEFT: case PhysicalJoystick::JT_2600DAPTOR_LEFT:
case PhysicalJoystick::JT_2600DAPTOR_RIGHT: case PhysicalJoystick::JT_2600DAPTOR_RIGHT:
@ -666,18 +667,20 @@ void PhysicalJoystickHandler::handleBtnEvent(int stick, int button, bool pressed
switch(myOSystem.console().leftController().type()) switch(myOSystem.console().leftController().type())
{ {
case Controller::Type::Keyboard: case Controller::Type::Keyboard:
if(button < 12) myEvent.set(SA_Key[j->type-4][button], pressed ? 1 : 0); if(button < NUM_KEY_BTN)
myEvent.set(SA_Key[j->type-PhysicalJoystick::JT_2600DAPTOR_LEFT][button], pressed ? 1 : 0);
break; break;
default: default:
if(button < 4) myEvent.set(SA_Button[j->type-4][button], pressed ? 1 : 0); if(button < NUM_JOY_BTN) myEvent.set(SA_Button[j->type-PhysicalJoystick::JT_2600DAPTOR_LEFT][button], pressed ? 1 : 0);
} }
switch(myOSystem.console().rightController().type()) switch(myOSystem.console().rightController().type())
{ {
case Controller::Type::Keyboard: case Controller::Type::Keyboard:
if(button < 12) myEvent.set(SA_Key[j->type-4][button], pressed ? 1 : 0); if(button < NUM_KEY_BTN)
myEvent.set(SA_Key[j->type-PhysicalJoystick::JT_2600DAPTOR_LEFT][button], pressed ? 1 : 0);
break; break;
default: default:
if(button < 4) myEvent.set(SA_Button[j->type-4][button], pressed ? 1 : 0); if(button < NUM_JOY_BTN) myEvent.set(SA_Button[j->type-PhysicalJoystick::JT_2600DAPTOR_LEFT][button], pressed ? 1 : 0);
} }
} }
break; // 2600DAPTOR button break; // 2600DAPTOR button
@ -756,7 +759,7 @@ ostream& operator<<(ostream& os, const PhysicalJoystickHandler& jh)
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
// Used by the Stelladaptor to send absolute axis values // Used by the Stelladaptor to send absolute axis values
const Event::Type PhysicalJoystickHandler::SA_Axis[2][2] = { const Event::Type PhysicalJoystickHandler::SA_Axis[NUM_PORTS][NUM_JOY_AXIS] = {
{ Event::SALeftAxis0Value, Event::SALeftAxis1Value }, { Event::SALeftAxis0Value, Event::SALeftAxis1Value },
{ Event::SARightAxis0Value, Event::SARightAxis1Value } { Event::SARightAxis0Value, Event::SARightAxis1Value }
}; };
@ -764,7 +767,7 @@ const Event::Type PhysicalJoystickHandler::SA_Axis[2][2] = {
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
// Used by the Stelladaptor to map button presses to joystick or paddles // Used by the Stelladaptor to map button presses to joystick or paddles
// (driving controllers and boostergrip are considered the same as joysticks) // (driving controllers and boostergrip are considered the same as joysticks)
const Event::Type PhysicalJoystickHandler::SA_Button[2][4] = { const Event::Type PhysicalJoystickHandler::SA_Button[NUM_PORTS][NUM_JOY_BTN] = {
{ Event::JoystickZeroFire, Event::JoystickZeroFire9, { Event::JoystickZeroFire, Event::JoystickZeroFire9,
Event::JoystickZeroFire5, Event::JoystickZeroFire9 }, Event::JoystickZeroFire5, Event::JoystickZeroFire9 },
{ Event::JoystickOneFire, Event::JoystickOneFire9, { Event::JoystickOneFire, Event::JoystickOneFire9,
@ -773,7 +776,7 @@ const Event::Type PhysicalJoystickHandler::SA_Button[2][4] = {
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
// Used by the 2600-daptor to map button presses to keypad keys // Used by the 2600-daptor to map button presses to keypad keys
const Event::Type PhysicalJoystickHandler::SA_Key[2][12] = { const Event::Type PhysicalJoystickHandler::SA_Key[NUM_PORTS][NUM_KEY_BTN] = {
{ Event::KeyboardZero1, Event::KeyboardZero2, Event::KeyboardZero3, { Event::KeyboardZero1, Event::KeyboardZero2, Event::KeyboardZero3,
Event::KeyboardZero4, Event::KeyboardZero5, Event::KeyboardZero6, Event::KeyboardZero4, Event::KeyboardZero5, Event::KeyboardZero6,
Event::KeyboardZero7, Event::KeyboardZero8, Event::KeyboardZero9, Event::KeyboardZero7, Event::KeyboardZero8, Event::KeyboardZero9,

View File

@ -83,17 +83,18 @@ class PhysicalJoystickHandler
void handleBtnEvent(int stick, int button, bool pressed); void handleBtnEvent(int stick, int button, bool pressed);
void handleHatEvent(int stick, int hat, int value); void handleHatEvent(int stick, int hat, int value);
Event::Type eventForAxis(int stick, int axis, int value, EventMode mode) const { Event::Type eventForAxis(int stick, int axis, int joyDir, EventMode mode) const {
const PhysicalJoystickPtr j = joy(stick); const PhysicalJoystickPtr j = joy(stick);
return (j && value != 0) ? j->axisTable[axis][(value > 0)][mode] : Event::NoType; return (j && joyDir != int(JoyDir::NEG))
? j->axisTable[axis][(joyDir > int(JoyDir::NEG))][mode] : Event::NoType;
} }
Event::Type eventForButton(int stick, int button, EventMode mode) const { Event::Type eventForButton(int stick, int button, EventMode mode) const {
const PhysicalJoystickPtr j = joy(stick); const PhysicalJoystickPtr j = joy(stick);
return j ? j->btnTable[button][mode] : Event::NoType; return j ? j->btnTable[button][mode] : Event::NoType;
} }
Event::Type eventForHat(int stick, int hat, JoyHat value, EventMode mode) const { Event::Type eventForHat(int stick, int hat, JoyHat hatDir, EventMode mode) const {
const PhysicalJoystickPtr j = joy(stick); const PhysicalJoystickPtr j = joy(stick);
return j ? j->hatTable[hat][int(value)][mode] : Event::NoType; return j ? j->hatTable[hat][int(hatDir)][mode] : Event::NoType;
} }
/** Returns a list of pairs consisting of joystick name and associated ID. */ /** Returns a list of pairs consisting of joystick name and associated ID. */
@ -126,9 +127,12 @@ class PhysicalJoystickHandler
friend ostream& operator<<(ostream& os, const PhysicalJoystickHandler& jh); friend ostream& operator<<(ostream& os, const PhysicalJoystickHandler& jh);
// Static lookup tables for Stelladaptor/2600-daptor axis/button support // Static lookup tables for Stelladaptor/2600-daptor axis/button support
static const Event::Type SA_Axis[2][2]; static const int NUM_JOY_BTN = 4;
static const Event::Type SA_Button[2][4]; static const int NUM_KEY_BTN = 12;
static const Event::Type SA_Key[2][12];
static const Event::Type SA_Axis[NUM_PORTS][NUM_JOY_AXIS];
static const Event::Type SA_Button[NUM_PORTS][NUM_JOY_BTN];
static const Event::Type SA_Key[NUM_PORTS][NUM_KEY_BTN];
}; };
#endif #endif

View File

@ -60,11 +60,11 @@ void PhysicalJoystick::initialize(int index, const string& desc,
numButtons = buttons; numButtons = buttons;
numHats = hats; numHats = hats;
if(numAxes) if(numAxes)
axisTable = new Event::Type[numAxes][2][kNumModes]; axisTable = new Event::Type[numAxes][NUM_JOY_DIRS][kNumModes];
if(numButtons) if(numButtons)
btnTable = new Event::Type[numButtons][kNumModes]; btnTable = new Event::Type[numButtons][kNumModes];
if(numHats) if(numHats)
hatTable = new Event::Type[numHats][4][kNumModes]; hatTable = new Event::Type[numHats][NUM_JOY_HAT_DIRS][kNumModes];
axisLastValue = new int[numAxes]; axisLastValue = new int[numAxes];
// Erase the joystick axis mapping array and last axis value // Erase the joystick axis mapping array and last axis value
@ -72,7 +72,8 @@ void PhysicalJoystick::initialize(int index, const string& desc,
{ {
axisLastValue[a] = 0; axisLastValue[a] = 0;
for(int m = 0; m < kNumModes; ++m) for(int m = 0; m < kNumModes; ++m)
axisTable[a][0][m] = axisTable[a][1][m] = Event::NoType; for (int d = 0; d < NUM_JOY_DIRS; ++d)
axisTable[a][d][m] = Event::NoType;
} }
// Erase the joystick button mapping array // Erase the joystick button mapping array
@ -83,8 +84,8 @@ void PhysicalJoystick::initialize(int index, const string& desc,
// Erase the joystick hat mapping array // Erase the joystick hat mapping array
for(int h = 0; h < numHats; ++h) for(int h = 0; h < numHats; ++h)
for(int m = 0; m < kNumModes; ++m) for(int m = 0; m < kNumModes; ++m)
hatTable[h][0][m] = hatTable[h][1][m] = for (int d = 0; d < NUM_JOY_HAT_DIRS; ++d)
hatTable[h][2][m] = hatTable[h][3][m] = Event::NoType; hatTable[h][d][m] = Event::NoType;
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
@ -99,8 +100,8 @@ string PhysicalJoystick::getMap() const
joybuf << name << "|" << numAxes; joybuf << name << "|" << numAxes;
for(int m = 0; m < kNumModes; ++m) for(int m = 0; m < kNumModes; ++m)
for(int a = 0; a < numAxes; ++a) for(int a = 0; a < numAxes; ++a)
for(int k = 0; k < 2; ++k) for (int d = 0; d < NUM_JOY_DIRS; ++d)
joybuf << " " << axisTable[a][k][m]; joybuf << " " << axisTable[a][d][m];
joybuf << "|" << numButtons; joybuf << "|" << numButtons;
for(int m = 0; m < kNumModes; ++m) for(int m = 0; m < kNumModes; ++m)
for(int b = 0; b < numButtons; ++b) for(int b = 0; b < numButtons; ++b)
@ -108,8 +109,8 @@ string PhysicalJoystick::getMap() const
joybuf << "|" << numHats; joybuf << "|" << numHats;
for(int m = 0; m < kNumModes; ++m) for(int m = 0; m < kNumModes; ++m)
for(int h = 0; h < numHats; ++h) for(int h = 0; h < numHats; ++h)
for(int k = 0; k < 4; ++k) for (int d = 0; d < NUM_JOY_HAT_DIRS; ++d)
joybuf << " " << hatTable[h][k][m]; joybuf << " " << hatTable[h][d][m];
return joybuf.str(); return joybuf.str();
} }
@ -133,15 +134,16 @@ bool PhysicalJoystick::setMap(const string& mapString)
// Parse axis/button/hat values // Parse axis/button/hat values
getValues(items[1], map); getValues(items[1], map);
if(int(map.size()) == numAxes * 2 * kNumModes) if(int(map.size()) == numAxes * NUM_JOY_DIRS * kNumModes)
{ {
// Fill the axes table with events // Fill the axes table with events
auto event = map.cbegin(); auto event = map.cbegin();
for(int m = 0; m < kNumModes; ++m) for(int m = 0; m < kNumModes; ++m)
for(int a = 0; a < numAxes; ++a) for(int a = 0; a < numAxes; ++a)
for(int k = 0; k < 2; ++k) for (int d = 0; d < NUM_JOY_DIRS; ++d)
axisTable[a][k][m] = Event::Type(*event++); axisTable[a][d][m] = Event::Type(*event++);
} }
getValues(items[2], map); getValues(items[2], map);
if(int(map.size()) == numButtons * kNumModes) if(int(map.size()) == numButtons * kNumModes)
{ {
@ -150,14 +152,15 @@ bool PhysicalJoystick::setMap(const string& mapString)
for(int b = 0; b < numButtons; ++b) for(int b = 0; b < numButtons; ++b)
btnTable[b][m] = Event::Type(*event++); btnTable[b][m] = Event::Type(*event++);
} }
getValues(items[3], map); getValues(items[3], map);
if(int(map.size()) == numHats * 4 * kNumModes) if(int(map.size()) == numHats * NUM_JOY_HAT_DIRS * kNumModes)
{ {
auto event = map.cbegin(); auto event = map.cbegin();
for(int m = 0; m < kNumModes; ++m) for(int m = 0; m < kNumModes; ++m)
for(int h = 0; h < numHats; ++h) for(int h = 0; h < numHats; ++h)
for(int k = 0; k < 4; ++k) for (int d = 0; d < NUM_JOY_HAT_DIRS; ++d)
hatTable[h][k][m] = Event::Type(*event++); hatTable[h][d][m] = Event::Type(*event++);
} }
return true; return true;
@ -168,7 +171,8 @@ void PhysicalJoystick::eraseMap(EventMode mode)
{ {
// Erase axis mappings // Erase axis mappings
for(int a = 0; a < numAxes; ++a) for(int a = 0; a < numAxes; ++a)
axisTable[a][0][mode] = axisTable[a][1][mode] = Event::NoType; for (int d = 0; d < NUM_JOY_DIRS; ++d)
axisTable[a][d][mode] = Event::NoType;
// Erase button mappings // Erase button mappings
for(int b = 0; b < numButtons; ++b) for(int b = 0; b < numButtons; ++b)
@ -176,8 +180,8 @@ void PhysicalJoystick::eraseMap(EventMode mode)
// Erase hat mappings // Erase hat mappings
for(int h = 0; h < numHats; ++h) for(int h = 0; h < numHats; ++h)
hatTable[h][0][mode] = hatTable[h][1][mode] = for (int d = 0; d < NUM_JOY_HAT_DIRS; ++d)
hatTable[h][2][mode] = hatTable[h][3][mode] = Event::NoType; hatTable[h][d][mode] = Event::NoType;
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
@ -185,23 +189,20 @@ void PhysicalJoystick::eraseEvent(Event::Type event, EventMode mode)
{ {
// Erase axis mappings // Erase axis mappings
for(int a = 0; a < numAxes; ++a) for(int a = 0; a < numAxes; ++a)
{ for (int d = 0; d < NUM_JOY_DIRS; ++d)
if(axisTable[a][0][mode] == event) axisTable[a][0][mode] = Event::NoType; if(axisTable[a][d][mode] == event)
if(axisTable[a][1][mode] == event) axisTable[a][1][mode] = Event::NoType; axisTable[a][d][mode] = Event::NoType;
}
// Erase button mappings // Erase button mappings
for(int b = 0; b < numButtons; ++b) for(int b = 0; b < numButtons; ++b)
if(btnTable[b][mode] == event) btnTable[b][mode] = Event::NoType; if(btnTable[b][mode] == event)
btnTable[b][mode] = Event::NoType;
// Erase hat mappings // Erase hat mappings
for(int h = 0; h < numHats; ++h) for(int h = 0; h < numHats; ++h)
{ for (int d = 0; d < NUM_JOY_HAT_DIRS; ++d)
if(hatTable[h][0][mode] == event) hatTable[h][0][mode] = Event::NoType; if(hatTable[h][d][mode] == event)
if(hatTable[h][1][mode] == event) hatTable[h][1][mode] = Event::NoType; hatTable[h][d][mode] = Event::NoType;
if(hatTable[h][2][mode] == event) hatTable[h][2][mode] = Event::NoType;
if(hatTable[h][3][mode] == event) hatTable[h][3][mode] = Event::NoType;
}
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

View File

@ -65,9 +65,9 @@ class PhysicalJoystick
int ID; int ID;
string name; string name;
int numAxes, numButtons, numHats; int numAxes, numButtons, numHats;
Event::Type (*axisTable)[2][kNumModes]; Event::Type (*axisTable)[NUM_JOY_DIRS][kNumModes];
Event::Type (*btnTable)[kNumModes]; Event::Type (*btnTable)[kNumModes];
Event::Type (*hatTable)[4][kNumModes]; Event::Type (*hatTable)[NUM_JOY_HAT_DIRS][kNumModes];
int* axisLastValue; int* axisLastValue;
private: private:

View File

@ -66,6 +66,11 @@ enum JoyHatMask {
EVENT_HATCENTER_M = 1<<4 EVENT_HATCENTER_M = 1<<4
}; };
static const int NUM_PORTS = 2;
static const int NUM_JOY_AXIS = 2;
static const int NUM_JOY_DIRS = 2;
static const int NUM_JOY_HAT_DIRS = 4;
// TODO - make this 'enum class' somehow // TODO - make this 'enum class' somehow
enum EventMode { enum EventMode {
kEmulationMode = 0, // make sure these are set correctly, kEmulationMode = 0, // make sure these are set correctly,