mirror of
https://git.suyu.dev/suyu/suyu.git
synced 2025-01-09 01:00:59 +01:00
Address review comments
This commit is contained in:
parent
1c08d532e0
commit
e1a3bda4d9
14 changed files with 44 additions and 46 deletions
|
@ -305,17 +305,15 @@ Common::Input::NfcStatus TransformToNfc(const Common::Input::CallbackStatus& cal
|
||||||
}
|
}
|
||||||
|
|
||||||
Common::Input::BodyColorStatus TransformToColor(const Common::Input::CallbackStatus& callback) {
|
Common::Input::BodyColorStatus TransformToColor(const Common::Input::CallbackStatus& callback) {
|
||||||
Common::Input::BodyColorStatus color{};
|
|
||||||
switch (callback.type) {
|
switch (callback.type) {
|
||||||
case Common::Input::InputType::Color:
|
case Common::Input::InputType::Color:
|
||||||
color = callback.color_status;
|
return callback.color_status;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
LOG_ERROR(Input, "Conversion from type {} to color not implemented", callback.type);
|
LOG_ERROR(Input, "Conversion from type {} to color not implemented", callback.type);
|
||||||
|
return {};
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return color;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void SanitizeAnalog(Common::Input::AnalogStatus& analog, bool clamp_value) {
|
void SanitizeAnalog(Common::Input::AnalogStatus& analog, bool clamp_value) {
|
||||||
|
|
|
@ -316,7 +316,7 @@ void Joycons::OnBatteryUpdate(std::size_t port, Joycon::ControllerType type,
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Common::Input::BatteryLevel battery{value.status.Value()};
|
Common::Input::BatteryLevel battery{};
|
||||||
switch (value.status) {
|
switch (value.status) {
|
||||||
case 0:
|
case 0:
|
||||||
battery = Common::Input::BatteryLevel::Empty;
|
battery = Common::Input::BatteryLevel::Empty;
|
||||||
|
|
|
@ -465,7 +465,7 @@ void JoyconDriver::SetCallbacks(const Joycon::JoyconCallbacks& callbacks) {
|
||||||
|
|
||||||
Joycon::DriverResult JoyconDriver::GetDeviceType(SDL_hid_device_info* device_info,
|
Joycon::DriverResult JoyconDriver::GetDeviceType(SDL_hid_device_info* device_info,
|
||||||
ControllerType& controller_type) {
|
ControllerType& controller_type) {
|
||||||
std::array<std::pair<u32, Joycon::ControllerType>, 4> supported_devices{
|
static constexpr std::array<std::pair<u32, Joycon::ControllerType>, 4> supported_devices{
|
||||||
std::pair<u32, Joycon::ControllerType>{0x2006, Joycon::ControllerType::Left},
|
std::pair<u32, Joycon::ControllerType>{0x2006, Joycon::ControllerType::Left},
|
||||||
{0x2007, Joycon::ControllerType::Right},
|
{0x2007, Joycon::ControllerType::Right},
|
||||||
{0x2009, Joycon::ControllerType::Pro},
|
{0x2009, Joycon::ControllerType::Pro},
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
namespace InputCommon::Joycon {
|
namespace InputCommon::Joycon {
|
||||||
|
|
||||||
CalibrationProtocol::CalibrationProtocol(std::shared_ptr<JoyconHandle> handle)
|
CalibrationProtocol::CalibrationProtocol(std::shared_ptr<JoyconHandle> handle)
|
||||||
: JoyconCommonProtocol(handle) {}
|
: JoyconCommonProtocol(std::move(handle)) {}
|
||||||
|
|
||||||
DriverResult CalibrationProtocol::GetLeftJoyStickCalibration(JoyStickCalibration& calibration) {
|
DriverResult CalibrationProtocol::GetLeftJoyStickCalibration(JoyStickCalibration& calibration) {
|
||||||
std::vector<u8> buffer;
|
std::vector<u8> buffer;
|
||||||
|
@ -136,12 +136,8 @@ DriverResult CalibrationProtocol::GetRingCalibration(RingCalibration& calibratio
|
||||||
ring_data_min = current_value - 800;
|
ring_data_min = current_value - 800;
|
||||||
ring_data_default = current_value;
|
ring_data_default = current_value;
|
||||||
}
|
}
|
||||||
if (ring_data_max < current_value) {
|
ring_data_max = std::max(ring_data_max, current_value);
|
||||||
ring_data_max = current_value;
|
ring_data_min = std::min(ring_data_min, current_value);
|
||||||
}
|
|
||||||
if (ring_data_min > current_value) {
|
|
||||||
ring_data_min = current_value;
|
|
||||||
}
|
|
||||||
calibration = {
|
calibration = {
|
||||||
.default_value = ring_data_default,
|
.default_value = ring_data_default,
|
||||||
.max_value = ring_data_max,
|
.max_value = ring_data_max,
|
||||||
|
|
|
@ -24,7 +24,7 @@ namespace InputCommon::Joycon {
|
||||||
/// Driver functions related to retrieving calibration data from the device
|
/// Driver functions related to retrieving calibration data from the device
|
||||||
class CalibrationProtocol final : private JoyconCommonProtocol {
|
class CalibrationProtocol final : private JoyconCommonProtocol {
|
||||||
public:
|
public:
|
||||||
CalibrationProtocol(std::shared_ptr<JoyconHandle> handle);
|
explicit CalibrationProtocol(std::shared_ptr<JoyconHandle> handle);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sends a request to obtain the left stick calibration from memory
|
* Sends a request to obtain the left stick calibration from memory
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
|
|
||||||
namespace InputCommon::Joycon {
|
namespace InputCommon::Joycon {
|
||||||
JoyconCommonProtocol::JoyconCommonProtocol(std::shared_ptr<JoyconHandle> hidapi_handle_)
|
JoyconCommonProtocol::JoyconCommonProtocol(std::shared_ptr<JoyconHandle> hidapi_handle_)
|
||||||
: hidapi_handle{hidapi_handle_} {}
|
: hidapi_handle{std::move(hidapi_handle_)} {}
|
||||||
|
|
||||||
u8 JoyconCommonProtocol::GetCounter() {
|
u8 JoyconCommonProtocol::GetCounter() {
|
||||||
hidapi_handle->packet_counter = (hidapi_handle->packet_counter + 1) & 0x0F;
|
hidapi_handle->packet_counter = (hidapi_handle->packet_counter + 1) & 0x0F;
|
||||||
|
@ -256,7 +256,7 @@ DriverResult JoyconCommonProtocol::WaitSetMCUMode(ReportMode report_mode, MCUMod
|
||||||
}
|
}
|
||||||
|
|
||||||
// crc-8-ccitt / polynomial 0x07 look up table
|
// crc-8-ccitt / polynomial 0x07 look up table
|
||||||
static constexpr uint8_t mcu_crc8_table[256] = {
|
constexpr std::array<u8, 256> mcu_crc8_table = {
|
||||||
0x00, 0x07, 0x0E, 0x09, 0x1C, 0x1B, 0x12, 0x15, 0x38, 0x3F, 0x36, 0x31, 0x24, 0x23, 0x2A, 0x2D,
|
0x00, 0x07, 0x0E, 0x09, 0x1C, 0x1B, 0x12, 0x15, 0x38, 0x3F, 0x36, 0x31, 0x24, 0x23, 0x2A, 0x2D,
|
||||||
0x70, 0x77, 0x7E, 0x79, 0x6C, 0x6B, 0x62, 0x65, 0x48, 0x4F, 0x46, 0x41, 0x54, 0x53, 0x5A, 0x5D,
|
0x70, 0x77, 0x7E, 0x79, 0x6C, 0x6B, 0x62, 0x65, 0x48, 0x4F, 0x46, 0x41, 0x54, 0x53, 0x5A, 0x5D,
|
||||||
0xE0, 0xE7, 0xEE, 0xE9, 0xFC, 0xFB, 0xF2, 0xF5, 0xD8, 0xDF, 0xD6, 0xD1, 0xC4, 0xC3, 0xCA, 0xCD,
|
0xE0, 0xE7, 0xEE, 0xE9, 0xFC, 0xFB, 0xF2, 0xF5, 0xD8, 0xDF, 0xD6, 0xD1, 0xC4, 0xC3, 0xCA, 0xCD,
|
||||||
|
@ -278,7 +278,7 @@ u8 JoyconCommonProtocol::CalculateMCU_CRC8(u8* buffer, u8 size) const {
|
||||||
u8 crc8 = 0x0;
|
u8 crc8 = 0x0;
|
||||||
|
|
||||||
for (int i = 0; i < size; ++i) {
|
for (int i = 0; i < size; ++i) {
|
||||||
crc8 = mcu_crc8_table[(u8)(crc8 ^ buffer[i])];
|
crc8 = mcu_crc8_table[static_cast<u8>(crc8 ^ buffer[i])];
|
||||||
}
|
}
|
||||||
return crc8;
|
return crc8;
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
namespace InputCommon::Joycon {
|
namespace InputCommon::Joycon {
|
||||||
|
|
||||||
GenericProtocol::GenericProtocol(std::shared_ptr<JoyconHandle> handle)
|
GenericProtocol::GenericProtocol(std::shared_ptr<JoyconHandle> handle)
|
||||||
: JoyconCommonProtocol(handle) {}
|
: JoyconCommonProtocol(std::move(handle)) {}
|
||||||
|
|
||||||
DriverResult GenericProtocol::EnablePassiveMode() {
|
DriverResult GenericProtocol::EnablePassiveMode() {
|
||||||
SetBlocking();
|
SetBlocking();
|
||||||
|
@ -43,7 +43,7 @@ DriverResult GenericProtocol::GetControllerType(ControllerType& controller_type)
|
||||||
}
|
}
|
||||||
|
|
||||||
DriverResult GenericProtocol::EnableImu(bool enable) {
|
DriverResult GenericProtocol::EnableImu(bool enable) {
|
||||||
const std::vector<u8> buffer{static_cast<u8>(enable ? 1 : 0)};
|
const std::array<u8, 1> buffer{static_cast<u8>(enable ? 1 : 0)};
|
||||||
std::vector<u8> output;
|
std::vector<u8> output;
|
||||||
SetBlocking();
|
SetBlocking();
|
||||||
const auto result = SendSubCommand(SubCommand::ENABLE_IMU, buffer, output);
|
const auto result = SendSubCommand(SubCommand::ENABLE_IMU, buffer, output);
|
||||||
|
@ -54,8 +54,8 @@ DriverResult GenericProtocol::EnableImu(bool enable) {
|
||||||
DriverResult GenericProtocol::SetImuConfig(GyroSensitivity gsen, GyroPerformance gfrec,
|
DriverResult GenericProtocol::SetImuConfig(GyroSensitivity gsen, GyroPerformance gfrec,
|
||||||
AccelerometerSensitivity asen,
|
AccelerometerSensitivity asen,
|
||||||
AccelerometerPerformance afrec) {
|
AccelerometerPerformance afrec) {
|
||||||
const std::vector<u8> buffer{static_cast<u8>(gsen), static_cast<u8>(asen),
|
const std::array<u8, 4> buffer{static_cast<u8>(gsen), static_cast<u8>(asen),
|
||||||
static_cast<u8>(gfrec), static_cast<u8>(afrec)};
|
static_cast<u8>(gfrec), static_cast<u8>(afrec)};
|
||||||
std::vector<u8> output;
|
std::vector<u8> output;
|
||||||
SetBlocking();
|
SetBlocking();
|
||||||
const auto result = SendSubCommand(SubCommand::SET_IMU_SENSITIVITY, buffer, output);
|
const auto result = SendSubCommand(SubCommand::SET_IMU_SENSITIVITY, buffer, output);
|
||||||
|
@ -115,7 +115,7 @@ DriverResult GenericProtocol::GetVersionNumber(FirmwareVersion& version) {
|
||||||
}
|
}
|
||||||
|
|
||||||
DriverResult GenericProtocol::SetHomeLight() {
|
DriverResult GenericProtocol::SetHomeLight() {
|
||||||
const std::vector<u8> buffer{0x0f, 0xf0, 0x00};
|
static constexpr std::array<u8, 3> buffer{0x0f, 0xf0, 0x00};
|
||||||
std::vector<u8> output;
|
std::vector<u8> output;
|
||||||
SetBlocking();
|
SetBlocking();
|
||||||
|
|
||||||
|
@ -130,7 +130,7 @@ DriverResult GenericProtocol::SetLedBusy() {
|
||||||
}
|
}
|
||||||
|
|
||||||
DriverResult GenericProtocol::SetLedPattern(u8 leds) {
|
DriverResult GenericProtocol::SetLedPattern(u8 leds) {
|
||||||
const std::vector<u8> buffer{leds};
|
const std::array<u8, 1> buffer{leds};
|
||||||
std::vector<u8> output;
|
std::vector<u8> output;
|
||||||
SetBlocking();
|
SetBlocking();
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@ namespace InputCommon::Joycon {
|
||||||
/// Joycon driver functions that easily implemented
|
/// Joycon driver functions that easily implemented
|
||||||
class GenericProtocol final : private JoyconCommonProtocol {
|
class GenericProtocol final : private JoyconCommonProtocol {
|
||||||
public:
|
public:
|
||||||
GenericProtocol(std::shared_ptr<JoyconHandle> handle);
|
explicit GenericProtocol(std::shared_ptr<JoyconHandle> handle);
|
||||||
|
|
||||||
/// Enables passive mode. This mode only sends button data on change. Sticks will return digital
|
/// Enables passive mode. This mode only sends button data on change. Sticks will return digital
|
||||||
/// data instead of analog. Motion will be disabled
|
/// data instead of analog. Motion will be disabled
|
||||||
|
|
|
@ -7,7 +7,8 @@
|
||||||
|
|
||||||
namespace InputCommon::Joycon {
|
namespace InputCommon::Joycon {
|
||||||
|
|
||||||
NfcProtocol::NfcProtocol(std::shared_ptr<JoyconHandle> handle) : JoyconCommonProtocol(handle) {}
|
NfcProtocol::NfcProtocol(std::shared_ptr<JoyconHandle> handle)
|
||||||
|
: JoyconCommonProtocol(std::move(handle)) {}
|
||||||
|
|
||||||
DriverResult NfcProtocol::EnableNfc() {
|
DriverResult NfcProtocol::EnableNfc() {
|
||||||
LOG_INFO(Input, "Enable NFC");
|
LOG_INFO(Input, "Enable NFC");
|
||||||
|
@ -160,9 +161,9 @@ DriverResult NfcProtocol::ReadTag(const TagFoundData& data) {
|
||||||
std::vector<u8> output;
|
std::vector<u8> output;
|
||||||
std::size_t tries = 0;
|
std::size_t tries = 0;
|
||||||
|
|
||||||
std::string uuid_string = "";
|
std::string uuid_string;
|
||||||
for (auto& content : data.uuid) {
|
for (auto& content : data.uuid) {
|
||||||
uuid_string += " " + fmt::format("{:02x}", content);
|
uuid_string += fmt::format(" {:02x}", content);
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG_INFO(Input, "Tag detected, type={}, uuid={}", data.type, uuid_string);
|
LOG_INFO(Input, "Tag detected, type={}, uuid={}", data.type, uuid_string);
|
||||||
|
@ -407,7 +408,7 @@ NFCReadBlockCommand NfcProtocol::GetReadBlockCommand(std::size_t pages) const {
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NfcProtocol::IsEnabled() {
|
bool NfcProtocol::IsEnabled() const {
|
||||||
return is_enabled;
|
return is_enabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,7 @@ namespace InputCommon::Joycon {
|
||||||
|
|
||||||
class NfcProtocol final : private JoyconCommonProtocol {
|
class NfcProtocol final : private JoyconCommonProtocol {
|
||||||
public:
|
public:
|
||||||
NfcProtocol(std::shared_ptr<JoyconHandle> handle);
|
explicit NfcProtocol(std::shared_ptr<JoyconHandle> handle);
|
||||||
|
|
||||||
DriverResult EnableNfc();
|
DriverResult EnableNfc();
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ public:
|
||||||
|
|
||||||
bool HasAmiibo();
|
bool HasAmiibo();
|
||||||
|
|
||||||
bool IsEnabled();
|
bool IsEnabled() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
struct TagFoundData {
|
struct TagFoundData {
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
namespace InputCommon::Joycon {
|
namespace InputCommon::Joycon {
|
||||||
|
|
||||||
RingConProtocol::RingConProtocol(std::shared_ptr<JoyconHandle> handle)
|
RingConProtocol::RingConProtocol(std::shared_ptr<JoyconHandle> handle)
|
||||||
: JoyconCommonProtocol(handle) {}
|
: JoyconCommonProtocol(std::move(handle)) {}
|
||||||
|
|
||||||
DriverResult RingConProtocol::EnableRingCon() {
|
DriverResult RingConProtocol::EnableRingCon() {
|
||||||
LOG_DEBUG(Input, "Enable Ringcon");
|
LOG_DEBUG(Input, "Enable Ringcon");
|
||||||
|
@ -78,7 +78,7 @@ DriverResult RingConProtocol::IsRingConnected(bool& is_connected) {
|
||||||
is_connected = false;
|
is_connected = false;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
std::vector<u8> empty_data(0);
|
std::array<u8, 1> empty_data{};
|
||||||
const auto result = SendSubCommand(SubCommand::UNKNOWN_RINGCON, empty_data, output);
|
const auto result = SendSubCommand(SubCommand::UNKNOWN_RINGCON, empty_data, output);
|
||||||
|
|
||||||
if (result != DriverResult::Success) {
|
if (result != DriverResult::Success) {
|
||||||
|
@ -101,11 +101,11 @@ DriverResult RingConProtocol::ConfigureRing() {
|
||||||
std::vector<u8> output;
|
std::vector<u8> output;
|
||||||
std::size_t tries = 0;
|
std::size_t tries = 0;
|
||||||
|
|
||||||
|
static constexpr std::array<u8, 37> ring_config{
|
||||||
|
0x06, 0x03, 0x25, 0x06, 0x00, 0x00, 0x00, 0x00, 0x1C, 0x16, 0xED, 0x34, 0x36,
|
||||||
|
0x00, 0x00, 0x00, 0x0A, 0x64, 0x0B, 0xE6, 0xA9, 0x22, 0x00, 0x00, 0x04, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x90, 0xA8, 0xE1, 0x34, 0x36};
|
||||||
do {
|
do {
|
||||||
std::vector<u8> ring_config{0x06, 0x03, 0x25, 0x06, 0x00, 0x00, 0x00, 0x00, 0x1C, 0x16,
|
|
||||||
0xED, 0x34, 0x36, 0x00, 0x00, 0x00, 0x0A, 0x64, 0x0B, 0xE6,
|
|
||||||
0xA9, 0x22, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x90, 0xA8, 0xE1, 0x34, 0x36};
|
|
||||||
result = SendSubCommand(SubCommand::UNKNOWN_RINGCON3, ring_config, output);
|
result = SendSubCommand(SubCommand::UNKNOWN_RINGCON3, ring_config, output);
|
||||||
|
|
||||||
if (result != DriverResult::Success) {
|
if (result != DriverResult::Success) {
|
||||||
|
@ -116,13 +116,13 @@ DriverResult RingConProtocol::ConfigureRing() {
|
||||||
}
|
}
|
||||||
} while (output[14] != 0x5C);
|
} while (output[14] != 0x5C);
|
||||||
|
|
||||||
std::vector<u8> ringcon_data{0x04, 0x01, 0x01, 0x02};
|
static constexpr std::array<u8, 4> ringcon_data{0x04, 0x01, 0x01, 0x02};
|
||||||
result = SendSubCommand(SubCommand::UNKNOWN_RINGCON2, ringcon_data, output);
|
result = SendSubCommand(SubCommand::UNKNOWN_RINGCON2, ringcon_data, output);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool RingConProtocol::IsEnabled() {
|
bool RingConProtocol::IsEnabled() const {
|
||||||
return is_enabled;
|
return is_enabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,7 @@ namespace InputCommon::Joycon {
|
||||||
|
|
||||||
class RingConProtocol final : private JoyconCommonProtocol {
|
class RingConProtocol final : private JoyconCommonProtocol {
|
||||||
public:
|
public:
|
||||||
RingConProtocol(std::shared_ptr<JoyconHandle> handle);
|
explicit RingConProtocol(std::shared_ptr<JoyconHandle> handle);
|
||||||
|
|
||||||
DriverResult EnableRingCon();
|
DriverResult EnableRingCon();
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ public:
|
||||||
|
|
||||||
DriverResult StartRingconPolling();
|
DriverResult StartRingconPolling();
|
||||||
|
|
||||||
bool IsEnabled();
|
bool IsEnabled() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DriverResult IsRingConnected(bool& is_connected);
|
DriverResult IsRingConnected(bool& is_connected);
|
||||||
|
|
|
@ -1,17 +1,20 @@
|
||||||
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
|
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
|
||||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
|
#include <cmath>
|
||||||
|
|
||||||
#include "common/logging/log.h"
|
#include "common/logging/log.h"
|
||||||
#include "input_common/helpers/joycon_protocol/rumble.h"
|
#include "input_common/helpers/joycon_protocol/rumble.h"
|
||||||
|
|
||||||
namespace InputCommon::Joycon {
|
namespace InputCommon::Joycon {
|
||||||
|
|
||||||
RumbleProtocol::RumbleProtocol(std::shared_ptr<JoyconHandle> handle)
|
RumbleProtocol::RumbleProtocol(std::shared_ptr<JoyconHandle> handle)
|
||||||
: JoyconCommonProtocol(handle) {}
|
: JoyconCommonProtocol(std::move(handle)) {}
|
||||||
|
|
||||||
DriverResult RumbleProtocol::EnableRumble(bool is_enabled) {
|
DriverResult RumbleProtocol::EnableRumble(bool is_enabled) {
|
||||||
LOG_DEBUG(Input, "Enable Rumble");
|
LOG_DEBUG(Input, "Enable Rumble");
|
||||||
const std::vector<u8> buffer{static_cast<u8>(is_enabled ? 1 : 0)};
|
const std::array<u8, 1> buffer{static_cast<u8>(is_enabled ? 1 : 0)};
|
||||||
std::vector<u8> output;
|
std::vector<u8> output;
|
||||||
SetBlocking();
|
SetBlocking();
|
||||||
const auto result = SendSubCommand(SubCommand::ENABLE_VIBRATION, buffer, output);
|
const auto result = SendSubCommand(SubCommand::ENABLE_VIBRATION, buffer, output);
|
||||||
|
@ -20,7 +23,7 @@ DriverResult RumbleProtocol::EnableRumble(bool is_enabled) {
|
||||||
}
|
}
|
||||||
|
|
||||||
DriverResult RumbleProtocol::SendVibration(const VibrationValue& vibration) {
|
DriverResult RumbleProtocol::SendVibration(const VibrationValue& vibration) {
|
||||||
std::vector<u8> buffer(sizeof(DefaultVibrationBuffer));
|
std::array<u8, sizeof(DefaultVibrationBuffer)> buffer{};
|
||||||
|
|
||||||
if (vibration.high_amplitude <= 0.0f && vibration.low_amplitude <= 0.0f) {
|
if (vibration.high_amplitude <= 0.0f && vibration.low_amplitude <= 0.0f) {
|
||||||
return SendVibrationReport(DefaultVibrationBuffer);
|
return SendVibrationReport(DefaultVibrationBuffer);
|
||||||
|
@ -66,7 +69,7 @@ u8 RumbleProtocol::EncodeHighAmplitude(f32 amplitude) const {
|
||||||
/* More information about these values can be found here:
|
/* More information about these values can be found here:
|
||||||
* https://github.com/dekuNukem/Nintendo_Switch_Reverse_Engineering/blob/master/rumble_data_table.md
|
* https://github.com/dekuNukem/Nintendo_Switch_Reverse_Engineering/blob/master/rumble_data_table.md
|
||||||
*/
|
*/
|
||||||
constexpr std::array<std::pair<f32, int>, 101> high_fequency_amplitude{
|
static constexpr std::array<std::pair<f32, int>, 101> high_fequency_amplitude{
|
||||||
std::pair<f32, int>{0.0f, 0x0},
|
std::pair<f32, int>{0.0f, 0x0},
|
||||||
{0.01f, 0x2},
|
{0.01f, 0x2},
|
||||||
{0.012f, 0x4},
|
{0.012f, 0x4},
|
||||||
|
@ -183,7 +186,7 @@ u16 RumbleProtocol::EncodeLowAmplitude(f32 amplitude) const {
|
||||||
/* More information about these values can be found here:
|
/* More information about these values can be found here:
|
||||||
* https://github.com/dekuNukem/Nintendo_Switch_Reverse_Engineering/blob/master/rumble_data_table.md
|
* https://github.com/dekuNukem/Nintendo_Switch_Reverse_Engineering/blob/master/rumble_data_table.md
|
||||||
*/
|
*/
|
||||||
constexpr std::array<std::pair<f32, int>, 101> high_fequency_amplitude{
|
static constexpr std::array<std::pair<f32, int>, 101> high_fequency_amplitude{
|
||||||
std::pair<f32, int>{0.0f, 0x0040},
|
std::pair<f32, int>{0.0f, 0x0040},
|
||||||
{0.01f, 0x8040},
|
{0.01f, 0x8040},
|
||||||
{0.012f, 0x0041},
|
{0.012f, 0x0041},
|
||||||
|
|
|
@ -17,7 +17,7 @@ namespace InputCommon::Joycon {
|
||||||
|
|
||||||
class RumbleProtocol final : private JoyconCommonProtocol {
|
class RumbleProtocol final : private JoyconCommonProtocol {
|
||||||
public:
|
public:
|
||||||
RumbleProtocol(std::shared_ptr<JoyconHandle> handle);
|
explicit RumbleProtocol(std::shared_ptr<JoyconHandle> handle);
|
||||||
|
|
||||||
DriverResult EnableRumble(bool is_enabled);
|
DriverResult EnableRumble(bool is_enabled);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue