From 49e58e227463540abc9532eb62b0b37f807e756c Mon Sep 17 00:00:00 2001 From: Julien Lebosquain Date: Wed, 21 Aug 2024 12:43:03 +0200 Subject: [PATCH 1/3] Added failing geometry bounds tests --- tests/Avalonia.Skia.UnitTests/RenderBoundsTests.cs | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/tests/Avalonia.Skia.UnitTests/RenderBoundsTests.cs b/tests/Avalonia.Skia.UnitTests/RenderBoundsTests.cs index a659c2b8b24..d0f531d6c25 100644 --- a/tests/Avalonia.Skia.UnitTests/RenderBoundsTests.cs +++ b/tests/Avalonia.Skia.UnitTests/RenderBoundsTests.cs @@ -13,12 +13,13 @@ public class RenderBoundsTests { [Theory, InlineData("M10 20 L 20 10 L 30 20", PenLineCap.Round, PenLineJoin.Miter, 2, 10, - 8.585786819458008, 8.585786819458008, 22.828428268432617, 12.828428268432617), + 9, 8.585786819458008, 22.000001907348633, 12.414215087890625), InlineData("M10 10 L 20 10", PenLineCap.Round, PenLineJoin.Miter,2, 10, 9,9,12,2), InlineData("M10 10 L 20 15 L 10 20", PenLineCap.Flat, PenLineJoin.Miter, 2, 20, - 9.552786827087402, 9.105572700500488, 12.683281898498535, 11.788853645324707) - + 9.552786827087402, 9.105572700500488, 12.683281898498535, 11.788853645324707), + InlineData("M0,0 A128,128 0 0 0 128,0", PenLineCap.Flat, PenLineJoin.Bevel, 0, 0, + 0, 0, 128, 17.14875030517578) ] public void RenderBoundsAreCorrectlyCalculated(string path, PenLineCap cap, PenLineJoin join, double thickness, double miterLimit, double x, double y, double width, double height) { From 82b6f2067d8e2b51915c31062d8ee45d0dae2c20 Mon Sep 17 00:00:00 2001 From: Julien Lebosquain Date: Wed, 21 Aug 2024 12:43:49 +0200 Subject: [PATCH 2/3] Fixed geometry bounds --- src/Skia/Avalonia.Skia/GeometryImpl.cs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Skia/Avalonia.Skia/GeometryImpl.cs b/src/Skia/Avalonia.Skia/GeometryImpl.cs index 47508970d51..7412ed72a74 100644 --- a/src/Skia/Avalonia.Skia/GeometryImpl.cs +++ b/src/Skia/Avalonia.Skia/GeometryImpl.cs @@ -82,7 +82,7 @@ public Rect GetRenderBounds(IPen? pen) _pathCache.UpdateIfNeeded(StrokePath, pen); var bounds = _pathCache.RenderBounds; if (StrokePath != FillPath && FillPath != null) - bounds = bounds.Union(FillPath.Bounds.ToAvaloniaRect()); + bounds = bounds.Union(FillPath.TightBounds.ToAvaloniaRect()); return bounds; } } @@ -178,7 +178,7 @@ private struct PathCache : IDisposable private Rect? _renderBounds; private static readonly SKPath s_emptyPath = new(); - public Rect RenderBounds => _renderBounds ??= (_path ?? _cachedFor ?? s_emptyPath).Bounds.ToAvaloniaRect(); + public Rect RenderBounds => _renderBounds ??= (_path ?? _cachedFor ?? s_emptyPath).TightBounds.ToAvaloniaRect(); public SKPath ExpandedPath => _path ?? s_emptyPath; public void UpdateIfNeeded(SKPath? strokePath, IPen? pen) From b184c02d5b623784615a47faa993917763b80e3c Mon Sep 17 00:00:00 2001 From: Julien Lebosquain Date: Wed, 21 Aug 2024 14:49:10 +0200 Subject: [PATCH 3/3] Fixed RenderboundsTests --- .../RenderBoundsTests.cs | 20 ++++++------------- 1 file changed, 6 insertions(+), 14 deletions(-) diff --git a/tests/Avalonia.Skia.UnitTests/RenderBoundsTests.cs b/tests/Avalonia.Skia.UnitTests/RenderBoundsTests.cs index d0f531d6c25..6f8302576f7 100644 --- a/tests/Avalonia.Skia.UnitTests/RenderBoundsTests.cs +++ b/tests/Avalonia.Skia.UnitTests/RenderBoundsTests.cs @@ -1,9 +1,4 @@ -using System; -using Avalonia.Controls.Shapes; -using Avalonia.Layout; -using Avalonia.Media; -using Avalonia.Platform; -using Avalonia.Rendering; +using Avalonia.Media; using Avalonia.UnitTests; using Xunit; @@ -30,14 +25,11 @@ public void RenderBoundsAreCorrectlyCalculated(string path, PenLineCap cap, PenL var pen = new Pen(Brushes.Black, thickness, null, cap, join, miterLimit); var bounds = geo.GetRenderBounds(pen); var tolerance = 0.001; - if ( - Math.Abs(bounds.X - x) > tolerance - || Math.Abs(bounds.Y - y) > tolerance - || Math.Abs(bounds.Width - width) > tolerance - || Math.Abs(bounds.Height - height) > tolerance) - Assert.Fail($"Expected {x}:{y}:{width}:{height}, got {bounds}"); - - Assert.Equal(new Rect(x, y, width, height), bounds); + + Assert.Equal(bounds.X, x, tolerance); + Assert.Equal(bounds.Y, y, tolerance); + Assert.Equal(bounds.Width, width, tolerance); + Assert.Equal(bounds.Height, height, tolerance); } } }