Skip to content

Commit

Permalink
Merge pull request ppy#18238 from peppy/fix-slider-ball-rotation
Browse files Browse the repository at this point in the history
Fix slider ball rotation becoming undefined when time is not flowing smoothly
  • Loading branch information
smoogipoo authored May 12, 2022
2 parents 5f2d9bf + c4854d4 commit b48308e
Showing 1 changed file with 6 additions and 6 deletions.
12 changes: 6 additions & 6 deletions osu.Game.Rulesets.Osu/Skinning/Default/SliderBall.cs
Original file line number Diff line number Diff line change
Expand Up @@ -195,16 +195,16 @@ private bool isValidTrackingAction(OsuAction action)

public void UpdateProgress(double completionProgress)
{
var newPos = drawableSlider.HitObject.CurvePositionAt(completionProgress);
Position = drawableSlider.HitObject.CurvePositionAt(completionProgress);

var diff = lastPosition.HasValue ? lastPosition.Value - newPos : newPos - drawableSlider.HitObject.CurvePositionAt(completionProgress + 0.01f);
if (diff == Vector2.Zero)
var diff = lastPosition.HasValue ? lastPosition.Value - Position : Position - drawableSlider.HitObject.CurvePositionAt(completionProgress + 0.01f);

// Ensure the value is substantially high enough to allow for Atan2 to get a valid angle.
if (diff.LengthFast < 0.01f)
return;

Position = newPos;
ball.Rotation = -90 + (float)(-Math.Atan2(diff.X, diff.Y) * 180 / Math.PI);

lastPosition = newPos;
lastPosition = Position;
}

private class FollowCircleContainer : CircularContainer
Expand Down

0 comments on commit b48308e

Please sign in to comment.