Skip to content

Commit

Permalink
Merge pull request #26647 from EVAST9919/triangles-masking
Browse files Browse the repository at this point in the history
Enable masking for `Triangles` backgrounds where possible
  • Loading branch information
peppy authored Jan 21, 2024
2 parents 1e44ba6 + 1393f52 commit b588715
Show file tree
Hide file tree
Showing 7 changed files with 15 additions and 12 deletions.
1 change: 1 addition & 0 deletions osu.Game.Rulesets.Osu/Skinning/Default/TrianglesPiece.cs
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ public TrianglesPiece(int? seed = null)
{
TriangleScale = 1.2f;
HideAlphaDiscrepancies = false;
ClampToDrawable = false;
}

protected override void Update()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ protected override void LoadComplete()

AddSliderStep("Triangle scale", 0f, 10f, 1f, s => triangles.TriangleScale = s);
AddSliderStep("Seed", 0, 1000, 0, s => triangles.Reset(s));
AddToggleStep("Masking", m => triangles.Masking = m);
AddToggleStep("ClampToDrawable", c => triangles.ClampToDrawable = c);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,7 @@ protected override void LoadComplete()
AddStep("White colour", () => box.Colour = triangles.Colour = maskedTriangles.Colour = Color4.White);
AddStep("Vertical gradient", () => box.Colour = triangles.Colour = maskedTriangles.Colour = ColourInfo.GradientVertical(Color4.White, Color4.Red));
AddStep("Horizontal gradient", () => box.Colour = triangles.Colour = maskedTriangles.Colour = ColourInfo.GradientHorizontal(Color4.White, Color4.Red));
AddToggleStep("Masking", m => maskedTriangles.Masking = m);
AddToggleStep("ClampToDrawable", c => maskedTriangles.ClampToDrawable = c);
}
}
}
10 changes: 5 additions & 5 deletions osu.Game/Graphics/Backgrounds/Triangles.cs
Original file line number Diff line number Diff line change
Expand Up @@ -78,9 +78,9 @@ public float TriangleScale

/// <summary>
/// If enabled, only the portion of triangles that falls within this <see cref="Drawable"/>'s
/// shape is drawn to the screen.
/// shape is drawn to the screen. Default is true.
/// </summary>
public bool Masking { get; set; }
public bool ClampToDrawable { get; set; } = true;

/// <summary>
/// Whether we should drop-off alpha values of triangles more quickly to improve
Expand Down Expand Up @@ -257,7 +257,7 @@ private class TrianglesDrawNode : DrawNode

private IShader shader;
private Texture texture;
private bool masking;
private bool clamp;

private readonly List<TriangleParticle> parts = new List<TriangleParticle>();
private readonly Vector2 triangleSize = new Vector2(1f, equilateral_triangle_ratio) * triangle_size;
Expand All @@ -276,7 +276,7 @@ public override void ApplyState()
shader = Source.shader;
texture = Source.texture;
size = Source.DrawSize;
masking = Source.Masking;
clamp = Source.ClampToDrawable;

parts.Clear();
parts.AddRange(Source.parts);
Expand Down Expand Up @@ -306,7 +306,7 @@ protected override void Draw(IRenderer renderer)

Vector2 topLeft = particle.Position - new Vector2(relativeSize.X * 0.5f, 0f);

Quad triangleQuad = masking ? clampToDrawable(topLeft, relativeSize) : new Quad(topLeft.X, topLeft.Y, relativeSize.X, relativeSize.Y);
Quad triangleQuad = clamp ? clampToDrawable(topLeft, relativeSize) : new Quad(topLeft.X, topLeft.Y, relativeSize.X, relativeSize.Y);

var drawQuad = new Quad(
Vector2Extensions.Transform(triangleQuad.TopLeft * size, DrawInfo.Matrix),
Expand Down
10 changes: 5 additions & 5 deletions osu.Game/Graphics/Backgrounds/TrianglesV2.cs
Original file line number Diff line number Diff line change
Expand Up @@ -34,9 +34,9 @@ public partial class TrianglesV2 : Drawable

/// <summary>
/// If enabled, only the portion of triangles that falls within this <see cref="Drawable"/>'s
/// shape is drawn to the screen.
/// shape is drawn to the screen. Default is true.
/// </summary>
public bool Masking { get; set; }
public bool ClampToDrawable { get; set; } = true;

private readonly BindableFloat spawnRatio = new BindableFloat(1f);

Expand Down Expand Up @@ -193,7 +193,7 @@ private class TrianglesDrawNode : DrawNode
private Vector2 size;
private float thickness;
private float texelSize;
private bool masking;
private bool clamp;

public TrianglesDrawNode(TrianglesV2 source)
: base(source)
Expand All @@ -208,7 +208,7 @@ public override void ApplyState()
texture = Source.texture;
size = Source.DrawSize;
thickness = Source.Thickness;
masking = Source.Masking;
clamp = Source.ClampToDrawable;

Quad triangleQuad = new Quad(
Vector2Extensions.Transform(Vector2.Zero, DrawInfo.Matrix),
Expand Down Expand Up @@ -248,7 +248,7 @@ protected override void Draw(IRenderer renderer)
{
Vector2 topLeft = particle.Position - new Vector2(relativeSize.X * 0.5f, 0f);

Quad triangleQuad = masking ? clampToDrawable(topLeft, relativeSize) : new Quad(topLeft.X, topLeft.Y, relativeSize.X, relativeSize.Y);
Quad triangleQuad = clamp ? clampToDrawable(topLeft, relativeSize) : new Quad(topLeft.X, topLeft.Y, relativeSize.X, relativeSize.Y);

var drawQuad = new Quad(
Vector2Extensions.Transform(triangleQuad.TopLeft * size, DrawInfo.Matrix),
Expand Down
1 change: 1 addition & 0 deletions osu.Game/Graphics/UserInterface/DialogButton.cs
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ public DialogButton(HoverSampleSet sampleSet = HoverSampleSet.Button)
TriangleScale = 4,
ColourDark = OsuColour.Gray(0.88f),
Shear = new Vector2(-0.2f, 0),
ClampToDrawable = false
},
},
},
Expand Down
1 change: 1 addition & 0 deletions osu.Game/Overlays/Mods/ModSelectColumn.cs
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@ protected ModSelectColumn()
Height = header_height,
Shear = new Vector2(-ShearedOverlayContainer.SHEAR, 0),
Velocity = 0.7f,
ClampToDrawable = false
},
headerText = new OsuTextFlowContainer(t =>
{
Expand Down

0 comments on commit b588715

Please sign in to comment.