mirror of
https://github.com/ppy/osu.git
synced 2025-01-07 22:16:10 +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:
parent
d2baffa0e7
commit
3178865cd3
@ -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;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user