osu/osu.Game/Beatmaps/ControlPoints/ControlPoint.cs

51 lines
1.7 KiB
C#
Raw Normal View History

2019-10-25 10:58:42 +00: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.
2018-04-13 09:19:50 +00:00
using System;
using Newtonsoft.Json;
using osu.Game.Graphics;
using osu.Game.Utils;
using osuTK.Graphics;
2018-04-13 09:19:50 +00:00
namespace osu.Game.Beatmaps.ControlPoints
{
public abstract class ControlPoint : IComparable<ControlPoint>, IDeepCloneable<ControlPoint>
2018-04-13 09:19:50 +00:00
{
/// <summary>
/// The time at which the control point takes effect.
/// </summary>
[JsonIgnore]
2021-09-10 05:35:53 +00:00
public double Time { get; set; }
2018-04-13 09:19:50 +00:00
2021-09-10 05:35:53 +00:00
public void AttachGroup(ControlPointGroup pointGroup) => Time = pointGroup.Time;
2019-10-25 10:48:01 +00:00
2018-04-13 09:19:50 +00:00
public int CompareTo(ControlPoint other) => Time.CompareTo(other.Time);
public virtual Color4 GetRepresentingColour(OsuColour colours) => colours.Yellow;
2020-04-08 08:42:35 +00:00
/// <summary>
2020-04-17 08:06:12 +00:00
/// Determines whether this <see cref="ControlPoint"/> results in a meaningful change when placed alongside another.
2020-04-08 08:42:35 +00:00
/// </summary>
2020-04-09 16:34:40 +00:00
/// <param name="existing">An existing control point to compare with.</param>
2020-04-17 08:06:12 +00:00
/// <returns>Whether this <see cref="ControlPoint"/> is redundant when placed alongside <paramref name="existing"/>.</returns>
public abstract bool IsRedundant(ControlPoint existing);
/// <summary>
2021-01-07 10:06:10 +00:00
/// Create an unbound copy of this control point.
/// </summary>
public ControlPoint DeepClone()
{
var copy = (ControlPoint)Activator.CreateInstance(GetType());
copy.CopyFrom(this);
return copy;
}
public virtual void CopyFrom(ControlPoint other)
{
2021-09-10 05:35:53 +00:00
Time = other.Time;
}
2018-04-13 09:19:50 +00:00
}
}