mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-07-24 14:49:42 -06:00
Hotkeys: Fix duplicated called hotkeys.
This commit is contained in:
@ -1307,37 +1307,78 @@ void CFrame::PollHotkeys(wxTimerEvent& event)
|
|||||||
|
|
||||||
void CFrame::ParseHotkeys(wxKeyEvent &event)
|
void CFrame::ParseHotkeys(wxKeyEvent &event)
|
||||||
{
|
{
|
||||||
if (IsHotkey(event, HK_TOGGLE_THROTTLE, false))
|
|
||||||
{
|
|
||||||
Core::SetIsFramelimiterTempDisabled(false);
|
|
||||||
}
|
|
||||||
else if (IsHotkey(event, HK_TOGGLE_THROTTLE, true))
|
|
||||||
{
|
|
||||||
Core::SetIsFramelimiterTempDisabled(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned int i = 0;
|
unsigned int i = 0;
|
||||||
for (i = 0; i < NUM_HOTKEYS; i++)
|
for (i = 0; i < NUM_HOTKEYS; i++)
|
||||||
{
|
{
|
||||||
bool held = false;
|
switch (i)
|
||||||
if (i == HK_FRAME_ADVANCE)
|
|
||||||
held = true;
|
|
||||||
|
|
||||||
if (IsHotkey(event, i, held))
|
|
||||||
{
|
{
|
||||||
int cmd = GetCmdForHotkey(i);
|
case HK_OPEN:
|
||||||
if (cmd >= 0)
|
case HK_CHANGE_DISC:
|
||||||
{
|
case HK_REFRESH_LIST:
|
||||||
wxCommandEvent evt(wxEVT_MENU, cmd);
|
case HK_RESET:
|
||||||
wxMenuItem* item = GetMenuBar()->FindItem(cmd);
|
case HK_FRAME_ADVANCE:
|
||||||
if (item && item->IsCheckable())
|
case HK_START_RECORDING:
|
||||||
|
case HK_PLAY_RECORDING:
|
||||||
|
case HK_EXPORT_RECORDING:
|
||||||
|
case HK_READ_ONLY_MODE:
|
||||||
|
|
||||||
|
case HK_LOAD_STATE_SLOT_1:
|
||||||
|
case HK_LOAD_STATE_SLOT_2:
|
||||||
|
case HK_LOAD_STATE_SLOT_3:
|
||||||
|
case HK_LOAD_STATE_SLOT_4:
|
||||||
|
case HK_LOAD_STATE_SLOT_5:
|
||||||
|
case HK_LOAD_STATE_SLOT_6:
|
||||||
|
case HK_LOAD_STATE_SLOT_7:
|
||||||
|
case HK_LOAD_STATE_SLOT_8:
|
||||||
|
case HK_LOAD_STATE_SLOT_9:
|
||||||
|
case HK_LOAD_STATE_SLOT_10:
|
||||||
|
|
||||||
|
case HK_SAVE_STATE_SLOT_1:
|
||||||
|
case HK_SAVE_STATE_SLOT_2:
|
||||||
|
case HK_SAVE_STATE_SLOT_3:
|
||||||
|
case HK_SAVE_STATE_SLOT_4:
|
||||||
|
case HK_SAVE_STATE_SLOT_5:
|
||||||
|
case HK_SAVE_STATE_SLOT_6:
|
||||||
|
case HK_SAVE_STATE_SLOT_7:
|
||||||
|
case HK_SAVE_STATE_SLOT_8:
|
||||||
|
case HK_SAVE_STATE_SLOT_9:
|
||||||
|
case HK_SAVE_STATE_SLOT_10:
|
||||||
|
|
||||||
|
case HK_LOAD_LAST_STATE_1:
|
||||||
|
case HK_LOAD_LAST_STATE_2:
|
||||||
|
case HK_LOAD_LAST_STATE_3:
|
||||||
|
case HK_LOAD_LAST_STATE_4:
|
||||||
|
case HK_LOAD_LAST_STATE_5:
|
||||||
|
case HK_LOAD_LAST_STATE_6:
|
||||||
|
case HK_LOAD_LAST_STATE_7:
|
||||||
|
case HK_LOAD_LAST_STATE_8:
|
||||||
|
|
||||||
|
case HK_SAVE_FIRST_STATE:
|
||||||
|
case HK_UNDO_LOAD_STATE:
|
||||||
|
case HK_UNDO_SAVE_STATE:
|
||||||
|
case HK_LOAD_STATE_FILE:
|
||||||
|
case HK_SAVE_STATE_FILE:
|
||||||
|
|
||||||
|
case HK_LOAD_STATE_SLOT_SELECTED:
|
||||||
|
|
||||||
|
if (IsHotkey(event, i))
|
||||||
{
|
{
|
||||||
item->wxMenuItemBase::Toggle();
|
int cmd = GetCmdForHotkey(i);
|
||||||
evt.SetInt(item->IsChecked());
|
if (cmd >= 0)
|
||||||
|
{
|
||||||
|
wxCommandEvent evt(wxEVT_MENU, cmd);
|
||||||
|
wxMenuItem* item = GetMenuBar()->FindItem(cmd);
|
||||||
|
if (item && item->IsCheckable())
|
||||||
|
{
|
||||||
|
item->wxMenuItemBase::Toggle();
|
||||||
|
evt.SetInt(item->IsChecked());
|
||||||
|
}
|
||||||
|
GetEventHandler()->AddPendingEvent(evt);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
GetEventHandler()->AddPendingEvent(evt);
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
// do nothing
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// On OS X, we claim all keyboard events while
|
// On OS X, we claim all keyboard events while
|
||||||
@ -1358,7 +1399,6 @@ void CFrame::ParseHotkeys(wxKeyEvent &event)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
int WiimoteId = -1;
|
|
||||||
// Toggle fullscreen
|
// Toggle fullscreen
|
||||||
if (IsHotkey(event, HK_FULLSCREEN))
|
if (IsHotkey(event, HK_FULLSCREEN))
|
||||||
DoFullscreen(!RendererIsFullscreen());
|
DoFullscreen(!RendererIsFullscreen());
|
||||||
@ -1379,7 +1419,9 @@ void CFrame::ParseHotkeys(wxKeyEvent &event)
|
|||||||
AudioCommon::IncreaseVolume(3);
|
AudioCommon::IncreaseVolume(3);
|
||||||
if (IsHotkey(event, HK_VOLUME_TOGGLE_MUTE))
|
if (IsHotkey(event, HK_VOLUME_TOGGLE_MUTE))
|
||||||
AudioCommon::ToggleMuteVolume();
|
AudioCommon::ToggleMuteVolume();
|
||||||
|
|
||||||
// Wiimote connect and disconnect hotkeys
|
// Wiimote connect and disconnect hotkeys
|
||||||
|
int WiimoteId = -1;
|
||||||
if (IsHotkey(event, HK_WIIMOTE1_CONNECT))
|
if (IsHotkey(event, HK_WIIMOTE1_CONNECT))
|
||||||
WiimoteId = 0;
|
WiimoteId = 0;
|
||||||
if (IsHotkey(event, HK_WIIMOTE2_CONNECT))
|
if (IsHotkey(event, HK_WIIMOTE2_CONNECT))
|
||||||
@ -1390,6 +1432,15 @@ void CFrame::ParseHotkeys(wxKeyEvent &event)
|
|||||||
WiimoteId = 3;
|
WiimoteId = 3;
|
||||||
if (IsHotkey(event, HK_BALANCEBOARD_CONNECT))
|
if (IsHotkey(event, HK_BALANCEBOARD_CONNECT))
|
||||||
WiimoteId = 4;
|
WiimoteId = 4;
|
||||||
|
|
||||||
|
// Actually perform the Wiimote connection or disconnection
|
||||||
|
if (WiimoteId >= 0 && SConfig::GetInstance().m_LocalCoreStartupParameter.bWii)
|
||||||
|
{
|
||||||
|
wxCommandEvent evt;
|
||||||
|
evt.SetId(IDM_CONNECT_WIIMOTE1 + WiimoteId);
|
||||||
|
OnConnectWiimote(evt);
|
||||||
|
}
|
||||||
|
|
||||||
if (IsHotkey(event, HK_TOGGLE_IR))
|
if (IsHotkey(event, HK_TOGGLE_IR))
|
||||||
{
|
{
|
||||||
OSDChoice = 1;
|
OSDChoice = 1;
|
||||||
@ -1425,6 +1476,14 @@ void CFrame::ParseHotkeys(wxKeyEvent &event)
|
|||||||
OSDChoice = 4;
|
OSDChoice = 4;
|
||||||
g_Config.bDisableFog = !g_Config.bDisableFog;
|
g_Config.bDisableFog = !g_Config.bDisableFog;
|
||||||
}
|
}
|
||||||
|
if (IsHotkey(event, HK_TOGGLE_THROTTLE, false))
|
||||||
|
{
|
||||||
|
Core::SetIsFramelimiterTempDisabled(false);
|
||||||
|
}
|
||||||
|
else if (IsHotkey(event, HK_TOGGLE_THROTTLE, true))
|
||||||
|
{
|
||||||
|
Core::SetIsFramelimiterTempDisabled(true);
|
||||||
|
}
|
||||||
if (IsHotkey(event, HK_DECREASE_FRAME_LIMIT))
|
if (IsHotkey(event, HK_DECREASE_FRAME_LIMIT))
|
||||||
{
|
{
|
||||||
if (--SConfig::GetInstance().m_Framelimit > 0x19)
|
if (--SConfig::GetInstance().m_Framelimit > 0x19)
|
||||||
@ -1476,14 +1535,6 @@ void CFrame::ParseHotkeys(wxKeyEvent &event)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Actually perform the Wiimote connection or disconnection
|
|
||||||
if (WiimoteId >= 0 && SConfig::GetInstance().m_LocalCoreStartupParameter.bWii)
|
|
||||||
{
|
|
||||||
wxCommandEvent evt;
|
|
||||||
evt.SetId(IDM_CONNECT_WIIMOTE1 + WiimoteId);
|
|
||||||
OnConnectWiimote(evt);
|
|
||||||
}
|
|
||||||
|
|
||||||
static float debugSpeed = 1.0f;
|
static float debugSpeed = 1.0f;
|
||||||
if (IsHotkey(event, HK_FREELOOK_DECREASE_SPEED, true))
|
if (IsHotkey(event, HK_FREELOOK_DECREASE_SPEED, true))
|
||||||
debugSpeed /= 1.1f;
|
debugSpeed /= 1.1f;
|
||||||
|
Reference in New Issue
Block a user