mirror of
https://github.com/ppy/osu.git
synced 2024-12-14 06:12:56 +08:00
Adjust to new path structure
This commit is contained in:
parent
54ab256c8e
commit
51e4feeda7
@ -45,8 +45,6 @@ namespace osu.Game.Rulesets.Osu.Edit.Blueprints.Sliders.Components
|
|||||||
{
|
{
|
||||||
base.Update();
|
base.Update();
|
||||||
|
|
||||||
slider.Path.Calculate();
|
|
||||||
|
|
||||||
var vertices = new List<Vector2>();
|
var vertices = new List<Vector2>();
|
||||||
slider.Path.GetPathToProgress(vertices, 0, 1);
|
slider.Path.GetPathToProgress(vertices, 0, 1);
|
||||||
|
|
||||||
|
@ -1,16 +1,15 @@
|
|||||||
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Extensions.IEnumerableExtensions;
|
using osu.Framework.Extensions.IEnumerableExtensions;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Input.Events;
|
using osu.Framework.Input.Events;
|
||||||
using osu.Framework.MathUtils;
|
|
||||||
using osu.Game.Graphics;
|
using osu.Game.Graphics;
|
||||||
using osu.Game.Rulesets.Edit;
|
using osu.Game.Rulesets.Edit;
|
||||||
|
using osu.Game.Rulesets.Objects;
|
||||||
using osu.Game.Rulesets.Objects.Types;
|
using osu.Game.Rulesets.Objects.Types;
|
||||||
using osu.Game.Rulesets.Osu.Edit.Blueprints.Sliders.Components;
|
using osu.Game.Rulesets.Osu.Edit.Blueprints.Sliders.Components;
|
||||||
using OpenTK;
|
using OpenTK;
|
||||||
@ -119,12 +118,8 @@ namespace osu.Game.Rulesets.Osu.Edit.Blueprints.Sliders
|
|||||||
|
|
||||||
private void updateSlider()
|
private void updateSlider()
|
||||||
{
|
{
|
||||||
for (int i = 0; i < segments.Count; i++)
|
var newControlPoints = segments.SelectMany(s => s.ControlPoints).Concat(cursor.Yield()).ToArray();
|
||||||
segments[i].Calculate(i == segments.Count - 1 ? (Vector2?)cursor : null);
|
HitObject.Path = new SliderPath(newControlPoints.Length > 2 ? PathType.Bezier : PathType.Linear, newControlPoints);
|
||||||
|
|
||||||
HitObject.ControlPoints = segments.SelectMany(s => s.ControlPoints).Concat(cursor.Yield()).ToArray();
|
|
||||||
HitObject.PathType = HitObject.ControlPoints.Length > 2 ? PathType.Bezier : PathType.Linear;
|
|
||||||
HitObject.Distance = segments.Sum(s => s.Distance);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setState(PlacementState newState)
|
private void setState(PlacementState newState)
|
||||||
@ -140,41 +135,12 @@ namespace osu.Game.Rulesets.Osu.Edit.Blueprints.Sliders
|
|||||||
|
|
||||||
private class Segment
|
private class Segment
|
||||||
{
|
{
|
||||||
public float Distance { get; private set; }
|
|
||||||
|
|
||||||
public readonly List<Vector2> ControlPoints = new List<Vector2>();
|
public readonly List<Vector2> ControlPoints = new List<Vector2>();
|
||||||
|
|
||||||
public Segment(Vector2 offset)
|
public Segment(Vector2 offset)
|
||||||
{
|
{
|
||||||
ControlPoints.Add(offset);
|
ControlPoints.Add(offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Calculate(Vector2? cursor = null)
|
|
||||||
{
|
|
||||||
Span<Vector2> allControlPoints = stackalloc Vector2[ControlPoints.Count + (cursor.HasValue ? 1 : 0)];
|
|
||||||
|
|
||||||
for (int i = 0; i < ControlPoints.Count; i++)
|
|
||||||
allControlPoints[i] = ControlPoints[i];
|
|
||||||
if (cursor.HasValue)
|
|
||||||
allControlPoints[allControlPoints.Length - 1] = cursor.Value;
|
|
||||||
|
|
||||||
List<Vector2> result;
|
|
||||||
|
|
||||||
switch (allControlPoints.Length)
|
|
||||||
{
|
|
||||||
case 1:
|
|
||||||
case 2:
|
|
||||||
result = PathApproximator.ApproximateLinear(allControlPoints);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
result = PathApproximator.ApproximateBezier(allControlPoints);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
Distance = 0;
|
|
||||||
for (int i = 0; i < result.Count - 1; i++)
|
|
||||||
Distance += Vector2.Distance(result[i], result[i + 1]);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user