1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-19 05:02:53 +08:00

Change set to list + minor changes

This commit is contained in:
MaxOhn 2019-08-20 23:18:57 +02:00
parent 30f923edde
commit d4d348390a

View File

@ -24,38 +24,46 @@ namespace osu.Game.Rulesets.Osu.Mods
public override double ScoreMultiplier => 1; public override double ScoreMultiplier => 1;
public override Type[] IncompatibleMods => new[] { typeof(OsuModAutopilot), typeof(OsuModAutoplay), typeof(OsuModWiggle), typeof(OsuModTransform) }; public override Type[] IncompatibleMods => new[] { typeof(OsuModAutopilot), typeof(OsuModAutoplay), typeof(OsuModWiggle), typeof(OsuModTransform) };
private readonly HashSet<DrawableOsuHitObject> movingObjects = new HashSet<DrawableOsuHitObject>(); private readonly List<DrawableOsuHitObject> movingObjects = new List<DrawableOsuHitObject>();
public void Update(Playfield playfield) public void Update(Playfield playfield)
{ {
var drawableCursor = playfield.Cursor.ActiveCursor; var cursorPos = playfield.Cursor.ActiveCursor.DrawPosition;
// Avoid crowded judgment displays and hide follow points // Avoid relocating judgment displays and hide follow points
playfield.DisplayJudgements.Value = false; playfield.DisplayJudgements.Value = false;
(playfield as OsuPlayfield)?.ConnectionLayer.Hide(); (playfield as OsuPlayfield)?.ConnectionLayer.Hide();
// First move objects to new destination, then remove them from movingObjects set if they're too old // First move objects to new destination, then remove them from movingObjects list if they're too old
movingObjects.RemoveWhere(d => movingObjects.RemoveAll(d =>
{ {
var currentTime = playfield.Clock.CurrentTime;
var h = d.HitObject; var h = d.HitObject;
var currentTime = playfield.Clock.CurrentTime;
var endTime = (h as IHasEndTime)?.EndTime ?? h.StartTime;
d.ClearTransforms();
switch (d) switch (d)
{ {
case DrawableHitCircle circle: case DrawableHitCircle circle:
circle.MoveTo(drawableCursor.DrawPosition, Math.Max(0, h.StartTime - currentTime - 10));
return currentTime > h.StartTime; // 10ms earlier on the note to reduce chance of missing when clicking early / cursor moves fast
circle.MoveTo(cursorPos, Math.Max(0, endTime - currentTime - 10));
return currentTime > endTime;
case DrawableSlider slider: case DrawableSlider slider:
// Move slider to cursor // Move slider to cursor
if (currentTime < h.StartTime) if (currentTime < h.StartTime)
d.MoveTo(drawableCursor.DrawPosition, Math.Max(0, h.StartTime - currentTime - 10)); {
slider.MoveTo(cursorPos, Math.Max(0, h.StartTime - currentTime - 10));
return false;
}
// Move slider so that sliderball stays on the cursor // Move slider so that sliderball stays on the cursor
else else
d.MoveTo(drawableCursor.DrawPosition - slider.Ball.DrawPosition); {
return currentTime > (h as IHasEndTime)?.EndTime; slider.MoveTo(cursorPos - slider.Ball.DrawPosition);
return currentTime > endTime;
}
case DrawableSpinner _: case DrawableSpinner _:
// TODO // TODO
@ -75,14 +83,15 @@ namespace osu.Game.Rulesets.Osu.Mods
private void drawableOnApplyCustomUpdateState(DrawableHitObject drawable, ArmedState state) private void drawableOnApplyCustomUpdateState(DrawableHitObject drawable, ArmedState state)
{ {
if (drawable is DrawableOsuHitObject d) if (drawable is DrawableOsuHitObject hitobject)
movingObjects.Add(d); movingObjects.Add(hitobject);
} }
} }
/* /*
* TODOs * TODOs
* - remove object timing glitches / artifacts * - fix sliders reappearing at original position after their EndTime (see https://puu.sh/E7zT4/111cf9cdc8.gif)
* - relocate / hide slider headcircle's explosion, flash, ...
* - automate spinners * - automate spinners
* - combine with OsuModRelax (?) * - combine with OsuModRelax (?)
* *