osu/osu.Game.Rulesets.Catch/Objects/CatchHitObject.cs

137 lines
4.4 KiB
C#
Raw Normal View History

// 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
2020-12-09 08:47:17 +00:00
using System;
using osu.Framework.Bindables;
2018-04-13 09:19:50 +00:00
using osu.Game.Beatmaps;
using osu.Game.Beatmaps.ControlPoints;
using osu.Game.Rulesets.Catch.Beatmaps;
using osu.Game.Rulesets.Catch.UI;
2018-04-13 09:19:50 +00:00
using osu.Game.Rulesets.Objects;
using osu.Game.Rulesets.Objects.Types;
2019-09-06 06:24:00 +00:00
using osu.Game.Rulesets.Scoring;
2018-04-13 09:19:50 +00:00
namespace osu.Game.Rulesets.Catch.Objects
{
public abstract class CatchHitObject : HitObject, IHasXPosition, IHasComboInformation
{
public const float OBJECT_RADIUS = 64;
2018-04-13 09:19:50 +00:00
public readonly Bindable<float> OriginalXBindable = new Bindable<float>();
2020-11-27 01:31:18 +00:00
/// <summary>
/// The horizontal position of the hit object between 0 and <see cref="CatchPlayfield.WIDTH"/>.
/// </summary>
/// <remarks>
/// This value is the original value specified in the beatmap, not affected by beatmap processing.
/// </remarks>
public float OriginalX
{
get => OriginalXBindable.Value;
set => OriginalXBindable.Value = value;
}
/// <summary>
/// The horizontal position of the fruit between 0 and <see cref="CatchPlayfield.WIDTH"/>.
/// </summary>
public float X
{
2020-12-09 08:47:17 +00:00
[Obsolete("Use EffectiveX instead")]
get => EffectiveX;
set => OriginalXBindable.Value = value;
}
public readonly Bindable<float> EffectiveXBindable = new Bindable<float>();
/// <summary>
/// The effective horizontal position of the hit object between 0 and <see cref="CatchPlayfield.WIDTH"/>.
/// </summary>
public float EffectiveX => EffectiveXBindable.Value;
2020-11-27 01:31:18 +00:00
private float xOffset;
/// <summary>
/// A random offset applied to the horizontal value, set by the <see cref="CatchBeatmapProcessor"/>.
/// </summary>
2020-11-27 01:31:18 +00:00
internal float XOffset
{
set
{
xOffset = value;
EffectiveXBindable.Value = OriginalX + xOffset;
2020-11-27 01:31:18 +00:00
}
}
2018-04-13 09:19:50 +00:00
2019-06-28 08:34:04 +00:00
public double TimePreempt = 1000;
2020-11-27 01:31:18 +00:00
public readonly Bindable<int> IndexInBeatmapBindable = new Bindable<int>();
public int IndexInBeatmap
{
get => IndexInBeatmapBindable.Value;
set => IndexInBeatmapBindable.Value = value;
}
2018-04-13 09:19:50 +00:00
public virtual bool NewCombo { get; set; }
2018-08-15 02:47:31 +00:00
public int ComboOffset { get; set; }
public Bindable<int> IndexInCurrentComboBindable { get; } = new Bindable<int>();
2018-04-13 09:19:50 +00:00
public int IndexInCurrentCombo
{
get => IndexInCurrentComboBindable.Value;
set => IndexInCurrentComboBindable.Value = value;
}
public Bindable<int> ComboIndexBindable { get; } = new Bindable<int>();
public int ComboIndex
{
get => ComboIndexBindable.Value;
set => ComboIndexBindable.Value = value;
}
2018-04-13 09:19:50 +00:00
public Bindable<bool> LastInComboBindable { get; } = new Bindable<bool>();
/// <summary>
2018-04-13 09:19:50 +00:00
/// The next fruit starts a new combo. Used for explodey.
/// </summary>
public virtual bool LastInCombo
{
get => LastInComboBindable.Value;
set => LastInComboBindable.Value = value;
}
2018-04-13 09:19:50 +00:00
2020-11-27 01:31:18 +00:00
public readonly Bindable<float> ScaleBindable = new Bindable<float>(1);
public float Scale
{
get => ScaleBindable.Value;
set => ScaleBindable.Value = value;
}
2018-04-13 09:19:50 +00:00
/// <summary>
/// The seed value used for visual randomness such as fruit rotation.
/// The value is <see cref="HitObject.StartTime"/> truncated to an integer.
/// </summary>
public int RandomSeed => (int)StartTime;
2018-04-13 09:19:50 +00:00
protected override void ApplyDefaultsToSelf(ControlPointInfo controlPointInfo, BeatmapDifficulty difficulty)
{
base.ApplyDefaultsToSelf(controlPointInfo, difficulty);
2019-06-28 08:34:04 +00:00
TimePreempt = (float)BeatmapDifficulty.DifficultyRange(difficulty.ApproachRate, 1800, 1200, 450);
Scale = (1.0f - 0.7f * (difficulty.CircleSize - 5) / 5) / 2;
2018-04-13 09:19:50 +00:00
}
2019-10-09 10:08:31 +00:00
protected override HitWindows CreateHitWindows() => HitWindows.Empty;
2020-11-27 01:31:18 +00:00
protected CatchHitObject()
{
OriginalXBindable.BindValueChanged(change => EffectiveXBindable.Value = change.NewValue + xOffset);
2020-11-27 01:31:18 +00:00
}
2018-04-13 09:19:50 +00:00
}
}