From 373c14a4f3b2360c4252a8ac834c23bb28068f6e Mon Sep 17 00:00:00 2001 From: Luigi Rosso Date: Wed, 9 Oct 2019 14:21:47 -0700 Subject: [PATCH] Fixing issue with image clipping. --- flare_flutter/CHANGELOG.md | 4 ++ flare_flutter/lib/flare.dart | 101 +++++++++++++++++------------------ flare_flutter/pubspec.yaml | 2 +- 3 files changed, 53 insertions(+), 54 deletions(-) diff --git a/flare_flutter/CHANGELOG.md b/flare_flutter/CHANGELOG.md index ef31e9c..c9846ef 100644 --- a/flare_flutter/CHANGELOG.md +++ b/flare_flutter/CHANGELOG.md @@ -1,3 +1,7 @@ +## [1.6.1] - 2019-10-09 14:20:54 + +- Image and Shapes share clipping logic. Fixes issue with image clipping. + ## [1.6.0] - 2019-10-09 11:08:52 - Using latest flare_dart with support for difference clipping. diff --git a/flare_flutter/lib/flare.dart b/flare_flutter/lib/flare.dart index 483b639..aa3edbb 100644 --- a/flare_flutter/lib/flare.dart +++ b/flare_flutter/lib/flare.dart @@ -53,6 +53,51 @@ abstract class FlutterActorDrawable { void onBlendModeChanged(ui.BlendMode blendMode); void draw(ui.Canvas canvas); + + List> get clipShapes; + ActorArtboard get artboard; + + void clip(ui.Canvas canvas) { + for (final List clips in clipShapes) { + for (final ClipShape clipShape in clips) { + var shape = clipShape.shape; + if (shape.renderCollapsed) { + continue; + } + if (clipShape.intersect) { + canvas.clipPath((shape as FlutterActorShape).path); + } else { + var artboardRect = Rect.fromLTWH( + artboard.origin[0] * artboard.width, + artboard.origin[1] * artboard.height, + artboard.width, + artboard.height); + + if (shape.fill != null && shape.fill.fillRule == FillRule.evenOdd) { + // One single clip path with subtraction rect and all sub paths. + var clipPath = ui.Path(); + clipPath.addRect(artboardRect); + for (final path in shape.paths) { + clipPath.addPath((path as FlutterPath).path, ui.Offset.zero, + matrix4: path.pathTransform?.mat4); + } + clipPath.fillType = PathFillType.evenOdd; + canvas.clipPath(clipPath); + } else { + // One clip path with rect per shape path. + for (final path in shape.paths) { + var clipPath = ui.Path(); + clipPath.addRect(artboardRect); + clipPath.addPath((path as FlutterPath).path, ui.Offset.zero, + matrix4: path.pathTransform?.mat4); + clipPath.fillType = PathFillType.evenOdd; + canvas.clipPath(clipPath); + } + } + } + } + } + } } abstract class FlutterFill { @@ -231,46 +276,7 @@ class FlutterActorShape extends ActorShape with FlutterActorDrawable { canvas.save(); - // Get Clips - for (final List clips in clipShapes) { - for (final ClipShape clipShape in clips) { - var shape = clipShape.shape; - if (shape.renderCollapsed) { - continue; - } - if (clipShape.intersect) { - canvas.clipPath((shape as FlutterActorShape).path); - } else { - var artboardRect = Rect.fromLTWH( - artboard.origin[0] * artboard.width, - artboard.origin[1] * artboard.height, - artboard.width, - artboard.height); - - if (shape.fill != null && shape.fill.fillRule == FillRule.evenOdd) { - // One single clip path with subtraction rect and all sub paths. - var clipPath = ui.Path(); - clipPath.addRect(artboardRect); - for (final path in shape.paths) { - clipPath.addPath((path as FlutterPath).path, ui.Offset.zero, - matrix4: path.pathTransform?.mat4); - } - clipPath.fillType = PathFillType.evenOdd; - canvas.clipPath(clipPath); - } else { - // One clip path with rect per shape path. - for (final path in shape.paths) { - var clipPath = ui.Path(); - clipPath.addRect(artboardRect); - clipPath.addPath((path as FlutterPath).path, ui.Offset.zero, - matrix4: path.pathTransform?.mat4); - clipPath.fillType = PathFillType.evenOdd; - canvas.clipPath(clipPath); - } - } - } - } - } + clip(canvas); ui.Path renderPath = getRenderPath(canvas); @@ -1129,19 +1135,8 @@ class FlutterActorImage extends ActorImage with FlutterActorDrawable { return; } canvas.save(); - // Get Clips - for (final List clips in clipShapes) { - if (clips.length == 1) { - canvas.clipPath((clips[0] as FlutterActorShape).path); - } else { - ui.Path clippingPath = ui.Path(); - for (final ClipShape clipShape in clips) { - clippingPath.addPath( - (clipShape.shape as FlutterActorShape).path, ui.Offset.zero); - } - canvas.clipPath(clippingPath); - } - } + + clip(canvas); _paint.color = _paint.color.withOpacity(renderOpacity.clamp(0.0, 1.0).toDouble()); diff --git a/flare_flutter/pubspec.yaml b/flare_flutter/pubspec.yaml index 206357d..cc300f9 100644 --- a/flare_flutter/pubspec.yaml +++ b/flare_flutter/pubspec.yaml @@ -1,6 +1,6 @@ name: flare_flutter description: Vector design and runtime animation for Flutter. -version: 1.6.0 +version: 1.6.1 author: "2Dimensions Team " homepage: https://github.com/2d-inc/Flare-Flutter environment: