From 070fb551cfcb73cb6ad121aca654bef0f6bccd6e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alberto=20Rodr=C3=ADguez?= Date: Wed, 11 Dec 2024 11:15:47 -0600 Subject: [PATCH] simplify vector draw The fill and stroke paints are handled by the skiasharpodrawing context, there is no need to handle them in the vector.draw() geometry. --- .../Drawing/Geometries/VectorGeometry.cs | 32 +------------------ 1 file changed, 1 insertion(+), 31 deletions(-) diff --git a/src/skiasharp/LiveChartsCore.SkiaSharp/Drawing/Geometries/VectorGeometry.cs b/src/skiasharp/LiveChartsCore.SkiaSharp/Drawing/Geometries/VectorGeometry.cs index 93cb827a7..755ed2c64 100644 --- a/src/skiasharp/LiveChartsCore.SkiaSharp/Drawing/Geometries/VectorGeometry.cs +++ b/src/skiasharp/LiveChartsCore.SkiaSharp/Drawing/Geometries/VectorGeometry.cs @@ -20,11 +20,9 @@ // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE // SOFTWARE. -using System; using System.Collections.Generic; using LiveChartsCore.Drawing; using LiveChartsCore.Drawing.Segments; -using LiveChartsCore.Painting; using SkiaSharp; namespace LiveChartsCore.SkiaSharpView.Drawing.Geometries; @@ -103,35 +101,7 @@ public void Draw(SkiaSharpDrawingContext context) if (last is not null) OnClose(context, path, last); - var hasGeometryOpacity = Opacity < 1; - - if (Fill is null && Stroke is null) - { - if (hasGeometryOpacity) context.ActiveLvcPaint.ApplyOpacityMask(context, Opacity); - context.Canvas.DrawPath(path, context.ActiveSkiaPaint); - if (hasGeometryOpacity) context.ActiveLvcPaint.RestoreOpacityMask(context, Opacity); - } - else if (Fill is not null) - { - var originalPaint = context.ActiveSkiaPaint; - var originalTask = context.ActiveLvcPaint; - - Fill.PaintStyle = PaintStyle.Fill; - Fill.InitializeTask(context); - - if (hasGeometryOpacity) Fill.ApplyOpacityMask(context, Opacity); - context.Canvas.DrawPath(path, context.ActiveSkiaPaint); - if (hasGeometryOpacity) Fill.RestoreOpacityMask(context, Opacity); - - Fill.Dispose(); - - context.ActiveSkiaPaint = originalPaint; - context.ActiveLvcPaint = originalTask; - } - else - { - throw new NotImplementedException("Fill and Stroke per vector is experiental."); - } + context.Canvas.DrawPath(path, context.ActiveSkiaPaint); if (!isValid) IsValid = false; }