From 5ef0b2dfacccbfd0e05baba0c6843885af0655e8 Mon Sep 17 00:00:00 2001 From: Luigi Rosso Date: Thu, 13 Jun 2019 18:25:03 -0700 Subject: [PATCH 1/2] =?UTF-8?q?Don=E2=80=99t=20use=20shapes=20that=20are?= =?UTF-8?q?=20render=20collapsed=20for=20clipping.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- flare_flutter/lib/flare.dart | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/flare_flutter/lib/flare.dart b/flare_flutter/lib/flare.dart index 9d6d743..742abe2 100644 --- a/flare_flutter/lib/flare.dart +++ b/flare_flutter/lib/flare.dart @@ -236,14 +236,25 @@ class FlutterActorShape extends ActorShape with FlutterActorDrawable { // Get Clips for (final List clips in clipShapes) { if (clips.length == 1) { - canvas.clipPath((clips[0] as FlutterActorShape).path); + if (clips.first.renderCollapsed) { + continue; + } + canvas.clipPath((clips.first as FlutterActorShape).path); } else { ui.Path clippingPath = ui.Path(); + bool empty = true; for (final ActorShape clipShape in clips) { + if (clipShape.renderCollapsed) { + continue; + } clippingPath.addPath( (clipShape as FlutterActorShape).path, ui.Offset.zero); + empty = false; + } + + if (!empty) { + canvas.clipPath(clippingPath); } - canvas.clipPath(clippingPath); } } if (fills != null) { From 0230aab0c7802c611085d505ee9ae9988e077558 Mon Sep 17 00:00:00 2001 From: Luigi Rosso Date: Thu, 20 Jun 2019 16:26:05 -0700 Subject: [PATCH 2/2] Fixing rounded rectangle. Issue #107 --- flare_dart/lib/actor_rectangle.dart | 24 +++++++++++++----------- 1 file changed, 13 insertions(+), 11 deletions(-) diff --git a/flare_dart/lib/actor_rectangle.dart b/flare_dart/lib/actor_rectangle.dart index dbc2053..4a6a838 100644 --- a/flare_dart/lib/actor_rectangle.dart +++ b/flare_dart/lib/actor_rectangle.dart @@ -1,12 +1,12 @@ +import 'dart:math'; + import "actor_artboard.dart"; +import "actor_component.dart"; import "actor_node.dart"; -import "math/vec2d.dart"; -import "stream_reader.dart"; import "actor_path.dart"; +import "math/vec2d.dart"; import "path_point.dart"; -import "actor_component.dart"; - -const double CircleConstant = 0.55; +import "stream_reader.dart"; class ActorRectangle extends ActorProceduralPath { double _radius = 0.0; @@ -14,6 +14,7 @@ class ActorRectangle extends ActorProceduralPath { @override void invalidatePath() {} + @override ActorComponent makeInstance(ActorArtboard resetArtboard) { ActorRectangle instance = ActorRectangle(); instance.copyRectangle(this, resetArtboard); @@ -41,17 +42,18 @@ class ActorRectangle extends ActorProceduralPath { @override List get points { - double halfWidth = width / 2.0; - double halfHeight = height / 2.0; + double halfWidth = width / 2; + double halfHeight = height / 2; + double renderRadius = min(_radius, min(halfWidth, halfHeight)); List _rectanglePathPoints = []; _rectanglePathPoints.add(StraightPathPoint.fromValues( - Vec2D.fromValues(-halfWidth, -halfHeight), _radius)); + Vec2D.fromValues(-halfWidth, -halfHeight), renderRadius)); _rectanglePathPoints.add(StraightPathPoint.fromValues( - Vec2D.fromValues(halfWidth, -halfHeight), _radius)); + Vec2D.fromValues(halfWidth, -halfHeight), renderRadius)); _rectanglePathPoints.add(StraightPathPoint.fromValues( - Vec2D.fromValues(halfWidth, halfHeight), _radius)); + Vec2D.fromValues(halfWidth, halfHeight), renderRadius)); _rectanglePathPoints.add(StraightPathPoint.fromValues( - Vec2D.fromValues(-halfWidth, halfHeight), _radius)); + Vec2D.fromValues(-halfWidth, halfHeight), renderRadius)); return _rectanglePathPoints; }