1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-19 12:22:57 +08:00

Only apply dim at top level objects

This commit is contained in:
Dean Herbert 2022-10-05 17:48:56 +09:00
parent 56d424003d
commit 52002d91dd

View File

@ -70,13 +70,17 @@ namespace osu.Game.Rulesets.Osu.Objects.Drawables
{ {
base.UpdateInitialTransforms(); base.UpdateInitialTransforms();
// Of note, no one noticed this was missing for years, but it definitely feels like it should still exist. // Dim should only be applied at a top level, as it will be implicitly applied to nested objects.
// For now this is applied across all skins, and matches stable. if (ParentHitObject == null)
// For simplicity, dim colour is applied to the DrawableHitObject itself. {
// We may need to make a nested container setup if this even causes a usage conflict (ie. with a mod). // Of note, no one noticed this was missing for years, but it definitely feels like it should still exist.
this.FadeColour(new Color4(195, 195, 195, 255)); // For now this is applied across all skins, and matches stable.
using (BeginDelayedSequence(InitialLifetimeOffset - OsuHitWindows.MISS_WINDOW)) // For simplicity, dim colour is applied to the DrawableHitObject itself.
this.FadeColour(Color4.White, 100); // We may need to make a nested container setup if this even causes a usage conflict (ie. with a mod).
this.FadeColour(new Color4(195, 195, 195, 255));
using (BeginDelayedSequence(InitialLifetimeOffset - OsuHitWindows.MISS_WINDOW))
this.FadeColour(Color4.White, 100);
}
} }
protected sealed override double InitialLifetimeOffset => HitObject.TimePreempt; protected sealed override double InitialLifetimeOffset => HitObject.TimePreempt;