Win32: Add and fix Autofire for D-pad (gocha)

This commit is contained in:
OV2 2011-01-14 00:09:35 +01:00
parent 63706037a5
commit 46bc2d4c5c
3 changed files with 59 additions and 43 deletions

View File

@ -865,38 +865,38 @@ void S9xWinScanJoypads ()
PadState[0] |= ToggleJoypadStorage[J].A||TurboToggleJoypadStorage[J].A ? 128 : 0; PadState[0] |= ToggleJoypadStorage[J].A||TurboToggleJoypadStorage[J].A ? 128 : 0;
PadState[1] = 0; PadState[1] = 0;
PadState[1] |= ToggleJoypadStorage[J].Right ? 1 : 0; PadState[1] |= ToggleJoypadStorage[J].Right||TurboToggleJoypadStorage[J].Right ? 1 : 0;
PadState[1] |= ToggleJoypadStorage[J].Left ? 2 : 0; PadState[1] |= ToggleJoypadStorage[J].Left||TurboToggleJoypadStorage[J].Left ? 2 : 0;
PadState[1] |= ToggleJoypadStorage[J].Down ? 4 : 0; PadState[1] |= ToggleJoypadStorage[J].Down||TurboToggleJoypadStorage[J].Down ? 4 : 0;
PadState[1] |= ToggleJoypadStorage[J].Up ? 8 : 0; PadState[1] |= ToggleJoypadStorage[J].Up||TurboToggleJoypadStorage[J].Up ? 8 : 0;
PadState[1] |= ToggleJoypadStorage[J].Start||TurboToggleJoypadStorage[J].Start ? 16 : 0; PadState[1] |= ToggleJoypadStorage[J].Start||TurboToggleJoypadStorage[J].Start ? 16 : 0;
PadState[1] |= ToggleJoypadStorage[J].Select||TurboToggleJoypadStorage[J].Select ? 32 : 0; PadState[1] |= ToggleJoypadStorage[J].Select||TurboToggleJoypadStorage[J].Select ? 32 : 0;
PadState[1] |= ToggleJoypadStorage[J].Y||TurboToggleJoypadStorage[J].Y ? 64 : 0; PadState[1] |= ToggleJoypadStorage[J].Y||TurboToggleJoypadStorage[J].Y ? 64 : 0;
PadState[1] |= ToggleJoypadStorage[J].B||TurboToggleJoypadStorage[J].B ? 128 : 0; PadState[1] |= ToggleJoypadStorage[J].B||TurboToggleJoypadStorage[J].B ? 128 : 0;
} }
// auto-hold AND regular key/joystick presses // auto-hold AND regular key/joystick presses
if(S9xGetState(Joypad[J+8].Left)) if(S9xGetState(Joypad[J+8].Autohold))
{ {
PadState[0] ^= (!S9xGetState(Joypad[J].R)||!S9xGetState(Joypad[J+8].R)) ? 16 : 0; PadState[0] ^= (!S9xGetState(Joypad[J].R)||!S9xGetState(Joypad[J+8].R)) ? 16 : 0;
PadState[0] ^= (!S9xGetState(Joypad[J].L)||!S9xGetState(Joypad[J+8].L)) ? 32 : 0; PadState[0] ^= (!S9xGetState(Joypad[J].L)||!S9xGetState(Joypad[J+8].L)) ? 32 : 0;
PadState[0] ^= (!S9xGetState(Joypad[J].X)||!S9xGetState(Joypad[J+8].X)) ? 64 : 0; PadState[0] ^= (!S9xGetState(Joypad[J].X)||!S9xGetState(Joypad[J+8].X)) ? 64 : 0;
PadState[0] ^= (!S9xGetState(Joypad[J].A)||!S9xGetState(Joypad[J+8].A)) ? 128 : 0; PadState[0] ^= (!S9xGetState(Joypad[J].A)||!S9xGetState(Joypad[J+8].A)) ? 128 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Right)) ? 1 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Right)) ? 1 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Right_Up)) ? 1 + 8 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Right_Up)) ? 1 + 8 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Right_Down)) ? 1 + 4 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Right_Down)) ? 1 + 4 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Left)) ? 2 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Left)) ? 2 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Left_Up)) ? 2 + 8 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Left_Up)) ? 2 + 8 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Left_Down)) ? 2 + 4 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Left_Down)) ? 2 + 4 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Down)) ? 4 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Down)) ? 4 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Up)) ? 8 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Up)) ? 8 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Start)||!S9xGetState(Joypad[J+8].Start)) ? 16 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Start)||!S9xGetState(Joypad[J+8].Start)) ? 16 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Select)||!S9xGetState(Joypad[J+8].Select)) ? 32 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Select)||!S9xGetState(Joypad[J+8].Select)) ? 32 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].Y)||!S9xGetState(Joypad[J+8].Y)) ? 64 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].Y)||!S9xGetState(Joypad[J+8].Y)) ? 64 : 0;
PadState[1] ^= (!S9xGetState(Joypad[J].B)||!S9xGetState(Joypad[J+8].B)) ? 128 : 0; PadState[1] ^= (!S9xGetState(Joypad[J].B)||!S9xGetState(Joypad[J+8].B)) ? 128 : 0;
} }
bool turbofy = !S9xGetState(Joypad[J+8].Up); // All Mod for turbo bool turbofy = !S9xGetState(Joypad[J+8].TempTurbo); // All Mod for turbo
//handle turbo case! (autofire / auto-fire) //handle turbo case! (autofire / auto-fire)
if(turbofy || ((GUI.TurboMask&TURBO_A_MASK))&&(PadState[0]&128) || !S9xGetState(Joypad[J+8].A )) PadState[0]^=(joypads[J]&128); if(turbofy || ((GUI.TurboMask&TURBO_A_MASK))&&(PadState[0]&128) || !S9xGetState(Joypad[J+8].A )) PadState[0]^=(joypads[J]&128);
@ -908,9 +908,9 @@ void S9xWinScanJoypads ()
if(turbofy || ((GUI.TurboMask&TURBO_STA_MASK))&&(PadState[1]&16) || !S9xGetState(Joypad[J+8].Start )) PadState[1]^=((joypads[J]&(16<<8))>>8); if(turbofy || ((GUI.TurboMask&TURBO_STA_MASK))&&(PadState[1]&16) || !S9xGetState(Joypad[J+8].Start )) PadState[1]^=((joypads[J]&(16<<8))>>8);
if(turbofy || ((GUI.TurboMask&TURBO_SEL_MASK))&&(PadState[1]&32) || !S9xGetState(Joypad[J+8].Select)) PadState[1]^=((joypads[J]&(32<<8))>>8); if(turbofy || ((GUI.TurboMask&TURBO_SEL_MASK))&&(PadState[1]&32) || !S9xGetState(Joypad[J+8].Select)) PadState[1]^=((joypads[J]&(32<<8))>>8);
if( ((GUI.TurboMask&TURBO_LEFT_MASK))&&(PadState[1]&2) ) PadState[1]^=((joypads[J]&(2<<8))>>8); if( ((GUI.TurboMask&TURBO_LEFT_MASK))&&(PadState[1]&2) ) PadState[1]^=((joypads[J]&(2<<8))>>8);
if( ((GUI.TurboMask&TURBO_UP_MASK))&&(PadState[1]&9) ) PadState[1]^=((joypads[J]&(8<<8))>>8); if( ((GUI.TurboMask&TURBO_UP_MASK))&&(PadState[1]&8) ) PadState[1]^=((joypads[J]&(8<<8))>>8);
if( ((GUI.TurboMask&TURBO_RIGHT_MASK))&&(PadState[1]&1) ) PadState[1]^=((joypads[J]&(1<<8))>>8); if( ((GUI.TurboMask&TURBO_RIGHT_MASK))&&(PadState[1]&1) ) PadState[1]^=((joypads[J]&(1<<8))>>8);
if( ((GUI.TurboMask&TURBO_RIGHT_MASK))&&(PadState[1]&4) ) PadState[1]^=((joypads[J]&(4<<8))>>8); if( ((GUI.TurboMask&TURBO_DOWN_MASK))&&(PadState[1]&4) ) PadState[1]^=((joypads[J]&(4<<8))>>8);
if(TurboToggleJoypadStorage[J].A ) PadState[0]^=(joypads[J]&128); if(TurboToggleJoypadStorage[J].A ) PadState[0]^=(joypads[J]&128);
if(TurboToggleJoypadStorage[J].B ) PadState[1]^=((joypads[J]&(128<<8))>>8); if(TurboToggleJoypadStorage[J].B ) PadState[1]^=((joypads[J]&(128<<8))>>8);
@ -920,6 +920,10 @@ void S9xWinScanJoypads ()
if(TurboToggleJoypadStorage[J].R ) PadState[0]^=(joypads[J]&16); if(TurboToggleJoypadStorage[J].R ) PadState[0]^=(joypads[J]&16);
if(TurboToggleJoypadStorage[J].Start ) PadState[1]^=((joypads[J]&(16<<8))>>8); if(TurboToggleJoypadStorage[J].Start ) PadState[1]^=((joypads[J]&(16<<8))>>8);
if(TurboToggleJoypadStorage[J].Select) PadState[1]^=((joypads[J]&(32<<8))>>8); if(TurboToggleJoypadStorage[J].Select) PadState[1]^=((joypads[J]&(32<<8))>>8);
if(TurboToggleJoypadStorage[J].Left ) PadState[1]^=((joypads[J]&(2<<8))>>8);
if(TurboToggleJoypadStorage[J].Up ) PadState[1]^=((joypads[J]&(8<<8))>>8);
if(TurboToggleJoypadStorage[J].Right ) PadState[1]^=((joypads[J]&(1<<8))>>8);
if(TurboToggleJoypadStorage[J].Down ) PadState[1]^=((joypads[J]&(4<<8))>>8);
//end turbo case... //end turbo case...

View File

@ -814,7 +814,7 @@ int HandleKeyMessage(WPARAM wParam, LPARAM lParam)
for (int J = 0; J < 5; J++) for (int J = 0; J < 5; J++)
{ {
extern bool S9xGetState (WORD KeyIdent); extern bool S9xGetState (WORD KeyIdent);
if(Joypad[J].Enabled && (!S9xGetState(Joypad[J+8].Left))) // enabled and Togglify if(Joypad[J].Enabled && (!S9xGetState(Joypad[J+8].Autohold))) // enabled and Togglify
{ {
SJoypad & p = ToggleJoypadStorage[J]; SJoypad & p = ToggleJoypadStorage[J];
if(wParam == Joypad[J].L) p.L = !p.L; if(wParam == Joypad[J].L) p.L = !p.L;
@ -829,10 +829,10 @@ int HandleKeyMessage(WPARAM wParam, LPARAM lParam)
if(wParam == Joypad[J].Right) p.Right = !p.Right; if(wParam == Joypad[J].Right) p.Right = !p.Right;
if(wParam == Joypad[J].Up) p.Up = !p.Up; if(wParam == Joypad[J].Up) p.Up = !p.Up;
if(wParam == Joypad[J].Down) p.Down = !p.Down; if(wParam == Joypad[J].Down) p.Down = !p.Down;
/// if(wParam == Joypad[J].Left_Down) p.Left_Down = !p.Left_Down; // if(wParam == Joypad[J].Left_Down) p.Left_Down = !p.Left_Down;
/// if(wParam == Joypad[J].Left_Up) p.Left_Up = !p.Left_Up; // if(wParam == Joypad[J].Left_Up) p.Left_Up = !p.Left_Up;
/// if(wParam == Joypad[J].Right_Down) p.Right_Down = !p.Right_Down; // if(wParam == Joypad[J].Right_Down) p.Right_Down = !p.Right_Down;
/// if(wParam == Joypad[J].Right_Up) p.Right_Up = !p.Right_Up; // if(wParam == Joypad[J].Right_Up) p.Right_Up = !p.Right_Up;
if(!Settings.UpAndDown) if(!Settings.UpAndDown)
{ {
if(p.Left && p.Right) if(p.Left && p.Right)
@ -841,7 +841,7 @@ int HandleKeyMessage(WPARAM wParam, LPARAM lParam)
p.Up = p.Down = false; p.Up = p.Down = false;
} }
} }
if(Joypad[J].Enabled && (!S9xGetState(Joypad[J+8].Down))) // enabled and turbo-togglify (TurboTog) if(Joypad[J].Enabled && (!S9xGetState(Joypad[J+8].Autofire))) // enabled and turbo-togglify (TurboTog)
{ {
SJoypad & p = TurboToggleJoypadStorage[J]; SJoypad & p = TurboToggleJoypadStorage[J];
if(wParam == Joypad[J].L) p.L = !p.L; if(wParam == Joypad[J].L) p.L = !p.L;
@ -852,23 +852,23 @@ int HandleKeyMessage(WPARAM wParam, LPARAM lParam)
if(wParam == Joypad[J].X) p.X = !p.X; if(wParam == Joypad[J].X) p.X = !p.X;
if(wParam == Joypad[J].Start) p.Start = !p.Start; if(wParam == Joypad[J].Start) p.Start = !p.Start;
if(wParam == Joypad[J].Select) p.Select = !p.Select; if(wParam == Joypad[J].Select) p.Select = !p.Select;
/// if(wParam == Joypad[J].Left) p.Left = !p.Left; if(wParam == Joypad[J].Left) p.Left = !p.Left;
/// if(wParam == Joypad[J].Right) p.Right = !p.Right; if(wParam == Joypad[J].Right) p.Right = !p.Right;
/// if(wParam == Joypad[J].Up) p.Up = !p.Up; if(wParam == Joypad[J].Up) p.Up = !p.Up;
/// if(wParam == Joypad[J].Down) p.Down = !p.Down; if(wParam == Joypad[J].Down) p.Down = !p.Down;
/// if(wParam == Joypad[J].Left_Down) p.Left_Down = !p.Left_Down; // if(wParam == Joypad[J].Left_Down) p.Left_Down = !p.Left_Down;
/// if(wParam == Joypad[J].Left_Up) p.Left_Up = !p.Left_Up; // if(wParam == Joypad[J].Left_Up) p.Left_Up = !p.Left_Up;
/// if(wParam == Joypad[J].Right_Down) p.Right_Down = !p.Right_Down; // if(wParam == Joypad[J].Right_Down) p.Right_Down = !p.Right_Down;
/// if(wParam == Joypad[J].Right_Up) p.Right_Up = !p.Right_Up; // if(wParam == Joypad[J].Right_Up) p.Right_Up = !p.Right_Up;
/* if(!Settings.UpAndDown) if(!Settings.UpAndDown)
{ {
if(p.Left && p.Right && ) if(p.Left && p.Right)
p.Left = p.Right = false; p.Left = p.Right = false;
if(p.Up && p.Down) if(p.Up && p.Down)
p.Up = p.Down = false; p.Up = p.Down = false;
}*/ }
} }
if(wParam == Joypad[J+8].Right) // clear all if(wParam == Joypad[J+8].ClearAll) // clear all
{ {
{ {
SJoypad & p = ToggleJoypadStorage[J]; SJoypad & p = ToggleJoypadStorage[J];

View File

@ -464,10 +464,22 @@ struct SCustomKeys {
struct SJoypad { struct SJoypad {
BOOL Enabled; BOOL Enabled;
WORD Left; union {
WORD Right; WORD Left;
WORD Up; WORD Autohold;
WORD Down; };
union {
WORD Right;
WORD ClearAll;
};
union {
WORD Up;
WORD TempTurbo;
};
union {
WORD Down;
WORD Autofire;
};
WORD Left_Up; WORD Left_Up;
WORD Left_Down; WORD Left_Down;
WORD Right_Up; WORD Right_Up;