Merge pull request #1412 from ggrtk/sdl-rumble-duration-fix
CommonHostInterface: Update rumble every frame regardless of change
This commit is contained in:
commit
c6da182232
|
@ -1055,16 +1055,10 @@ void CommonHostInterface::UpdateControllerRumble()
|
|||
if (!controller)
|
||||
continue;
|
||||
|
||||
bool changed = false;
|
||||
for (u32 i = 0; i < rumble.num_motors; i++)
|
||||
{
|
||||
const float strength = controller->GetVibrationMotorStrength(i);
|
||||
changed |= (strength != rumble.last_strength[i]);
|
||||
rumble.last_strength[i] = strength;
|
||||
}
|
||||
rumble.last_strength[i] = controller->GetVibrationMotorStrength(i);
|
||||
|
||||
if (changed)
|
||||
rumble.update_callback(rumble.last_strength.data(), rumble.num_motors);
|
||||
rumble.update_callback(rumble.last_strength.data(), rumble.num_motors);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1072,15 +1066,10 @@ void CommonHostInterface::StopControllerRumble()
|
|||
{
|
||||
for (ControllerRumbleState& rumble : m_controller_vibration_motors)
|
||||
{
|
||||
bool changed = false;
|
||||
for (u32 i = 0; i < rumble.num_motors; i++)
|
||||
{
|
||||
changed |= (rumble.last_strength[i] != 0.0f);
|
||||
rumble.last_strength[i] = 0.0f;
|
||||
}
|
||||
|
||||
if (changed)
|
||||
rumble.update_callback(rumble.last_strength.data(), rumble.num_motors);
|
||||
rumble.update_callback(rumble.last_strength.data(), rumble.num_motors);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -710,7 +710,7 @@ void SDLControllerInterface::SetControllerRumbleStrength(int controller_index, c
|
|||
return;
|
||||
|
||||
// we'll update before this duration is elapsed
|
||||
static constexpr u32 DURATION = 1000;
|
||||
static constexpr u32 DURATION = 65535; // SDL_MAX_RUMBLE_DURATION_MS
|
||||
|
||||
#if SDL_VERSION_ATLEAST(2, 0, 9)
|
||||
if (it->use_game_controller_rumble)
|
||||
|
|
Loading…
Reference in New Issue