mirror of
https://github.com/ppy/osu.git
synced 2025-01-28 06:03:08 +08:00
Merge pull request #26181 from rushiiMachine/flashlight-playfield-based-size-
Make flashlight scale with playfield
This commit is contained in:
commit
588e510363
@ -5,6 +5,7 @@ using System.Collections.Generic;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NUnit.Framework;
|
using NUnit.Framework;
|
||||||
using osu.Framework.Testing;
|
using osu.Framework.Testing;
|
||||||
|
using osu.Framework.Utils;
|
||||||
using osu.Game.Rulesets.Mods;
|
using osu.Game.Rulesets.Mods;
|
||||||
using osu.Game.Rulesets.Objects;
|
using osu.Game.Rulesets.Objects;
|
||||||
using osu.Game.Rulesets.Osu.Beatmaps;
|
using osu.Game.Rulesets.Osu.Beatmaps;
|
||||||
@ -32,6 +33,27 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestComboBasedSize([Values] bool comboBasedSize) => CreateModTest(new ModTestData { Mod = new OsuModFlashlight { ComboBasedSize = { Value = comboBasedSize } }, PassCondition = () => true });
|
public void TestComboBasedSize([Values] bool comboBasedSize) => CreateModTest(new ModTestData { Mod = new OsuModFlashlight { ComboBasedSize = { Value = comboBasedSize } }, PassCondition = () => true });
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestPlayfieldBasedSize()
|
||||||
|
{
|
||||||
|
ModFlashlight mod = new OsuModFlashlight();
|
||||||
|
CreateModTest(new ModTestData
|
||||||
|
{
|
||||||
|
Mod = mod,
|
||||||
|
PassCondition = () =>
|
||||||
|
{
|
||||||
|
var flashlightOverlay = Player.DrawableRuleset.Overlays
|
||||||
|
.OfType<ModFlashlight<OsuHitObject>.Flashlight>()
|
||||||
|
.First();
|
||||||
|
|
||||||
|
return Precision.AlmostEquals(mod.DefaultFlashlightSize * .5f, flashlightOverlay.GetSize());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
AddStep("adjust playfield scale", () =>
|
||||||
|
Player.DrawableRuleset.Playfield.Scale = new Vector2(.5f));
|
||||||
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestSliderDimsOnlyAfterStartTime()
|
public void TestSliderDimsOnlyAfterStartTime()
|
||||||
{
|
{
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
// 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;
|
||||||
|
using System.Diagnostics;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using osu.Framework.Allocation;
|
using osu.Framework.Allocation;
|
||||||
using osu.Framework.Bindables;
|
using osu.Framework.Bindables;
|
||||||
@ -13,6 +14,7 @@ using osu.Framework.Graphics.Shaders;
|
|||||||
using osu.Framework.Graphics.Shaders.Types;
|
using osu.Framework.Graphics.Shaders.Types;
|
||||||
using osu.Framework.Graphics.Sprites;
|
using osu.Framework.Graphics.Sprites;
|
||||||
using osu.Framework.Localisation;
|
using osu.Framework.Localisation;
|
||||||
|
using osu.Framework.Utils;
|
||||||
using osu.Game.Configuration;
|
using osu.Game.Configuration;
|
||||||
using osu.Game.Graphics;
|
using osu.Game.Graphics;
|
||||||
using osu.Game.Graphics.OpenGL.Vertices;
|
using osu.Game.Graphics.OpenGL.Vertices;
|
||||||
@ -84,6 +86,7 @@ namespace osu.Game.Rulesets.Mods
|
|||||||
flashlight.Depth = float.MinValue;
|
flashlight.Depth = float.MinValue;
|
||||||
|
|
||||||
flashlight.Combo.BindTo(Combo);
|
flashlight.Combo.BindTo(Combo);
|
||||||
|
flashlight.GetPlayfieldScale = () => drawableRuleset.Playfield.Scale;
|
||||||
|
|
||||||
drawableRuleset.Overlays.Add(flashlight);
|
drawableRuleset.Overlays.Add(flashlight);
|
||||||
}
|
}
|
||||||
@ -100,6 +103,8 @@ namespace osu.Game.Rulesets.Mods
|
|||||||
|
|
||||||
public override bool RemoveCompletedTransforms => false;
|
public override bool RemoveCompletedTransforms => false;
|
||||||
|
|
||||||
|
internal Func<Vector2>? GetPlayfieldScale;
|
||||||
|
|
||||||
private readonly float defaultFlashlightSize;
|
private readonly float defaultFlashlightSize;
|
||||||
private readonly float sizeMultiplier;
|
private readonly float sizeMultiplier;
|
||||||
private readonly bool comboBasedSize;
|
private readonly bool comboBasedSize;
|
||||||
@ -139,10 +144,19 @@ namespace osu.Game.Rulesets.Mods
|
|||||||
|
|
||||||
protected abstract string FragmentShader { get; }
|
protected abstract string FragmentShader { get; }
|
||||||
|
|
||||||
protected float GetSize()
|
public float GetSize()
|
||||||
{
|
{
|
||||||
float size = defaultFlashlightSize * sizeMultiplier;
|
float size = defaultFlashlightSize * sizeMultiplier;
|
||||||
|
|
||||||
|
if (GetPlayfieldScale != null)
|
||||||
|
{
|
||||||
|
Vector2 playfieldScale = GetPlayfieldScale();
|
||||||
|
|
||||||
|
Debug.Assert(Precision.AlmostEquals(Math.Abs(playfieldScale.X), Math.Abs(playfieldScale.Y)),
|
||||||
|
@"Playfield has non-proportional scaling. Flashlight implementations should be revisited with regard to balance.");
|
||||||
|
size *= Math.Abs(playfieldScale.X);
|
||||||
|
}
|
||||||
|
|
||||||
if (isBreakTime.Value)
|
if (isBreakTime.Value)
|
||||||
size *= 2.5f;
|
size *= 2.5f;
|
||||||
else if (comboBasedSize)
|
else if (comboBasedSize)
|
||||||
|
Loading…
Reference in New Issue
Block a user