mirror of https://github.com/PCSX2/pcsx2.git
parent
65882ae14d
commit
9308410e12
|
@ -26,11 +26,23 @@ ControllerGlobalSettingsWidget::ControllerGlobalSettingsWidget(QWidget* parent,
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
SettingWidgetBinder::BindWidgetToBoolSetting(sif, m_ui.enableSDLRawInput, "InputSources", "SDLRawInput", false);
|
SettingWidgetBinder::BindWidgetToBoolSetting(sif, m_ui.enableSDLRawInput, "InputSources", "SDLRawInput", false);
|
||||||
#else
|
#else
|
||||||
m_ui.gridLayout_2->removeWidget(m_ui.enableSDLRawInput);
|
m_ui.sdlGridLayout->removeWidget(m_ui.enableSDLRawInput);
|
||||||
m_ui.enableSDLRawInput->deleteLater();
|
m_ui.enableSDLRawInput->deleteLater();
|
||||||
m_ui.enableSDLRawInput = nullptr;
|
m_ui.enableSDLRawInput = nullptr;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __APPLE__
|
||||||
|
SettingWidgetBinder::BindWidgetToBoolSetting(sif, m_ui.enableSDLIOKitDriver, "InputSources", "SDLIOKitDriver", true);
|
||||||
|
SettingWidgetBinder::BindWidgetToBoolSetting(sif, m_ui.enableSDLMFIDriver, "InputSources", "SDLMFIDriver", true);
|
||||||
|
#else
|
||||||
|
m_ui.sdlGridLayout->removeWidget(m_ui.enableSDLIOKitDriver);
|
||||||
|
m_ui.enableSDLIOKitDriver->deleteLater();
|
||||||
|
m_ui.enableSDLIOKitDriver = nullptr;
|
||||||
|
m_ui.sdlGridLayout->removeWidget(m_ui.enableSDLMFIDriver);
|
||||||
|
m_ui.enableSDLMFIDriver->deleteLater();
|
||||||
|
m_ui.enableSDLMFIDriver = nullptr;
|
||||||
|
#endif
|
||||||
|
|
||||||
ControllerSettingWidgetBinder::BindWidgetToInputProfileBool(sif, m_ui.enableMouseMapping, "UI", "EnableMouseMapping", false);
|
ControllerSettingWidgetBinder::BindWidgetToInputProfileBool(sif, m_ui.enableMouseMapping, "UI", "EnableMouseMapping", false);
|
||||||
connect(m_ui.mouseSettings, &QToolButton::clicked, this, &ControllerGlobalSettingsWidget::mouseSettingsClicked);
|
connect(m_ui.mouseSettings, &QToolButton::clicked, this, &ControllerGlobalSettingsWidget::mouseSettingsClicked);
|
||||||
|
|
||||||
|
@ -103,6 +115,10 @@ void ControllerGlobalSettingsWidget::updateSDLOptionsEnabled()
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
m_ui.enableSDLRawInput->setEnabled(enabled);
|
m_ui.enableSDLRawInput->setEnabled(enabled);
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef __APPLE__
|
||||||
|
m_ui.enableSDLIOKitDriver->setEnabled(enabled);
|
||||||
|
m_ui.enableSDLMFIDriver->setEnabled(enabled);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void ControllerGlobalSettingsWidget::ledSettingsClicked()
|
void ControllerGlobalSettingsWidget::ledSettingsClicked()
|
||||||
|
|
|
@ -126,7 +126,7 @@
|
||||||
<property name="title">
|
<property name="title">
|
||||||
<string>SDL Input Source</string>
|
<string>SDL Input Source</string>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QGridLayout" name="gridLayout_2">
|
<layout class="QGridLayout" name="sdlGridLayout">
|
||||||
<item row="1" column="0">
|
<item row="1" column="0">
|
||||||
<widget class="QCheckBox" name="enableSDLSource">
|
<widget class="QCheckBox" name="enableSDLSource">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
|
@ -173,6 +173,20 @@
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item row="3" column="0">
|
||||||
|
<widget class="QCheckBox" name="enableSDLIOKitDriver">
|
||||||
|
<property name="text">
|
||||||
|
<string>Enable IOKit Driver</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item row="3" column="1">
|
||||||
|
<widget class="QCheckBox" name="enableSDLMFIDriver">
|
||||||
|
<property name="text">
|
||||||
|
<string>Enable MFI Driver</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
|
|
@ -160,9 +160,23 @@ void SDLInputSource::UpdateSettings(SettingsInterface& si, std::unique_lock<std:
|
||||||
const bool old_controller_enhanced_mode = m_controller_enhanced_mode;
|
const bool old_controller_enhanced_mode = m_controller_enhanced_mode;
|
||||||
const bool old_controller_raw_mode = m_controller_raw_mode;
|
const bool old_controller_raw_mode = m_controller_raw_mode;
|
||||||
|
|
||||||
|
#ifdef __APPLE__
|
||||||
|
const bool old_enable_iokit_driver = m_enable_iokit_driver;
|
||||||
|
const bool old_enable_mfi_driver = m_enable_mfi_driver;
|
||||||
|
#endif
|
||||||
|
|
||||||
LoadSettings(si);
|
LoadSettings(si);
|
||||||
|
|
||||||
if (m_controller_enhanced_mode != old_controller_enhanced_mode || m_controller_raw_mode != old_controller_raw_mode)
|
#ifdef __APPLE__
|
||||||
|
const bool drivers_changed =
|
||||||
|
(m_enable_iokit_driver != old_enable_iokit_driver || m_enable_mfi_driver != old_enable_mfi_driver);
|
||||||
|
#else
|
||||||
|
constexpr bool drivers_changed = false;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (m_controller_enhanced_mode != old_controller_enhanced_mode ||
|
||||||
|
m_controller_raw_mode != old_controller_raw_mode ||
|
||||||
|
drivers_changed)
|
||||||
{
|
{
|
||||||
settings_lock.unlock();
|
settings_lock.unlock();
|
||||||
ShutdownSubsystem();
|
ShutdownSubsystem();
|
||||||
|
@ -186,10 +200,6 @@ void SDLInputSource::Shutdown()
|
||||||
|
|
||||||
void SDLInputSource::LoadSettings(SettingsInterface& si)
|
void SDLInputSource::LoadSettings(SettingsInterface& si)
|
||||||
{
|
{
|
||||||
m_controller_enhanced_mode = si.GetBoolValue("InputSources", "SDLControllerEnhancedMode", false);
|
|
||||||
m_controller_raw_mode = si.GetBoolValue("InputSources", "SDLRawInput", false);
|
|
||||||
m_sdl_hints = si.GetKeyValueList("SDLHints");
|
|
||||||
|
|
||||||
for (u32 i = 0; i < MAX_LED_COLORS; i++)
|
for (u32 i = 0; i < MAX_LED_COLORS; i++)
|
||||||
{
|
{
|
||||||
const u32 color = GetRGBForPlayerId(si, i);
|
const u32 color = GetRGBForPlayerId(si, i);
|
||||||
|
@ -204,6 +214,16 @@ void SDLInputSource::LoadSettings(SettingsInterface& si)
|
||||||
|
|
||||||
SetControllerRGBLED(it->game_controller, color);
|
SetControllerRGBLED(it->game_controller, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_sdl_hints = si.GetKeyValueList("SDLHints");
|
||||||
|
|
||||||
|
m_controller_enhanced_mode = si.GetBoolValue("InputSources", "SDLControllerEnhancedMode", false);
|
||||||
|
m_controller_raw_mode = si.GetBoolValue("InputSources", "SDLRawInput", false);
|
||||||
|
|
||||||
|
#ifdef __APPLE__
|
||||||
|
m_enable_iokit_driver = si.GetBoolValue("InputSources", "SDLIOKitDriver", true);
|
||||||
|
m_enable_mfi_driver = si.GetBoolValue("InputSources", "SDLMFIDriver", true);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 SDLInputSource::GetRGBForPlayerId(SettingsInterface& si, u32 player_id)
|
u32 SDLInputSource::GetRGBForPlayerId(SettingsInterface& si, u32 player_id)
|
||||||
|
@ -252,6 +272,12 @@ void SDLInputSource::SetHints()
|
||||||
SDL_SetHint(SDL_HINT_JOYSTICK_HIDAPI_PS3, "1");
|
SDL_SetHint(SDL_HINT_JOYSTICK_HIDAPI_PS3, "1");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __APPLE__
|
||||||
|
Console.WriteLnFmt("IOKit is {}, MFI is {}.", m_enable_iokit_driver ? "enabled" : "disabled", m_enable_mfi_driver ? "enabled" : "disabled");
|
||||||
|
SDL_SetHint(SDL_HINT_JOYSTICK_IOKIT, m_enable_iokit_driver ? "1" : "0");
|
||||||
|
SDL_SetHint(SDL_HINT_JOYSTICK_MFI, m_enable_mfi_driver ? "1" : "0");
|
||||||
|
#endif
|
||||||
|
|
||||||
for (const std::pair<std::string, std::string>& hint : m_sdl_hints)
|
for (const std::pair<std::string, std::string>& hint : m_sdl_hints)
|
||||||
SDL_SetHint(hint.first.c_str(), hint.second.c_str());
|
SDL_SetHint(hint.first.c_str(), hint.second.c_str());
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,8 +2,11 @@
|
||||||
// SPDX-License-Identifier: LGPL-3.0+
|
// SPDX-License-Identifier: LGPL-3.0+
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "Input/InputSource.h"
|
#include "Input/InputSource.h"
|
||||||
#include "SDL.h"
|
|
||||||
|
#include <SDL.h>
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
|
@ -84,9 +87,15 @@ private:
|
||||||
|
|
||||||
ControllerDataVector m_controllers;
|
ControllerDataVector m_controllers;
|
||||||
|
|
||||||
|
std::array<u32, MAX_LED_COLORS> m_led_colors{};
|
||||||
|
std::vector<std::pair<std::string, std::string>> m_sdl_hints;
|
||||||
|
|
||||||
bool m_sdl_subsystem_initialized = false;
|
bool m_sdl_subsystem_initialized = false;
|
||||||
bool m_controller_enhanced_mode = false;
|
bool m_controller_enhanced_mode = false;
|
||||||
bool m_controller_raw_mode = false;
|
bool m_controller_raw_mode = false;
|
||||||
std::array<u32, MAX_LED_COLORS> m_led_colors{};
|
|
||||||
std::vector<std::pair<std::string, std::string>> m_sdl_hints;
|
#ifdef __APPLE__
|
||||||
|
bool m_enable_iokit_driver = false;
|
||||||
|
bool m_enable_mfi_driver = false;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue