leafer-draw 2.0.6 → 2.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2896,6 +2896,32 @@ const BezierHelper = {
2896
2896
  getDerivative(t, fromV, v1, v2, toV) {
2897
2897
  const o = 1 - t;
2898
2898
  return 3 * o * o * (v1 - fromV) + 6 * o * t * (v2 - v1) + 3 * t * t * (toV - v2);
2899
+ },
2900
+ cut(t, fromX, fromY, x1, y1, x2, y2, toX, toY) {
2901
+ if (t <= 0) return {
2902
+ left: null,
2903
+ right: [ x1, y1, x2, y2, toX, toY ]
2904
+ }; else if (t >= 1) return {
2905
+ left: [ x1, y1, x2, y2, toX, toY ],
2906
+ right: null
2907
+ };
2908
+ const u = 1 - t;
2909
+ const leftX1 = fromX * u + x1 * t;
2910
+ const leftY1 = fromY * u + y1 * t;
2911
+ const P12x = x1 * u + x2 * t;
2912
+ const P12y = y1 * u + y2 * t;
2913
+ const rightX2 = x2 * u + toX * t;
2914
+ const rightY2 = y2 * u + toY * t;
2915
+ const leftX2 = leftX1 * u + P12x * t;
2916
+ const leftY2 = leftY1 * u + P12y * t;
2917
+ const rightX1 = P12x * u + rightX2 * t;
2918
+ const rightY1 = P12y * u + rightY2 * t;
2919
+ const leftX = leftX2 * u + rightX1 * t;
2920
+ const leftY = leftY2 * u + rightY1 * t;
2921
+ return {
2922
+ left: [ leftX1, leftY1, leftX2, leftY2, leftX, leftY ],
2923
+ right: [ rightX1, rightY1, rightX2, rightY2, toX, toY ]
2924
+ };
2899
2925
  }
2900
2926
  };
2901
2927
 
@@ -7053,7 +7079,7 @@ class LeafLevelList {
7053
7079
  }
7054
7080
  }
7055
7081
 
7056
- const version = "2.0.6";
7082
+ const version = "2.0.7";
7057
7083
 
7058
7084
  const debug$4 = Debug.get("LeaferCanvas");
7059
7085
 
@@ -8577,7 +8603,7 @@ let UI = UI_1 = class UI extends Leaf {
8577
8603
  __updateRenderPath(updateCache) {
8578
8604
  const data = this.__;
8579
8605
  if (data.path) {
8580
- data.__pathForRender = data.cornerRadius ? PathCorner.smooth(data.path, data.cornerRadius, data.cornerSmoothing) : data.path;
8606
+ data.__pathForRender = data.cornerRadius || data.path.radius ? PathCorner.smooth(data.path, data.cornerRadius, data.cornerSmoothing) : data.path;
8581
8607
  if (data.__useArrow) PathArrow.addArrows(this, updateCache);
8582
8608
  } else data.__pathForRender && (data.__pathForRender = undefined);
8583
8609
  }
@@ -9410,7 +9436,7 @@ let Ellipse = class Ellipse extends UI {
9410
9436
  }
9411
9437
  }
9412
9438
  if (!open) closePath$2(path);
9413
- if (Platform.ellipseToCurve || data.__useArrow) data.path = this.getPath(true);
9439
+ if (Platform.ellipseToCurve || data.__useArrow || data.cornerRadius) data.path = this.getPath(true);
9414
9440
  }
9415
9441
  };
9416
9442
 
@@ -9436,7 +9462,7 @@ let Polygon = class Polygon extends UI {
9436
9462
  const data = this.__;
9437
9463
  const path = data.path = [];
9438
9464
  if (data.points) {
9439
- drawPoints$1(path, data.points, data.curve, true);
9465
+ drawPoints$1(path, data.points, data.curve, data.closed);
9440
9466
  } else {
9441
9467
  const {width: width, height: height, sides: sides} = data;
9442
9468
  const rx = width / 2, ry = height / 2;