1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-06 02:33:25 +08:00
osu-lazer/osu.Game/Beatmaps/ControlPoints/ControlPoint.cs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

85 lines
2.7 KiB
C#
Raw Normal View History

2019-10-25 18:58:42 +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.
2018-04-13 17:19:50 +08:00
using System;
using System.Diagnostics.CodeAnalysis;
using Newtonsoft.Json;
using osu.Game.Graphics;
using osu.Game.Utils;
using osuTK.Graphics;
2018-04-13 17:19:50 +08:00
namespace osu.Game.Beatmaps.ControlPoints
{
[DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.PublicParameterlessConstructor)]
public abstract class ControlPoint : IComparable<ControlPoint>, IDeepCloneable<ControlPoint>, IEquatable<ControlPoint>, IControlPoint
{
/// <summary>
/// Invoked when any of this <see cref="ControlPoint"/>'s properties have changed.
/// </summary>
public event Action<ControlPoint>? Changed;
protected void RaiseChanged() => Changed?.Invoke(this);
private double time;
[JsonIgnore]
public double Time
{
get => time;
set
{
if (time == value)
return;
time = value;
RaiseChanged();
}
}
2018-04-13 17:19:50 +08:00
2021-09-10 13:35:53 +08:00
public void AttachGroup(ControlPointGroup pointGroup) => Time = pointGroup.Time;
2019-10-25 18:48:01 +08:00
public int CompareTo(ControlPoint? other) => Time.CompareTo(other?.Time);
2018-04-13 17:19:50 +08:00
public virtual Color4 GetRepresentingColour(OsuColour colours) => colours.Yellow;
2020-04-08 16:42:35 +08:00
/// <summary>
2020-04-17 16:06:12 +08:00
/// Determines whether this <see cref="ControlPoint"/> results in a meaningful change when placed alongside another.
2020-04-08 16:42:35 +08:00
/// </summary>
2020-04-10 00:34:40 +08:00
/// <param name="existing">An existing control point to compare with.</param>
2020-04-17 16:06:12 +08:00
/// <returns>Whether this <see cref="ControlPoint"/> is redundant when placed alongside <paramref name="existing"/>.</returns>
2022-06-20 15:52:01 +08:00
public abstract bool IsRedundant(ControlPoint? existing);
/// <summary>
2021-01-07 18:06:10 +08: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 13:35:53 +08:00
Time = other.Time;
}
2022-06-20 13:56:04 +08:00
public sealed override bool Equals(object? obj)
=> obj is ControlPoint otherControlPoint
&& Equals(otherControlPoint);
public virtual bool Equals(ControlPoint? other)
{
if (ReferenceEquals(other, null)) return false;
if (ReferenceEquals(other, this)) return true;
return Time == other.Time;
}
2022-06-20 13:56:04 +08:00
// ReSharper disable once NonReadonlyMemberInGetHashCode
public override int GetHashCode() => Time.GetHashCode();
}
}