Merge pull request #7519 from stenzek/controller-window

Core: Switch controller interface to render surface on booting
This commit is contained in:
Pierre Bourdon 2018-11-12 17:26:03 +01:00 committed by GitHub
commit 97e3200f57
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 63 additions and 19 deletions

View File

@ -456,10 +456,14 @@ static void EmuThread(std::unique_ptr<BootParameters> boot, WindowSystemInfo wsi
return; return;
} }
// The frontend will likely have initialized the controller interface, as it needs
// it to provide the configuration dialogs. In this case, instead of re-initializing
// entirely, we switch the window used for inputs to the render window. This way, the
// cursor position is relative to the render window, instead of the main window.
bool init_controllers = false; bool init_controllers = false;
if (!g_controller_interface.IsInit()) if (!g_controller_interface.IsInit())
{ {
g_controller_interface.Initialize(wsi.render_surface); g_controller_interface.Initialize(wsi);
Pad::Initialize(); Pad::Initialize();
Keyboard::Initialize(); Keyboard::Initialize();
init_controllers = true; init_controllers = true;
@ -467,6 +471,7 @@ static void EmuThread(std::unique_ptr<BootParameters> boot, WindowSystemInfo wsi
else else
{ {
// Update references in case controllers were refreshed // Update references in case controllers were refreshed
g_controller_interface.ChangeWindow(wsi.render_surface);
Pad::LoadConfig(); Pad::LoadConfig();
Keyboard::LoadConfig(); Keyboard::LoadConfig();
} }

View File

@ -19,6 +19,8 @@
#include "DolphinQt/QtUtils/QueueOnObject.h" #include "DolphinQt/QtUtils/QueueOnObject.h"
#include "DolphinQt/Settings.h" #include "DolphinQt/Settings.h"
#include "InputCommon/ControllerInterface/ControllerInterface.h"
#include "VideoCommon/RenderBase.h" #include "VideoCommon/RenderBase.h"
#include "VideoCommon/VideoConfig.h" #include "VideoCommon/VideoConfig.h"
@ -32,8 +34,16 @@ Host* Host::GetInstance()
void Host::SetRenderHandle(void* handle) void Host::SetRenderHandle(void* handle)
{ {
if (m_render_handle == handle)
return;
m_render_handle = handle;
if (g_renderer) if (g_renderer)
{
g_renderer->ChangeSurface(handle); g_renderer->ChangeSurface(handle);
if (g_controller_interface.IsInit())
g_controller_interface.ChangeWindow(handle);
}
} }
bool Host::GetRenderFocus() bool Host::GetRenderFocus()

View File

@ -169,6 +169,7 @@ MainWindow::MainWindow(std::unique_ptr<BootParameters> boot_parameters) : QMainW
setWindowIcon(Resources::GetAppIcon()); setWindowIcon(Resources::GetAppIcon());
setUnifiedTitleAndToolBarOnMac(true); setUnifiedTitleAndToolBarOnMac(true);
setAcceptDrops(true); setAcceptDrops(true);
setAttribute(Qt::WA_NativeWindow);
InitControllers(); InitControllers();
@ -237,7 +238,7 @@ void MainWindow::InitControllers()
if (g_controller_interface.IsInit()) if (g_controller_interface.IsInit())
return; return;
g_controller_interface.Initialize(reinterpret_cast<void*>(winId())); g_controller_interface.Initialize(GetWindowSystemInfo(windowHandle()));
Pad::Initialize(); Pad::Initialize();
Keyboard::Initialize(); Keyboard::Initialize();
Wiimote::Initialize(Wiimote::InitializeMode::DO_NOT_WAIT_FOR_WIIMOTES); Wiimote::Initialize(Wiimote::InitializeMode::DO_NOT_WAIT_FOR_WIIMOTES);
@ -874,6 +875,7 @@ void MainWindow::SetFullScreenResolution(bool fullscreen)
// Try To Set Selected Mode And Get Results. NOTE: CDS_FULLSCREEN Gets Rid Of Start Bar. // Try To Set Selected Mode And Get Results. NOTE: CDS_FULLSCREEN Gets Rid Of Start Bar.
ChangeDisplaySettings(&screen_settings, CDS_FULLSCREEN); ChangeDisplaySettings(&screen_settings, CDS_FULLSCREEN);
#elif defined(HAVE_XRANDR) && HAVE_XRANDR #elif defined(HAVE_XRANDR) && HAVE_XRANDR
if (m_xrr_config)
m_xrr_config->ToggleDisplayMode(fullscreen); m_xrr_config->ToggleDisplayMode(fullscreen);
#endif #endif
} }
@ -938,6 +940,11 @@ void MainWindow::HideRenderWidget(bool reinit)
if (m_render_widget->isFullScreen()) if (m_render_widget->isFullScreen())
SetFullScreenResolution(focus); SetFullScreenResolution(focus);
}); });
// The controller interface will still be registered to the old render widget, if the core
// has booted. Therefore, we should re-bind it to the main window for now. When the core
// is next started, it will be swapped back to the new render widget.
g_controller_interface.ChangeWindow(GetWindowSystemInfo(windowHandle()).render_surface);
} }
} }
@ -1003,14 +1010,18 @@ void MainWindow::ShowGraphicsWindow()
if (!m_graphics_window) if (!m_graphics_window)
{ {
#if defined(HAVE_XRANDR) && HAVE_XRANDR #if defined(HAVE_XRANDR) && HAVE_XRANDR
if (GetWindowSystemType() == WindowSystemType::X11)
{
m_xrr_config = std::make_unique<X11Utils::XRRConfiguration>( m_xrr_config = std::make_unique<X11Utils::XRRConfiguration>(
static_cast<Display*>(QGuiApplication::platformNativeInterface()->nativeResourceForWindow( static_cast<Display*>(QGuiApplication::platformNativeInterface()->nativeResourceForWindow(
"display", windowHandle())), "display", windowHandle())),
winId()); winId());
}
m_graphics_window = new GraphicsWindow(m_xrr_config.get(), this); m_graphics_window = new GraphicsWindow(m_xrr_config.get(), this);
#else #else
m_graphics_window = new GraphicsWindow(nullptr, this); m_graphics_window = new GraphicsWindow(nullptr, this);
#endif #endif
InstallHotkeyFilter(m_graphics_window);
} }
m_graphics_window->show(); m_graphics_window->show();
@ -1273,6 +1284,7 @@ void MainWindow::NetPlayQuit()
void MainWindow::EnableScreenSaver(bool enable) void MainWindow::EnableScreenSaver(bool enable)
{ {
#if defined(HAVE_XRANDR) && HAVE_XRANDR #if defined(HAVE_XRANDR) && HAVE_XRANDR
if (GetWindowSystemType() == WindowSystemType::X11)
UICommon::EnableScreenSaver(winId(), enable); UICommon::EnableScreenSaver(winId(), enable);
#else #else
UICommon::EnableScreenSaver(enable); UICommon::EnableScreenSaver(enable);

View File

@ -173,7 +173,7 @@ private:
MenuBar* m_menu_bar; MenuBar* m_menu_bar;
SearchBar* m_search_bar; SearchBar* m_search_bar;
GameList* m_game_list; GameList* m_game_list;
RenderWidget* m_render_widget; RenderWidget* m_render_widget = nullptr;
bool m_rendering_to_main; bool m_rendering_to_main;
bool m_stop_requested = false; bool m_stop_requested = false;
bool m_exit_requested = false; bool m_exit_requested = false;

View File

@ -41,12 +41,12 @@ ControllerInterface g_controller_interface;
// //
// Detect devices and inputs outputs / will make refresh function later // Detect devices and inputs outputs / will make refresh function later
// //
void ControllerInterface::Initialize(void* const hwnd) void ControllerInterface::Initialize(const WindowSystemInfo& wsi)
{ {
if (m_is_init) if (m_is_init)
return; return;
m_hwnd = hwnd; m_wsi = wsi;
m_is_populating_devices = true; m_is_populating_devices = true;
#ifdef CIFACE_USE_DINPUT #ifdef CIFACE_USE_DINPUT
@ -59,7 +59,8 @@ void ControllerInterface::Initialize(void* const hwnd)
// nothing needed // nothing needed
#endif #endif
#ifdef CIFACE_USE_OSX #ifdef CIFACE_USE_OSX
ciface::OSX::Init(hwnd); if (m_wsi.type == WindowSystemType::MacOS)
ciface::OSX::Init(wsi.render_surface);
// nothing needed for Quartz // nothing needed for Quartz
#endif #endif
#ifdef CIFACE_USE_SDL #ifdef CIFACE_USE_SDL
@ -79,6 +80,15 @@ void ControllerInterface::Initialize(void* const hwnd)
RefreshDevices(); RefreshDevices();
} }
void ControllerInterface::ChangeWindow(void* hwnd)
{
if (!m_is_init)
return;
m_wsi.render_surface = hwnd;
RefreshDevices();
}
void ControllerInterface::RefreshDevices() void ControllerInterface::RefreshDevices()
{ {
if (!m_is_init) if (!m_is_init)
@ -92,17 +102,22 @@ void ControllerInterface::RefreshDevices()
m_is_populating_devices = true; m_is_populating_devices = true;
#ifdef CIFACE_USE_DINPUT #ifdef CIFACE_USE_DINPUT
ciface::DInput::PopulateDevices(reinterpret_cast<HWND>(m_hwnd)); if (m_wsi.type == WindowSystemType::Windows)
ciface::DInput::PopulateDevices(reinterpret_cast<HWND>(m_wsi.render_surface));
#endif #endif
#ifdef CIFACE_USE_XINPUT #ifdef CIFACE_USE_XINPUT
ciface::XInput::PopulateDevices(); ciface::XInput::PopulateDevices();
#endif #endif
#ifdef CIFACE_USE_XLIB #ifdef CIFACE_USE_XLIB
ciface::XInput2::PopulateDevices(m_hwnd); if (m_wsi.type == WindowSystemType::X11)
ciface::XInput2::PopulateDevices(m_wsi.render_surface);
#endif #endif
#ifdef CIFACE_USE_OSX #ifdef CIFACE_USE_OSX
ciface::OSX::PopulateDevices(m_hwnd); if (m_wsi.type == WindowSystemType::MacOS)
ciface::Quartz::PopulateDevices(m_hwnd); {
ciface::OSX::PopulateDevices(m_wsi.render_surface);
ciface::Quartz::PopulateDevices(m_wsi.render_surface);
}
#endif #endif
#ifdef CIFACE_USE_SDL #ifdef CIFACE_USE_SDL
ciface::SDL::PopulateDevices(); ciface::SDL::PopulateDevices();

View File

@ -10,6 +10,7 @@
#include <mutex> #include <mutex>
#include <vector> #include <vector>
#include "Common/WindowSystemInfo.h"
#include "InputCommon/ControllerInterface/Device.h" #include "InputCommon/ControllerInterface/Device.h"
// enable disable sources // enable disable sources
@ -39,8 +40,9 @@
class ControllerInterface : public ciface::Core::DeviceContainer class ControllerInterface : public ciface::Core::DeviceContainer
{ {
public: public:
ControllerInterface() : m_is_init(false), m_hwnd(nullptr) {} ControllerInterface() : m_is_init(false) {}
void Initialize(void* const hwnd); void Initialize(const WindowSystemInfo& wsi);
void ChangeWindow(void* hwnd);
void RefreshDevices(); void RefreshDevices();
void Shutdown(); void Shutdown();
void AddDevice(std::shared_ptr<ciface::Core::Device> device); void AddDevice(std::shared_ptr<ciface::Core::Device> device);
@ -56,7 +58,7 @@ private:
mutable std::mutex m_callbacks_mutex; mutable std::mutex m_callbacks_mutex;
bool m_is_init; bool m_is_init;
std::atomic<bool> m_is_populating_devices{false}; std::atomic<bool> m_is_populating_devices{false};
void* m_hwnd; WindowSystemInfo m_wsi;
}; };
extern ControllerInterface g_controller_interface; extern ControllerInterface g_controller_interface;