2019-02-15 15:17:01 +08:00
|
|
|
// 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.
|
|
|
|
|
2019-02-22 13:43:05 +08:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
2019-02-27 13:15:45 +08:00
|
|
|
using System.Linq;
|
2019-02-21 14:24:26 +08:00
|
|
|
using System.Threading;
|
2019-02-15 15:38:27 +08:00
|
|
|
using NUnit.Framework;
|
2019-02-21 14:24:26 +08:00
|
|
|
using osu.Framework.Allocation;
|
2019-05-31 13:40:53 +08:00
|
|
|
using osu.Framework.Audio;
|
2019-02-22 19:44:02 +08:00
|
|
|
using osu.Framework.Bindables;
|
2019-02-21 14:24:26 +08:00
|
|
|
using osu.Framework.Graphics;
|
2019-02-28 15:18:46 +08:00
|
|
|
using osu.Framework.Input.Events;
|
|
|
|
using osu.Framework.Input.States;
|
2019-02-27 13:15:45 +08:00
|
|
|
using osu.Framework.Platform;
|
2019-02-19 18:44:26 +08:00
|
|
|
using osu.Framework.Screens;
|
|
|
|
using osu.Game.Beatmaps;
|
2019-02-22 10:41:28 +08:00
|
|
|
using osu.Game.Configuration;
|
2019-02-27 13:15:45 +08:00
|
|
|
using osu.Game.Database;
|
2019-02-15 15:17:01 +08:00
|
|
|
using osu.Game.Graphics;
|
2019-02-22 19:34:51 +08:00
|
|
|
using osu.Game.Graphics.Containers;
|
2019-05-21 13:13:52 +08:00
|
|
|
using osu.Game.Graphics.Sprites;
|
2019-02-27 13:15:45 +08:00
|
|
|
using osu.Game.Rulesets;
|
|
|
|
using osu.Game.Rulesets.Osu.Mods;
|
2019-02-18 17:58:34 +08:00
|
|
|
using osu.Game.Scoring;
|
2019-02-15 15:17:01 +08:00
|
|
|
using osu.Game.Screens;
|
|
|
|
using osu.Game.Screens.Backgrounds;
|
|
|
|
using osu.Game.Screens.Play;
|
2019-02-21 14:24:26 +08:00
|
|
|
using osu.Game.Screens.Play.PlayerSettings;
|
2019-02-27 13:15:45 +08:00
|
|
|
using osu.Game.Screens.Select;
|
|
|
|
using osu.Game.Tests.Resources;
|
2019-02-18 18:53:55 +08:00
|
|
|
using osu.Game.Users;
|
2019-02-28 13:40:31 +08:00
|
|
|
using osuTK;
|
2019-02-18 18:53:55 +08:00
|
|
|
using osuTK.Graphics;
|
2019-02-15 15:17:01 +08:00
|
|
|
|
2019-03-25 00:02:36 +08:00
|
|
|
namespace osu.Game.Tests.Visual.Background
|
2019-02-15 15:17:01 +08:00
|
|
|
{
|
2019-02-15 15:38:27 +08:00
|
|
|
[TestFixture]
|
2019-05-15 03:37:25 +08:00
|
|
|
public class TestSceneBackgroundScreenBeatmap : ManualInputManagerTestScene
|
2019-02-15 15:17:01 +08:00
|
|
|
{
|
2019-02-22 13:43:05 +08:00
|
|
|
public override IReadOnlyList<Type> RequiredTypes => new[]
|
|
|
|
{
|
|
|
|
typeof(ScreenWithBeatmapBackground),
|
|
|
|
typeof(PlayerLoader),
|
2019-02-22 19:34:51 +08:00
|
|
|
typeof(Player),
|
2019-02-26 16:31:21 +08:00
|
|
|
typeof(UserDimContainer),
|
|
|
|
typeof(OsuScreen)
|
2019-02-22 13:43:05 +08:00
|
|
|
};
|
|
|
|
|
2019-02-19 18:44:26 +08:00
|
|
|
private DummySongSelect songSelect;
|
2019-03-13 15:47:03 +08:00
|
|
|
private TestPlayerLoader playerLoader;
|
|
|
|
private TestPlayer player;
|
2019-02-27 13:15:45 +08:00
|
|
|
private DatabaseContextFactory factory;
|
|
|
|
private BeatmapManager manager;
|
|
|
|
private RulesetStore rulesets;
|
2019-02-21 14:24:26 +08:00
|
|
|
|
2019-02-27 13:15:45 +08:00
|
|
|
[BackgroundDependencyLoader]
|
2019-05-31 13:40:53 +08:00
|
|
|
private void load(GameHost host, AudioManager audio)
|
2019-02-27 13:15:45 +08:00
|
|
|
{
|
|
|
|
factory = new DatabaseContextFactory(LocalStorage);
|
|
|
|
factory.ResetDatabase();
|
|
|
|
|
|
|
|
using (var usage = factory.Get())
|
|
|
|
usage.Migrate();
|
|
|
|
|
|
|
|
factory.ResetDatabase();
|
|
|
|
|
|
|
|
using (var usage = factory.Get())
|
|
|
|
usage.Migrate();
|
|
|
|
|
|
|
|
Dependencies.Cache(rulesets = new RulesetStore(factory));
|
2019-05-31 13:40:53 +08:00
|
|
|
Dependencies.Cache(manager = new BeatmapManager(LocalStorage, factory, rulesets, null, audio, host, Beatmap.Default));
|
2019-02-27 16:02:04 +08:00
|
|
|
Dependencies.Cache(new OsuConfigManager(LocalStorage));
|
2019-02-27 13:15:45 +08:00
|
|
|
|
2019-05-28 17:59:21 +08:00
|
|
|
manager.Import(TestResources.GetTestBeatmapForImport()).Wait();
|
2019-03-20 19:47:25 +08:00
|
|
|
|
2019-02-27 13:15:45 +08:00
|
|
|
Beatmap.SetDefault();
|
|
|
|
}
|
|
|
|
|
|
|
|
[SetUp]
|
2019-03-20 19:47:25 +08:00
|
|
|
public virtual void SetUp() => Schedule(() =>
|
2019-02-27 16:02:04 +08:00
|
|
|
{
|
2019-03-25 11:39:40 +08:00
|
|
|
Child = new OsuScreenStack(songSelect = new DummySongSelect())
|
|
|
|
{
|
|
|
|
RelativeSizeAxes = Axes.Both
|
|
|
|
};
|
2019-03-20 19:47:25 +08:00
|
|
|
});
|
2019-02-27 13:15:45 +08:00
|
|
|
|
2019-02-24 17:10:59 +08:00
|
|
|
/// <summary>
|
2019-03-13 15:47:03 +08:00
|
|
|
/// Check if <see cref="PlayerLoader"/> properly triggers the visual settings preview when a user hovers over the visual settings panel.
|
2019-02-24 17:10:59 +08:00
|
|
|
/// </summary>
|
|
|
|
[Test]
|
|
|
|
public void PlayerLoaderSettingsHoverTest()
|
|
|
|
{
|
2019-02-28 17:26:41 +08:00
|
|
|
setupUserSettings();
|
2019-03-27 16:34:58 +08:00
|
|
|
AddStep("Start player loader", () => songSelect.Push(playerLoader = new TestPlayerLoader(player = new TestPlayer { BlockLoad = true })));
|
2019-03-19 16:24:26 +08:00
|
|
|
AddUntilStep("Wait for Player Loader to load", () => playerLoader?.IsLoaded ?? false);
|
2019-02-26 08:54:28 +08:00
|
|
|
AddAssert("Background retained from song select", () => songSelect.IsBackgroundCurrent());
|
2019-02-21 14:24:26 +08:00
|
|
|
AddStep("Trigger background preview", () =>
|
|
|
|
{
|
|
|
|
InputManager.MoveMouseTo(playerLoader.ScreenPos);
|
|
|
|
InputManager.MoveMouseTo(playerLoader.VisualSettingsPos);
|
|
|
|
});
|
2019-02-26 09:11:36 +08:00
|
|
|
waitForDim();
|
2019-03-13 15:47:03 +08:00
|
|
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
2019-02-28 19:01:15 +08:00
|
|
|
AddStep("Stop background preview", () => InputManager.MoveMouseTo(playerLoader.ScreenPos));
|
|
|
|
waitForDim();
|
2019-03-14 15:09:17 +08:00
|
|
|
AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && playerLoader.IsBlurCorrect());
|
2019-02-24 17:10:59 +08:00
|
|
|
}
|
2019-02-21 14:24:26 +08:00
|
|
|
|
2019-02-24 17:10:59 +08:00
|
|
|
/// <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:
|
2019-03-13 15:47:03 +08:00
|
|
|
/// 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.
|
2019-02-24 17:10:59 +08:00
|
|
|
/// </summary>
|
|
|
|
[Test]
|
|
|
|
public void PlayerLoaderTransitionTest()
|
|
|
|
{
|
2019-02-28 19:01:15 +08:00
|
|
|
performFullSetup();
|
2019-02-28 15:18:46 +08:00
|
|
|
AddStep("Trigger hover event", () => playerLoader.TriggerOnHover());
|
2019-02-26 08:54:28 +08:00
|
|
|
AddAssert("Background retained from song select", () => songSelect.IsBackgroundCurrent());
|
2019-02-26 09:11:36 +08:00
|
|
|
waitForDim();
|
2019-03-13 15:47:03 +08:00
|
|
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
2019-02-24 17:10:59 +08:00
|
|
|
}
|
2019-02-22 10:41:28 +08:00
|
|
|
|
2019-02-24 17:10:59 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Make sure the background is fully invisible (Alpha == 0) when the background should be disabled by the storyboard.
|
|
|
|
/// </summary>
|
|
|
|
[Test]
|
|
|
|
public void StoryboardBackgroundVisibilityTest()
|
|
|
|
{
|
2019-02-28 17:26:41 +08:00
|
|
|
performFullSetup();
|
2019-02-27 16:56:44 +08:00
|
|
|
createFakeStoryboard();
|
2019-02-28 19:01:15 +08:00
|
|
|
AddStep("Storyboard Enabled", () =>
|
|
|
|
{
|
|
|
|
player.ReplacesBackground.Value = true;
|
|
|
|
player.StoryboardEnabled.Value = true;
|
|
|
|
});
|
2019-02-27 16:56:44 +08:00
|
|
|
waitForDim();
|
|
|
|
AddAssert("Background is invisible, storyboard is visible", () => songSelect.IsBackgroundInvisible() && player.IsStoryboardVisible());
|
2019-02-28 19:01:15 +08:00
|
|
|
AddStep("Storyboard Disabled", () =>
|
2019-02-22 10:41:28 +08:00
|
|
|
{
|
2019-02-27 16:56:44 +08:00
|
|
|
player.ReplacesBackground.Value = false;
|
|
|
|
player.StoryboardEnabled.Value = false;
|
2019-02-22 10:41:28 +08:00
|
|
|
});
|
2019-02-26 09:11:36 +08:00
|
|
|
waitForDim();
|
2019-02-27 16:56:44 +08:00
|
|
|
AddAssert("Background is visible, storyboard is invisible", () => songSelect.IsBackgroundVisible() && player.IsStoryboardInvisible());
|
2019-02-18 17:58:34 +08:00
|
|
|
}
|
|
|
|
|
2019-02-25 11:35:01 +08:00
|
|
|
/// <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()
|
|
|
|
{
|
2019-02-28 17:26:41 +08:00
|
|
|
performFullSetup();
|
2019-02-27 16:56:44 +08:00
|
|
|
createFakeStoryboard();
|
2019-02-28 19:01:15 +08:00
|
|
|
AddStep("Exit to song select", () => player.Exit());
|
2019-02-26 09:11:36 +08:00
|
|
|
waitForDim();
|
2019-02-26 08:54:28 +08:00
|
|
|
AddAssert("Background is visible", () => songSelect.IsBackgroundVisible());
|
2019-02-25 11:35:01 +08:00
|
|
|
}
|
|
|
|
|
2019-02-18 18:53:55 +08:00
|
|
|
/// <summary>
|
2019-03-19 12:06:14 +08:00
|
|
|
/// Check if the <see cref="UserDimContainer"/> is properly accepting user-defined visual changes at all.
|
2019-02-18 18:53:55 +08:00
|
|
|
/// </summary>
|
|
|
|
[Test]
|
|
|
|
public void DisableUserDimTest()
|
|
|
|
{
|
2019-02-28 17:26:41 +08:00
|
|
|
performFullSetup();
|
2019-02-28 19:01:15 +08:00
|
|
|
waitForDim();
|
2019-03-13 15:47:03 +08:00
|
|
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
2019-02-28 19:01:15 +08:00
|
|
|
AddStep("EnableUserDim disabled", () => songSelect.DimEnabled.Value = false);
|
2019-02-26 09:11:36 +08:00
|
|
|
waitForDim();
|
2019-03-13 15:47:03 +08:00
|
|
|
AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && songSelect.IsUserBlurDisabled());
|
2019-02-28 19:01:15 +08:00
|
|
|
AddStep("EnableUserDim enabled", () => songSelect.DimEnabled.Value = true);
|
2019-02-26 09:11:36 +08:00
|
|
|
waitForDim();
|
2019-03-13 15:47:03 +08:00
|
|
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
2019-02-15 15:17:01 +08:00
|
|
|
}
|
|
|
|
|
2019-02-15 15:50:37 +08:00
|
|
|
/// <summary>
|
2019-03-13 15:47:03 +08:00
|
|
|
/// Check if the visual settings container retains dim and blur when pausing
|
2019-02-15 15:50:37 +08:00
|
|
|
/// </summary>
|
2019-02-15 15:38:27 +08:00
|
|
|
[Test]
|
2019-02-18 18:53:55 +08:00
|
|
|
public void PauseTest()
|
2019-02-15 15:38:27 +08:00
|
|
|
{
|
2019-02-28 17:26:41 +08:00
|
|
|
performFullSetup(true);
|
2019-03-18 10:48:11 +08:00
|
|
|
AddStep("Pause", () => player.Pause());
|
2019-02-28 19:01:15 +08:00
|
|
|
waitForDim();
|
2019-03-13 15:47:03 +08:00
|
|
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
2019-03-18 10:48:11 +08:00
|
|
|
AddStep("Unpause", () => player.Resume());
|
2019-02-26 09:11:36 +08:00
|
|
|
waitForDim();
|
2019-03-13 15:47:03 +08:00
|
|
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
2019-02-18 18:53:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
2019-03-13 15:47:03 +08:00
|
|
|
/// Check if the visual settings container removes user dim when suspending <see cref="Player"/> for <see cref="SoloResults"/>
|
2019-02-18 18:53:55 +08:00
|
|
|
/// </summary>
|
|
|
|
[Test]
|
|
|
|
public void TransitionTest()
|
|
|
|
{
|
2019-02-28 17:26:41 +08:00
|
|
|
performFullSetup();
|
2019-03-14 15:09:17 +08:00
|
|
|
var results = new FadeAccessibleResults(new ScoreInfo { User = new User { Username = "osu!" } });
|
|
|
|
AddStep("Transition to Results", () => player.Push(results));
|
2019-03-19 19:22:21 +08:00
|
|
|
AddUntilStep("Wait for results is current", results.IsCurrentScreen);
|
2019-02-26 09:11:36 +08:00
|
|
|
waitForDim();
|
2019-03-14 15:09:17 +08:00
|
|
|
AddAssert("Screen is undimmed, original background retained", () =>
|
|
|
|
songSelect.IsBackgroundUndimmed() && songSelect.IsBackgroundCurrent() && results.IsBlurCorrect());
|
2019-02-19 18:44:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
2019-03-13 15:47:03 +08:00
|
|
|
/// Check if background gets undimmed and unblurred when leaving <see cref="Player"/> for <see cref="PlaySongSelect"/>
|
2019-02-19 18:44:26 +08:00
|
|
|
/// </summary>
|
|
|
|
[Test]
|
|
|
|
public void TransitionOutTest()
|
|
|
|
{
|
2019-02-28 17:26:41 +08:00
|
|
|
performFullSetup();
|
2019-02-28 19:01:15 +08:00
|
|
|
AddStep("Exit to song select", () => player.Exit());
|
2019-02-26 09:11:36 +08:00
|
|
|
waitForDim();
|
2019-03-14 15:09:17 +08:00
|
|
|
AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && songSelect.IsBlurCorrect());
|
2019-02-15 15:38:27 +08:00
|
|
|
}
|
|
|
|
|
2019-03-20 16:18:42 +08:00
|
|
|
/// <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));
|
2019-03-20 18:45:04 +08:00
|
|
|
AddStep("Resume PlayerLoader", () => player.Restart());
|
2019-03-20 16:18:42 +08:00
|
|
|
waitForDim();
|
|
|
|
AddAssert("Screen is dimmed and blur applied", () => songSelect.IsBackgroundDimmed() && songSelect.IsUserBlurApplied());
|
|
|
|
AddStep("Move mouse to center of screen", () => InputManager.MoveMouseTo(playerLoader.ScreenPos));
|
2019-03-20 16:31:06 +08:00
|
|
|
waitForDim();
|
2019-03-20 16:18:42 +08:00
|
|
|
AddAssert("Screen is undimmed and user blur removed", () => songSelect.IsBackgroundUndimmed() && playerLoader.IsBlurCorrect());
|
2019-02-15 15:38:27 +08:00
|
|
|
}
|
|
|
|
|
2019-03-19 16:24:26 +08:00
|
|
|
private void waitForDim() => AddWaitStep("Wait for dim", 5);
|
2019-02-26 09:11:36 +08:00
|
|
|
|
2019-02-28 19:01:15 +08:00
|
|
|
private void createFakeStoryboard() => AddStep("Create storyboard", () =>
|
2019-02-27 16:56:44 +08:00
|
|
|
{
|
2019-02-28 19:01:15 +08:00
|
|
|
player.StoryboardEnabled.Value = false;
|
|
|
|
player.ReplacesBackground.Value = false;
|
2019-05-21 13:13:52 +08:00
|
|
|
player.CurrentStoryboardContainer.Add(new OsuSpriteText
|
2019-02-27 16:56:44 +08:00
|
|
|
{
|
2019-02-28 13:33:29 +08:00
|
|
|
Size = new Vector2(250, 50),
|
2019-02-27 16:56:44 +08:00
|
|
|
Alpha = 1,
|
2019-02-28 15:18:46 +08:00
|
|
|
Colour = Color4.Tomato,
|
2019-02-28 13:33:29 +08:00
|
|
|
Anchor = Anchor.Centre,
|
|
|
|
Origin = Anchor.Centre,
|
|
|
|
Text = "THIS IS A STORYBOARD",
|
2019-02-27 16:56:44 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2019-02-28 17:26:41 +08:00
|
|
|
private void performFullSetup(bool allowPause = false)
|
2019-02-26 08:56:22 +08:00
|
|
|
{
|
2019-02-28 17:26:41 +08:00
|
|
|
setupUserSettings();
|
2019-02-26 08:56:22 +08:00
|
|
|
|
2019-03-28 10:18:54 +08:00
|
|
|
AddStep("Start player loader", () => songSelect.Push(playerLoader = new TestPlayerLoader(player = new TestPlayer(allowPause))));
|
|
|
|
|
2019-03-19 16:24:26 +08:00
|
|
|
AddUntilStep("Wait for Player Loader to load", () => playerLoader.IsLoaded);
|
2019-02-27 13:15:45 +08:00
|
|
|
AddStep("Move mouse to center of screen", () => InputManager.MoveMouseTo(playerLoader.ScreenPos));
|
2019-03-19 16:24:26 +08:00
|
|
|
AddUntilStep("Wait for player to load", () => player.IsLoaded);
|
2019-02-26 08:56:22 +08:00
|
|
|
}
|
|
|
|
|
2019-02-28 17:26:41 +08:00
|
|
|
private void setupUserSettings()
|
2019-02-26 08:56:22 +08:00
|
|
|
{
|
2019-03-19 16:24:26 +08:00
|
|
|
AddUntilStep("Song select has selection", () => songSelect.Carousel.SelectedBeatmap != null);
|
2019-02-28 17:26:41 +08:00
|
|
|
AddStep("Set default user settings", () =>
|
2019-02-26 16:31:21 +08:00
|
|
|
{
|
2019-04-10 16:13:12 +08:00
|
|
|
Mods.Value = Mods.Value.Concat(new[] { new OsuModNoFail() }).ToArray();
|
2019-02-27 16:02:04 +08:00
|
|
|
songSelect.DimLevel.Value = 0.7f;
|
2019-03-13 15:47:03 +08:00
|
|
|
songSelect.BlurLevel.Value = 0.4f;
|
2019-02-26 16:31:21 +08:00
|
|
|
});
|
2019-02-26 08:56:22 +08:00
|
|
|
}
|
|
|
|
|
2019-02-27 13:15:45 +08:00
|
|
|
private class DummySongSelect : PlaySongSelect
|
2019-02-19 18:44:26 +08:00
|
|
|
{
|
2019-02-26 16:31:21 +08:00
|
|
|
protected override BackgroundScreen CreateBackground()
|
|
|
|
{
|
2019-02-27 13:15:45 +08:00
|
|
|
FadeAccessibleBackground background = new FadeAccessibleBackground(Beatmap.Value);
|
2019-02-26 16:31:21 +08:00
|
|
|
DimEnabled.BindTo(background.EnableUserDim);
|
|
|
|
return background;
|
|
|
|
}
|
|
|
|
|
2019-02-22 15:56:03 +08:00
|
|
|
public readonly Bindable<bool> DimEnabled = new Bindable<bool>();
|
2019-02-27 16:02:04 +08:00
|
|
|
public readonly Bindable<double> DimLevel = new Bindable<double>();
|
2019-02-28 15:18:46 +08:00
|
|
|
public readonly Bindable<double> BlurLevel = new Bindable<double>();
|
2019-02-24 17:10:59 +08:00
|
|
|
|
2019-02-27 13:15:45 +08:00
|
|
|
public new BeatmapCarousel Carousel => base.Carousel;
|
|
|
|
|
2019-02-24 17:10:59 +08:00
|
|
|
[BackgroundDependencyLoader]
|
|
|
|
private void load(OsuConfigManager config)
|
|
|
|
{
|
2019-02-27 16:02:04 +08:00
|
|
|
config.BindWith(OsuSetting.DimLevel, DimLevel);
|
2019-02-28 15:18:46 +08:00
|
|
|
config.BindWith(OsuSetting.BlurLevel, BlurLevel);
|
2019-02-22 15:56:03 +08:00
|
|
|
}
|
2019-02-21 14:24:26 +08:00
|
|
|
|
2019-02-27 16:02:04 +08:00
|
|
|
public bool IsBackgroundDimmed() => ((FadeAccessibleBackground)Background).CurrentColour == OsuColour.Gray(1 - (float)DimLevel.Value);
|
2019-02-21 14:24:26 +08:00
|
|
|
|
2019-02-26 08:54:28 +08:00
|
|
|
public bool IsBackgroundUndimmed() => ((FadeAccessibleBackground)Background).CurrentColour == Color4.White;
|
2019-02-22 10:41:28 +08:00
|
|
|
|
2019-03-13 15:47:03 +08:00
|
|
|
public bool IsUserBlurApplied() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2((float)BlurLevel.Value * 25);
|
|
|
|
|
|
|
|
public bool IsUserBlurDisabled() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(0);
|
|
|
|
|
2019-02-26 08:54:28 +08:00
|
|
|
public bool IsBackgroundInvisible() => ((FadeAccessibleBackground)Background).CurrentAlpha == 0;
|
2019-02-22 10:41:28 +08:00
|
|
|
|
2019-02-26 08:54:28 +08:00
|
|
|
public bool IsBackgroundVisible() => ((FadeAccessibleBackground)Background).CurrentAlpha == 1;
|
2019-02-22 13:43:05 +08:00
|
|
|
|
2019-03-14 15:09:17 +08:00
|
|
|
public bool IsBlurCorrect() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(BACKGROUND_BLUR);
|
|
|
|
|
2019-02-22 13:43:05 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Make sure every time a screen gets pushed, the background doesn't get replaced
|
|
|
|
/// </summary>
|
2019-02-24 19:03:24 +08:00
|
|
|
/// <returns>Whether or not the original background (The one created in DummySongSelect) is still the current background</returns>
|
2019-02-26 08:54:28 +08:00
|
|
|
public bool IsBackgroundCurrent() => ((FadeAccessibleBackground)Background).IsCurrentScreen();
|
2019-02-19 18:44:26 +08:00
|
|
|
}
|
2019-02-15 15:17:01 +08:00
|
|
|
|
2019-02-28 19:01:15 +08:00
|
|
|
private class FadeAccessibleResults : SoloResults
|
2019-02-18 18:53:55 +08:00
|
|
|
{
|
2019-02-28 19:01:15 +08:00
|
|
|
public FadeAccessibleResults(ScoreInfo score)
|
2019-02-26 08:56:22 +08:00
|
|
|
: base(score)
|
2019-02-18 18:53:55 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2019-02-27 13:15:45 +08:00
|
|
|
protected override BackgroundScreen CreateBackground() => new FadeAccessibleBackground(Beatmap.Value);
|
2019-03-14 15:09:17 +08:00
|
|
|
|
|
|
|
public bool IsBlurCorrect() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(BACKGROUND_BLUR);
|
2019-02-18 18:53:55 +08:00
|
|
|
}
|
|
|
|
|
2019-05-10 14:39:25 +08:00
|
|
|
private class TestPlayer : Visual.TestPlayer
|
2019-02-15 15:17:01 +08:00
|
|
|
{
|
2019-02-27 13:15:45 +08:00
|
|
|
protected override BackgroundScreen CreateBackground() => new FadeAccessibleBackground(Beatmap.Value);
|
2019-02-15 15:17:01 +08:00
|
|
|
|
2019-02-27 16:56:44 +08:00
|
|
|
protected override UserDimContainer CreateStoryboardContainer()
|
|
|
|
{
|
|
|
|
return new TestUserDimContainer(true)
|
|
|
|
{
|
|
|
|
RelativeSizeAxes = Axes.Both,
|
|
|
|
Alpha = 1,
|
|
|
|
EnableUserDim = { Value = true }
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-02-27 16:02:04 +08:00
|
|
|
public UserDimContainer CurrentStoryboardContainer => StoryboardContainer;
|
2019-02-28 15:51:17 +08:00
|
|
|
|
2019-02-24 17:10:59 +08:00
|
|
|
// Whether or not the player should be allowed to load.
|
2019-03-27 16:34:58 +08:00
|
|
|
public bool BlockLoad;
|
2019-02-21 14:24:26 +08:00
|
|
|
|
2019-02-22 10:41:28 +08:00
|
|
|
public Bindable<bool> StoryboardEnabled;
|
|
|
|
public readonly Bindable<bool> ReplacesBackground = new Bindable<bool>();
|
2019-02-24 17:10:59 +08:00
|
|
|
public readonly Bindable<bool> IsPaused = new Bindable<bool>();
|
2019-02-22 13:43:05 +08:00
|
|
|
|
2019-03-26 15:53:44 +08:00
|
|
|
public TestPlayer(bool allowPause = true)
|
|
|
|
: base(allowPause)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2019-02-27 16:56:44 +08:00
|
|
|
public bool IsStoryboardVisible() => ((TestUserDimContainer)CurrentStoryboardContainer).CurrentAlpha == 1;
|
|
|
|
|
|
|
|
public bool IsStoryboardInvisible() => ((TestUserDimContainer)CurrentStoryboardContainer).CurrentAlpha <= 1;
|
|
|
|
|
2019-02-21 14:24:26 +08:00
|
|
|
[BackgroundDependencyLoader]
|
2019-03-27 13:33:50 +08:00
|
|
|
private void load(OsuConfigManager config, CancellationToken token)
|
2019-02-15 15:17:01 +08:00
|
|
|
{
|
2019-03-27 16:34:58 +08:00
|
|
|
while (BlockLoad && !token.IsCancellationRequested)
|
2019-02-21 14:24:26 +08:00
|
|
|
Thread.Sleep(1);
|
2019-03-27 13:33:50 +08:00
|
|
|
|
2019-02-22 10:41:28 +08:00
|
|
|
StoryboardEnabled = config.GetBindable<bool>(OsuSetting.ShowStoryboard);
|
|
|
|
ReplacesBackground.BindTo(Background.StoryboardReplacesBackground);
|
2019-03-19 22:44:15 +08:00
|
|
|
DrawableRuleset.IsPaused.BindTo(IsPaused);
|
2019-02-15 15:17:01 +08:00
|
|
|
}
|
2019-02-21 14:24:26 +08:00
|
|
|
}
|
2019-02-15 15:17:01 +08:00
|
|
|
|
2019-03-13 15:47:03 +08:00
|
|
|
private class TestPlayerLoader : PlayerLoader
|
2019-02-21 14:24:26 +08:00
|
|
|
{
|
|
|
|
public VisualSettings VisualSettingsPos => VisualSettings;
|
2019-02-22 10:41:28 +08:00
|
|
|
public BackgroundScreen ScreenPos => Background;
|
2019-02-21 14:24:26 +08:00
|
|
|
|
2019-03-13 15:47:03 +08:00
|
|
|
public TestPlayerLoader(Player player)
|
2019-02-26 08:56:22 +08:00
|
|
|
: base(() => player)
|
2019-02-15 15:38:27 +08:00
|
|
|
{
|
|
|
|
}
|
2019-02-21 17:19:50 +08:00
|
|
|
|
2019-02-28 19:01:15 +08:00
|
|
|
public void TriggerOnHover() => OnHover(new HoverEvent(new InputState()));
|
2019-02-28 15:18:46 +08:00
|
|
|
|
2019-03-14 15:09:17 +08:00
|
|
|
public bool IsBlurCorrect() => ((FadeAccessibleBackground)Background).CurrentBlur == new Vector2(BACKGROUND_BLUR);
|
|
|
|
|
2019-02-27 13:15:45 +08:00
|
|
|
protected override BackgroundScreen CreateBackground() => new FadeAccessibleBackground(Beatmap.Value);
|
2019-02-18 18:53:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
private class FadeAccessibleBackground : BackgroundScreenBeatmap
|
|
|
|
{
|
2019-02-28 19:01:15 +08:00
|
|
|
protected override UserDimContainer CreateFadeContainer() => fadeContainer = new TestUserDimContainer { RelativeSizeAxes = Axes.Both };
|
2019-02-22 17:01:50 +08:00
|
|
|
|
2019-02-28 19:01:15 +08:00
|
|
|
public Color4 CurrentColour => fadeContainer.CurrentColour;
|
2019-03-13 15:47:03 +08:00
|
|
|
|
2019-02-28 19:01:15 +08:00
|
|
|
public float CurrentAlpha => fadeContainer.CurrentAlpha;
|
2019-02-22 19:34:51 +08:00
|
|
|
|
2019-02-28 15:18:46 +08:00
|
|
|
public Vector2 CurrentBlur => Background.BlurSigma;
|
|
|
|
|
2019-02-28 19:01:15 +08:00
|
|
|
private TestUserDimContainer fadeContainer;
|
|
|
|
|
2019-02-27 13:15:45 +08:00
|
|
|
public FadeAccessibleBackground(WorkingBeatmap beatmap)
|
|
|
|
: base(beatmap)
|
|
|
|
{
|
|
|
|
}
|
2019-02-27 16:56:44 +08:00
|
|
|
}
|
2019-02-27 13:15:45 +08:00
|
|
|
|
2019-02-27 16:56:44 +08:00
|
|
|
private class TestUserDimContainer : UserDimContainer
|
|
|
|
{
|
2019-02-28 19:01:15 +08:00
|
|
|
public Color4 CurrentColour => DimContainer.Colour;
|
|
|
|
public float CurrentAlpha => DimContainer.Alpha;
|
|
|
|
|
2019-02-27 16:56:44 +08:00
|
|
|
public TestUserDimContainer(bool isStoryboard = false)
|
|
|
|
: base(isStoryboard)
|
2019-02-22 19:34:51 +08:00
|
|
|
{
|
2019-02-22 10:41:28 +08:00
|
|
|
}
|
2019-02-15 15:17:01 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|