1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-13 09:23:06 +08:00

Modify slider position directly

This commit is contained in:
smoogipoo 2018-10-24 13:42:51 +09:00
parent 8fa783b4c5
commit 6310c183fa
2 changed files with 20 additions and 35 deletions

View File

@ -23,12 +23,10 @@ namespace osu.Game.Rulesets.Osu.Edit.Masks
{
public new Slider HitObject => (Slider)base.HitObject;
private readonly CirclePlacementMask headMask;
private readonly CirclePlacementMask tailMask;
private readonly Path path;
private Path path;
private Container<SliderControlPoint> controlPointContainer;
private readonly List<Segment> segments = new List<Segment>();
private readonly Container<SliderControlPoint> controlPointContainer;
private Vector2 cursor;
private PlacementState state;
@ -37,24 +35,23 @@ namespace osu.Game.Rulesets.Osu.Edit.Masks
: base(new Slider())
{
RelativeSizeAxes = Axes.Both;
InternalChildren = new Drawable[]
{
path = new SmoothPath { PathWidth = 3 },
headMask = new CirclePlacementMask(),
tailMask = new CirclePlacementMask(),
controlPointContainer = new Container<SliderControlPoint> { RelativeSizeAxes = Axes.Both }
};
segments.Add(new Segment(Vector2.Zero));
setState(PlacementState.Initial);
}
[BackgroundDependencyLoader]
private void load(OsuColour colours)
{
InternalChildren = new Drawable[]
{
path = new SmoothPath { PathWidth = 3 },
new CirclePlacementMask(HitObject.HeadCircle),
new CirclePlacementMask(HitObject.TailCircle),
controlPointContainer = new Container<SliderControlPoint> { RelativeSizeAxes = Axes.Both }
};
path.Colour = colours.YellowDark;
setState(PlacementState.Initial);
}
protected override bool OnMouseMove(MouseMoveEvent e)
@ -62,11 +59,10 @@ namespace osu.Game.Rulesets.Osu.Edit.Masks
switch (state)
{
case PlacementState.Initial:
headMask.Position = e.MousePosition;
HitObject.Position = e.MousePosition;
return true;
case PlacementState.Body:
tailMask.Position = e.MousePosition;
cursor = tailMask.Position - headMask.Position;
cursor = e.MousePosition - HitObject.Position;
controlPointContainer.Last().NextPoint = e.MousePosition;
return true;
}
@ -121,7 +117,6 @@ namespace osu.Game.Rulesets.Osu.Edit.Masks
private void endCurve()
{
HitObject.Position = headMask.Position;
HitObject.ControlPoints = segments.SelectMany(s => s.ControlPoints).Concat(cursor.Yield()).ToList();
HitObject.CurveType = HitObject.ControlPoints.Count > 2 ? CurveType.Bezier : CurveType.Linear;
HitObject.Distance = segments.Sum(s => s.Distance);
@ -138,7 +133,7 @@ namespace osu.Game.Rulesets.Osu.Edit.Masks
switch (state)
{
case PlacementState.Body:
path.Position = headMask.Position;
path.Position = HitObject.Position;
path.ClearVertices();
for (int i = 0; i < segments.Count; i++)
@ -154,16 +149,6 @@ namespace osu.Game.Rulesets.Osu.Edit.Masks
private void setState(PlacementState newState)
{
switch (newState)
{
case PlacementState.Initial:
tailMask.Alpha = 0;
break;
case PlacementState.Body:
tailMask.Alpha = 1;
break;
}
state = newState;
}

View File

@ -12,15 +12,15 @@ namespace osu.Game.Rulesets.Osu.Edit.Masks
{
private class CirclePlacementMask : PlacementMask
{
public new HitCircle HitObject => (HitCircle)base.HitObject;
public CirclePlacementMask()
: base(new HitCircle())
public CirclePlacementMask(HitCircle hitCircle)
: base(hitCircle)
{
Origin = Anchor.Centre;
AutoSizeAxes = Axes.Both;
InternalChild = new HitCircleMask(HitObject);
InternalChild = new HitCircleMask(hitCircle);
hitCircle.PositionChanged += _ => Position = hitCircle.StackedPosition;
}
protected override bool Handle(UIEvent e) => false;