diff --git a/osu.Game.Tests/Visual/TestCaseBackgroundScreenBeatmap.cs b/osu.Game.Tests/Visual/TestCaseBackgroundScreenBeatmap.cs
index bcd8651b47..ba3a02a843 100644
--- a/osu.Game.Tests/Visual/TestCaseBackgroundScreenBeatmap.cs
+++ b/osu.Game.Tests/Visual/TestCaseBackgroundScreenBeatmap.cs
@@ -48,8 +48,8 @@ namespace osu.Game.Tests.Visual
};
private DummySongSelect songSelect;
- private DimAccessiblePlayerLoader playerLoader;
- private DimAccessiblePlayer player;
+ private TestPlayerLoader playerLoader;
+ private TestPlayer player;
private DatabaseContextFactory factory;
private BeatmapManager manager;
private RulesetStore rulesets;
@@ -74,30 +74,26 @@ namespace osu.Game.Tests.Visual
Dependencies.Cache(manager = new BeatmapManager(LocalStorage, factory, rulesets, null, null, host, Beatmap.Default));
Dependencies.Cache(new OsuConfigManager(LocalStorage));
+ manager.Import(TestResources.GetTestBeatmapForImport());
+
Beatmap.SetDefault();
}
[SetUp]
- public virtual void SetUp()
+ public virtual void SetUp() => Schedule(() =>
{
- Schedule(() =>
- {
- manager.Delete(manager.GetAllUsableBeatmapSets());
- var temp = TestResources.GetTestBeatmapForImport();
- manager.Import(temp);
- Child = screenStackContainer = new ScreenStackCacheContainer { RelativeSizeAxes = Axes.Both };
- screenStackContainer.ScreenStack.Push(songSelect = new DummySongSelect());
- });
- }
+ Child = screenStackContainer = new ScreenStackCacheContainer { RelativeSizeAxes = Axes.Both };
+ screenStackContainer.ScreenStack.Push(songSelect = new DummySongSelect());
+ });
///
- /// Check if properly triggers background dim previews when a user hovers over the visual settings panel.
+ /// Check if properly triggers the visual settings preview when a user hovers over the visual settings panel.
///
[Test]
public void PlayerLoaderSettingsHoverTest()
{
setupUserSettings();
- AddStep("Start player loader", () => songSelect.Push(playerLoader = new DimAccessiblePlayerLoader(player = new DimAccessiblePlayer())));
+ AddStep("Start player loader", () => songSelect.Push(playerLoader = new TestPlayerLoader(player = new TestPlayer())));
AddUntilStep("Wait for Player Loader to load", () => playerLoader?.IsLoaded ?? false);
AddAssert("Background retained from song select", () => songSelect.IsBackgroundCurrent());
AddStep("Trigger background preview", () =>
@@ -106,16 +102,16 @@ namespace osu.Game.Tests.Visual
InputManager.MoveMouseTo(playerLoader.VisualSettingsPos);
});
waitForDim();
- AddAssert("Screen is dimmed", () => songSelect.IsBackgroundDimmed());
+ AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
AddStep("Stop background preview", () => InputManager.MoveMouseTo(playerLoader.ScreenPos));
waitForDim();
- AddAssert("Screen is undimmed", () => songSelect.IsBackgroundUndimmed());
+ AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && playerLoader.IsBlurCorrect());
}
///
/// In the case of a user triggering the dim preview the instant player gets loaded, then moving the cursor off of the visual settings:
- /// The OnHover of PlayerLoader will trigger, which could potentially trigger an undim unless checked for in PlayerLoader.
- /// We need to check that in this scenario, the dim is still properly applied after entering player.
+ /// The OnHover of PlayerLoader will trigger, which could potentially cause visual settings to be unapplied unless checked for in PlayerLoader.
+ /// We need to check that in this scenario, the dim and blur is still properly applied after entering player.
///
[Test]
public void PlayerLoaderTransitionTest()
@@ -124,7 +120,7 @@ namespace osu.Game.Tests.Visual
AddStep("Trigger hover event", () => playerLoader.TriggerOnHover());
AddAssert("Background retained from song select", () => songSelect.IsBackgroundCurrent());
waitForDim();
- AddAssert("Screen is dimmed and unblurred", () => songSelect.IsBackgroundDimmed() && songSelect.IsBackgroundUnblurred());
+ AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
}
///
@@ -165,24 +161,24 @@ namespace osu.Game.Tests.Visual
}
///
- /// Check if the is properly accepting user dim changes at all.
+ /// Check if the is properly accepting user-defined visual changes at all.
///
[Test]
public void DisableUserDimTest()
{
performFullSetup();
waitForDim();
- AddAssert("Screen is dimmed", () => songSelect.IsBackgroundDimmed());
+ AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
AddStep("EnableUserDim disabled", () => songSelect.DimEnabled.Value = false);
waitForDim();
- AddAssert("Screen is undimmed", () => songSelect.IsBackgroundUndimmed());
+ AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && songSelect.IsUserBlurDisabled());
AddStep("EnableUserDim enabled", () => songSelect.DimEnabled.Value = true);
waitForDim();
- AddAssert("Screen is dimmed", () => songSelect.IsBackgroundDimmed());
+ AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
}
///
- /// Check if the fade container retains dim when pausing
+ /// Check if the visual settings container retains dim and blur when pausing
///
[Test]
public void PauseTest()
@@ -190,26 +186,29 @@ namespace osu.Game.Tests.Visual
performFullSetup(true);
AddStep("Pause", () => player.Pause());
waitForDim();
- AddAssert("Screen is dimmed", () => songSelect.IsBackgroundDimmed());
+ AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
AddStep("Unpause", () => player.Resume());
waitForDim();
- AddAssert("Screen is dimmed", () => songSelect.IsBackgroundDimmed());
+ AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
}
///
- /// Check if the fade container removes user dim when suspending for
+ /// Check if the visual settings container removes user dim when suspending for
///
[Test]
public void TransitionTest()
{
performFullSetup();
- AddStep("Transition to Results", () => player.Push(new FadeAccessibleResults(new ScoreInfo { User = new User { Username = "osu!" } })));
+ var results = new FadeAccessibleResults(new ScoreInfo { User = new User { Username = "osu!" } });
+ AddStep("Transition to Results", () => player.Push(results));
+ AddUntilStep("Wait for results is current", results.IsCurrentScreen);
waitForDim();
- AddAssert("Screen is undimmed and is original background", () => songSelect.IsBackgroundUndimmed() && songSelect.IsBackgroundCurrent());
+ AddAssert("Screen is undimmed, original background retained", () =>
+ songSelect.IsBackgroundUndimmed() && songSelect.IsBackgroundCurrent() && results.IsBlurCorrect());
}
///
- /// Check if background gets undimmed when leaving for
+ /// Check if background gets undimmed and unblurred when leaving for
///
[Test]
public void TransitionOutTest()
@@ -217,7 +216,23 @@ namespace osu.Game.Tests.Visual
performFullSetup();
AddStep("Exit to song select", () => player.Exit());
waitForDim();
- AddAssert("Screen is undimmed", () => songSelect.IsBackgroundUndimmed());
+ AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && songSelect.IsBlurCorrect());
+ }
+
+ ///
+ /// Check if hovering on the visual settings dialogue after resuming from player still previews the background dim.
+ ///
+ [Test]
+ public void ResumeFromPlayerTest()
+ {
+ performFullSetup();
+ AddStep("Move mouse to Visual Settings", () => InputManager.MoveMouseTo(playerLoader.VisualSettingsPos));
+ AddStep("Resume PlayerLoader", () => player.Restart());
+ waitForDim();
+ AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
+ AddStep("Move mouse to center of screen", () => InputManager.MoveMouseTo(playerLoader.ScreenPos));
+ waitForDim();
+ AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && playerLoader.IsBlurCorrect());
}
private void waitForDim() => AddWaitStep("Wait for dim", 5);
@@ -243,7 +258,7 @@ namespace osu.Game.Tests.Visual
AddStep("Start player loader", () =>
{
- songSelect.Push(playerLoader = new DimAccessiblePlayerLoader(player = new DimAccessiblePlayer
+ songSelect.Push(playerLoader = new TestPlayerLoader(player = new TestPlayer
{
AllowPause = allowPause,
Ready = true,
@@ -261,7 +276,7 @@ namespace osu.Game.Tests.Visual
{
Beatmap.Value.Mods.Value = Beatmap.Value.Mods.Value.Concat(new[] { new OsuModNoFail() });
songSelect.DimLevel.Value = 0.7f;
- songSelect.BlurLevel.Value = 0.0f;
+ songSelect.BlurLevel.Value = 0.4f;
});
}
@@ -289,14 +304,18 @@ namespace osu.Game.Tests.Visual
public bool IsBackgroundDimmed() => ((FadeAccessibleBackground)Background).CurrentColour == OsuColour.Gray(1 - (float)DimLevel.Value);
- public bool IsBackgroundUnblurred() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(0);
-
public bool IsBackgroundUndimmed() => ((FadeAccessibleBackground)Background).CurrentColour == Color4.White;
+ public bool IsUserBlurApplied() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2((float)BlurLevel.Value * 25);
+
+ public bool IsUserBlurDisabled() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(0);
+
public bool IsBackgroundInvisible() => ((FadeAccessibleBackground)Background).CurrentAlpha == 0;
public bool IsBackgroundVisible() => ((FadeAccessibleBackground)Background).CurrentAlpha == 1;
+ public bool IsBlurCorrect() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(BACKGROUND_BLUR);
+
///
/// Make sure every time a screen gets pushed, the background doesn't get replaced
///
@@ -312,9 +331,11 @@ namespace osu.Game.Tests.Visual
}
protected override BackgroundScreen CreateBackground() => new FadeAccessibleBackground(Beatmap.Value);
+
+ public bool IsBlurCorrect() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(BACKGROUND_BLUR);
}
- private class DimAccessiblePlayer : Player
+ private class TestPlayer : Player
{
protected override BackgroundScreen CreateBackground() => new FadeAccessibleBackground(Beatmap.Value);
@@ -366,18 +387,20 @@ namespace osu.Game.Tests.Visual
}
}
- private class DimAccessiblePlayerLoader : PlayerLoader
+ private class TestPlayerLoader : PlayerLoader
{
public VisualSettings VisualSettingsPos => VisualSettings;
public BackgroundScreen ScreenPos => Background;
- public DimAccessiblePlayerLoader(Player player)
+ public TestPlayerLoader(Player player)
: base(() => player)
{
}
public void TriggerOnHover() => OnHover(new HoverEvent(new InputState()));
+ public bool IsBlurCorrect() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(BACKGROUND_BLUR);
+
protected override BackgroundScreen CreateBackground() => new FadeAccessibleBackground(Beatmap.Value);
}
@@ -386,6 +409,7 @@ namespace osu.Game.Tests.Visual
protected override UserDimContainer CreateFadeContainer() => fadeContainer = new TestUserDimContainer { RelativeSizeAxes = Axes.Both };
public Color4 CurrentColour => fadeContainer.CurrentColour;
+
public float CurrentAlpha => fadeContainer.CurrentAlpha;
public Vector2 CurrentBlur => Background.BlurSigma;
diff --git a/osu.Game/Graphics/Containers/UserDimContainer.cs b/osu.Game/Graphics/Containers/UserDimContainer.cs
index 4c8928e122..b078f40420 100644
--- a/osu.Game/Graphics/Containers/UserDimContainer.cs
+++ b/osu.Game/Graphics/Containers/UserDimContainer.cs
@@ -1,27 +1,26 @@
// Copyright (c) ppy Pty Ltd . Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
+using System;
using osu.Framework.Allocation;
using osu.Framework.Bindables;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Game.Configuration;
+using osu.Game.Graphics.Backgrounds;
+using osuTK;
using osuTK.Graphics;
namespace osu.Game.Graphics.Containers
{
///
- /// A container that applies user-configured dim levels to its contents.
+ /// A container that applies user-configured visual settings to its contents.
/// This container specifies behavior that applies to both Storyboards and Backgrounds.
///
public class UserDimContainer : Container
{
private const float background_fade_duration = 800;
- private Bindable dimLevel { get; set; }
-
- private Bindable showStoryboard { get; set; }
-
///
/// Whether or not user-configured dim levels should be applied to the container.
///
@@ -32,19 +31,40 @@ namespace osu.Game.Graphics.Containers
///
public readonly Bindable StoryboardReplacesBackground = new Bindable();
+ ///
+ /// The amount of blur to be applied to the background in addition to user-specified blur.
+ ///
+ ///
+ /// Used in contexts where there can potentially be both user and screen-specified blurring occuring at the same time, such as in
+ ///
+ public readonly Bindable BlurAmount = new Bindable();
+
+ private Bindable userDimLevel { get; set; }
+
+ private Bindable userBlurLevel { get; set; }
+
+ private Bindable showStoryboard { get; set; }
+
protected Container DimContainer { get; }
protected override Container Content => DimContainer;
private readonly bool isStoryboard;
+ ///
+ /// As an optimisation, we add the two blur portions to be applied rather than actually applying two separate blurs.
+ ///
+ private Vector2 blurTarget => EnableUserDim.Value
+ ? new Vector2(BlurAmount.Value + (float)userBlurLevel.Value * 25)
+ : new Vector2(BlurAmount.Value);
+
///
/// Creates a new .
///
- /// Whether or not this instance of UserDimContainer contains a storyboard.
+ /// Whether or not this instance contains a storyboard.
///
/// While both backgrounds and storyboards allow user dim levels to be applied, storyboards can be toggled via
- /// and can cause backgrounds to become hidden via .
+ /// and can cause backgrounds to become hidden via . Storyboards are also currently unable to be blurred.
///
///
public UserDimContainer(bool isStoryboard = false)
@@ -53,36 +73,62 @@ namespace osu.Game.Graphics.Containers
AddInternal(DimContainer = new Container { RelativeSizeAxes = Axes.Both });
}
+ private Background background;
+
+ public Background Background
+ {
+ get => background;
+ set
+ {
+ base.Add(background = value);
+ background.BlurTo(blurTarget, 0, Easing.OutQuint);
+ }
+ }
+
+ public override void Add(Drawable drawable)
+ {
+ if (drawable is Background)
+ throw new InvalidOperationException($"Use {nameof(Background)} to set a background.");
+
+ base.Add(drawable);
+ }
+
[BackgroundDependencyLoader]
private void load(OsuConfigManager config)
{
- dimLevel = config.GetBindable(OsuSetting.DimLevel);
+ userDimLevel = config.GetBindable(OsuSetting.DimLevel);
+ userBlurLevel = config.GetBindable(OsuSetting.BlurLevel);
showStoryboard = config.GetBindable(OsuSetting.ShowStoryboard);
- EnableUserDim.ValueChanged += _ => updateBackgroundDim();
- dimLevel.ValueChanged += _ => updateBackgroundDim();
- showStoryboard.ValueChanged += _ => updateBackgroundDim();
- StoryboardReplacesBackground.ValueChanged += _ => updateBackgroundDim();
+
+ EnableUserDim.ValueChanged += _ => updateVisuals();
+ userDimLevel.ValueChanged += _ => updateVisuals();
+ userBlurLevel.ValueChanged += _ => updateVisuals();
+ showStoryboard.ValueChanged += _ => updateVisuals();
+ StoryboardReplacesBackground.ValueChanged += _ => updateVisuals();
+ BlurAmount.ValueChanged += _ => updateVisuals();
}
protected override void LoadComplete()
{
base.LoadComplete();
- updateBackgroundDim();
+ updateVisuals();
}
- private void updateBackgroundDim()
+ private void updateVisuals()
{
if (isStoryboard)
{
- DimContainer.FadeTo(!showStoryboard.Value || dimLevel.Value == 1 ? 0 : 1, background_fade_duration, Easing.OutQuint);
+ DimContainer.FadeTo(!showStoryboard.Value || userDimLevel.Value == 1 ? 0 : 1, background_fade_duration, Easing.OutQuint);
}
else
{
// The background needs to be hidden in the case of it being replaced by the storyboard
DimContainer.FadeTo(showStoryboard.Value && StoryboardReplacesBackground.Value ? 0 : 1, background_fade_duration, Easing.OutQuint);
+
+ Background?.BlurTo(blurTarget, background_fade_duration, Easing.OutQuint);
}
- DimContainer.FadeColour(EnableUserDim.Value ? OsuColour.Gray(1 - (float)dimLevel.Value) : Color4.White, background_fade_duration, Easing.OutQuint);
+ DimContainer.FadeColour(EnableUserDim.Value ? OsuColour.Gray(1 - (float)userDimLevel.Value) : Color4.White, background_fade_duration, Easing.OutQuint);
}
}
}
diff --git a/osu.Game/Rulesets/Difficulty/DifficultyCalculator.cs b/osu.Game/Rulesets/Difficulty/DifficultyCalculator.cs
index db8bdde6bb..aad55f8a38 100644
--- a/osu.Game/Rulesets/Difficulty/DifficultyCalculator.cs
+++ b/osu.Game/Rulesets/Difficulty/DifficultyCalculator.cs
@@ -37,6 +37,8 @@ namespace osu.Game.Rulesets.Difficulty
/// A structure describing the difficulty of the beatmap.
public DifficultyAttributes Calculate(params Mod[] mods)
{
+ mods = mods.Select(m => m.CreateCopy()).ToArray();
+
beatmap.Mods.Value = mods;
IBeatmap playableBeatmap = beatmap.GetPlayableBeatmap(ruleset.RulesetInfo);
diff --git a/osu.Game/Rulesets/Mods/Mod.cs b/osu.Game/Rulesets/Mods/Mod.cs
index 705c5c4ef6..1f9907caa7 100644
--- a/osu.Game/Rulesets/Mods/Mod.cs
+++ b/osu.Game/Rulesets/Mods/Mod.cs
@@ -65,5 +65,10 @@ namespace osu.Game.Rulesets.Mods
///
[JsonIgnore]
public virtual Type[] IncompatibleMods => new Type[] { };
+
+ ///
+ /// Creates a copy of this initialised to a default state.
+ ///
+ public virtual Mod CreateCopy() => (Mod)Activator.CreateInstance(GetType());
}
}
diff --git a/osu.Game/Rulesets/Objects/Legacy/Catch/ConvertSpinner.cs b/osu.Game/Rulesets/Objects/Legacy/Catch/ConvertSpinner.cs
index 41281e805e..0089d1eb88 100644
--- a/osu.Game/Rulesets/Objects/Legacy/Catch/ConvertSpinner.cs
+++ b/osu.Game/Rulesets/Objects/Legacy/Catch/ConvertSpinner.cs
@@ -8,12 +8,14 @@ namespace osu.Game.Rulesets.Objects.Legacy.Catch
///
/// Legacy osu!catch Spinner-type, used for parsing Beatmaps.
///
- internal sealed class ConvertSpinner : HitObject, IHasEndTime, IHasCombo
+ internal sealed class ConvertSpinner : HitObject, IHasEndTime, IHasXPosition, IHasCombo
{
public double EndTime { get; set; }
public double Duration => EndTime - StartTime;
+ public float X => 256; // Required for CatchBeatmapConverter
+
public bool NewCombo { get; set; }
public int ComboOffset { get; set; }
diff --git a/osu.Game/Screens/Backgrounds/BackgroundScreenBeatmap.cs b/osu.Game/Screens/Backgrounds/BackgroundScreenBeatmap.cs
index 54ce005469..6df418753c 100644
--- a/osu.Game/Screens/Backgrounds/BackgroundScreenBeatmap.cs
+++ b/osu.Game/Screens/Backgrounds/BackgroundScreenBeatmap.cs
@@ -12,8 +12,10 @@ using osu.Game.Graphics.Containers;
namespace osu.Game.Screens.Backgrounds
{
- public class BackgroundScreenBeatmap : BlurrableBackgroundScreen
+ public class BackgroundScreenBeatmap : BackgroundScreen
{
+ protected Background Background;
+
private WorkingBeatmap beatmap;
///
@@ -23,6 +25,11 @@ namespace osu.Game.Screens.Backgrounds
public readonly Bindable StoryboardReplacesBackground = new Bindable();
+ ///
+ /// The amount of blur to be applied in addition to user-specified blur.
+ ///
+ public readonly Bindable BlurAmount = new Bindable();
+
private readonly UserDimContainer fadeContainer;
protected virtual UserDimContainer CreateFadeContainer() => new UserDimContainer { RelativeSizeAxes = Axes.Both };
@@ -32,6 +39,7 @@ namespace osu.Game.Screens.Backgrounds
Beatmap = beatmap;
InternalChild = fadeContainer = CreateFadeContainer();
fadeContainer.EnableUserDim.BindTo(EnableUserDim);
+ fadeContainer.BlurAmount.BindTo(BlurAmount);
}
[BackgroundDependencyLoader]
@@ -77,8 +85,7 @@ namespace osu.Game.Screens.Backgrounds
}
b.Depth = newDepth;
- fadeContainer.Add(Background = b);
- Background.BlurSigma = BlurTarget;
+ fadeContainer.Background = Background = b;
StoryboardReplacesBackground.BindTo(fadeContainer.StoryboardReplacesBackground);
}
diff --git a/osu.Game/Screens/Backgrounds/BackgroundScreenDefault.cs b/osu.Game/Screens/Backgrounds/BackgroundScreenDefault.cs
index e015f95ff8..7092ac0c4a 100644
--- a/osu.Game/Screens/Backgrounds/BackgroundScreenDefault.cs
+++ b/osu.Game/Screens/Backgrounds/BackgroundScreenDefault.cs
@@ -13,8 +13,10 @@ using osu.Game.Users;
namespace osu.Game.Screens.Backgrounds
{
- public class BackgroundScreenDefault : BlurrableBackgroundScreen
+ public class BackgroundScreenDefault : BackgroundScreen
{
+ private Background background;
+
private int currentDisplay;
private const int background_count = 5;
@@ -39,10 +41,10 @@ namespace osu.Game.Screens.Backgrounds
private void display(Background newBackground)
{
- Background?.FadeOut(800, Easing.InOutSine);
- Background?.Expire();
+ background?.FadeOut(800, Easing.InOutSine);
+ background?.Expire();
- AddInternal(Background = newBackground);
+ AddInternal(background = newBackground);
currentDisplay++;
}
@@ -56,16 +58,16 @@ namespace osu.Game.Screens.Backgrounds
private Background createBackground()
{
- Background background;
+ Background newBackground;
if (user.Value?.IsSupporter ?? false)
- background = new SkinnedBackground(skin.Value, backgroundName);
+ newBackground = new SkinnedBackground(skin.Value, backgroundName);
else
- background = new Background(backgroundName);
+ newBackground = new Background(backgroundName);
- background.Depth = currentDisplay;
+ newBackground.Depth = currentDisplay;
- return background;
+ return newBackground;
}
private class SkinnedBackground : Background
diff --git a/osu.Game/Screens/BlurrableBackgroundScreen.cs b/osu.Game/Screens/BlurrableBackgroundScreen.cs
deleted file mode 100644
index 5520abfe6e..0000000000
--- a/osu.Game/Screens/BlurrableBackgroundScreen.cs
+++ /dev/null
@@ -1,23 +0,0 @@
-// Copyright (c) ppy Pty Ltd . Licensed under the MIT Licence.
-// See the LICENCE file in the repository root for full licence text.
-
-using osu.Framework.Graphics;
-using osu.Framework.Graphics.Transforms;
-using osu.Game.Graphics.Backgrounds;
-using osuTK;
-
-namespace osu.Game.Screens
-{
- public abstract class BlurrableBackgroundScreen : BackgroundScreen
- {
- protected Background Background;
-
- protected Vector2 BlurTarget;
-
- public TransformSequence BlurTo(Vector2 sigma, double duration = 0, Easing easing = Easing.None)
- {
- BlurTarget = sigma;
- return Background?.BlurTo(BlurTarget, duration, easing);
- }
- }
-}
diff --git a/osu.Game/Screens/Play/Player.cs b/osu.Game/Screens/Play/Player.cs
index e0ae17303a..88467aa7f5 100644
--- a/osu.Game/Screens/Play/Player.cs
+++ b/osu.Game/Screens/Play/Player.cs
@@ -77,7 +77,7 @@ namespace osu.Game.Screens.Play
if (StoryboardContainer == null || storyboard != null)
return;
- if (!ShowStoryboard.Value)
+ if (!showStoryboard.Value)
return;
var beatmap = Beatmap.Value;
@@ -93,6 +93,8 @@ namespace osu.Game.Screens.Play
#endregion
+ private Bindable showStoryboard;
+
protected virtual UserDimContainer CreateStoryboardContainer() => new UserDimContainer(true)
{
RelativeSizeAxes = Axes.Both,
@@ -117,6 +119,7 @@ namespace osu.Game.Screens.Play
sampleRestart = audio.Sample.Get(@"Gameplay/restart");
mouseWheelDisabled = config.GetBindable(OsuSetting.MouseDisableWheel);
+ showStoryboard = config.GetBindable(OsuSetting.ShowStoryboard);
ScoreProcessor = DrawableRuleset.CreateScoreProcessor();
if (!ScoreProcessor.Mode.Disabled)
@@ -422,9 +425,10 @@ namespace osu.Game.Screens.Play
.Delay(250)
.FadeIn(250);
- ShowStoryboard.ValueChanged += _ => initializeStoryboard(true);
+ showStoryboard.ValueChanged += _ => initializeStoryboard(true);
Background.EnableUserDim.Value = true;
+ Background.BlurAmount.Value = 0;
Background.StoryboardReplacesBackground.BindTo(storyboardReplacesBackground);
StoryboardContainer.StoryboardReplacesBackground.BindTo(storyboardReplacesBackground);
diff --git a/osu.Game/Screens/Play/PlayerLoader.cs b/osu.Game/Screens/Play/PlayerLoader.cs
index 269baad955..e9ee5d3fa8 100644
--- a/osu.Game/Screens/Play/PlayerLoader.cs
+++ b/osu.Game/Screens/Play/PlayerLoader.cs
@@ -8,7 +8,7 @@ using osu.Framework.Allocation;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Sprites;
-using osu.Framework.Input.Events;
+using osu.Framework.Input;
using osu.Framework.Localisation;
using osu.Framework.Screens;
using osu.Framework.Threading;
@@ -26,8 +26,9 @@ namespace osu.Game.Screens.Play
{
public class PlayerLoader : ScreenWithBeatmapBackground
{
+ protected const float BACKGROUND_BLUR = 15;
+
private readonly Func createPlayer;
- private static readonly Vector2 background_blur = new Vector2(15);
private Player player;
@@ -42,6 +43,8 @@ namespace osu.Game.Screens.Play
private Task loadTask;
+ private InputManager inputManager;
+
public PlayerLoader(Func createPlayer)
{
this.createPlayer = createPlayer;
@@ -133,6 +136,7 @@ namespace osu.Game.Screens.Play
base.OnEntering(last);
content.ScaleTo(0.7f);
+ Background?.FadeColour(Color4.White, 800, Easing.OutQuint);
contentIn();
@@ -151,43 +155,20 @@ namespace osu.Game.Screens.Play
logo.Delay(resuming ? 0 : 500).MoveToOffset(new Vector2(0, -0.24f), 500, Easing.InOutExpo);
}
+ protected override void LoadComplete()
+ {
+ inputManager = GetContainingInputManager();
+ base.LoadComplete();
+ }
+
private ScheduledDelegate pushDebounce;
protected VisualSettings VisualSettings;
+ // Hhere because IsHovered will not update unless we do so.
+ public override bool HandlePositionalInput => true;
+
private bool readyForPush => player.LoadState == LoadState.Ready && IsHovered && GetContainingInputManager()?.DraggedDrawable == null;
- protected override bool OnHover(HoverEvent e)
- {
- // restore our screen defaults
- if (this.IsCurrentScreen())
- {
- InitializeBackgroundElements();
- Background.EnableUserDim.Value = false;
- }
-
- return base.OnHover(e);
- }
-
- protected override void OnHoverLost(HoverLostEvent e)
- {
- if (GetContainingInputManager()?.HoveredDrawables.Contains(VisualSettings) == true)
- {
- // Update background elements is only being called here because blur logic still exists in Player.
- // Will need to be removed when resolving https://github.com/ppy/osu/issues/4322
- UpdateBackgroundElements();
- if (this.IsCurrentScreen())
- Background.EnableUserDim.Value = true;
- }
-
- base.OnHoverLost(e);
- }
-
- protected override void InitializeBackgroundElements()
- {
- Background?.FadeColour(Color4.White, BACKGROUND_FADE_DURATION, Easing.OutQuint);
- Background?.BlurTo(background_blur, BACKGROUND_FADE_DURATION, Easing.OutQuint);
- }
-
private void pushWhenLoaded()
{
if (!this.IsCurrentScreen()) return;
@@ -266,6 +247,29 @@ namespace osu.Game.Screens.Play
}
}
+ protected override void Update()
+ {
+ base.Update();
+
+ if (!this.IsCurrentScreen())
+ return;
+
+ // We need to perform this check here rather than in OnHover as any number of children of VisualSettings
+ // may also be handling the hover events.
+ if (inputManager.HoveredDrawables.Contains(VisualSettings))
+ {
+ // Preview user-defined background dim and blur when hovered on the visual settings panel.
+ Background.EnableUserDim.Value = true;
+ Background.BlurAmount.Value = 0;
+ }
+ else
+ {
+ // Returns background dim and blur to the values specified by PlayerLoader.
+ Background.EnableUserDim.Value = false;
+ Background.BlurAmount.Value = BACKGROUND_BLUR;
+ }
+ }
+
private class BeatmapMetadataDisplay : Container
{
private class MetadataLine : Container
diff --git a/osu.Game/Screens/Play/ScreenWithBeatmapBackground.cs b/osu.Game/Screens/Play/ScreenWithBeatmapBackground.cs
index 3aabceaaef..d7d2c97598 100644
--- a/osu.Game/Screens/Play/ScreenWithBeatmapBackground.cs
+++ b/osu.Game/Screens/Play/ScreenWithBeatmapBackground.cs
@@ -1,13 +1,7 @@
// Copyright (c) ppy Pty Ltd . Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
-using osu.Framework.Allocation;
-using osu.Framework.Bindables;
-using osu.Framework.Graphics;
-using osu.Framework.Screens;
-using osu.Game.Configuration;
using osu.Game.Screens.Backgrounds;
-using osuTK;
namespace osu.Game.Screens.Play
{
@@ -16,50 +10,5 @@ namespace osu.Game.Screens.Play
protected override BackgroundScreen CreateBackground() => new BackgroundScreenBeatmap(Beatmap.Value);
protected new BackgroundScreenBeatmap Background => (BackgroundScreenBeatmap)base.Background;
-
- protected const float BACKGROUND_FADE_DURATION = 800;
-
- #region User Settings
-
- protected Bindable BlurLevel;
- protected Bindable ShowStoryboard;
-
- #endregion
-
- [BackgroundDependencyLoader]
- private void load(OsuConfigManager config)
- {
- BlurLevel = config.GetBindable(OsuSetting.BlurLevel);
- ShowStoryboard = config.GetBindable(OsuSetting.ShowStoryboard);
- }
-
- public override void OnEntering(IScreen last)
- {
- base.OnEntering(last);
- BlurLevel.ValueChanged += _ => UpdateBackgroundElements();
- InitializeBackgroundElements();
- }
-
- public override void OnResuming(IScreen last)
- {
- base.OnResuming(last);
- InitializeBackgroundElements();
- }
-
- ///
- /// Called once on entering screen. By Default, performs a full call.
- ///
- protected virtual void InitializeBackgroundElements() => UpdateBackgroundElements();
-
- ///
- /// Called when background elements require updates, usually due to a user changing a setting.
- ///
- ///
- protected void UpdateBackgroundElements()
- {
- if (!this.IsCurrentScreen()) return;
-
- Background?.BlurTo(new Vector2((float)BlurLevel.Value * 25), BACKGROUND_FADE_DURATION, Easing.OutQuint);
- }
}
}
diff --git a/osu.Game/Screens/Ranking/Results.cs b/osu.Game/Screens/Ranking/Results.cs
index 47ac472b9e..dafb4c0aad 100644
--- a/osu.Game/Screens/Ranking/Results.cs
+++ b/osu.Game/Screens/Ranking/Results.cs
@@ -24,6 +24,8 @@ namespace osu.Game.Screens.Ranking
{
public abstract class Results : OsuScreen
{
+ protected const float BACKGROUND_BLUR = 20;
+
private Container circleOuterBackground;
private Container circleOuter;
private Container circleInner;
@@ -38,8 +40,6 @@ namespace osu.Game.Screens.Ranking
private Container currentPage;
- private static readonly Vector2 background_blur = new Vector2(20);
-
protected override BackgroundScreen CreateBackground() => new BackgroundScreenBeatmap(Beatmap.Value);
private const float overscan = 1.3f;
@@ -58,7 +58,7 @@ namespace osu.Game.Screens.Ranking
public override void OnEntering(IScreen last)
{
base.OnEntering(last);
- (Background as BackgroundScreenBeatmap)?.BlurTo(background_blur, 2500, Easing.OutQuint);
+ ((BackgroundScreenBeatmap)Background).BlurAmount.Value = BACKGROUND_BLUR;
Background.ScaleTo(1.1f, transition_time, Easing.OutQuint);
allCircles.ForEach(c =>
diff --git a/osu.Game/Screens/Select/SongSelect.cs b/osu.Game/Screens/Select/SongSelect.cs
index 66e900c9fd..a86d0beb39 100644
--- a/osu.Game/Screens/Select/SongSelect.cs
+++ b/osu.Game/Screens/Select/SongSelect.cs
@@ -38,7 +38,7 @@ namespace osu.Game.Screens.Select
public abstract class SongSelect : OsuScreen
{
private static readonly Vector2 wedged_container_size = new Vector2(0.5f, 245);
- private static readonly Vector2 background_blur = new Vector2(20);
+ protected const float BACKGROUND_BLUR = 20;
private const float left_area_padding = 20;
public readonly FilterControl FilterControl;
@@ -64,7 +64,6 @@ namespace osu.Game.Screens.Select
protected override BackgroundScreen CreateBackground()
{
var background = new BackgroundScreenBeatmap();
- background.BlurTo(background_blur);
return background;
}
@@ -561,7 +560,7 @@ namespace osu.Game.Screens.Select
if (Background is BackgroundScreenBeatmap backgroundModeBeatmap)
{
backgroundModeBeatmap.Beatmap = beatmap;
- backgroundModeBeatmap.BlurTo(background_blur, 750, Easing.OutQuint);
+ backgroundModeBeatmap.BlurAmount.Value = BACKGROUND_BLUR;
backgroundModeBeatmap.FadeColour(Color4.White, 250);
}
diff --git a/osu.Game/osu.Game.csproj b/osu.Game/osu.Game.csproj
index c02207702c..d8561770fd 100644
--- a/osu.Game/osu.Game.csproj
+++ b/osu.Game/osu.Game.csproj
@@ -16,7 +16,7 @@
-
+
diff --git a/osu.iOS.props b/osu.iOS.props
index 2633da77b3..3dcb647cd2 100644
--- a/osu.iOS.props
+++ b/osu.iOS.props
@@ -105,8 +105,8 @@
-
-
+
+