1
0
mirror of https://github.com/ppy/osu.git synced 2024-11-19 06:42:54 +08:00
osu-lazer/osu.Game.Rulesets.Taiko/Mods/TaikoModHidden.cs

104 lines
4.3 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 17:19:50 +08:00
2021-06-11 15:07:38 +08:00
using osu.Framework.Bindables;
using osu.Framework.Graphics;
using osu.Game.Beatmaps;
using osu.Game.Beatmaps.ControlPoints;
using osu.Game.Configuration;
2018-04-13 17:19:50 +08:00
using osu.Game.Rulesets.Mods;
using osu.Game.Rulesets.Objects;
2021-05-15 11:51:39 +08:00
using osu.Game.Rulesets.Objects.Drawables;
using osu.Game.Rulesets.Scoring;
2021-06-11 15:07:38 +08:00
using osu.Game.Rulesets.Taiko.Objects.Drawables;
2018-04-13 17:19:50 +08:00
namespace osu.Game.Rulesets.Taiko.Mods
{
2021-06-11 15:07:38 +08:00
public class TaikoModHidden : ModHidden, IApplicableToDifficulty
2018-04-13 17:19:50 +08:00
{
public override string Description => @"Beats fade out before you hit them!";
public override double ScoreMultiplier => 1.06;
2021-06-11 15:07:38 +08:00
2021-06-16 04:33:27 +08:00
[SettingSource("Fade-out Time", "The bigger this multiplier is, the sooner the notes will start fading out")]
public BindableNumber<double> FadeOutTimeMultiplier { get; } = new BindableDouble
{
MinValue = 0.5,
MaxValue = 1.5,
Default = 1.0,
Value = 1.0,
Precision = 0.01,
};
2021-06-16 04:32:26 +08:00
/// <summary>
/// In stable taiko, the hit position is 160, so the active playfield is essentially 160 pixels shorter
/// than the actual screen width. The normalized playfield height is 480, so on a 4:3 screen the
/// playfield ratio of the active area up to the hit position will actually be (640 - 160) / 480 = 1.
/// For custom resolutions/aspect ratios (x:y), the screen width given the normalized height becomes 480 * x / y instead,
/// and the playfield ratio becomes (480 * x / y - 160) / 480 = x / y - 1/3.
/// This constant is equal to the playfield ratio on 4:3 screens divided by the playfield ratio on 16:9 screens.
/// </summary>
2021-06-11 16:54:30 +08:00
private const double hd_sv_scale = (4.0 / 3.0 - 1.0 / 3.0) / (16.0 / 9.0 - 1.0 / 3.0);
2021-06-16 04:32:26 +08:00
2021-06-11 15:07:38 +08:00
private BeatmapDifficulty difficulty;
private ControlPointInfo controlPointInfo;
2021-05-15 11:51:39 +08:00
protected override void ApplyIncreasedVisibilityState(DrawableHitObject hitObject, ArmedState state)
{
2021-06-11 15:07:38 +08:00
ApplyNormalVisibilityState(hitObject, state);
}
protected double MultiplierAt(double position)
{
var beatLength = controlPointInfo.TimingPointAt(position)?.BeatLength;
var speedMultiplier = controlPointInfo.DifficultyPointAt(position)?.SpeedMultiplier;
return difficulty.SliderMultiplier * (speedMultiplier ?? 1.0) * TimingControlPoint.DEFAULT_BEAT_LENGTH / (beatLength ?? TimingControlPoint.DEFAULT_BEAT_LENGTH);
2021-05-15 11:51:39 +08:00
}
protected override void ApplyNormalVisibilityState(DrawableHitObject hitObject, ArmedState state)
{
2021-06-11 15:07:38 +08:00
switch (hitObject)
{
case DrawableDrumRollTick _:
break;
case DrawableHit _:
break;
default:
return;
}
// I *think* it's like this because stable's default velocity multiplier is 1.4
2021-06-16 04:33:27 +08:00
var preempt = 14000 / MultiplierAt(hitObject.HitObject.StartTime) * FadeOutTimeMultiplier.Value;
2021-06-11 15:07:38 +08:00
var start = hitObject.HitObject.StartTime - preempt * 0.6;
var duration = preempt * 0.3;
using (hitObject.BeginAbsoluteSequence(start))
{
hitObject.FadeOut(duration);
// DrawableHitObject sets LifetimeEnd to LatestTransformEndTime if it isn't manually changed.
// in order for the object to not be killed before its actual end time (as the latest transform ends earlier), set lifetime end explicitly.
hitObject.LifetimeEnd = state == ArmedState.Idle
? hitObject.HitObject.GetEndTime() + hitObject.HitObject.HitWindows.WindowFor(HitResult.Miss)
: hitObject.HitStateUpdateTime;
2021-06-11 15:07:38 +08:00
}
}
public void ReadFromDifficulty(BeatmapDifficulty difficulty)
{
}
public void ApplyToDifficulty(BeatmapDifficulty difficulty)
{
this.difficulty = difficulty;
difficulty.SliderMultiplier /= hd_sv_scale;
}
public override void ApplyToBeatmap(IBeatmap beatmap)
{
controlPointInfo = beatmap.ControlPointInfo;
2021-05-15 11:51:39 +08:00
}
2018-04-13 17:19:50 +08:00
}
}