1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-26 16:12:54 +08:00

using BindValueChanged and IsCurrentScreen for setting binding

This commit is contained in:
Jérémiah DÉCOMBE 2023-01-24 09:09:05 +01:00
parent c1876aac88
commit d783998c81

View File

@ -127,24 +127,21 @@ namespace osu.Game.Screens.Select
private Bindable<float> backgroundBlurLevel { get; set; } = new BindableFloat();
private void applyBackgroundBlur(float blurLevel)
{
ApplyToBackground(background =>
{
background.IgnoreUserSettings.Value = true;
background.BlurAmount.Value = blurLevel * BACKGROUND_BLUR;
});
}
private void applyBackgroundBlur(ValueChangedEvent<float> blurLevelValueChange)
{
applyBackgroundBlur(blurLevelValueChange.NewValue);
}
[BackgroundDependencyLoader(true)]
private void load(AudioManager audio, OsuColour colours, ManageCollectionsDialog? manageCollectionsDialog, DifficultyRecommender? recommender, OsuConfigManager config)
{
backgroundBlurLevel = config.GetBindable<float>(OsuSetting.SongSelectBackgoundBlurLevel);
backgroundBlurLevel.BindValueChanged(e =>
{
if (this.IsCurrentScreen())
{
ApplyToBackground(background =>
{
background.IgnoreUserSettings.Value = true;
background.BlurAmount.Value = e.NewValue * BACKGROUND_BLUR;
});
}
}, true);
LoadComponentAsync(Carousel = new BeatmapCarousel
{
@ -568,9 +565,6 @@ namespace osu.Game.Screens.Select
{
base.OnEntering(e);
backgroundBlurLevel.ValueChanged += applyBackgroundBlur;
applyBackgroundBlur(backgroundBlurLevel.Value);
this.FadeInFromZero(250);
FilterControl.Activate();
@ -618,8 +612,6 @@ namespace osu.Game.Screens.Select
public override void OnResuming(ScreenTransitionEvent e)
{
base.OnResuming(e);
backgroundBlurLevel.ValueChanged += applyBackgroundBlur;
applyBackgroundBlur(backgroundBlurLevel.Value);
// required due to https://github.com/ppy/osu-framework/issues/3218
ModSelect.SelectedMods.Disabled = false;
@ -665,8 +657,6 @@ namespace osu.Game.Screens.Select
// Without this, it's possible for a transfer to happen while we are not the current screen.
transferRulesetValue();
backgroundBlurLevel.ValueChanged -= applyBackgroundBlur;
ModSelect.SelectedMods.UnbindFrom(selectedMods);
playExitingTransition();
@ -675,8 +665,6 @@ namespace osu.Game.Screens.Select
public override bool OnExiting(ScreenExitEvent e)
{
backgroundBlurLevel.ValueChanged -= applyBackgroundBlur;
if (base.OnExiting(e))
return true;