forked from ShuriZma/suyu
Merge pull request #10386 from german77/high
input_common: Map motion with relative values not absolute ones
This commit is contained in:
commit
e8a025b4f8
|
@ -380,13 +380,16 @@ void InputEngine::TriggerOnMotionChange(const PadIdentifier& identifier, int mot
|
||||||
if (!configuring || !mapping_callback.on_data) {
|
if (!configuring || !mapping_callback.on_data) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
const auto old_value = GetMotion(identifier, motion);
|
||||||
bool is_active = false;
|
bool is_active = false;
|
||||||
if (std::abs(value.accel_x) > 1.5f || std::abs(value.accel_y) > 1.5f ||
|
if (std::abs(value.accel_x - old_value.accel_x) > 1.5f ||
|
||||||
std::abs(value.accel_z) > 1.5f) {
|
std::abs(value.accel_y - old_value.accel_y) > 1.5f ||
|
||||||
|
std::abs(value.accel_z - old_value.accel_z) > 1.5f) {
|
||||||
is_active = true;
|
is_active = true;
|
||||||
}
|
}
|
||||||
if (std::abs(value.gyro_x) > 0.6f || std::abs(value.gyro_y) > 0.6f ||
|
if (std::abs(value.gyro_x - old_value.gyro_x) > 0.6f ||
|
||||||
std::abs(value.gyro_z) > 0.6f) {
|
std::abs(value.gyro_y - old_value.gyro_y) > 0.6f ||
|
||||||
|
std::abs(value.gyro_z - old_value.gyro_z) > 0.6f) {
|
||||||
is_active = true;
|
is_active = true;
|
||||||
}
|
}
|
||||||
if (!is_active) {
|
if (!is_active) {
|
||||||
|
|
Loading…
Reference in New Issue