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

Add null check and simplify scaling conditional logic via switch

This commit is contained in:
Dean Herbert 2019-07-18 18:39:33 +09:00
parent eca63980d2
commit 36c557c752

View File

@ -84,7 +84,6 @@ namespace osu.Game.Skinning
scaling.Invalidate(); scaling.Invalidate();
Drawable.Origin = Anchor.Centre; Drawable.Origin = Anchor.Centre;
Drawable.Anchor = Anchor.Centre; Drawable.Anchor = Anchor.Centre;
InternalChild = Drawable; InternalChild = Drawable;
} }
else else
@ -97,24 +96,34 @@ namespace osu.Game.Skinning
if (!scaling.IsValid) if (!scaling.IsValid)
{ {
if (Drawable != null && confineMode != ConfineMode.NoScaling && (!isDefault || ApplySizeRestrictionsToDefault)) try
{ {
bool applyScaling = confineMode == ConfineMode.ScaleToFit || if (Drawable == null || (isDefault && !ApplySizeRestrictionsToDefault)) return;
(confineMode == ConfineMode.ScaleDownToFit && (Drawable.DrawSize.X > DrawSize.X || Drawable.DrawSize.Y > DrawSize.Y));
if (applyScaling) switch (confineMode)
{ {
case ConfineMode.NoScaling:
return;
case ConfineMode.ScaleDownToFit:
if (Drawable.DrawSize.X <= DrawSize.X && Drawable.DrawSize.Y <= DrawSize.Y)
return;
break;
}
Drawable.RelativeSizeAxes = Axes.Both; Drawable.RelativeSizeAxes = Axes.Both;
Drawable.Size = Vector2.One; Drawable.Size = Vector2.One;
Drawable.Scale = Vector2.One; Drawable.Scale = Vector2.One;
Drawable.FillMode = FillMode.Fit; Drawable.FillMode = FillMode.Fit;
} }
} finally
{
scaling.Validate(); scaling.Validate();
} }
} }
} }
}
public enum ConfineMode public enum ConfineMode
{ {