leafer-ui 2.0.6 → 2.0.8

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.8";
7057
7083
 
7058
7084
  const debug$5 = Debug.get("LeaferCanvas");
7059
7085
 
@@ -8777,7 +8803,7 @@ let UI = UI_1 = class UI extends Leaf {
8777
8803
  __updateRenderPath(updateCache) {
8778
8804
  const data = this.__;
8779
8805
  if (data.path) {
8780
- data.__pathForRender = data.cornerRadius ? PathCorner.smooth(data.path, data.cornerRadius, data.cornerSmoothing) : data.path;
8806
+ data.__pathForRender = data.cornerRadius || data.path.radius ? PathCorner.smooth(data.path, data.cornerRadius, data.cornerSmoothing) : data.path;
8781
8807
  if (data.__useArrow) PathArrow.addArrows(this, updateCache);
8782
8808
  } else data.__pathForRender && (data.__pathForRender = undefined);
8783
8809
  }
@@ -9610,7 +9636,7 @@ let Ellipse = class Ellipse extends UI {
9610
9636
  }
9611
9637
  }
9612
9638
  if (!open) closePath$2(path);
9613
- if (Platform.ellipseToCurve || data.__useArrow) data.path = this.getPath(true);
9639
+ if (Platform.ellipseToCurve || data.__useArrow || data.cornerRadius) data.path = this.getPath(true);
9614
9640
  }
9615
9641
  };
9616
9642
 
@@ -9636,7 +9662,7 @@ let Polygon = class Polygon extends UI {
9636
9662
  const data = this.__;
9637
9663
  const path = data.path = [];
9638
9664
  if (data.points) {
9639
- drawPoints$1(path, data.points, data.curve, true);
9665
+ drawPoints$1(path, data.points, data.curve, data.closed);
9640
9666
  } else {
9641
9667
  const {width: width, height: height, sides: sides} = data;
9642
9668
  const rx = width / 2, ry = height / 2;