PlaystationMouse: Add option to use relative mode

This commit is contained in:
Connor McLaughlin 2020-12-28 00:34:49 +10:00
parent ca42d027ac
commit 8bb5ff47eb
3 changed files with 31 additions and 1 deletions

View file

@ -249,6 +249,9 @@ Controller::SettingList Controller::GetSettings(ControllerType type)
case ControllerType::NeGcon: case ControllerType::NeGcon:
return NeGcon::StaticGetSettings(); return NeGcon::StaticGetSettings();
case ControllerType::PlayStationMouse:
return PlayStationMouse::StaticGetSettings();
default: default:
return {}; return {};
} }

View file

@ -161,7 +161,7 @@ void PlayStationMouse::UpdatePosition()
m_last_host_position_y = mouse_y; m_last_host_position_y = mouse_y;
if (delta_x != 0 || delta_y != 0) if (delta_x != 0 || delta_y != 0)
Log_InfoPrintf("dx=%d, dy=%d", delta_x, delta_y); Log_DevPrintf("dx=%d, dy=%d", delta_x, delta_y);
m_delta_x = static_cast<s8>(std::clamp<s32>(delta_x, std::numeric_limits<s8>::min(), std::numeric_limits<s8>::max())); m_delta_x = static_cast<s8>(std::clamp<s32>(delta_x, std::numeric_limits<s8>::min(), std::numeric_limits<s8>::max()));
m_delta_y = static_cast<s8>(std::clamp<s32>(delta_y, std::numeric_limits<s8>::min(), std::numeric_limits<s8>::max())); m_delta_y = static_cast<s8>(std::clamp<s32>(delta_y, std::numeric_limits<s8>::min(), std::numeric_limits<s8>::max()));
@ -208,3 +208,26 @@ u32 PlayStationMouse::StaticGetVibrationMotorCount()
{ {
return 0; return 0;
} }
Controller::SettingList PlayStationMouse::StaticGetSettings()
{
static constexpr std::array<SettingInfo, 1> settings = {{
{SettingInfo::Type::Boolean, "RelativeMouseMode", TRANSLATABLE("PlaystationMouse", "Relative Mouse Mode"),
TRANSLATABLE("RelativeMouseMode", "Locks the mouse cursor to the window, use for FPS games.")},
}};
return SettingList(settings.begin(), settings.end());
}
void PlayStationMouse::LoadSettings(const char* section)
{
Controller::LoadSettings(section);
m_use_relative_mode = g_host_interface->GetBoolSettingValue(section, "RelativeMouseMode");
}
bool PlayStationMouse::GetSoftwareCursor(const Common::RGBA8Image** image, float* image_scale, bool* relative_mode)
{
*relative_mode = m_use_relative_mode;
return m_use_relative_mode;
}

View file

@ -23,6 +23,7 @@ public:
static AxisList StaticGetAxisNames(); static AxisList StaticGetAxisNames();
static ButtonList StaticGetButtonNames(); static ButtonList StaticGetButtonNames();
static u32 StaticGetVibrationMotorCount(); static u32 StaticGetVibrationMotorCount();
static SettingList StaticGetSettings();
ControllerType GetType() const override; ControllerType GetType() const override;
std::optional<s32> GetAxisCodeByName(std::string_view axis_name) const override; std::optional<s32> GetAxisCodeByName(std::string_view axis_name) const override;
@ -39,6 +40,7 @@ public:
void SetButtonState(Button button, bool pressed); void SetButtonState(Button button, bool pressed);
void LoadSettings(const char* section) override;
bool GetSoftwareCursor(const Common::RGBA8Image** image, float* image_scale, bool* relative_mode) override; bool GetSoftwareCursor(const Common::RGBA8Image** image, float* image_scale, bool* relative_mode) override;
private: private:
@ -63,4 +65,6 @@ private:
s8 m_delta_y = 0; s8 m_delta_y = 0;
TransferState m_transfer_state = TransferState::Idle; TransferState m_transfer_state = TransferState::Idle;
bool m_use_relative_mode = false;
}; };