1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-22 22:42:58 +08:00
osu-lazer/osu.Game/Screens/Edit/Compose/Components/CircularDistanceSnapGrid.cs

87 lines
3.2 KiB
C#
Raw Normal View History

2019-10-11 16:13:28 +08:00
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
using System;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Shapes;
2019-10-11 16:13:28 +08:00
using osu.Framework.Graphics.UserInterface;
using osu.Game.Rulesets.Objects;
2019-10-11 16:13:28 +08:00
using osuTK;
namespace osu.Game.Screens.Edit.Compose.Components
{
public abstract class CircularDistanceSnapGrid : DistanceSnapGrid
2019-10-11 16:13:28 +08:00
{
protected CircularDistanceSnapGrid(HitObject referenceObject, Vector2 startPosition, double startTime, double? endTime = null)
: base(referenceObject, startPosition, startTime, endTime)
2019-10-11 16:13:28 +08:00
{
}
protected override void CreateContent()
2019-10-11 16:13:28 +08:00
{
2019-10-23 16:56:09 +08:00
const float crosshair_thickness = 1;
const float crosshair_max_size = 10;
2019-10-23 16:56:09 +08:00
AddRangeInternal(new[]
{
2019-10-23 16:56:09 +08:00
new Box
{
Origin = Anchor.Centre,
Position = StartPosition,
2019-10-23 16:56:09 +08:00
Width = crosshair_thickness,
EdgeSmoothness = new Vector2(1),
Height = Math.Min(crosshair_max_size, DistanceSpacing * 2),
},
new Box
{
Origin = Anchor.Centre,
Position = StartPosition,
2019-10-23 16:56:09 +08:00
EdgeSmoothness = new Vector2(1),
Width = Math.Min(crosshair_max_size, DistanceSpacing * 2),
Height = crosshair_thickness,
}
});
float dx = Math.Max(StartPosition.X, DrawWidth - StartPosition.X);
float dy = Math.Max(StartPosition.Y, DrawHeight - StartPosition.Y);
2019-10-16 18:32:45 +08:00
float maxDistance = new Vector2(dx, dy).Length;
int requiredCircles = Math.Min(MaxIntervals, (int)(maxDistance / DistanceSpacing));
2019-10-11 16:13:28 +08:00
for (int i = 0; i < requiredCircles; i++)
{
float radius = (i + 1) * DistanceSpacing * 2;
AddInternal(new CircularProgress
{
Origin = Anchor.Centre,
Position = StartPosition,
2019-10-11 16:13:28 +08:00
Current = { Value = 1 },
Size = new Vector2(radius),
InnerRadius = 4 * 1f / radius,
Colour = GetColourForIndexFromPlacement(i)
2019-10-11 16:13:28 +08:00
});
}
}
public override (Vector2 position, double time) GetSnappedPosition(Vector2 position)
2019-10-11 16:13:28 +08:00
{
if (MaxIntervals == 0)
return (StartPosition, StartTime);
Vector2 direction = position - StartPosition;
if (direction == Vector2.Zero)
direction = new Vector2(0.001f, 0.001f);
2019-10-11 16:13:28 +08:00
float distance = direction.Length;
float radius = DistanceSpacing;
int radialCount = Math.Clamp((int)MathF.Round(distance / radius), 1, MaxIntervals);
2019-10-11 16:13:28 +08:00
Vector2 normalisedDirection = direction * new Vector2(1f / distance);
Vector2 snappedPosition = StartPosition + normalisedDirection * radialCount * radius;
return (snappedPosition, StartTime + SnapProvider.GetSnappedDurationFromDistance(ReferenceObject, (snappedPosition - StartPosition).Length));
2019-10-11 16:13:28 +08:00
}
}
}