mirror of https://github.com/snes9xgit/snes9x.git
Restore Mac function buttons
This commit is contained in:
parent
6fcfe8c3f8
commit
ece780059e
415
macosx/mac-os.mm
415
macosx/mac-os.mm
|
@ -174,8 +174,60 @@ CFStringRef multiCartPath[2];
|
||||||
IconRef macIconRef[118];
|
IconRef macIconRef[118];
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
ToggleBG0,
|
||||||
|
ToggleBG1,
|
||||||
|
ToggleBG2,
|
||||||
|
ToggleBG3,
|
||||||
|
ToggleSprites,
|
||||||
|
SwapJoypads,
|
||||||
|
SoundChannel0,
|
||||||
|
SoundChannel1,
|
||||||
|
SoundChannel2,
|
||||||
|
SoundChannel3,
|
||||||
|
SoundChannel4,
|
||||||
|
SoundChannel5,
|
||||||
|
SoundChannel6,
|
||||||
|
SoundChannel7,
|
||||||
|
SoundChannelsOn,
|
||||||
|
ToggleDisplayPressedKeys,
|
||||||
|
ToggleDisplayMovieFrame,
|
||||||
|
IncreaseFrameAdvanceRate,
|
||||||
|
DecreaseFrameAdvanceRate,
|
||||||
|
ToggleEmulationPause,
|
||||||
|
AdvanceFrame,
|
||||||
|
kNumFunctionButtons
|
||||||
|
} S9xFunctionButtonCommand;
|
||||||
|
|
||||||
|
uint8 functionButtons[kNumFunctionButtons] = {
|
||||||
|
kVK_F1,
|
||||||
|
kVK_F2,
|
||||||
|
kVK_F3,
|
||||||
|
kVK_F4,
|
||||||
|
kVK_F5,
|
||||||
|
kVK_F6,
|
||||||
|
kVK_ANSI_1,
|
||||||
|
kVK_ANSI_2,
|
||||||
|
kVK_ANSI_3,
|
||||||
|
kVK_ANSI_4,
|
||||||
|
kVK_ANSI_5,
|
||||||
|
kVK_ANSI_6,
|
||||||
|
kVK_ANSI_7,
|
||||||
|
kVK_ANSI_8,
|
||||||
|
kVK_ANSI_9,
|
||||||
|
kVK_ANSI_0,
|
||||||
|
kVK_ANSI_Minus,
|
||||||
|
kVK_ANSI_Q,
|
||||||
|
kVK_ANSI_W,
|
||||||
|
kVK_ANSI_O,
|
||||||
|
kVK_ANSI_P
|
||||||
|
};
|
||||||
|
|
||||||
bool8 pressedKeys[MAC_MAX_PLAYERS][kNumButtons] = { 0 };
|
bool8 pressedKeys[MAC_MAX_PLAYERS][kNumButtons] = { 0 };
|
||||||
bool8 pressedGamepadButtons[MAC_MAX_PLAYERS][kNumButtons] = { 0 };
|
bool8 pressedGamepadButtons[MAC_MAX_PLAYERS][kNumButtons] = { 0 };
|
||||||
|
bool8 pressedFunctionButtons[kNumFunctionButtons] = { 0 };
|
||||||
|
bool8 heldFunctionButtons[kNumFunctionButtons] = { 0 };
|
||||||
os_unfair_lock keyLock;
|
os_unfair_lock keyLock;
|
||||||
os_unfair_lock renderLock;
|
os_unfair_lock renderLock;
|
||||||
|
|
||||||
|
@ -244,43 +296,6 @@ enum
|
||||||
mRecentItem = 203
|
mRecentItem = 203
|
||||||
};
|
};
|
||||||
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
kmF1Key = 0x7A,
|
|
||||||
kmF2Key = 0x78,
|
|
||||||
kmF3Key = 0x63,
|
|
||||||
kmF4Key = 0x76,
|
|
||||||
kmF5Key = 0x60,
|
|
||||||
kmF6Key = 0x61,
|
|
||||||
km0Key = 0x1D,
|
|
||||||
km1Key = 0x12,
|
|
||||||
km2Key = 0x13,
|
|
||||||
km3Key = 0x14,
|
|
||||||
km4Key = 0x15,
|
|
||||||
km5Key = 0x17,
|
|
||||||
km6Key = 0x16,
|
|
||||||
km7Key = 0x1A,
|
|
||||||
km8Key = 0x1C,
|
|
||||||
km9Key = 0x19,
|
|
||||||
kmAKey = 0x00,
|
|
||||||
kmBKey = 0x0B,
|
|
||||||
kmCKey = 0x08,
|
|
||||||
kmEscKey = 0x35,
|
|
||||||
kmCtrKey = 0x3B,
|
|
||||||
kmMinusKey = 0x1B,
|
|
||||||
kmQKey = 0x0C,
|
|
||||||
kmWKey = 0x0D,
|
|
||||||
kmOKey = 0x1F,
|
|
||||||
kmPKey = 0x23
|
|
||||||
};
|
|
||||||
|
|
||||||
struct ButtonCommand
|
|
||||||
{
|
|
||||||
char command[16];
|
|
||||||
uint8 keycode;
|
|
||||||
bool8 held;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GameViewInfo
|
struct GameViewInfo
|
||||||
{
|
{
|
||||||
int globalLeft;
|
int globalLeft;
|
||||||
|
@ -302,33 +317,6 @@ static uint16 changeAuto[2] = { 0x0000, 0x0000 };
|
||||||
|
|
||||||
static GameViewInfo scopeViewInfo;
|
static GameViewInfo scopeViewInfo;
|
||||||
|
|
||||||
static ButtonCommand btncmd[] =
|
|
||||||
{
|
|
||||||
{ "ToggleBG0", kmF1Key, false },
|
|
||||||
{ "ToggleBG1", kmF2Key, false },
|
|
||||||
{ "ToggleBG2", kmF3Key, false },
|
|
||||||
{ "ToggleBG3", kmF4Key, false },
|
|
||||||
{ "ToggleSprites", kmF5Key, false },
|
|
||||||
{ "SwapJoypads", kmF6Key, false },
|
|
||||||
{ "SoundChannel0", km1Key, false },
|
|
||||||
{ "SoundChannel1", km2Key, false },
|
|
||||||
{ "SoundChannel2", km3Key, false },
|
|
||||||
{ "SoundChannel3", km4Key, false },
|
|
||||||
{ "SoundChannel4", km5Key, false },
|
|
||||||
{ "SoundChannel5", km6Key, false },
|
|
||||||
{ "SoundChannel6", km7Key, false },
|
|
||||||
{ "SoundChannel7", km8Key, false },
|
|
||||||
{ "SoundChannelsOn", km9Key, false },
|
|
||||||
{ "_mac1", km0Key, false },
|
|
||||||
{ "_mac2", kmMinusKey, false },
|
|
||||||
{ "_mac3", kmQKey, false },
|
|
||||||
{ "_mac4", kmWKey, false },
|
|
||||||
{ "_mac5", kmOKey, false },
|
|
||||||
{ "_mac6", kmPKey, false }
|
|
||||||
};
|
|
||||||
|
|
||||||
#define kCommandListSize (sizeof(btncmd) / sizeof(btncmd[0]))
|
|
||||||
|
|
||||||
static void Initialize (void);
|
static void Initialize (void);
|
||||||
static void Deinitialize (void);
|
static void Deinitialize (void);
|
||||||
static void InitAutofire (void);
|
static void InitAutofire (void);
|
||||||
|
@ -2113,148 +2101,148 @@ static void ProcessInput (void)
|
||||||
|
|
||||||
CopyPressedKeys(keys, gamepadButtons);
|
CopyPressedKeys(keys, gamepadButtons);
|
||||||
|
|
||||||
if (ISpKeyIsPressed(keys, gamepadButtons, kISpEsc))
|
|
||||||
{
|
|
||||||
pauseEmulation = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ISpKeyIsPressed(keys, gamepadButtons, kISpFreeze))
|
|
||||||
{
|
|
||||||
MacStopSound();
|
|
||||||
while (ISpKeyIsPressed(keys, gamepadButtons, kISpFreeze))
|
|
||||||
CopyPressedKeys(keys, gamepadButtons);
|
|
||||||
|
|
||||||
isok = SNES9X_Freeze();
|
|
||||||
os_unfair_lock_lock(&renderLock);
|
|
||||||
ClearGFXScreen();
|
|
||||||
os_unfair_lock_unlock(&renderLock);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ISpKeyIsPressed(keys, gamepadButtons, kISpDefrost))
|
|
||||||
{
|
|
||||||
MacStopSound();
|
|
||||||
while (ISpKeyIsPressed(keys, gamepadButtons, kISpDefrost))
|
|
||||||
CopyPressedKeys(keys, gamepadButtons);
|
|
||||||
|
|
||||||
isok = SNES9X_Defrost();
|
|
||||||
os_unfair_lock_lock(&renderLock);
|
|
||||||
ClearGFXScreen();
|
|
||||||
os_unfair_lock_unlock(&renderLock);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ISpKeyIsPressed(keys, gamepadButtons, kISpScreenshot))
|
|
||||||
{
|
|
||||||
Settings.TakeScreenshot = true;
|
|
||||||
while (ISpKeyIsPressed(keys, gamepadButtons, kISpScreenshot))
|
|
||||||
CopyPressedKeys(keys, gamepadButtons);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ISpKeyIsPressed(keys, gamepadButtons, kISpSPC))
|
|
||||||
{
|
|
||||||
S9xDumpSPCSnapshot();
|
|
||||||
while (ISpKeyIsPressed(keys, gamepadButtons, kISpSPC))
|
|
||||||
CopyPressedKeys(keys, gamepadButtons);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ISpKeyIsPressed(keys, gamepadButtons, kISpFFUp))
|
|
||||||
{
|
|
||||||
if (!ffUpSp)
|
|
||||||
{
|
|
||||||
ChangeTurboRate(+1);
|
|
||||||
ffUpSp = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
ffUpSp = false;
|
|
||||||
|
|
||||||
if (ISpKeyIsPressed(keys, gamepadButtons, kISpFFDown))
|
|
||||||
{
|
|
||||||
if (!ffDownSp)
|
|
||||||
{
|
|
||||||
ChangeTurboRate(-1);
|
|
||||||
ffDownSp = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
ffDownSp = false;
|
|
||||||
|
|
||||||
fnbtn = ISpKeyIsPressed(keys, gamepadButtons, kISpFunction);
|
fnbtn = ISpKeyIsPressed(keys, gamepadButtons, kISpFunction);
|
||||||
altbtn = ISpKeyIsPressed(keys, gamepadButtons, kISpAlt);
|
altbtn = ISpKeyIsPressed(keys, gamepadButtons, kISpAlt);
|
||||||
|
|
||||||
// if (fnbtn)
|
if (fnbtn)
|
||||||
// {
|
{
|
||||||
// if (!lastTimeFn)
|
if (!lastTimeFn)
|
||||||
// {
|
{
|
||||||
// for (unsigned int i = 0; i < kCommandListSize; i++)
|
memset(heldFunctionButtons, 0, kNumFunctionButtons);
|
||||||
// btncmd[i].held = false;
|
}
|
||||||
// }
|
|
||||||
//
|
lastTimeFn = true;
|
||||||
// lastTimeFn = true;
|
lastTimeTT = false;
|
||||||
// lastTimeTT = false;
|
ffUp = ffDown = false;
|
||||||
// ffUp = ffDown = false;
|
|
||||||
//
|
for (unsigned int i = 0; i < kNumFunctionButtons; i++)
|
||||||
// for (unsigned int i = 0; i < kCommandListSize; i++)
|
{
|
||||||
// {
|
if (pressedFunctionButtons[i])
|
||||||
// if (KeyIsPressed(keys, btncmd[i].keycode))
|
{
|
||||||
// {
|
if (!heldFunctionButtons[i])
|
||||||
// if (!(btncmd[i].held))
|
{
|
||||||
// {
|
s9xcommand_t s9xcmd;
|
||||||
// btncmd[i].held = true;
|
static char msg[64];
|
||||||
//
|
|
||||||
// if (strncmp(btncmd[i].command, "_mac", 4) == 0)
|
heldFunctionButtons[i] = true;
|
||||||
// {
|
|
||||||
// static char msg[64];
|
switch ((S9xFunctionButtonCommand) i)
|
||||||
//
|
{
|
||||||
// switch (btncmd[i].command[4] - '0')
|
case ToggleBG0:
|
||||||
// {
|
s9xcmd = S9xGetCommandT("ToggleBG0");
|
||||||
// case 1:
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
// Settings.DisplayPressedKeys = !Settings.DisplayPressedKeys;
|
break;
|
||||||
// break;
|
|
||||||
//
|
case ToggleBG1:
|
||||||
// case 2:
|
s9xcmd = S9xGetCommandT("ToggleBG1");
|
||||||
// if (S9xMovieActive())
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
// Settings.DisplayMovieFrame = !Settings.DisplayMovieFrame;
|
break;
|
||||||
// break;
|
|
||||||
//
|
case ToggleBG2:
|
||||||
// case 3:
|
s9xcmd = S9xGetCommandT("ToggleBG2");
|
||||||
// if (macFrameAdvanceRate < 5000000)
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
// macFrameAdvanceRate += 100000;
|
break;
|
||||||
// sprintf(msg, "Emulation Speed: 100/%d", macFrameAdvanceRate / 10000);
|
|
||||||
// S9xSetInfoString(msg);
|
case ToggleBG3:
|
||||||
// break;
|
s9xcmd = S9xGetCommandT("ToggleBG3");
|
||||||
//
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
// case 4:
|
break;
|
||||||
// if (macFrameAdvanceRate > 500000)
|
|
||||||
// macFrameAdvanceRate -= 100000;
|
case ToggleSprites:
|
||||||
// sprintf(msg, "Emulation Speed: 100/%d", macFrameAdvanceRate / 10000);
|
s9xcmd = S9xGetCommandT("ToggleSprites");
|
||||||
// S9xSetInfoString(msg);
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
// break;
|
break;
|
||||||
//
|
|
||||||
// case 5:
|
case SwapJoypads:
|
||||||
// pauseEmulation = !pauseEmulation;
|
s9xcmd = S9xGetCommandT("SwapJoypads");
|
||||||
// break;
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
//
|
break;
|
||||||
// case 6:
|
|
||||||
// frameAdvance = true;
|
case SoundChannel0:
|
||||||
// break;
|
s9xcmd = S9xGetCommandT("SoundChannel0");
|
||||||
// }
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
// }
|
break;
|
||||||
// else
|
|
||||||
// {
|
case SoundChannel1:
|
||||||
// s9xcommand_t s9xcmd;
|
s9xcmd = S9xGetCommandT("SoundChannel1");
|
||||||
//
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
// s9xcmd = S9xGetCommandT(btncmd[i].command);
|
break;
|
||||||
// S9xApplyCommand(s9xcmd, 1, 0);
|
|
||||||
// }
|
case SoundChannel2:
|
||||||
// }
|
s9xcmd = S9xGetCommandT("SoundChannel2");
|
||||||
// }
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
// else
|
break;
|
||||||
// btncmd[i].held = false;
|
|
||||||
// }
|
case SoundChannel3:
|
||||||
// }
|
s9xcmd = S9xGetCommandT("SoundChannel3");
|
||||||
// else
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SoundChannel4:
|
||||||
|
s9xcmd = S9xGetCommandT("SoundChannel4");
|
||||||
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SoundChannel5:
|
||||||
|
s9xcmd = S9xGetCommandT("SoundChannel5");
|
||||||
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SoundChannel6:
|
||||||
|
s9xcmd = S9xGetCommandT("SoundChannel6");
|
||||||
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SoundChannel7:
|
||||||
|
s9xcmd = S9xGetCommandT("SoundChannel7");
|
||||||
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SoundChannelsOn:
|
||||||
|
s9xcmd = S9xGetCommandT("SoundChannelsOn");
|
||||||
|
S9xApplyCommand(s9xcmd, 1, 0);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ToggleDisplayPressedKeys:
|
||||||
|
Settings.DisplayPressedKeys = !Settings.DisplayPressedKeys;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ToggleDisplayMovieFrame:
|
||||||
|
if (S9xMovieActive())
|
||||||
|
Settings.DisplayMovieFrame = !Settings.DisplayMovieFrame;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case IncreaseFrameAdvanceRate:
|
||||||
|
if (macFrameAdvanceRate < 5000000)
|
||||||
|
macFrameAdvanceRate += 100000;
|
||||||
|
sprintf(msg, "Emulation Speed: 100/%d", macFrameAdvanceRate / 10000);
|
||||||
|
S9xSetInfoString(msg);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case DecreaseFrameAdvanceRate:
|
||||||
|
if (macFrameAdvanceRate > 500000)
|
||||||
|
macFrameAdvanceRate -= 100000;
|
||||||
|
sprintf(msg, "Emulation Speed: 100/%d", macFrameAdvanceRate / 10000);
|
||||||
|
S9xSetInfoString(msg);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ToggleEmulationPause:
|
||||||
|
pauseEmulation = !pauseEmulation;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case AdvanceFrame:
|
||||||
|
frameAdvance = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kNumFunctionButtons:
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
lastTimeFn = false;
|
lastTimeFn = false;
|
||||||
|
|
||||||
|
@ -2871,6 +2859,16 @@ void QuitWithFatalError ( NSString *message)
|
||||||
{
|
{
|
||||||
pressedKeys[button.player][button.buttonCode] = true;
|
pressedKeys[button.player][button.buttonCode] = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for ( NSUInteger i = 0; i < kNumFunctionButtons; ++i )
|
||||||
|
{
|
||||||
|
if ( event.keyCode == functionButtons[i])
|
||||||
|
{
|
||||||
|
pressedFunctionButtons[i] = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
os_unfair_lock_unlock(&keyLock);
|
os_unfair_lock_unlock(&keyLock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2882,6 +2880,17 @@ void QuitWithFatalError ( NSString *message)
|
||||||
{
|
{
|
||||||
pressedKeys[button.player][button.buttonCode] = false;
|
pressedKeys[button.player][button.buttonCode] = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for ( NSUInteger i = 0; i < kNumFunctionButtons; ++i )
|
||||||
|
{
|
||||||
|
if ( event.keyCode == functionButtons[i])
|
||||||
|
{
|
||||||
|
pressedFunctionButtons[i] = false;
|
||||||
|
heldFunctionButtons[i] = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
os_unfair_lock_unlock(&keyLock);
|
os_unfair_lock_unlock(&keyLock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue