mirror of https://github.com/PCSX2/pcsx2.git
Qt: Toggle for DualSense Player LED
This commit is contained in:
parent
483c7f41de
commit
162354decf
|
@ -144,6 +144,9 @@ ControllerLEDSettingsDialog::ControllerLEDSettingsDialog(QWidget* parent, Contro
|
||||||
linkButton(m_ui.SDL2LED, 2);
|
linkButton(m_ui.SDL2LED, 2);
|
||||||
linkButton(m_ui.SDL3LED, 3);
|
linkButton(m_ui.SDL3LED, 3);
|
||||||
|
|
||||||
|
SettingsInterface* sif = dialog->getProfileSettingsInterface();
|
||||||
|
|
||||||
|
ControllerSettingWidgetBinder::BindWidgetToInputProfileBool(sif, m_ui.enableSDLPS5PlayerLED, "InputSources", "SDLPS5PlayerLED", false);
|
||||||
connect(m_ui.buttonBox->button(QDialogButtonBox::Close), &QPushButton::clicked, this, &QDialog::accept);
|
connect(m_ui.buttonBox->button(QDialogButtonBox::Close), &QPushButton::clicked, this, &QDialog::accept);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>501</width>
|
<width>501</width>
|
||||||
<height>108</height>
|
<height>128</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
|
@ -26,14 +26,14 @@
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="0" column="1">
|
<item row="0" column="3">
|
||||||
<widget class="QGroupBox" name="groupBox_2">
|
<widget class="QGroupBox" name="groupBox_4">
|
||||||
<property name="title">
|
<property name="title">
|
||||||
<string>SDL-1 LED</string>
|
<string>SDL-3 LED</string>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_3">
|
<layout class="QVBoxLayout" name="verticalLayout">
|
||||||
<item>
|
<item>
|
||||||
<widget class="ColorPickerButton" name="SDL1LED"/>
|
<widget class="ColorPickerButton" name="SDL3LED"/>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
|
@ -50,24 +50,53 @@
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="0" column="3">
|
<item row="0" column="1">
|
||||||
<widget class="QGroupBox" name="groupBox_4">
|
<widget class="QGroupBox" name="groupBox_2">
|
||||||
<property name="title">
|
<property name="title">
|
||||||
<string>SDL-3 LED</string>
|
<string>SDL-1 LED</string>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout">
|
<layout class="QVBoxLayout" name="verticalLayout_3">
|
||||||
<item>
|
<item>
|
||||||
<widget class="ColorPickerButton" name="SDL3LED"/>
|
<widget class="ColorPickerButton" name="SDL1LED"/>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="0" colspan="4">
|
<item row="3" column="0" colspan="4">
|
||||||
<widget class="QDialogButtonBox" name="buttonBox">
|
<layout class="QHBoxLayout" name="horizontalLayout" stretch="1,0">
|
||||||
<property name="standardButtons">
|
<property name="sizeConstraint">
|
||||||
<set>QDialogButtonBox::Close</set>
|
<enum>QLayout::SetDefaultConstraint</enum>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
<property name="bottomMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<item>
|
||||||
|
<widget class="QCheckBox" name="enableSDLPS5PlayerLED">
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="Minimum" vsizetype="Fixed">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
|
</property>
|
||||||
|
<property name="text">
|
||||||
|
<string>Enable DualSense Player LED</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QDialogButtonBox" name="buttonBox">
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="Expanding" vsizetype="Fixed">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
|
</property>
|
||||||
|
<property name="standardButtons">
|
||||||
|
<set>QDialogButtonBox::Close</set>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
|
|
|
@ -3916,6 +3916,9 @@ void FullscreenUI::DrawControllerSettingsPage()
|
||||||
DrawToggleSetting(bsi, FSUI_ICONSTR(ICON_FA_WIFI, "SDL DualShock 4 / DualSense Enhanced Mode"),
|
DrawToggleSetting(bsi, FSUI_ICONSTR(ICON_FA_WIFI, "SDL DualShock 4 / DualSense Enhanced Mode"),
|
||||||
FSUI_CSTR("Provides vibration and LED control support over Bluetooth."), "InputSources", "SDLControllerEnhancedMode", false,
|
FSUI_CSTR("Provides vibration and LED control support over Bluetooth."), "InputSources", "SDLControllerEnhancedMode", false,
|
||||||
bsi->GetBoolValue("InputSources", "SDL", true), false);
|
bsi->GetBoolValue("InputSources", "SDL", true), false);
|
||||||
|
DrawToggleSetting(bsi, FSUI_ICONSTR(ICON_FA_LIGHTBULB, "SDL DualSense Player LED"),
|
||||||
|
FSUI_CSTR("Enable/Disable the Player LED on DualSense controllers."), "InputSources", "SDLPS5PlayerLED", false,
|
||||||
|
bsi->GetBoolValue("InputSources", "SDLControllerEnhancedMode", true), false);
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
DrawToggleSetting(bsi, FSUI_ICONSTR(ICON_FA_COG, "SDL Raw Input"), FSUI_CSTR("Allow SDL to use raw access to input devices."),
|
DrawToggleSetting(bsi, FSUI_ICONSTR(ICON_FA_COG, "SDL Raw Input"), FSUI_CSTR("Allow SDL to use raw access to input devices."),
|
||||||
"InputSources", "SDLRawInput", false, bsi->GetBoolValue("InputSources", "SDL", true), false);
|
"InputSources", "SDLRawInput", false, bsi->GetBoolValue("InputSources", "SDL", true), false);
|
||||||
|
|
|
@ -158,6 +158,7 @@ bool SDLInputSource::Initialize(SettingsInterface& si, std::unique_lock<std::mut
|
||||||
void SDLInputSource::UpdateSettings(SettingsInterface& si, std::unique_lock<std::mutex>& settings_lock)
|
void SDLInputSource::UpdateSettings(SettingsInterface& si, std::unique_lock<std::mutex>& settings_lock)
|
||||||
{
|
{
|
||||||
const bool old_controller_enhanced_mode = m_controller_enhanced_mode;
|
const bool old_controller_enhanced_mode = m_controller_enhanced_mode;
|
||||||
|
const bool old_controller_ps5_player_led = m_controller_ps5_player_led;
|
||||||
const bool old_controller_raw_mode = m_controller_raw_mode;
|
const bool old_controller_raw_mode = m_controller_raw_mode;
|
||||||
|
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
|
@ -175,6 +176,7 @@ void SDLInputSource::UpdateSettings(SettingsInterface& si, std::unique_lock<std:
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (m_controller_enhanced_mode != old_controller_enhanced_mode ||
|
if (m_controller_enhanced_mode != old_controller_enhanced_mode ||
|
||||||
|
m_controller_ps5_player_led != old_controller_ps5_player_led ||
|
||||||
m_controller_raw_mode != old_controller_raw_mode ||
|
m_controller_raw_mode != old_controller_raw_mode ||
|
||||||
drivers_changed)
|
drivers_changed)
|
||||||
{
|
{
|
||||||
|
@ -218,6 +220,7 @@ void SDLInputSource::LoadSettings(SettingsInterface& si)
|
||||||
m_sdl_hints = si.GetKeyValueList("SDLHints");
|
m_sdl_hints = si.GetKeyValueList("SDLHints");
|
||||||
|
|
||||||
m_controller_enhanced_mode = si.GetBoolValue("InputSources", "SDLControllerEnhancedMode", false);
|
m_controller_enhanced_mode = si.GetBoolValue("InputSources", "SDLControllerEnhancedMode", false);
|
||||||
|
m_controller_ps5_player_led = si.GetBoolValue("InputSources", "SDLPS5PlayerLED", false);
|
||||||
m_controller_raw_mode = si.GetBoolValue("InputSources", "SDLRawInput", false);
|
m_controller_raw_mode = si.GetBoolValue("InputSources", "SDLRawInput", false);
|
||||||
|
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
|
@ -264,6 +267,7 @@ void SDLInputSource::SetHints()
|
||||||
SDL_SetHint(SDL_HINT_JOYSTICK_RAWINPUT, m_controller_raw_mode ? "1" : "0");
|
SDL_SetHint(SDL_HINT_JOYSTICK_RAWINPUT, m_controller_raw_mode ? "1" : "0");
|
||||||
SDL_SetHint(SDL_HINT_JOYSTICK_HIDAPI_PS4_RUMBLE, m_controller_enhanced_mode ? "1" : "0");
|
SDL_SetHint(SDL_HINT_JOYSTICK_HIDAPI_PS4_RUMBLE, m_controller_enhanced_mode ? "1" : "0");
|
||||||
SDL_SetHint(SDL_HINT_JOYSTICK_HIDAPI_PS5_RUMBLE, m_controller_enhanced_mode ? "1" : "0");
|
SDL_SetHint(SDL_HINT_JOYSTICK_HIDAPI_PS5_RUMBLE, m_controller_enhanced_mode ? "1" : "0");
|
||||||
|
SDL_SetHint(SDL_HINT_JOYSTICK_HIDAPI_PS5_PLAYER_LED, m_controller_ps5_player_led ? "1" : "0");
|
||||||
// Enable Wii U Pro Controller support
|
// Enable Wii U Pro Controller support
|
||||||
SDL_SetHint(SDL_HINT_JOYSTICK_HIDAPI_WII, "1");
|
SDL_SetHint(SDL_HINT_JOYSTICK_HIDAPI_WII, "1");
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
|
|
|
@ -93,6 +93,7 @@ private:
|
||||||
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;
|
||||||
|
bool m_controller_ps5_player_led = false;
|
||||||
|
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
bool m_enable_iokit_driver = false;
|
bool m_enable_iokit_driver = false;
|
||||||
|
|
|
@ -159,6 +159,7 @@ void Pad::SetDefaultControllerConfig(SettingsInterface& si)
|
||||||
InputManager::GetInputSourceDefaultEnabled(static_cast<InputSourceType>(i)));
|
InputManager::GetInputSourceDefaultEnabled(static_cast<InputSourceType>(i)));
|
||||||
}
|
}
|
||||||
si.SetBoolValue("InputSources", "SDLControllerEnhancedMode", false);
|
si.SetBoolValue("InputSources", "SDLControllerEnhancedMode", false);
|
||||||
|
si.SetBoolValue("InputSources", "SDLPS5PlayerLED", false);
|
||||||
si.SetBoolValue("Pad", "MultitapPort1", false);
|
si.SetBoolValue("Pad", "MultitapPort1", false);
|
||||||
si.SetBoolValue("Pad", "MultitapPort2", false);
|
si.SetBoolValue("Pad", "MultitapPort2", false);
|
||||||
si.SetFloatValue("Pad", "PointerXScale", 8.0f);
|
si.SetFloatValue("Pad", "PointerXScale", 8.0f);
|
||||||
|
@ -329,6 +330,7 @@ void Pad::CopyConfiguration(SettingsInterface* dest_si, const SettingsInterface&
|
||||||
InputManager::InputSourceToString(static_cast<InputSourceType>(i)));
|
InputManager::InputSourceToString(static_cast<InputSourceType>(i)));
|
||||||
}
|
}
|
||||||
dest_si->CopyBoolValue(src_si, "InputSources", "SDLControllerEnhancedMode");
|
dest_si->CopyBoolValue(src_si, "InputSources", "SDLControllerEnhancedMode");
|
||||||
|
dest_si->CopyBoolValue(src_si, "InputSources", "SDLPS5PlayerLED");
|
||||||
}
|
}
|
||||||
|
|
||||||
for (u32 port = 0; port < Pad::NUM_CONTROLLER_PORTS; port++)
|
for (u32 port = 0; port < Pad::NUM_CONTROLLER_PORTS; port++)
|
||||||
|
|
Loading…
Reference in New Issue