mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-10 08:09:26 +01:00
commit
012a4c18ff
@ -361,8 +361,13 @@ void EmuThread()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Keyboard::Initialize(s_window_handle);
|
bool init_controllers = false;
|
||||||
|
if (!g_controller_interface.IsInit())
|
||||||
|
{
|
||||||
Pad::Initialize(s_window_handle);
|
Pad::Initialize(s_window_handle);
|
||||||
|
Keyboard::Initialize(s_window_handle);
|
||||||
|
init_controllers = true;
|
||||||
|
}
|
||||||
|
|
||||||
// Load and Init Wiimotes - only if we are booting in Wii mode
|
// Load and Init Wiimotes - only if we are booting in Wii mode
|
||||||
if (core_parameter.bWii)
|
if (core_parameter.bWii)
|
||||||
@ -479,10 +484,13 @@ void EmuThread()
|
|||||||
HW::Shutdown();
|
HW::Shutdown();
|
||||||
INFO_LOG(CONSOLE, "%s", StopMessage(false, "HW shutdown").c_str());
|
INFO_LOG(CONSOLE, "%s", StopMessage(false, "HW shutdown").c_str());
|
||||||
|
|
||||||
|
if (init_controllers)
|
||||||
|
{
|
||||||
Wiimote::Shutdown();
|
Wiimote::Shutdown();
|
||||||
|
|
||||||
Keyboard::Shutdown();
|
Keyboard::Shutdown();
|
||||||
Pad::Shutdown();
|
Pad::Shutdown();
|
||||||
|
init_controllers = false;
|
||||||
|
}
|
||||||
|
|
||||||
g_video_backend->Shutdown();
|
g_video_backend->Shutdown();
|
||||||
AudioCommon::ShutdownSoundStream();
|
AudioCommon::ShutdownSoundStream();
|
||||||
|
@ -35,6 +35,7 @@ void Shutdown()
|
|||||||
// if plugin isn't initialized, init and load config
|
// if plugin isn't initialized, init and load config
|
||||||
void Initialize(void* const hwnd)
|
void Initialize(void* const hwnd)
|
||||||
{
|
{
|
||||||
|
if (s_config.controllers.empty())
|
||||||
for (unsigned int i = 0; i < 4; ++i)
|
for (unsigned int i = 0; i < 4; ++i)
|
||||||
s_config.controllers.push_back(new GCKeyboard(i));
|
s_config.controllers.push_back(new GCKeyboard(i));
|
||||||
|
|
||||||
|
@ -36,6 +36,7 @@ void Shutdown()
|
|||||||
void Initialize(void* const hwnd)
|
void Initialize(void* const hwnd)
|
||||||
{
|
{
|
||||||
// add 4 gcpads
|
// add 4 gcpads
|
||||||
|
if (s_config.controllers.empty())
|
||||||
for (unsigned int i = 0; i < 4; ++i)
|
for (unsigned int i = 0; i < 4; ++i)
|
||||||
s_config.controllers.push_back(new GCPad(i));
|
s_config.controllers.push_back(new GCPad(i));
|
||||||
|
|
||||||
|
@ -40,6 +40,7 @@ void Shutdown()
|
|||||||
void Initialize(void* const hwnd, bool wait)
|
void Initialize(void* const hwnd, bool wait)
|
||||||
{
|
{
|
||||||
// add 4 Wiimotes
|
// add 4 Wiimotes
|
||||||
|
if (s_config.controllers.empty())
|
||||||
for (unsigned int i = WIIMOTE_CHAN_0; i < MAX_BBMOTES; ++i)
|
for (unsigned int i = WIIMOTE_CHAN_0; i < MAX_BBMOTES; ++i)
|
||||||
s_config.controllers.push_back(new WiimoteEmu::Wiimote(i));
|
s_config.controllers.push_back(new WiimoteEmu::Wiimote(i));
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@ const std::string hotkey_labels[] =
|
|||||||
_trans("Change Disc"),
|
_trans("Change Disc"),
|
||||||
_trans("Refresh List"),
|
_trans("Refresh List"),
|
||||||
|
|
||||||
_trans("Play/Pause"),
|
_trans("Toggle Pause"),
|
||||||
_trans("Stop"),
|
_trans("Stop"),
|
||||||
_trans("Reset"),
|
_trans("Reset"),
|
||||||
_trans("Frame Advance"),
|
_trans("Frame Advance"),
|
||||||
@ -205,6 +205,7 @@ bool IsPressed(int Id, bool held)
|
|||||||
|
|
||||||
void Initialize(void* const hwnd)
|
void Initialize(void* const hwnd)
|
||||||
{
|
{
|
||||||
|
if (s_config.controllers.empty())
|
||||||
s_config.controllers.push_back(new HotkeyManager());
|
s_config.controllers.push_back(new HotkeyManager());
|
||||||
|
|
||||||
g_controller_interface.Initialize(hwnd);
|
g_controller_interface.Initialize(hwnd);
|
||||||
|
@ -50,6 +50,9 @@
|
|||||||
#include "Core/Movie.h"
|
#include "Core/Movie.h"
|
||||||
#include "Core/State.h"
|
#include "Core/State.h"
|
||||||
#include "Core/HW/DVDInterface.h"
|
#include "Core/HW/DVDInterface.h"
|
||||||
|
#include "Core/HW/GCKeyboard.h"
|
||||||
|
#include "Core/HW/GCPad.h"
|
||||||
|
#include "Core/HW/Wiimote.h"
|
||||||
|
|
||||||
#include "DolphinWX/Frame.h"
|
#include "DolphinWX/Frame.h"
|
||||||
#include "DolphinWX/GameListCtrl.h"
|
#include "DolphinWX/GameListCtrl.h"
|
||||||
@ -345,15 +348,21 @@ END_EVENT_TABLE()
|
|||||||
// Creation and close, quit functions
|
// Creation and close, quit functions
|
||||||
|
|
||||||
|
|
||||||
bool CFrame::InitHotkeys()
|
bool CFrame::InitControllers()
|
||||||
{
|
{
|
||||||
if (!g_controller_interface.IsInit())
|
if (!g_controller_interface.IsInit())
|
||||||
{
|
{
|
||||||
#if defined(HAVE_X11) && HAVE_X11
|
#if defined(HAVE_X11) && HAVE_X11
|
||||||
Window win = X11Utils::XWindowFromHandle(GetHandle());
|
Window win = X11Utils::XWindowFromHandle(GetHandle());
|
||||||
HotkeyManagerEmu::Initialize(reinterpret_cast<void*>(win));
|
HotkeyManagerEmu::Initialize(reinterpret_cast<void*>(win));
|
||||||
|
Pad::Initialize(reinterpret_cast<void*>(win));
|
||||||
|
Keyboard::Initialize(reinterpret_cast<void*>(win));
|
||||||
|
Wiimote::Initialize(reinterpret_cast<void*>(win));
|
||||||
#else
|
#else
|
||||||
HotkeyManagerEmu::Initialize(reinterpret_cast<void*>(GetHandle()));
|
HotkeyManagerEmu::Initialize(reinterpret_cast<void*>(GetHandle()));
|
||||||
|
Pad::Initialize(reinterpret_cast<void*>(GetHandle()));
|
||||||
|
Keyboard::Initialize(reinterpret_cast<void*>(GetHandle()));
|
||||||
|
Wiimote::Initialize(reinterpret_cast<void*>(GetHandle()));
|
||||||
#endif
|
#endif
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -497,7 +506,7 @@ CFrame::CFrame(wxFrame* parent,
|
|||||||
g_pCodeWindow->UpdateButtonStates();
|
g_pCodeWindow->UpdateButtonStates();
|
||||||
|
|
||||||
// check if game is running
|
// check if game is running
|
||||||
m_bHotkeysInit = InitHotkeys();
|
m_bHotkeysInit = InitControllers();
|
||||||
|
|
||||||
m_poll_hotkey_timer = new wxTimer(this);
|
m_poll_hotkey_timer = new wxTimer(this);
|
||||||
Bind(wxEVT_TIMER, &CFrame::PollHotkeys, this);
|
Bind(wxEVT_TIMER, &CFrame::PollHotkeys, this);
|
||||||
@ -510,7 +519,11 @@ CFrame::~CFrame()
|
|||||||
|
|
||||||
if (m_bHotkeysInit)
|
if (m_bHotkeysInit)
|
||||||
{
|
{
|
||||||
|
Wiimote::Shutdown();
|
||||||
|
Keyboard::Shutdown();
|
||||||
|
Pad::Shutdown();
|
||||||
HotkeyManagerEmu::Shutdown();
|
HotkeyManagerEmu::Shutdown();
|
||||||
|
m_bHotkeysInit = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
drives.clear();
|
drives.clear();
|
||||||
@ -938,6 +951,9 @@ void CFrame::OnGameListCtrl_ItemActivated(wxListEvent& WXUNUSED (event))
|
|||||||
|
|
||||||
static bool IsHotkey(wxKeyEvent &event, int Id, bool keyUp = false)
|
static bool IsHotkey(wxKeyEvent &event, int Id, bool keyUp = false)
|
||||||
{
|
{
|
||||||
|
if (Core::GetState() == Core::CORE_UNINITIALIZED)
|
||||||
|
return false;
|
||||||
|
|
||||||
// Input event hotkey
|
// Input event hotkey
|
||||||
if (event.GetKeyCode() == WXK_NONE)
|
if (event.GetKeyCode() == WXK_NONE)
|
||||||
{
|
{
|
||||||
@ -1261,7 +1277,7 @@ void CFrame::PollHotkeys(wxTimerEvent& event)
|
|||||||
{
|
{
|
||||||
if (Core::GetState() == Core::CORE_UNINITIALIZED || Core::GetState() == Core::CORE_PAUSE)
|
if (Core::GetState() == Core::CORE_UNINITIALIZED || Core::GetState() == Core::CORE_PAUSE)
|
||||||
{
|
{
|
||||||
InitHotkeys();
|
m_bHotkeysInit = InitControllers();
|
||||||
g_controller_interface.UpdateInput();
|
g_controller_interface.UpdateInput();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -346,7 +346,7 @@ private:
|
|||||||
void PollHotkeys(wxTimerEvent&);
|
void PollHotkeys(wxTimerEvent&);
|
||||||
void ParseHotkeys(wxKeyEvent &event);
|
void ParseHotkeys(wxKeyEvent &event);
|
||||||
|
|
||||||
bool InitHotkeys();
|
bool InitControllers();
|
||||||
|
|
||||||
// Event table
|
// Event table
|
||||||
DECLARE_EVENT_TABLE();
|
DECLARE_EVENT_TABLE();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user