1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-14 02:03:22 +08:00

Fix health processor event leaks

This commit is contained in:
Salman Ahmed 2023-12-05 19:44:01 +03:00
parent 4d82a55594
commit 927cfe4257

View File

@ -7,6 +7,7 @@ using System.Linq;
using osu.Framework.Allocation;
using osu.Framework.Bindables;
using osu.Framework.Extensions.Color4Extensions;
using osu.Framework.Extensions.ObjectExtensions;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Colour;
using osu.Framework.Graphics.Containers;
@ -156,8 +157,8 @@ namespace osu.Game.Screens.Play.HUD
{
base.LoadComplete();
HealthProcessor.NewJudgement += result => pendingJudgementResult = result;
Current.BindValueChanged(_ => Scheduler.AddOnce(updateCurrent), true);
HealthProcessor.NewJudgement += onNewJudgement;
Current.BindValueChanged(onCurrentChanged, true);
// we're about to set `RelativeSizeAxes` depending on the value of `UseRelativeSize`.
// setting `RelativeSizeAxes` internally transforms absolute sizing to relative and back to keep the size the same,
@ -170,7 +171,12 @@ namespace osu.Game.Screens.Play.HUD
BarHeight.BindValueChanged(_ => updatePath(), true);
}
private void updateCurrent()
private void onNewJudgement(JudgementResult result) => pendingJudgementResult = result;
private void onCurrentChanged(ValueChangedEvent<double> valueChangedEvent)
=> Scheduler.AddOnce(updateDisplay);
private void updateDisplay()
{
var result = pendingJudgementResult;
@ -333,6 +339,14 @@ namespace osu.Game.Screens.Play.HUD
mainBar.Position = healthBarVertices[0];
}
protected override void Dispose(bool isDisposing)
{
base.Dispose(isDisposing);
if (HealthProcessor.IsNotNull())
HealthProcessor.NewJudgement -= onNewJudgement;
}
private partial class BackgroundPath : SmoothPath
{
protected override Color4 ColourAt(float position)