1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-07 22:22:59 +08:00

Fix playfield skinnable layer bounds being incorrectly calculated with multiple stages

Closes #24514.

The original PR was _supposed_ to be handling this, and had code that
_looked_ like it would handle it, but was in fact subtly wrong, as the
union of `RectangleF.Empty` (initial value of `area`) and an arbitrary
other rectangle is _not_ the second rectangle, but rather a rectangle
that contains _both_ the second rectangle and the point (0,0),
thus leading to the bound calculation fail.
This commit is contained in:
Bartłomiej Dach 2023-08-12 21:55:20 +02:00
parent d2baffa0e7
commit 3178865cd3
No known key found for this signature in database

View File

@ -30,15 +30,15 @@ namespace osu.Game.Rulesets.Mania.UI
{ {
get get
{ {
if (Stages.Count == 1) RectangleF totalArea = RectangleF.Empty;
return Stages.First().ScreenSpaceDrawQuad;
RectangleF area = RectangleF.Empty; for (int i = 0; i < Stages.Count; ++i)
{
var stageArea = Stages[i].ScreenSpaceDrawQuad.AABBFloat;
totalArea = i == 0 ? stageArea : RectangleF.Union(totalArea, stageArea);
}
foreach (var stage in Stages) return totalArea;
area = RectangleF.Union(area, stage.ScreenSpaceDrawQuad.AABBFloat);
return area;
} }
} }