1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-13 02:32:55 +08:00

Merge pull request #23038 from cdwcgt/scale-background-dim

Add feature to adjust `ScalingContainer` background dim
This commit is contained in:
Dean Herbert 2023-05-02 15:36:52 +09:00 committed by GitHub
commit 4a97c2c105
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 33 additions and 4 deletions

View File

@ -157,6 +157,7 @@ namespace osu.Game.Configuration
SetDefault(OsuSetting.Scaling, ScalingMode.Off); SetDefault(OsuSetting.Scaling, ScalingMode.Off);
SetDefault(OsuSetting.SafeAreaConsiderations, true); SetDefault(OsuSetting.SafeAreaConsiderations, true);
SetDefault(OsuSetting.ScalingBackgroundDim, 0.9f, 0.5f, 1f);
SetDefault(OsuSetting.ScalingSizeX, 0.8f, 0.2f, 1f); SetDefault(OsuSetting.ScalingSizeX, 0.8f, 0.2f, 1f);
SetDefault(OsuSetting.ScalingSizeY, 0.8f, 0.2f, 1f); SetDefault(OsuSetting.ScalingSizeY, 0.8f, 0.2f, 1f);
@ -364,6 +365,7 @@ namespace osu.Game.Configuration
ScalingPositionY, ScalingPositionY,
ScalingSizeX, ScalingSizeX,
ScalingSizeY, ScalingSizeY,
ScalingBackgroundDim,
UIScale, UIScale,
IntroSequence, IntroSequence,
NotifyOnUsernameMentioned, NotifyOnUsernameMentioned,

View File

@ -15,6 +15,7 @@ using osu.Game.Configuration;
using osu.Game.Screens; using osu.Game.Screens;
using osu.Game.Screens.Backgrounds; using osu.Game.Screens.Backgrounds;
using osuTK; using osuTK;
using osuTK.Graphics;
namespace osu.Game.Graphics.Containers namespace osu.Game.Graphics.Containers
{ {
@ -46,6 +47,8 @@ namespace osu.Game.Graphics.Containers
private BackgroundScreenStack backgroundStack; private BackgroundScreenStack backgroundStack;
private Bindable<float> scalingMenuBackgroundDim;
private RectangleF? customRect; private RectangleF? customRect;
private bool customRectIsRelativePosition; private bool customRectIsRelativePosition;
@ -138,6 +141,9 @@ namespace osu.Game.Graphics.Containers
safeAreaPadding = safeArea.SafeAreaPadding.GetBoundCopy(); safeAreaPadding = safeArea.SafeAreaPadding.GetBoundCopy();
safeAreaPadding.BindValueChanged(_ => Scheduler.AddOnce(updateSize)); safeAreaPadding.BindValueChanged(_ => Scheduler.AddOnce(updateSize));
scalingMenuBackgroundDim = config.GetBindable<float>(OsuSetting.ScalingBackgroundDim);
scalingMenuBackgroundDim.ValueChanged += _ => Scheduler.AddOnce(updateSize);
} }
protected override void LoadComplete() protected override void LoadComplete()
@ -148,7 +154,9 @@ namespace osu.Game.Graphics.Containers
sizableContainer.FinishTransforms(); sizableContainer.FinishTransforms();
} }
private bool requiresBackgroundVisible => (scalingMode.Value == ScalingMode.Everything || scalingMode.Value == ScalingMode.ExcludeOverlays) && (sizeX.Value != 1 || sizeY.Value != 1); private bool requiresBackgroundVisible => (scalingMode.Value == ScalingMode.Everything || scalingMode.Value == ScalingMode.ExcludeOverlays)
&& (sizeX.Value != 1 || sizeY.Value != 1)
&& scalingMenuBackgroundDim.Value < 1;
private void updateSize() private void updateSize()
{ {
@ -161,8 +169,8 @@ namespace osu.Game.Graphics.Containers
{ {
AddInternal(backgroundStack = new BackgroundScreenStack AddInternal(backgroundStack = new BackgroundScreenStack
{ {
Colour = OsuColour.Gray(0.1f),
Alpha = 0, Alpha = 0,
Colour = Color4.Black,
Depth = float.MaxValue Depth = float.MaxValue
}); });
@ -170,6 +178,7 @@ namespace osu.Game.Graphics.Containers
} }
backgroundStack.FadeIn(TRANSITION_DURATION); backgroundStack.FadeIn(TRANSITION_DURATION);
backgroundStack.FadeColour(OsuColour.Gray(1.0f - scalingMenuBackgroundDim.Value), TRANSITION_DURATION, Easing.OutQuint);
} }
else else
backgroundStack?.FadeOut(TRANSITION_DURATION); backgroundStack?.FadeOut(TRANSITION_DURATION);

View File

@ -30,6 +30,7 @@ namespace osu.Game.Overlays.Settings.Sections.Graphics
protected override LocalisableString Header => GraphicsSettingsStrings.LayoutHeader; protected override LocalisableString Header => GraphicsSettingsStrings.LayoutHeader;
private FillFlowContainer<SettingsSlider<float>> scalingSettings = null!; private FillFlowContainer<SettingsSlider<float>> scalingSettings = null!;
private SettingsSlider<float> dimSlider = null!;
private readonly Bindable<Display> currentDisplay = new Bindable<Display>(); private readonly Bindable<Display> currentDisplay = new Bindable<Display>();
@ -57,6 +58,8 @@ namespace osu.Game.Overlays.Settings.Sections.Graphics
private Bindable<float> scalingSizeX = null!; private Bindable<float> scalingSizeX = null!;
private Bindable<float> scalingSizeY = null!; private Bindable<float> scalingSizeY = null!;
private Bindable<float> scalingBackgroundDim = null!;
private const int transition_duration = 400; private const int transition_duration = 400;
[BackgroundDependencyLoader] [BackgroundDependencyLoader]
@ -70,6 +73,7 @@ namespace osu.Game.Overlays.Settings.Sections.Graphics
scalingSizeY = osuConfig.GetBindable<float>(OsuSetting.ScalingSizeY); scalingSizeY = osuConfig.GetBindable<float>(OsuSetting.ScalingSizeY);
scalingPositionX = osuConfig.GetBindable<float>(OsuSetting.ScalingPositionX); scalingPositionX = osuConfig.GetBindable<float>(OsuSetting.ScalingPositionX);
scalingPositionY = osuConfig.GetBindable<float>(OsuSetting.ScalingPositionY); scalingPositionY = osuConfig.GetBindable<float>(OsuSetting.ScalingPositionY);
scalingBackgroundDim = osuConfig.GetBindable<float>(OsuSetting.ScalingBackgroundDim);
if (window != null) if (window != null)
{ {
@ -161,6 +165,13 @@ namespace osu.Game.Overlays.Settings.Sections.Graphics
KeyboardStep = 0.01f, KeyboardStep = 0.01f,
DisplayAsPercentage = true DisplayAsPercentage = true
}, },
dimSlider = new SettingsSlider<float>
{
LabelText = GameplaySettingsStrings.BackgroundDim,
Current = scalingBackgroundDim,
KeyboardStep = 0.01f,
DisplayAsPercentage = true,
},
} }
}, },
}; };
@ -216,8 +227,15 @@ namespace osu.Game.Overlays.Settings.Sections.Graphics
scalingSettings.AutoSizeAxes = scalingMode.Value != ScalingMode.Off ? Axes.Y : Axes.None; scalingSettings.AutoSizeAxes = scalingMode.Value != ScalingMode.Off ? Axes.Y : Axes.None;
scalingSettings.ForEach(s => scalingSettings.ForEach(s =>
{ {
s.TransferValueOnCommit = scalingMode.Value == ScalingMode.Everything; if (s == dimSlider)
s.CanBeShown.Value = scalingMode.Value != ScalingMode.Off; {
s.CanBeShown.Value = scalingMode.Value == ScalingMode.Everything || scalingMode.Value == ScalingMode.ExcludeOverlays;
}
else
{
s.TransferValueOnCommit = scalingMode.Value == ScalingMode.Everything;
s.CanBeShown.Value = scalingMode.Value != ScalingMode.Off;
}
}); });
} }
} }