mirror of
https://github.com/ppy/osu.git
synced 2025-01-14 04:02:59 +08:00
Remove determinant limit
This has since been added into the framework through https://github.com/ppy/osu-framework/pull/4302
This commit is contained in:
parent
9df059b01d
commit
ce9130ca50
@ -158,48 +158,11 @@ namespace osu.Game.Rulesets.Osu.Edit.Blueprints.Sliders.Components
|
||||
continue;
|
||||
|
||||
Vector2[] points = slider.Path.PointsInSegment(segmentStartPoint).Select(p => p.Position.Value).ToArray();
|
||||
if (points.Length == 3 && !validCircularArcSegment(points))
|
||||
if (points.Length == 3 && circularArcBoundingBox(points).Area >= 640 * 480)
|
||||
segmentStartPoint.Type.Value = PathType.Bezier;
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Returns whether the given points are arranged in a valid way. Invalid if points
|
||||
/// are almost entirely linear - as this causes the radius to approach infinity,
|
||||
/// or if the bounding box of the arc is too large.
|
||||
/// </summary>
|
||||
/// <param name="points">The three points that make up this circular arc segment.</param>
|
||||
/// <returns></returns>
|
||||
private bool validCircularArcSegment(IReadOnlyList<Vector2> points)
|
||||
{
|
||||
float det = circularArcDeterminant(points);
|
||||
RectangleF boundingBox = circularArcBoundingBox(points);
|
||||
|
||||
// Determinant limit prevents memory exhaustion as a result of approximating the subpath.
|
||||
// Bounding box area limit prevents memory exhaustion as a result of drawing the texture.
|
||||
return Math.Abs(det) > 0.001f && boundingBox.Area < 640 * 480;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Computes the determinant of the circular arc segment defined by the given points.
|
||||
/// </summary>
|
||||
/// <param name="points">The three points defining the circular arc.</param>
|
||||
/// <returns></returns>
|
||||
private float circularArcDeterminant(IReadOnlyList<Vector2> points)
|
||||
{
|
||||
Vector2 a = points[0];
|
||||
Vector2 b = points[1];
|
||||
Vector2 c = points[2];
|
||||
|
||||
float maxLength = points.Max(p => p.Length);
|
||||
|
||||
Vector2 normA = new Vector2(a.X / maxLength, a.Y / maxLength);
|
||||
Vector2 normB = new Vector2(b.X / maxLength, b.Y / maxLength);
|
||||
Vector2 normC = new Vector2(c.X / maxLength, c.Y / maxLength);
|
||||
|
||||
return (normA.X - normB.X) * (normB.Y - normC.Y) - (normB.X - normC.X) * (normA.Y - normB.Y);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Computes the bounding box of the circular arc segment defined by the given points.
|
||||
/// </summary>
|
||||
|
Loading…
Reference in New Issue
Block a user