mirror of
https://github.com/ppy/osu.git
synced 2024-12-14 10:52:53 +08:00
Remove IUpdatableByHitObject completely
This commit is contained in:
parent
07d6a75e23
commit
b1d1a2400b
@ -6,7 +6,6 @@ using System.Collections.Generic;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using osu.Framework.Input.States;
|
using osu.Framework.Input.States;
|
||||||
using osu.Game.Rulesets.Mods;
|
using osu.Game.Rulesets.Mods;
|
||||||
using osu.Game.Rulesets.Objects.Drawables;
|
|
||||||
using osu.Game.Rulesets.Objects.Types;
|
using osu.Game.Rulesets.Objects.Types;
|
||||||
using osu.Game.Rulesets.Osu.Objects.Drawables;
|
using osu.Game.Rulesets.Osu.Objects.Drawables;
|
||||||
using osu.Game.Rulesets.UI;
|
using osu.Game.Rulesets.UI;
|
||||||
@ -14,48 +13,45 @@ using static osu.Game.Input.Handlers.ReplayInputHandler;
|
|||||||
|
|
||||||
namespace osu.Game.Rulesets.Osu.Mods
|
namespace osu.Game.Rulesets.Osu.Mods
|
||||||
{
|
{
|
||||||
public class OsuModRelax : ModRelax, IApplicableFailOverride, IUpdatableByHitObject, IUpdatableByPlayfield
|
public class OsuModRelax : ModRelax, IApplicableFailOverride, IUpdatableByPlayfield
|
||||||
{
|
{
|
||||||
public override string Description => @"You don't need to click. Give your clicking/tapping fingers a break from the heat of things.";
|
public override string Description => @"You don't need to click. Give your clicking/tapping fingers a break from the heat of things.";
|
||||||
public override Type[] IncompatibleMods => base.IncompatibleMods.Append(typeof(OsuModAutopilot)).ToArray();
|
public override Type[] IncompatibleMods => base.IncompatibleMods.Append(typeof(OsuModAutopilot)).ToArray();
|
||||||
|
|
||||||
public bool AllowFail => false;
|
public bool AllowFail => false;
|
||||||
|
|
||||||
private bool hitStill;
|
|
||||||
private bool hitOnce;
|
|
||||||
|
|
||||||
public void Update(DrawableHitObject drawable)
|
|
||||||
{
|
|
||||||
const float relax_leniency = 3;
|
|
||||||
|
|
||||||
if (!(drawable is DrawableOsuHitObject osuHit))
|
|
||||||
return;
|
|
||||||
|
|
||||||
double time = osuHit.Clock.CurrentTime;
|
|
||||||
|
|
||||||
if (time >= osuHit.HitObject.StartTime - relax_leniency)
|
|
||||||
{
|
|
||||||
if (osuHit.HitObject is IHasEndTime hasEnd && time > hasEnd.EndTime || osuHit.IsHit)
|
|
||||||
return;
|
|
||||||
|
|
||||||
hitStill |= osuHit is DrawableSlider slider && (slider.Ball.IsHovered || osuHit.IsHovered) || osuHit is DrawableSpinner;
|
|
||||||
|
|
||||||
hitOnce |= osuHit is DrawableHitCircle && osuHit.IsHovered;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Update(Playfield playfield)
|
public void Update(Playfield playfield)
|
||||||
{
|
{
|
||||||
var osuHit = playfield.HitObjects.Objects.First(d => d is DrawableOsuHitObject) as DrawableOsuHitObject;
|
bool hitStill = false;
|
||||||
|
bool hitOnce = false;
|
||||||
|
|
||||||
|
const float relax_leniency = 3;
|
||||||
|
|
||||||
|
foreach (var drawable in playfield.HitObjects.Objects)
|
||||||
|
{
|
||||||
|
if (!(drawable is DrawableOsuHitObject osuHit))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
double time = osuHit.Clock.CurrentTime;
|
||||||
|
|
||||||
|
if (osuHit.IsAlive && time >= osuHit.HitObject.StartTime - relax_leniency)
|
||||||
|
{
|
||||||
|
if (osuHit.HitObject is IHasEndTime hasEnd && time > hasEnd.EndTime || osuHit.IsHit)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
hitStill |= osuHit is DrawableSlider slider && (slider.Ball.IsHovered || osuHit.IsHovered) || osuHit is DrawableSpinner;
|
||||||
|
|
||||||
|
hitOnce |= osuHit is DrawableHitCircle && osuHit.IsHovered;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var osuHitSample = playfield.HitObjects.Objects.First(d => d is DrawableOsuHitObject) as DrawableOsuHitObject;
|
||||||
if (hitOnce)
|
if (hitOnce)
|
||||||
{
|
{
|
||||||
hit(osuHit, false);
|
hit(osuHitSample, false);
|
||||||
hit(osuHit, true);
|
hit(osuHitSample, true);
|
||||||
}
|
}
|
||||||
hit(osuHit, hitStill);
|
hit(osuHitSample, hitStill);
|
||||||
|
|
||||||
hitOnce = false;
|
|
||||||
hitStill = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool wasHit;
|
private bool wasHit;
|
||||||
|
@ -1,12 +0,0 @@
|
|||||||
// Copyright (c) 2007-2018 ppy Pty Ltd <contact@ppy.sh>.
|
|
||||||
// Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
|
||||||
|
|
||||||
using osu.Game.Rulesets.Objects.Drawables;
|
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.Mods
|
|
||||||
{
|
|
||||||
public interface IUpdatableByHitObject : IApplicableMod
|
|
||||||
{
|
|
||||||
void Update(DrawableHitObject drawable);
|
|
||||||
}
|
|
||||||
}
|
|
@ -13,8 +13,6 @@ using osu.Game.Rulesets.Objects.Types;
|
|||||||
using osu.Game.Rulesets.Scoring;
|
using osu.Game.Rulesets.Scoring;
|
||||||
using osu.Game.Skinning;
|
using osu.Game.Skinning;
|
||||||
using OpenTK.Graphics;
|
using OpenTK.Graphics;
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Rulesets.Mods;
|
|
||||||
|
|
||||||
namespace osu.Game.Rulesets.Objects.Drawables
|
namespace osu.Game.Rulesets.Objects.Drawables
|
||||||
{
|
{
|
||||||
@ -43,8 +41,6 @@ namespace osu.Game.Rulesets.Objects.Drawables
|
|||||||
public IReadOnlyList<Judgement> Judgements => judgements;
|
public IReadOnlyList<Judgement> Judgements => judgements;
|
||||||
private readonly List<Judgement> judgements = new List<Judgement>();
|
private readonly List<Judgement> judgements = new List<Judgement>();
|
||||||
|
|
||||||
private WorkingBeatmap beatmap;
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Whether a visible judgement should be displayed when this representation is hit.
|
/// Whether a visible judgement should be displayed when this representation is hit.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -84,9 +80,8 @@ namespace osu.Game.Rulesets.Objects.Drawables
|
|||||||
}
|
}
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(IBindableBeatmap bBeatmap)
|
private void load()
|
||||||
{
|
{
|
||||||
beatmap = bBeatmap.Value;
|
|
||||||
var samples = GetSamples().ToArray();
|
var samples = GetSamples().ToArray();
|
||||||
|
|
||||||
if (samples.Any())
|
if (samples.Any())
|
||||||
@ -137,11 +132,6 @@ namespace osu.Game.Rulesets.Objects.Drawables
|
|||||||
{
|
{
|
||||||
base.Update();
|
base.Update();
|
||||||
|
|
||||||
if(beatmap != null)
|
|
||||||
foreach (var mod in beatmap.Mods.Value)
|
|
||||||
if (mod is IUpdatableByHitObject updatable)
|
|
||||||
updatable.Update(this);
|
|
||||||
|
|
||||||
var endTime = (HitObject as IHasEndTime)?.EndTime ?? HitObject.StartTime;
|
var endTime = (HitObject as IHasEndTime)?.EndTime ?? HitObject.StartTime;
|
||||||
|
|
||||||
while (judgements.Count > 0)
|
while (judgements.Count > 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user