1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-28 18:12:56 +08:00

Remove dead branch and mark implementation as temporary

The previous implementation was checking if the `x0` or `x2` anchors
were selected to decide on which way to transfer the drawable's scale,
but that check actually ends up being always true for corner anchors. To
visualise, this is how the corner anchors correspond to `Anchor` flags:

    x0  x1  x2
    |   |   |
y0 -O---O---O-
    |   |   |
y1 -O---+---O-
    |   |   |
y2 -O---O---O-
    |   |   |

The Os indicate where the reference anchors are on a selection box.
The first conditional eliminates the middle ones, which makes sense.
But after excluding them from further deliberations (marking via X):

    x0  x1  x2
    |   |   |
y0 -O---X---O-
    |   |   |
y1 -X---+---X-
    |   |   |
y2 -O---X---O-
    |   |   |

The remaining anchors always have `x0` or `x2` set. So to avoid
confusion, just always transfer one way for now. At some point this
should be torn out in favour of an actual implementation of the desired
behaviour.
This commit is contained in:
Bartłomiej Dach 2021-05-13 17:50:12 +02:00
parent 0fa90a80d4
commit 25b1443c50

View File

@ -158,10 +158,8 @@ namespace osu.Game.Skinning.Editor
// for now aspect lock scale adjustments that occur at corners. // for now aspect lock scale adjustments that occur at corners.
if (!reference.HasFlagFast(Anchor.x1) && !reference.HasFlagFast(Anchor.y1)) if (!reference.HasFlagFast(Anchor.x1) && !reference.HasFlagFast(Anchor.y1))
{ {
if (reference.HasFlagFast(Anchor.x0) || reference.HasFlagFast(Anchor.x2)) // TODO: temporary implementation - only dragging the corner handles across the X axis changes size.
scale.Y = scale.X; scale.Y = scale.X;
else
scale.X = scale.Y;
} }
} }