mirror of
https://github.com/osukey/osukey.git
synced 2025-05-09 23:57:18 +09:00
Lighten background during breaks (#7142)
Lighten background during breaks Co-authored-by: Dean Herbert <pe@ppy.sh>
This commit is contained in:
commit
1cd26a0707
427
osu.Game.Tests/Visual/Background/TestSceneUserDimBackgrounds.cs
Normal file
427
osu.Game.Tests/Visual/Background/TestSceneUserDimBackgrounds.cs
Normal file
@ -0,0 +1,427 @@
|
|||||||
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Threading;
|
||||||
|
using NUnit.Framework;
|
||||||
|
using osu.Framework.Allocation;
|
||||||
|
using osu.Framework.Audio;
|
||||||
|
using osu.Framework.Bindables;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Sprites;
|
||||||
|
using osu.Framework.Input.Events;
|
||||||
|
using osu.Framework.Input.States;
|
||||||
|
using osu.Framework.Platform;
|
||||||
|
using osu.Framework.Screens;
|
||||||
|
using osu.Game.Beatmaps;
|
||||||
|
using osu.Game.Configuration;
|
||||||
|
using osu.Game.Graphics;
|
||||||
|
using osu.Game.Graphics.Containers;
|
||||||
|
using osu.Game.Graphics.Sprites;
|
||||||
|
using osu.Game.Rulesets;
|
||||||
|
using osu.Game.Rulesets.Osu.Mods;
|
||||||
|
using osu.Game.Scoring;
|
||||||
|
using osu.Game.Screens;
|
||||||
|
using osu.Game.Screens.Backgrounds;
|
||||||
|
using osu.Game.Screens.Play;
|
||||||
|
using osu.Game.Screens.Play.PlayerSettings;
|
||||||
|
using osu.Game.Screens.Select;
|
||||||
|
using osu.Game.Tests.Resources;
|
||||||
|
using osu.Game.Users;
|
||||||
|
using osuTK;
|
||||||
|
using osuTK.Graphics;
|
||||||
|
|
||||||
|
namespace osu.Game.Tests.Visual.Background
|
||||||
|
{
|
||||||
|
[TestFixture]
|
||||||
|
public class TestSceneUserDimBackgrounds : ManualInputManagerTestScene
|
||||||
|
{
|
||||||
|
public override IReadOnlyList<Type> RequiredTypes => new[]
|
||||||
|
{
|
||||||
|
typeof(ScreenWithBeatmapBackground),
|
||||||
|
typeof(PlayerLoader),
|
||||||
|
typeof(Player),
|
||||||
|
typeof(UserDimContainer),
|
||||||
|
typeof(OsuScreen)
|
||||||
|
};
|
||||||
|
|
||||||
|
private DummySongSelect songSelect;
|
||||||
|
private TestPlayerLoader playerLoader;
|
||||||
|
private TestPlayer player;
|
||||||
|
private BeatmapManager manager;
|
||||||
|
private RulesetStore rulesets;
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load(GameHost host, AudioManager audio)
|
||||||
|
{
|
||||||
|
Dependencies.Cache(rulesets = new RulesetStore(ContextFactory));
|
||||||
|
Dependencies.Cache(manager = new BeatmapManager(LocalStorage, ContextFactory, rulesets, null, audio, host, Beatmap.Default));
|
||||||
|
Dependencies.Cache(new OsuConfigManager(LocalStorage));
|
||||||
|
|
||||||
|
manager.Import(TestResources.GetTestBeatmapForImport()).Wait();
|
||||||
|
|
||||||
|
Beatmap.SetDefault();
|
||||||
|
}
|
||||||
|
|
||||||
|
[SetUp]
|
||||||
|
public virtual void SetUp() => Schedule(() =>
|
||||||
|
{
|
||||||
|
Child = new OsuScreenStack(songSelect = new DummySongSelect())
|
||||||
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Check if <see cref="PlayerLoader"/> properly triggers the visual settings preview when a user hovers over the visual settings panel.
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void PlayerLoaderSettingsHoverTest()
|
||||||
|
{
|
||||||
|
setupUserSettings();
|
||||||
|
AddStep("Start player loader", () => songSelect.Push(playerLoader = new TestPlayerLoader(player = new TestPlayer { BlockLoad = true })));
|
||||||
|
AddUntilStep("Wait for Player Loader to load", () => playerLoader?.IsLoaded ?? false);
|
||||||
|
AddAssert("Background retained from song select", () => songSelect.IsBackgroundCurrent());
|
||||||
|
AddStep("Trigger background preview", () =>
|
||||||
|
{
|
||||||
|
InputManager.MoveMouseTo(playerLoader.ScreenPos);
|
||||||
|
InputManager.MoveMouseTo(playerLoader.VisualSettingsPos);
|
||||||
|
});
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
||||||
|
AddStep("Stop background preview", () => InputManager.MoveMouseTo(playerLoader.ScreenPos));
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && playerLoader.IsBlurCorrect());
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 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 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.
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void PlayerLoaderTransitionTest()
|
||||||
|
{
|
||||||
|
performFullSetup();
|
||||||
|
AddStep("Trigger hover event", () => playerLoader.TriggerOnHover());
|
||||||
|
AddAssert("Background retained from song select", () => songSelect.IsBackgroundCurrent());
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Make sure the background is fully invisible (Alpha == 0) when the background should be disabled by the storyboard.
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void StoryboardBackgroundVisibilityTest()
|
||||||
|
{
|
||||||
|
performFullSetup();
|
||||||
|
createFakeStoryboard();
|
||||||
|
AddStep("Enable Storyboard", () =>
|
||||||
|
{
|
||||||
|
player.ReplacesBackground.Value = true;
|
||||||
|
player.StoryboardEnabled.Value = true;
|
||||||
|
});
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Background is invisible, storyboard is visible", () => songSelect.IsBackgroundInvisible() && player.IsStoryboardVisible);
|
||||||
|
AddStep("Disable Storyboard", () =>
|
||||||
|
{
|
||||||
|
player.ReplacesBackground.Value = false;
|
||||||
|
player.StoryboardEnabled.Value = false;
|
||||||
|
});
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Background is visible, storyboard is invisible", () => songSelect.IsBackgroundVisible() && !player.IsStoryboardVisible);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// When exiting player, the screen that it suspends/exits to needs to have a fully visible (Alpha == 1) background.
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void StoryboardTransitionTest()
|
||||||
|
{
|
||||||
|
performFullSetup();
|
||||||
|
createFakeStoryboard();
|
||||||
|
AddStep("Exit to song select", () => player.Exit());
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Background is visible", () => songSelect.IsBackgroundVisible());
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Ensure <see cref="UserDimContainer"/> is properly accepting user-defined visual changes for a background.
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void DisableUserDimBackgroundTest()
|
||||||
|
{
|
||||||
|
performFullSetup();
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
||||||
|
AddStep("Enable user dim", () => songSelect.DimEnabled.Value = false);
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && songSelect.IsUserBlurDisabled());
|
||||||
|
AddStep("Disable user dim", () => songSelect.DimEnabled.Value = true);
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Ensure <see cref="UserDimContainer"/> is properly accepting user-defined visual changes for a storyboard.
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void DisableUserDimStoryboardTest()
|
||||||
|
{
|
||||||
|
performFullSetup();
|
||||||
|
createFakeStoryboard();
|
||||||
|
AddStep("Enable Storyboard", () =>
|
||||||
|
{
|
||||||
|
player.ReplacesBackground.Value = true;
|
||||||
|
player.StoryboardEnabled.Value = true;
|
||||||
|
});
|
||||||
|
AddStep("Enable user dim", () => player.DimmableStoryboard.EnableUserDim.Value = true);
|
||||||
|
AddStep("Set dim level to 1", () => songSelect.DimLevel.Value = 1f);
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Storyboard is invisible", () => !player.IsStoryboardVisible);
|
||||||
|
AddStep("Disable user dim", () => player.DimmableStoryboard.EnableUserDim.Value = false);
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Storyboard is visible", () => player.IsStoryboardVisible);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Check if the visual settings container retains dim and blur when pausing
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void PauseTest()
|
||||||
|
{
|
||||||
|
performFullSetup(true);
|
||||||
|
AddStep("Pause", () => player.Pause());
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
||||||
|
AddStep("Unpause", () => player.Resume());
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Check if the visual settings container removes user dim when suspending <see cref="Player"/> for <see cref="SoloResults"/>
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TransitionTest()
|
||||||
|
{
|
||||||
|
performFullSetup();
|
||||||
|
FadeAccessibleResults results = null;
|
||||||
|
AddStep("Transition to Results", () => player.Push(results =
|
||||||
|
new FadeAccessibleResults(new ScoreInfo { User = new User { Username = "osu!" } })));
|
||||||
|
AddUntilStep("Wait for results is current", () => results.IsCurrentScreen());
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Screen is undimmed, original background retained", () =>
|
||||||
|
songSelect.IsBackgroundUndimmed() && songSelect.IsBackgroundCurrent() && results.IsBlurCorrect());
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Check if background gets undimmed and unblurred when leaving <see cref="Player"/> for <see cref="PlaySongSelect"/>
|
||||||
|
/// </summary>
|
||||||
|
[Test]
|
||||||
|
public void TransitionOutTest()
|
||||||
|
{
|
||||||
|
performFullSetup();
|
||||||
|
AddStep("Exit to song select", () => player.Exit());
|
||||||
|
waitForDim();
|
||||||
|
AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && songSelect.IsBlurCorrect());
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Check if hovering on the visual settings dialogue after resuming from player still previews the background dim.
|
||||||
|
/// </summary>
|
||||||
|
[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);
|
||||||
|
|
||||||
|
private void createFakeStoryboard() => AddStep("Create storyboard", () =>
|
||||||
|
{
|
||||||
|
player.StoryboardEnabled.Value = false;
|
||||||
|
player.ReplacesBackground.Value = false;
|
||||||
|
player.DimmableStoryboard.Add(new OsuSpriteText
|
||||||
|
{
|
||||||
|
Size = new Vector2(500, 50),
|
||||||
|
Alpha = 1,
|
||||||
|
Colour = Color4.White,
|
||||||
|
Anchor = Anchor.Centre,
|
||||||
|
Origin = Anchor.Centre,
|
||||||
|
Text = "THIS IS A STORYBOARD",
|
||||||
|
Font = new FontUsage(size: 50)
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
private void performFullSetup(bool allowPause = false)
|
||||||
|
{
|
||||||
|
setupUserSettings();
|
||||||
|
|
||||||
|
AddStep("Start player loader", () => songSelect.Push(playerLoader = new TestPlayerLoader(player = new TestPlayer(allowPause))));
|
||||||
|
|
||||||
|
AddUntilStep("Wait for Player Loader to load", () => playerLoader.IsLoaded);
|
||||||
|
AddStep("Move mouse to center of screen", () => InputManager.MoveMouseTo(playerLoader.ScreenPos));
|
||||||
|
AddUntilStep("Wait for player to load", () => player.IsLoaded);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupUserSettings()
|
||||||
|
{
|
||||||
|
AddUntilStep("Song select has selection", () => songSelect.Carousel.SelectedBeatmap != null);
|
||||||
|
AddStep("Set default user settings", () =>
|
||||||
|
{
|
||||||
|
Mods.Value = Mods.Value.Concat(new[] { new OsuModNoFail() }).ToArray();
|
||||||
|
songSelect.DimLevel.Value = 0.7f;
|
||||||
|
songSelect.BlurLevel.Value = 0.4f;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void Dispose(bool isDisposing)
|
||||||
|
{
|
||||||
|
base.Dispose(isDisposing);
|
||||||
|
rulesets?.Dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
private class DummySongSelect : PlaySongSelect
|
||||||
|
{
|
||||||
|
protected override BackgroundScreen CreateBackground()
|
||||||
|
{
|
||||||
|
FadeAccessibleBackground background = new FadeAccessibleBackground(Beatmap.Value);
|
||||||
|
DimEnabled.BindTo(background.EnableUserDim);
|
||||||
|
return background;
|
||||||
|
}
|
||||||
|
|
||||||
|
public readonly Bindable<bool> DimEnabled = new Bindable<bool>();
|
||||||
|
public readonly Bindable<double> DimLevel = new Bindable<double>();
|
||||||
|
public readonly Bindable<double> BlurLevel = new Bindable<double>();
|
||||||
|
|
||||||
|
public new BeatmapCarousel Carousel => base.Carousel;
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load(OsuConfigManager config)
|
||||||
|
{
|
||||||
|
config.BindWith(OsuSetting.DimLevel, DimLevel);
|
||||||
|
config.BindWith(OsuSetting.BlurLevel, BlurLevel);
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsBackgroundDimmed() => ((FadeAccessibleBackground)Background).CurrentColour == OsuColour.Gray(1f - ((FadeAccessibleBackground)Background).CurrentDim);
|
||||||
|
|
||||||
|
public bool IsBackgroundUndimmed() => ((FadeAccessibleBackground)Background).CurrentColour == Color4.White;
|
||||||
|
|
||||||
|
public bool IsUserBlurApplied() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2((float)BlurLevel.Value * BackgroundScreenBeatmap.USER_BLUR_FACTOR);
|
||||||
|
|
||||||
|
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);
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Make sure every time a screen gets pushed, the background doesn't get replaced
|
||||||
|
/// </summary>
|
||||||
|
/// <returns>Whether or not the original background (The one created in DummySongSelect) is still the current background</returns>
|
||||||
|
public bool IsBackgroundCurrent() => ((FadeAccessibleBackground)Background).IsCurrentScreen();
|
||||||
|
}
|
||||||
|
|
||||||
|
private class FadeAccessibleResults : SoloResults
|
||||||
|
{
|
||||||
|
public FadeAccessibleResults(ScoreInfo score)
|
||||||
|
: base(score)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override BackgroundScreen CreateBackground() => new FadeAccessibleBackground(Beatmap.Value);
|
||||||
|
|
||||||
|
public bool IsBlurCorrect() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(BACKGROUND_BLUR);
|
||||||
|
}
|
||||||
|
|
||||||
|
private class TestPlayer : Visual.TestPlayer
|
||||||
|
{
|
||||||
|
protected override BackgroundScreen CreateBackground() => new FadeAccessibleBackground(Beatmap.Value);
|
||||||
|
|
||||||
|
public new DimmableStoryboard DimmableStoryboard => base.DimmableStoryboard;
|
||||||
|
|
||||||
|
// Whether or not the player should be allowed to load.
|
||||||
|
public bool BlockLoad;
|
||||||
|
|
||||||
|
public Bindable<bool> StoryboardEnabled;
|
||||||
|
public readonly Bindable<bool> ReplacesBackground = new Bindable<bool>();
|
||||||
|
public readonly Bindable<bool> IsPaused = new Bindable<bool>();
|
||||||
|
|
||||||
|
public TestPlayer(bool allowPause = true)
|
||||||
|
: base(allowPause)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsStoryboardVisible => DimmableStoryboard.ContentDisplayed;
|
||||||
|
|
||||||
|
[BackgroundDependencyLoader]
|
||||||
|
private void load(OsuConfigManager config, CancellationToken token)
|
||||||
|
{
|
||||||
|
while (BlockLoad && !token.IsCancellationRequested)
|
||||||
|
Thread.Sleep(1);
|
||||||
|
|
||||||
|
StoryboardEnabled = config.GetBindable<bool>(OsuSetting.ShowStoryboard);
|
||||||
|
ReplacesBackground.BindTo(Background.StoryboardReplacesBackground);
|
||||||
|
DrawableRuleset.IsPaused.BindTo(IsPaused);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private class TestPlayerLoader : PlayerLoader
|
||||||
|
{
|
||||||
|
public VisualSettings VisualSettingsPos => VisualSettings;
|
||||||
|
public BackgroundScreen ScreenPos => Background;
|
||||||
|
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
|
private class FadeAccessibleBackground : BackgroundScreenBeatmap
|
||||||
|
{
|
||||||
|
protected override DimmableBackground CreateFadeContainer() => dimmable = new TestDimmableBackground { RelativeSizeAxes = Axes.Both };
|
||||||
|
|
||||||
|
public Color4 CurrentColour => dimmable.CurrentColour;
|
||||||
|
|
||||||
|
public float CurrentAlpha => dimmable.CurrentAlpha;
|
||||||
|
|
||||||
|
public float CurrentDim => dimmable.DimLevel;
|
||||||
|
|
||||||
|
public Vector2 CurrentBlur => Background.BlurSigma;
|
||||||
|
|
||||||
|
private TestDimmableBackground dimmable;
|
||||||
|
|
||||||
|
public FadeAccessibleBackground(WorkingBeatmap beatmap)
|
||||||
|
: base(beatmap)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private class TestDimmableBackground : BackgroundScreenBeatmap.DimmableBackground
|
||||||
|
{
|
||||||
|
public Color4 CurrentColour => Content.Colour;
|
||||||
|
public float CurrentAlpha => Content.Alpha;
|
||||||
|
|
||||||
|
public new float DimLevel => base.DimLevel;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,423 +1,98 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Threading;
|
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Audio;
|
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Sprites;
|
using osu.Framework.Graphics.Shapes;
|
||||||
using osu.Framework.Input.Events;
|
|
||||||
using osu.Framework.Input.States;
|
|
||||||
using osu.Framework.Platform;
|
|
||||||
using osu.Framework.Screens;
|
|
||||||
using osu.Game.Beatmaps;
|
|
||||||
using osu.Game.Configuration;
|
using osu.Game.Configuration;
|
||||||
using osu.Game.Graphics;
|
using osu.Game.Graphics;
|
||||||
using osu.Game.Graphics.Containers;
|
using osu.Game.Graphics.Containers;
|
||||||
using osu.Game.Graphics.Sprites;
|
|
||||||
using osu.Game.Rulesets;
|
|
||||||
using osu.Game.Rulesets.Osu.Mods;
|
|
||||||
using osu.Game.Scoring;
|
|
||||||
using osu.Game.Screens;
|
|
||||||
using osu.Game.Screens.Backgrounds;
|
|
||||||
using osu.Game.Screens.Play;
|
|
||||||
using osu.Game.Screens.Play.PlayerSettings;
|
|
||||||
using osu.Game.Screens.Select;
|
|
||||||
using osu.Game.Tests.Resources;
|
|
||||||
using osu.Game.Users;
|
|
||||||
using osuTK;
|
|
||||||
using osuTK.Graphics;
|
using osuTK.Graphics;
|
||||||
|
|
||||||
namespace osu.Game.Tests.Visual.Background
|
namespace osu.Game.Tests.Visual.Background
|
||||||
{
|
{
|
||||||
[TestFixture]
|
public class TestSceneUserDimContainer : OsuTestScene
|
||||||
public class TestSceneUserDimContainer : ManualInputManagerTestScene
|
|
||||||
{
|
{
|
||||||
public override IReadOnlyList<Type> RequiredTypes => new[]
|
private TestUserDimContainer userDimContainer;
|
||||||
{
|
|
||||||
typeof(ScreenWithBeatmapBackground),
|
|
||||||
typeof(PlayerLoader),
|
|
||||||
typeof(Player),
|
|
||||||
typeof(UserDimContainer),
|
|
||||||
typeof(OsuScreen)
|
|
||||||
};
|
|
||||||
|
|
||||||
private DummySongSelect songSelect;
|
private readonly BindableBool isBreakTime = new BindableBool();
|
||||||
private TestPlayerLoader playerLoader;
|
|
||||||
private TestPlayer player;
|
|
||||||
private BeatmapManager manager;
|
|
||||||
private RulesetStore rulesets;
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
private Bindable<bool> lightenDuringBreaks = new Bindable<bool>();
|
||||||
private void load(GameHost host, AudioManager audio)
|
|
||||||
{
|
|
||||||
Dependencies.Cache(rulesets = new RulesetStore(ContextFactory));
|
|
||||||
Dependencies.Cache(manager = new BeatmapManager(LocalStorage, ContextFactory, rulesets, null, audio, host, Beatmap.Default));
|
|
||||||
Dependencies.Cache(new OsuConfigManager(LocalStorage));
|
|
||||||
|
|
||||||
manager.Import(TestResources.GetTestBeatmapForImport()).Wait();
|
|
||||||
|
|
||||||
Beatmap.SetDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
[SetUp]
|
|
||||||
public virtual void SetUp() => Schedule(() =>
|
|
||||||
{
|
|
||||||
Child = new OsuScreenStack(songSelect = new DummySongSelect())
|
|
||||||
{
|
|
||||||
RelativeSizeAxes = Axes.Both
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Check if <see cref="PlayerLoader"/> properly triggers the visual settings preview when a user hovers over the visual settings panel.
|
|
||||||
/// </summary>
|
|
||||||
[Test]
|
|
||||||
public void PlayerLoaderSettingsHoverTest()
|
|
||||||
{
|
|
||||||
setupUserSettings();
|
|
||||||
AddStep("Start player loader", () => songSelect.Push(playerLoader = new TestPlayerLoader(player = new TestPlayer { BlockLoad = true })));
|
|
||||||
AddUntilStep("Wait for Player Loader to load", () => playerLoader?.IsLoaded ?? false);
|
|
||||||
AddAssert("Background retained from song select", () => songSelect.IsBackgroundCurrent());
|
|
||||||
AddStep("Trigger background preview", () =>
|
|
||||||
{
|
|
||||||
InputManager.MoveMouseTo(playerLoader.ScreenPos);
|
|
||||||
InputManager.MoveMouseTo(playerLoader.VisualSettingsPos);
|
|
||||||
});
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
|
||||||
AddStep("Stop background preview", () => InputManager.MoveMouseTo(playerLoader.ScreenPos));
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && playerLoader.IsBlurCorrect());
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// 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 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.
|
|
||||||
/// </summary>
|
|
||||||
[Test]
|
|
||||||
public void PlayerLoaderTransitionTest()
|
|
||||||
{
|
|
||||||
performFullSetup();
|
|
||||||
AddStep("Trigger hover event", () => playerLoader.TriggerOnHover());
|
|
||||||
AddAssert("Background retained from song select", () => songSelect.IsBackgroundCurrent());
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Make sure the background is fully invisible (Alpha == 0) when the background should be disabled by the storyboard.
|
|
||||||
/// </summary>
|
|
||||||
[Test]
|
|
||||||
public void StoryboardBackgroundVisibilityTest()
|
|
||||||
{
|
|
||||||
performFullSetup();
|
|
||||||
createFakeStoryboard();
|
|
||||||
AddStep("Enable Storyboard", () =>
|
|
||||||
{
|
|
||||||
player.ReplacesBackground.Value = true;
|
|
||||||
player.StoryboardEnabled.Value = true;
|
|
||||||
});
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Background is invisible, storyboard is visible", () => songSelect.IsBackgroundInvisible() && player.IsStoryboardVisible);
|
|
||||||
AddStep("Disable Storyboard", () =>
|
|
||||||
{
|
|
||||||
player.ReplacesBackground.Value = false;
|
|
||||||
player.StoryboardEnabled.Value = false;
|
|
||||||
});
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Background is visible, storyboard is invisible", () => songSelect.IsBackgroundVisible() && !player.IsStoryboardVisible);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// When exiting player, the screen that it suspends/exits to needs to have a fully visible (Alpha == 1) background.
|
|
||||||
/// </summary>
|
|
||||||
[Test]
|
|
||||||
public void StoryboardTransitionTest()
|
|
||||||
{
|
|
||||||
performFullSetup();
|
|
||||||
createFakeStoryboard();
|
|
||||||
AddStep("Exit to song select", () => player.Exit());
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Background is visible", () => songSelect.IsBackgroundVisible());
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Ensure <see cref="UserDimContainer"/> is properly accepting user-defined visual changes for a background.
|
|
||||||
/// </summary>
|
|
||||||
[Test]
|
|
||||||
public void DisableUserDimBackgroundTest()
|
|
||||||
{
|
|
||||||
performFullSetup();
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
|
||||||
AddStep("Enable user dim", () => songSelect.DimEnabled.Value = false);
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && songSelect.IsUserBlurDisabled());
|
|
||||||
AddStep("Disable user dim", () => songSelect.DimEnabled.Value = true);
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Ensure <see cref="UserDimContainer"/> is properly accepting user-defined visual changes for a storyboard.
|
|
||||||
/// </summary>
|
|
||||||
[Test]
|
|
||||||
public void DisableUserDimStoryboardTest()
|
|
||||||
{
|
|
||||||
performFullSetup();
|
|
||||||
createFakeStoryboard();
|
|
||||||
AddStep("Enable Storyboard", () =>
|
|
||||||
{
|
|
||||||
player.ReplacesBackground.Value = true;
|
|
||||||
player.StoryboardEnabled.Value = true;
|
|
||||||
});
|
|
||||||
AddStep("Enable user dim", () => player.DimmableStoryboard.EnableUserDim.Value = true);
|
|
||||||
AddStep("Set dim level to 1", () => songSelect.DimLevel.Value = 1f);
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Storyboard is invisible", () => !player.IsStoryboardVisible);
|
|
||||||
AddStep("Disable user dim", () => player.DimmableStoryboard.EnableUserDim.Value = false);
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Storyboard is visible", () => player.IsStoryboardVisible);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Check if the visual settings container retains dim and blur when pausing
|
|
||||||
/// </summary>
|
|
||||||
[Test]
|
|
||||||
public void PauseTest()
|
|
||||||
{
|
|
||||||
performFullSetup(true);
|
|
||||||
AddStep("Pause", () => player.Pause());
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
|
||||||
AddStep("Unpause", () => player.Resume());
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Check if the visual settings container removes user dim when suspending <see cref="Player"/> for <see cref="SoloResults"/>
|
|
||||||
/// </summary>
|
|
||||||
[Test]
|
|
||||||
public void TransitionTest()
|
|
||||||
{
|
|
||||||
performFullSetup();
|
|
||||||
FadeAccessibleResults results = null;
|
|
||||||
AddStep("Transition to Results", () => player.Push(results =
|
|
||||||
new FadeAccessibleResults(new ScoreInfo { User = new User { Username = "osu!" } })));
|
|
||||||
AddUntilStep("Wait for results is current", () => results.IsCurrentScreen());
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Screen is undimmed, original background retained", () =>
|
|
||||||
songSelect.IsBackgroundUndimmed() && songSelect.IsBackgroundCurrent() && results.IsBlurCorrect());
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Check if background gets undimmed and unblurred when leaving <see cref="Player"/> for <see cref="PlaySongSelect"/>
|
|
||||||
/// </summary>
|
|
||||||
[Test]
|
|
||||||
public void TransitionOutTest()
|
|
||||||
{
|
|
||||||
performFullSetup();
|
|
||||||
AddStep("Exit to song select", () => player.Exit());
|
|
||||||
waitForDim();
|
|
||||||
AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && songSelect.IsBlurCorrect());
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Check if hovering on the visual settings dialogue after resuming from player still previews the background dim.
|
|
||||||
/// </summary>
|
|
||||||
[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);
|
|
||||||
|
|
||||||
private void createFakeStoryboard() => AddStep("Create storyboard", () =>
|
|
||||||
{
|
|
||||||
player.StoryboardEnabled.Value = false;
|
|
||||||
player.ReplacesBackground.Value = false;
|
|
||||||
player.DimmableStoryboard.Add(new OsuSpriteText
|
|
||||||
{
|
|
||||||
Size = new Vector2(500, 50),
|
|
||||||
Alpha = 1,
|
|
||||||
Colour = Color4.White,
|
|
||||||
Anchor = Anchor.Centre,
|
|
||||||
Origin = Anchor.Centre,
|
|
||||||
Text = "THIS IS A STORYBOARD",
|
|
||||||
Font = new FontUsage(size: 50)
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
private void performFullSetup(bool allowPause = false)
|
|
||||||
{
|
|
||||||
setupUserSettings();
|
|
||||||
|
|
||||||
AddStep("Start player loader", () => songSelect.Push(playerLoader = new TestPlayerLoader(player = new TestPlayer(allowPause))));
|
|
||||||
|
|
||||||
AddUntilStep("Wait for Player Loader to load", () => playerLoader.IsLoaded);
|
|
||||||
AddStep("Move mouse to center of screen", () => InputManager.MoveMouseTo(playerLoader.ScreenPos));
|
|
||||||
AddUntilStep("Wait for player to load", () => player.IsLoaded);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setupUserSettings()
|
|
||||||
{
|
|
||||||
AddUntilStep("Song select has selection", () => songSelect.Carousel.SelectedBeatmap != null);
|
|
||||||
AddStep("Set default user settings", () =>
|
|
||||||
{
|
|
||||||
Mods.Value = Mods.Value.Concat(new[] { new OsuModNoFail() }).ToArray();
|
|
||||||
songSelect.DimLevel.Value = 0.7f;
|
|
||||||
songSelect.BlurLevel.Value = 0.4f;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void Dispose(bool isDisposing)
|
|
||||||
{
|
|
||||||
base.Dispose(isDisposing);
|
|
||||||
rulesets?.Dispose();
|
|
||||||
}
|
|
||||||
|
|
||||||
private class DummySongSelect : PlaySongSelect
|
|
||||||
{
|
|
||||||
protected override BackgroundScreen CreateBackground()
|
|
||||||
{
|
|
||||||
FadeAccessibleBackground background = new FadeAccessibleBackground(Beatmap.Value);
|
|
||||||
DimEnabled.BindTo(background.EnableUserDim);
|
|
||||||
return background;
|
|
||||||
}
|
|
||||||
|
|
||||||
public readonly Bindable<bool> DimEnabled = new Bindable<bool>();
|
|
||||||
public readonly Bindable<double> DimLevel = new Bindable<double>();
|
|
||||||
public readonly Bindable<double> BlurLevel = new Bindable<double>();
|
|
||||||
|
|
||||||
public new BeatmapCarousel Carousel => base.Carousel;
|
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(OsuConfigManager config)
|
private void load(OsuConfigManager config)
|
||||||
{
|
{
|
||||||
config.BindWith(OsuSetting.DimLevel, DimLevel);
|
lightenDuringBreaks = config.GetBindable<bool>(OsuSetting.LightenDuringBreaks);
|
||||||
config.BindWith(OsuSetting.BlurLevel, BlurLevel);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public bool IsBackgroundDimmed() => ((FadeAccessibleBackground)Background).CurrentColour == OsuColour.Gray(1 - (float)DimLevel.Value);
|
[SetUp]
|
||||||
|
public void SetUp() => Schedule(() =>
|
||||||
public bool IsBackgroundUndimmed() => ((FadeAccessibleBackground)Background).CurrentColour == Color4.White;
|
|
||||||
|
|
||||||
public bool IsUserBlurApplied() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2((float)BlurLevel.Value * BackgroundScreenBeatmap.USER_BLUR_FACTOR);
|
|
||||||
|
|
||||||
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);
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Make sure every time a screen gets pushed, the background doesn't get replaced
|
|
||||||
/// </summary>
|
|
||||||
/// <returns>Whether or not the original background (The one created in DummySongSelect) is still the current background</returns>
|
|
||||||
public bool IsBackgroundCurrent() => ((FadeAccessibleBackground)Background).IsCurrentScreen();
|
|
||||||
}
|
|
||||||
|
|
||||||
private class FadeAccessibleResults : SoloResults
|
|
||||||
{
|
{
|
||||||
public FadeAccessibleResults(ScoreInfo score)
|
Child = userDimContainer = new TestUserDimContainer
|
||||||
: base(score)
|
|
||||||
{
|
{
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
Child = new Box
|
||||||
|
{
|
||||||
|
Colour = Color4.White,
|
||||||
|
RelativeSizeAxes = Axes.Both,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
userDimContainer.IsBreakTime.BindTo(isBreakTime);
|
||||||
|
isBreakTime.Value = false;
|
||||||
|
|
||||||
|
lightenDuringBreaks.Value = false;
|
||||||
|
});
|
||||||
|
|
||||||
|
private const float test_user_dim = 0.6f;
|
||||||
|
private const float test_user_dim_lightened = test_user_dim - UserDimContainer.BREAK_LIGHTEN_AMOUNT;
|
||||||
|
|
||||||
|
[TestCase(test_user_dim, test_user_dim_lightened)]
|
||||||
|
[TestCase(0.2f, 0.0f)]
|
||||||
|
[TestCase(0.0f, 0.0f)]
|
||||||
|
public void TestBreakLightening(float userDim, float expectedBreakDim)
|
||||||
|
{
|
||||||
|
AddStep($"set dim level {userDim}", () => userDimContainer.UserDimLevel.Value = userDim);
|
||||||
|
AddStep("set lighten during break", () => lightenDuringBreaks.Value = true);
|
||||||
|
|
||||||
|
AddStep("set break", () => isBreakTime.Value = true);
|
||||||
|
AddUntilStep("has lightened", () => userDimContainer.DimEqual(expectedBreakDim));
|
||||||
|
AddStep("clear break", () => isBreakTime.Value = false);
|
||||||
|
AddUntilStep("not lightened", () => userDimContainer.DimEqual(userDim));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override BackgroundScreen CreateBackground() => new FadeAccessibleBackground(Beatmap.Value);
|
[Test]
|
||||||
|
public void TestEnableSettingDuringBreak()
|
||||||
|
{
|
||||||
|
AddStep("set dim level 0.6", () => userDimContainer.UserDimLevel.Value = test_user_dim);
|
||||||
|
|
||||||
public bool IsBlurCorrect() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(BACKGROUND_BLUR);
|
AddStep("set break", () => isBreakTime.Value = true);
|
||||||
|
AddUntilStep("not lightened", () => userDimContainer.DimEqual(test_user_dim));
|
||||||
|
AddStep("set lighten during break", () => lightenDuringBreaks.Value = true);
|
||||||
|
AddUntilStep("has lightened", () => userDimContainer.DimEqual(test_user_dim_lightened));
|
||||||
}
|
}
|
||||||
|
|
||||||
private class TestPlayer : Visual.TestPlayer
|
[Test]
|
||||||
|
public void TestDisableSettingDuringBreak()
|
||||||
{
|
{
|
||||||
protected override BackgroundScreen CreateBackground() => new FadeAccessibleBackground(Beatmap.Value);
|
AddStep("set dim level 0.6", () => userDimContainer.UserDimLevel.Value = test_user_dim);
|
||||||
|
AddStep("set lighten during break", () => lightenDuringBreaks.Value = true);
|
||||||
|
|
||||||
public new DimmableStoryboard DimmableStoryboard => base.DimmableStoryboard;
|
AddStep("set break", () => isBreakTime.Value = true);
|
||||||
|
AddUntilStep("has lightened", () => userDimContainer.DimEqual(test_user_dim_lightened));
|
||||||
// Whether or not the player should be allowed to load.
|
AddStep("clear lighten during break", () => lightenDuringBreaks.Value = false);
|
||||||
public bool BlockLoad;
|
AddUntilStep("not lightened", () => userDimContainer.DimEqual(test_user_dim));
|
||||||
|
AddStep("clear break", () => isBreakTime.Value = false);
|
||||||
public Bindable<bool> StoryboardEnabled;
|
AddUntilStep("not lightened", () => userDimContainer.DimEqual(test_user_dim));
|
||||||
public readonly Bindable<bool> ReplacesBackground = new Bindable<bool>();
|
|
||||||
public readonly Bindable<bool> IsPaused = new Bindable<bool>();
|
|
||||||
|
|
||||||
public TestPlayer(bool allowPause = true)
|
|
||||||
: base(allowPause)
|
|
||||||
{
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public bool IsStoryboardVisible => DimmableStoryboard.ContentDisplayed;
|
private class TestUserDimContainer : UserDimContainer
|
||||||
|
|
||||||
[BackgroundDependencyLoader]
|
|
||||||
private void load(OsuConfigManager config, CancellationToken token)
|
|
||||||
{
|
{
|
||||||
while (BlockLoad && !token.IsCancellationRequested)
|
public bool DimEqual(float expectedDimLevel) => Content.Colour == OsuColour.Gray(1f - expectedDimLevel);
|
||||||
Thread.Sleep(1);
|
|
||||||
|
|
||||||
StoryboardEnabled = config.GetBindable<bool>(OsuSetting.ShowStoryboard);
|
public new Bindable<double> UserDimLevel => base.UserDimLevel;
|
||||||
ReplacesBackground.BindTo(Background.StoryboardReplacesBackground);
|
|
||||||
DrawableRuleset.IsPaused.BindTo(IsPaused);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private class TestPlayerLoader : PlayerLoader
|
|
||||||
{
|
|
||||||
public VisualSettings VisualSettingsPos => VisualSettings;
|
|
||||||
public BackgroundScreen ScreenPos => Background;
|
|
||||||
|
|
||||||
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);
|
|
||||||
}
|
|
||||||
|
|
||||||
private class FadeAccessibleBackground : BackgroundScreenBeatmap
|
|
||||||
{
|
|
||||||
protected override DimmableBackground CreateFadeContainer() => dimmable = new TestDimmableBackground { RelativeSizeAxes = Axes.Both };
|
|
||||||
|
|
||||||
public Color4 CurrentColour => dimmable.CurrentColour;
|
|
||||||
|
|
||||||
public float CurrentAlpha => dimmable.CurrentAlpha;
|
|
||||||
|
|
||||||
public Vector2 CurrentBlur => Background.BlurSigma;
|
|
||||||
|
|
||||||
private TestDimmableBackground dimmable;
|
|
||||||
|
|
||||||
public FadeAccessibleBackground(WorkingBeatmap beatmap)
|
|
||||||
: base(beatmap)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private class TestDimmableBackground : BackgroundScreenBeatmap.DimmableBackground
|
|
||||||
{
|
|
||||||
public Color4 CurrentColour => Content.Colour;
|
|
||||||
public float CurrentAlpha => Content.Alpha;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -80,6 +80,7 @@ namespace osu.Game.Configuration
|
|||||||
// Gameplay
|
// Gameplay
|
||||||
Set(OsuSetting.DimLevel, 0.3, 0, 1, 0.01);
|
Set(OsuSetting.DimLevel, 0.3, 0, 1, 0.01);
|
||||||
Set(OsuSetting.BlurLevel, 0, 0, 1, 0.01);
|
Set(OsuSetting.BlurLevel, 0, 0, 1, 0.01);
|
||||||
|
Set(OsuSetting.LightenDuringBreaks, true);
|
||||||
|
|
||||||
Set(OsuSetting.HitLighting, true);
|
Set(OsuSetting.HitLighting, true);
|
||||||
|
|
||||||
@ -142,6 +143,7 @@ namespace osu.Game.Configuration
|
|||||||
AutoCursorSize,
|
AutoCursorSize,
|
||||||
DimLevel,
|
DimLevel,
|
||||||
BlurLevel,
|
BlurLevel,
|
||||||
|
LightenDuringBreaks,
|
||||||
ShowStoryboard,
|
ShowStoryboard,
|
||||||
ShowVideoBackground,
|
ShowVideoBackground,
|
||||||
KeyOverlay,
|
KeyOverlay,
|
||||||
|
@ -1,11 +1,13 @@
|
|||||||
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
|
using System;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
using osu.Framework.Graphics;
|
using osu.Framework.Graphics;
|
||||||
using osu.Framework.Graphics.Containers;
|
using osu.Framework.Graphics.Containers;
|
||||||
using osu.Game.Configuration;
|
using osu.Game.Configuration;
|
||||||
|
using osu.Game.Screens.Play;
|
||||||
|
|
||||||
namespace osu.Game.Graphics.Containers
|
namespace osu.Game.Graphics.Containers
|
||||||
{
|
{
|
||||||
@ -14,7 +16,12 @@ namespace osu.Game.Graphics.Containers
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public abstract class UserDimContainer : Container
|
public abstract class UserDimContainer : Container
|
||||||
{
|
{
|
||||||
protected const float BACKGROUND_FADE_DURATION = 800;
|
/// <summary>
|
||||||
|
/// Amount of lightening to apply to current dim level during break times.
|
||||||
|
/// </summary>
|
||||||
|
public const float BREAK_LIGHTEN_AMOUNT = 0.3f;
|
||||||
|
|
||||||
|
protected const double BACKGROUND_FADE_DURATION = 800;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Whether or not user-configured dim levels should be applied to the container.
|
/// Whether or not user-configured dim levels should be applied to the container.
|
||||||
@ -26,6 +33,12 @@ namespace osu.Game.Graphics.Containers
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public readonly Bindable<bool> StoryboardReplacesBackground = new Bindable<bool>();
|
public readonly Bindable<bool> StoryboardReplacesBackground = new Bindable<bool>();
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Whether player is in break time.
|
||||||
|
/// Must be bound to <see cref="BreakOverlay.IsBreakTime"/> to allow for dim adjustments in gameplay.
|
||||||
|
/// </summary>
|
||||||
|
public readonly IBindable<bool> IsBreakTime = new Bindable<bool>();
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Whether the content of this container is currently being displayed.
|
/// Whether the content of this container is currently being displayed.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -33,11 +46,14 @@ namespace osu.Game.Graphics.Containers
|
|||||||
|
|
||||||
protected Bindable<double> UserDimLevel { get; private set; }
|
protected Bindable<double> UserDimLevel { get; private set; }
|
||||||
|
|
||||||
|
protected Bindable<bool> LightenDuringBreaks { get; private set; }
|
||||||
|
|
||||||
protected Bindable<bool> ShowStoryboard { get; private set; }
|
protected Bindable<bool> ShowStoryboard { get; private set; }
|
||||||
|
|
||||||
protected Bindable<bool> ShowVideo { get; private set; }
|
protected Bindable<bool> ShowVideo { get; private set; }
|
||||||
|
|
||||||
protected double DimLevel => EnableUserDim.Value ? UserDimLevel.Value : 0;
|
private float breakLightening => LightenDuringBreaks.Value && IsBreakTime.Value ? BREAK_LIGHTEN_AMOUNT : 0;
|
||||||
|
protected float DimLevel => Math.Max(EnableUserDim.Value ? (float)UserDimLevel.Value - breakLightening : 0, 0);
|
||||||
|
|
||||||
protected override Container<Drawable> Content => dimContent;
|
protected override Container<Drawable> Content => dimContent;
|
||||||
|
|
||||||
@ -55,11 +71,14 @@ namespace osu.Game.Graphics.Containers
|
|||||||
private void load(OsuConfigManager config)
|
private void load(OsuConfigManager config)
|
||||||
{
|
{
|
||||||
UserDimLevel = config.GetBindable<double>(OsuSetting.DimLevel);
|
UserDimLevel = config.GetBindable<double>(OsuSetting.DimLevel);
|
||||||
|
LightenDuringBreaks = config.GetBindable<bool>(OsuSetting.LightenDuringBreaks);
|
||||||
ShowStoryboard = config.GetBindable<bool>(OsuSetting.ShowStoryboard);
|
ShowStoryboard = config.GetBindable<bool>(OsuSetting.ShowStoryboard);
|
||||||
ShowVideo = config.GetBindable<bool>(OsuSetting.ShowVideoBackground);
|
ShowVideo = config.GetBindable<bool>(OsuSetting.ShowVideoBackground);
|
||||||
|
|
||||||
EnableUserDim.ValueChanged += _ => UpdateVisuals();
|
EnableUserDim.ValueChanged += _ => UpdateVisuals();
|
||||||
UserDimLevel.ValueChanged += _ => UpdateVisuals();
|
UserDimLevel.ValueChanged += _ => UpdateVisuals();
|
||||||
|
LightenDuringBreaks.ValueChanged += _ => UpdateVisuals();
|
||||||
|
IsBreakTime.ValueChanged += _ => UpdateVisuals();
|
||||||
ShowStoryboard.ValueChanged += _ => UpdateVisuals();
|
ShowStoryboard.ValueChanged += _ => UpdateVisuals();
|
||||||
ShowVideo.ValueChanged += _ => UpdateVisuals();
|
ShowVideo.ValueChanged += _ => UpdateVisuals();
|
||||||
StoryboardReplacesBackground.ValueChanged += _ => UpdateVisuals();
|
StoryboardReplacesBackground.ValueChanged += _ => UpdateVisuals();
|
||||||
@ -84,7 +103,7 @@ namespace osu.Game.Graphics.Containers
|
|||||||
ContentDisplayed = ShowDimContent;
|
ContentDisplayed = ShowDimContent;
|
||||||
|
|
||||||
dimContent.FadeTo(ContentDisplayed ? 1 : 0, BACKGROUND_FADE_DURATION, Easing.OutQuint);
|
dimContent.FadeTo(ContentDisplayed ? 1 : 0, BACKGROUND_FADE_DURATION, Easing.OutQuint);
|
||||||
dimContent.FadeColour(OsuColour.Gray(1 - (float)DimLevel), BACKGROUND_FADE_DURATION, Easing.OutQuint);
|
dimContent.FadeColour(OsuColour.Gray(1f - DimLevel), BACKGROUND_FADE_DURATION, Easing.OutQuint);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,6 +30,11 @@ namespace osu.Game.Overlays.Settings.Sections.Gameplay
|
|||||||
KeyboardStep = 0.01f
|
KeyboardStep = 0.01f
|
||||||
},
|
},
|
||||||
new SettingsCheckbox
|
new SettingsCheckbox
|
||||||
|
{
|
||||||
|
LabelText = "Lighten playfield during breaks",
|
||||||
|
Bindable = config.GetBindable<bool>(OsuSetting.LightenDuringBreaks)
|
||||||
|
},
|
||||||
|
new SettingsCheckbox
|
||||||
{
|
{
|
||||||
LabelText = "Show score overlay",
|
LabelText = "Show score overlay",
|
||||||
Bindable = config.GetBindable<bool>(OsuSetting.ShowInterface)
|
Bindable = config.GetBindable<bool>(OsuSetting.ShowInterface)
|
||||||
|
@ -38,6 +38,8 @@ namespace osu.Game.Screens.Backgrounds
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public readonly Bindable<float> BlurAmount = new Bindable<float>();
|
public readonly Bindable<float> BlurAmount = new Bindable<float>();
|
||||||
|
|
||||||
|
internal readonly IBindable<bool> IsBreakTime = new Bindable<bool>();
|
||||||
|
|
||||||
private readonly DimmableBackground dimmable;
|
private readonly DimmableBackground dimmable;
|
||||||
|
|
||||||
protected virtual DimmableBackground CreateFadeContainer() => new DimmableBackground { RelativeSizeAxes = Axes.Both };
|
protected virtual DimmableBackground CreateFadeContainer() => new DimmableBackground { RelativeSizeAxes = Axes.Both };
|
||||||
@ -48,6 +50,7 @@ namespace osu.Game.Screens.Backgrounds
|
|||||||
|
|
||||||
InternalChild = dimmable = CreateFadeContainer();
|
InternalChild = dimmable = CreateFadeContainer();
|
||||||
dimmable.EnableUserDim.BindTo(EnableUserDim);
|
dimmable.EnableUserDim.BindTo(EnableUserDim);
|
||||||
|
dimmable.IsBreakTime.BindTo(IsBreakTime);
|
||||||
dimmable.BlurAmount.BindTo(BlurAmount);
|
dimmable.BlurAmount.BindTo(BlurAmount);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -511,6 +511,11 @@ namespace osu.Game.Screens.Play
|
|||||||
Background.EnableUserDim.Value = true;
|
Background.EnableUserDim.Value = true;
|
||||||
Background.BlurAmount.Value = 0;
|
Background.BlurAmount.Value = 0;
|
||||||
|
|
||||||
|
// bind component bindables.
|
||||||
|
Background.IsBreakTime.BindTo(breakOverlay.IsBreakTime);
|
||||||
|
DimmableStoryboard.IsBreakTime.BindTo(breakOverlay.IsBreakTime);
|
||||||
|
DimmableVideo.IsBreakTime.BindTo(breakOverlay.IsBreakTime);
|
||||||
|
|
||||||
Background.StoryboardReplacesBackground.BindTo(storyboardReplacesBackground);
|
Background.StoryboardReplacesBackground.BindTo(storyboardReplacesBackground);
|
||||||
DimmableStoryboard.StoryboardReplacesBackground.BindTo(storyboardReplacesBackground);
|
DimmableStoryboard.StoryboardReplacesBackground.BindTo(storyboardReplacesBackground);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user