@leafer-ui/miniapp 1.0.0-rc.22 → 1.0.0-rc.23

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.
@@ -3,7 +3,7 @@ const Platform = {
3
3
  hitCanvasSize: 100,
4
4
  maxCacheSize: 2560 * 1600,
5
5
  maxPatternSize: 4096 * 2160,
6
- suffix: 'leaf',
6
+ suffix: '',
7
7
  crossOrigin: 'anonymous'
8
8
  }
9
9
  };
@@ -33,24 +33,12 @@ const I$2 = IncrementId;
33
33
  const { round, pow: pow$1, PI: PI$4 } = Math;
34
34
  const MathHelper = {
35
35
  within(value, min, max) {
36
- if (value < min)
36
+ if (min !== undefined && value < min)
37
37
  value = min;
38
- if (value > max)
38
+ if (max !== undefined && value > max)
39
39
  value = max;
40
40
  return value;
41
41
  },
42
- minus(value, isFourNumber) {
43
- if (value instanceof Array) {
44
- if (isFourNumber)
45
- value = MathHelper.fourNumber(value, 0);
46
- for (let i = 0; i < value.length; i++)
47
- value[i] = -value[i];
48
- }
49
- else {
50
- value = -value;
51
- }
52
- return value;
53
- },
54
42
  fourNumber(num, maxValue) {
55
43
  let data;
56
44
  if (num instanceof Array) {
@@ -147,9 +135,11 @@ const MatrixHelper = {
147
135
  t.e += x;
148
136
  t.f += y;
149
137
  },
150
- translateInner(t, x, y) {
138
+ translateInner(t, x, y, isMoveOrigin) {
151
139
  t.e += t.a * x + t.c * y;
152
140
  t.f += t.b * x + t.d * y;
141
+ if (isMoveOrigin)
142
+ t.e -= x, t.f -= y;
153
143
  },
154
144
  scale(t, scaleX, scaleY = scaleX) {
155
145
  t.a *= scaleX;
@@ -216,8 +206,10 @@ const MatrixHelper = {
216
206
  t.e = child.e * a + child.f * c + e;
217
207
  t.f = child.e * b + child.f * d + f;
218
208
  },
219
- multiplyParent(t, parent, to, abcdChanged, childScaleData) {
220
- const { e, f } = t;
209
+ multiplyParent(t, parent, to, abcdChanged, childScaleData, scrollData) {
210
+ let { e, f } = t;
211
+ if (scrollData)
212
+ e += scrollData.scrollX, f += scrollData.scrollY;
221
213
  to || (to = t);
222
214
  if (abcdChanged === undefined)
223
215
  abcdChanged = t.a !== 1 || t.b || t.c || t.d !== 1;
@@ -338,7 +330,7 @@ const MatrixHelper = {
338
330
  t.e = x;
339
331
  t.f = y;
340
332
  if (origin)
341
- M$6.translateInner(t, -origin.x, -origin.y);
333
+ M$6.translateInner(t, -origin.x, -origin.y, true);
342
334
  },
343
335
  getLayout(t, origin, firstSkewY) {
344
336
  const { a, b, c, d, e, f } = t;
@@ -758,7 +750,7 @@ const { float, fourNumber } = MathHelper;
758
750
  const { floor, ceil: ceil$2 } = Math;
759
751
  let right$1, bottom$1, boundsRight, boundsBottom;
760
752
  const point = {};
761
- const toPoint$1 = {};
753
+ const toPoint$2 = {};
762
754
  const BoundsHelper = {
763
755
  tempBounds: {},
764
756
  set(t, x = 0, y = 0, width = 0, height = 0) {
@@ -773,15 +765,17 @@ const BoundsHelper = {
773
765
  t.width = bounds.width;
774
766
  t.height = bounds.height;
775
767
  },
776
- copyAndSpread(t, bounds, spreadX, spreadY) {
777
- if (spreadX instanceof Array) {
778
- const four = fourNumber(spreadX);
779
- B.set(t, bounds.x - four[3], bounds.y - four[0], bounds.width + four[1] + four[3], bounds.height + four[2] + four[0]);
768
+ copyAndSpread(t, bounds, spread, isShrink) {
769
+ if (spread instanceof Array) {
770
+ const four = fourNumber(spread);
771
+ isShrink
772
+ ? B.set(t, bounds.x + four[3], bounds.y + four[0], bounds.width - four[1] - four[3], bounds.height - four[2] - four[0])
773
+ : B.set(t, bounds.x - four[3], bounds.y - four[0], bounds.width + four[1] + four[3], bounds.height + four[2] + four[0]);
780
774
  }
781
775
  else {
782
- if (!spreadY)
783
- spreadY = spreadX;
784
- B.set(t, bounds.x - spreadX, bounds.y - spreadY, bounds.width + spreadX * 2, bounds.height + spreadY * 2);
776
+ if (isShrink)
777
+ spread = -spread;
778
+ B.set(t, bounds.x - spread, bounds.y - spread, bounds.width + spread * 2, bounds.height + spread * 2);
785
779
  }
786
780
  },
787
781
  minX(t) { return t.width > 0 ? t.x : t.x + t.width; },
@@ -858,17 +852,17 @@ const BoundsHelper = {
858
852
  else {
859
853
  point.x = t.x;
860
854
  point.y = t.y;
861
- toOuterPoint$1(matrix, point, toPoint$1);
862
- setPoint$3(tempPointBounds$1, toPoint$1.x, toPoint$1.y);
855
+ toOuterPoint$1(matrix, point, toPoint$2);
856
+ setPoint$3(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
863
857
  point.x = t.x + t.width;
864
- toOuterPoint$1(matrix, point, toPoint$1);
865
- addPoint$3(tempPointBounds$1, toPoint$1.x, toPoint$1.y);
858
+ toOuterPoint$1(matrix, point, toPoint$2);
859
+ addPoint$3(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
866
860
  point.y = t.y + t.height;
867
- toOuterPoint$1(matrix, point, toPoint$1);
868
- addPoint$3(tempPointBounds$1, toPoint$1.x, toPoint$1.y);
861
+ toOuterPoint$1(matrix, point, toPoint$2);
862
+ addPoint$3(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
869
863
  point.x = t.x;
870
- toOuterPoint$1(matrix, point, toPoint$1);
871
- addPoint$3(tempPointBounds$1, toPoint$1.x, toPoint$1.y);
864
+ toOuterPoint$1(matrix, point, toPoint$2);
865
+ addPoint$3(tempPointBounds$1, toPoint$2.x, toPoint$2.y);
872
866
  toBounds$4(tempPointBounds$1, to);
873
867
  }
874
868
  },
@@ -881,13 +875,16 @@ const BoundsHelper = {
881
875
  const scale = Math.min(baseScale, Math.min(t.width / put.width, t.height / put.height));
882
876
  return new Matrix(scale, 0, 0, scale, -put.x * scale, -put.y * scale);
883
877
  },
884
- getSpread(t, spreadX, spreadY) {
878
+ getSpread(t, spread) {
885
879
  const n = {};
886
- B.copyAndSpread(n, t, spreadX, spreadY);
880
+ B.copyAndSpread(n, t, spread);
887
881
  return n;
888
882
  },
889
- spread(t, spreadX, spreadY = spreadX) {
890
- B.copyAndSpread(t, t, spreadX, spreadY);
883
+ spread(t, spread) {
884
+ B.copyAndSpread(t, t, spread);
885
+ },
886
+ shrink(t, shrink) {
887
+ B.copyAndSpread(t, t, shrink, true);
891
888
  },
892
889
  ceil(t) {
893
890
  const { x, y } = t;
@@ -1067,12 +1064,12 @@ class Bounds {
1067
1064
  getFitMatrix(put, baseScale) {
1068
1065
  return BoundsHelper.getFitMatrix(this, put, baseScale);
1069
1066
  }
1070
- spread(fourNumber, spreadY) {
1071
- BoundsHelper.spread(this, fourNumber, spreadY);
1067
+ spread(fourNumber) {
1068
+ BoundsHelper.spread(this, fourNumber);
1072
1069
  return this;
1073
1070
  }
1074
1071
  shrink(fourNumber) {
1075
- BoundsHelper.spread(this, MathHelper.minus(fourNumber, true));
1072
+ BoundsHelper.shrink(this, fourNumber);
1076
1073
  return this;
1077
1074
  }
1078
1075
  ceil() {
@@ -1189,6 +1186,10 @@ var Direction9;
1189
1186
  Direction9[Direction9["bottomLeft"] = 6] = "bottomLeft";
1190
1187
  Direction9[Direction9["left"] = 7] = "left";
1191
1188
  Direction9[Direction9["center"] = 8] = "center";
1189
+ Direction9[Direction9["top-left"] = 0] = "top-left";
1190
+ Direction9[Direction9["top-right"] = 2] = "top-right";
1191
+ Direction9[Direction9["bottom-right"] = 4] = "bottom-right";
1192
+ Direction9[Direction9["bottom-left"] = 6] = "bottom-left";
1192
1193
  })(Direction9 || (Direction9 = {}));
1193
1194
 
1194
1195
  const directionData = [
@@ -1202,6 +1203,7 @@ const directionData = [
1202
1203
  { x: 0, y: 0.5 },
1203
1204
  { x: 0.5, y: 0.5 }
1204
1205
  ];
1206
+ directionData.forEach(item => item.type = 'percent');
1205
1207
  const AroundHelper = {
1206
1208
  directionData,
1207
1209
  tempPoint: {},
@@ -1209,15 +1211,19 @@ const AroundHelper = {
1209
1211
  toPoint(around, bounds, to, onlySize, pointBounds) {
1210
1212
  to || (to = {});
1211
1213
  const point = get$5(around);
1212
- to.x = point.x * bounds.width;
1213
- to.y = point.y * bounds.height;
1214
- if (pointBounds) {
1215
- to.x -= pointBounds.x;
1216
- to.y -= pointBounds.y;
1217
- if (point.x)
1218
- to.x -= (point.x === 1) ? pointBounds.width : (point.x === 0.5 ? point.x * pointBounds.width : 0);
1219
- if (point.y)
1220
- to.y -= (point.y === 1) ? pointBounds.height : (point.y === 0.5 ? point.y * pointBounds.height : 0);
1214
+ to.x = point.x;
1215
+ to.y = point.y;
1216
+ if (point.type === 'percent') {
1217
+ to.x *= bounds.width;
1218
+ to.y *= bounds.height;
1219
+ if (pointBounds) {
1220
+ to.x -= pointBounds.x;
1221
+ to.y -= pointBounds.y;
1222
+ if (point.x)
1223
+ to.x -= (point.x === 1) ? pointBounds.width : (point.x === 0.5 ? point.x * pointBounds.width : 0);
1224
+ if (point.y)
1225
+ to.y -= (point.y === 1) ? pointBounds.height : (point.y === 0.5 ? point.y * pointBounds.height : 0);
1226
+ }
1221
1227
  }
1222
1228
  if (!onlySize) {
1223
1229
  to.x += bounds.x;
@@ -1229,6 +1235,13 @@ function get$5(around) {
1229
1235
  return typeof around === 'string' ? directionData[Direction9[around]] : around;
1230
1236
  }
1231
1237
 
1238
+ const { toPoint: toPoint$1 } = AroundHelper;
1239
+ const AlignHelper = {
1240
+ toPoint(align, contentBounds, bounds, to, onlySize) {
1241
+ toPoint$1(align, bounds, to, onlySize, contentBounds);
1242
+ }
1243
+ };
1244
+
1232
1245
  const StringNumberMap = {
1233
1246
  '0': 1,
1234
1247
  '1': 1,
@@ -1461,13 +1474,19 @@ const DataHelper = {
1461
1474
  },
1462
1475
  clone(data) {
1463
1476
  return JSON.parse(JSON.stringify(data));
1477
+ },
1478
+ toMap(list) {
1479
+ const map = {};
1480
+ for (let i = 0, len = list.length; i < len; i++)
1481
+ map[list[i]] = true;
1482
+ return map;
1464
1483
  }
1465
1484
  };
1466
1485
  const { assign } = DataHelper;
1467
1486
 
1468
1487
  class LeafData {
1469
1488
  get __blendMode() {
1470
- if (this.eraser)
1489
+ if (this.eraser && this.eraser !== 'path')
1471
1490
  return 'destination-out';
1472
1491
  const { blendMode } = this;
1473
1492
  return blendMode === 'pass-through' ? null : blendMode;
@@ -2097,7 +2116,7 @@ class LeaferCanvasBase extends Canvas$1 {
2097
2116
  }
2098
2117
  clear() {
2099
2118
  const { pixelRatio } = this;
2100
- this.clearRect(0, 0, this.width * pixelRatio, this.height * pixelRatio);
2119
+ this.clearRect(0, 0, this.width * pixelRatio + 2, this.height * pixelRatio + 2);
2101
2120
  }
2102
2121
  isSameSize(size) {
2103
2122
  return this.width === size.width && this.height === size.height && this.pixelRatio === size.pixelRatio;
@@ -3753,6 +3772,8 @@ function maskType(defaultValue) {
3753
3772
  this.__setAttr(key, value);
3754
3773
  this.__layout.boxChanged || this.__layout.boxChange();
3755
3774
  this.waitParent(() => { this.parent.__updateMask(value); });
3775
+ if (typeof value === 'string')
3776
+ this.maskType = value;
3756
3777
  }
3757
3778
  }));
3758
3779
  }
@@ -4182,11 +4203,19 @@ const WaitHelper = {
4182
4203
 
4183
4204
  const { getRelativeWorld: getRelativeWorld$1 } = LeafHelper;
4184
4205
  const { toOuterOf: toOuterOf$2, getPoints, copy: copy$6 } = BoundsHelper;
4206
+ const localContent = '_localContentBounds';
4207
+ const worldContent = '_worldContentBounds', worldBox = '_worldBoxBounds', worldStroke = '_worldStrokeBounds';
4185
4208
  class LeafLayout {
4209
+ get contentBounds() { return this._contentBounds || this.boxBounds; }
4210
+ set contentBounds(bounds) { this._contentBounds = bounds; }
4186
4211
  get strokeBounds() { return this._strokeBounds || this.boxBounds; }
4187
4212
  get renderBounds() { return this._renderBounds || this.boxBounds; }
4213
+ get localContentBounds() { toOuterOf$2(this.contentBounds, this.leaf.__localMatrix, this[localContent] || (this[localContent] = {})); return this[localContent]; }
4188
4214
  get localStrokeBounds() { return this._localStrokeBounds || this; }
4189
4215
  get localRenderBounds() { return this._localRenderBounds || this; }
4216
+ get worldContentBounds() { toOuterOf$2(this.contentBounds, this.leaf.__world, this[worldContent] || (this[worldContent] = {})); return this[worldContent]; }
4217
+ get worldBoxBounds() { toOuterOf$2(this.boxBounds, this.leaf.__world, this[worldBox] || (this[worldBox] = {})); return this[worldBox]; }
4218
+ get worldStrokeBounds() { toOuterOf$2(this.strokeBounds, this.leaf.__world, this[worldStroke] || (this[worldStroke] = {})); return this[worldStroke]; }
4190
4219
  get a() { return 1; }
4191
4220
  get b() { return 0; }
4192
4221
  get c() { return 0; }
@@ -4269,7 +4298,6 @@ class LeafLayout {
4269
4298
  case 'content':
4270
4299
  if (this.contentBounds)
4271
4300
  return this.contentBounds;
4272
- case 'margin':
4273
4301
  case 'box':
4274
4302
  return this.boxBounds;
4275
4303
  case 'stroke':
@@ -4282,8 +4310,9 @@ class LeafLayout {
4282
4310
  return this.localRenderBounds;
4283
4311
  case 'stroke':
4284
4312
  return this.localStrokeBounds;
4285
- case 'margin':
4286
4313
  case 'content':
4314
+ if (this.contentBounds)
4315
+ return this.localContentBounds;
4287
4316
  case 'box':
4288
4317
  return this.leaf.__localBoxBounds;
4289
4318
  }
@@ -4292,15 +4321,13 @@ class LeafLayout {
4292
4321
  switch (type) {
4293
4322
  case 'render':
4294
4323
  return this.leaf.__world;
4324
+ case 'stroke':
4325
+ return this.worldStrokeBounds;
4295
4326
  case 'content':
4296
4327
  if (this.contentBounds)
4297
- return this.getWorldContentBounds();
4298
- case 'margin':
4328
+ return this.worldContentBounds;
4299
4329
  case 'box':
4300
- return this.getWorldBoxBounds();
4301
- case 'margin':
4302
- case 'stroke':
4303
- return this.getWorldStrokeBounds();
4330
+ return this.worldBoxBounds;
4304
4331
  }
4305
4332
  }
4306
4333
  getLayoutBounds(type, relative = 'world', unscale) {
@@ -4363,20 +4390,24 @@ class LeafLayout {
4363
4390
  points.forEach(point => leaf.innerToWorld(point, null, false, relativeLeaf));
4364
4391
  return points;
4365
4392
  }
4366
- getWorldContentBounds() {
4367
- this._worldContentBounds || (this._worldContentBounds = {});
4368
- toOuterOf$2(this.contentBounds, this.leaf.__world, this._worldContentBounds);
4369
- return this._worldContentBounds;
4393
+ shrinkContent() {
4394
+ const { x, y, width, height } = this.boxBounds;
4395
+ this._contentBounds = { x, y, width, height };
4396
+ }
4397
+ spreadStroke() {
4398
+ const { x, y, width, height } = this.strokeBounds;
4399
+ this._strokeBounds = { x, y, width, height };
4400
+ this._localStrokeBounds = { x, y, width, height };
4401
+ if (!this.renderSpread)
4402
+ this.spreadRenderCancel();
4370
4403
  }
4371
- getWorldBoxBounds() {
4372
- this._worldBoxBounds || (this._worldBoxBounds = {});
4373
- toOuterOf$2(this.boxBounds, this.leaf.__world, this._worldBoxBounds);
4374
- return this._worldBoxBounds;
4404
+ spreadRender() {
4405
+ const { x, y, width, height } = this.renderBounds;
4406
+ this._renderBounds = { x, y, width, height };
4407
+ this._localRenderBounds = { x, y, width, height };
4375
4408
  }
4376
- getWorldStrokeBounds() {
4377
- this._worldStrokeBounds || (this._worldStrokeBounds = {});
4378
- toOuterOf$2(this.strokeBounds, this.leaf.__world, this._worldStrokeBounds);
4379
- return this._worldStrokeBounds;
4409
+ shrinkContentCancel() {
4410
+ this._contentBounds = undefined;
4380
4411
  }
4381
4412
  spreadStrokeCancel() {
4382
4413
  const same = this.renderBounds === this.strokeBounds;
@@ -4389,18 +4420,6 @@ class LeafLayout {
4389
4420
  this._renderBounds = this._strokeBounds;
4390
4421
  this._localRenderBounds = this._localStrokeBounds;
4391
4422
  }
4392
- spreadStroke() {
4393
- const { x, y, width, height } = this.strokeBounds;
4394
- this._strokeBounds = { x, y, width, height };
4395
- this._localStrokeBounds = { x, y, width, height };
4396
- if (!this.renderSpread)
4397
- this.spreadRenderCancel();
4398
- }
4399
- spreadRender() {
4400
- const { x, y, width, height } = this.renderBounds;
4401
- this._renderBounds = { x, y, width, height };
4402
- this._localRenderBounds = { x, y, width, height };
4403
- }
4404
4423
  boxChange() {
4405
4424
  this.boxChanged = true;
4406
4425
  this.localBoxChanged || this.localBoxChange();
@@ -4487,24 +4506,40 @@ const LeafEventer = {
4487
4506
  });
4488
4507
  },
4489
4508
  off(type, listener, options) {
4490
- let capture;
4491
- if (options)
4492
- capture = typeof options === 'boolean' ? options : options.capture;
4493
- let events, index;
4494
- const map = __getListenerMap(this, capture);
4495
- const typeList = typeof type === 'string' ? type.split(' ') : type;
4496
- typeList.forEach(type => {
4497
- if (type) {
4498
- events = map[type];
4499
- if (events) {
4500
- index = events.findIndex(item => item.listener === listener);
4501
- if (index > -1)
4502
- events.splice(index, 1);
4503
- if (!events.length)
4504
- delete map[type];
4505
- }
4509
+ if (type) {
4510
+ const typeList = typeof type === 'string' ? type.split(' ') : type;
4511
+ if (listener) {
4512
+ let capture;
4513
+ if (options)
4514
+ capture = typeof options === 'boolean' ? options : options.capture;
4515
+ let events, index;
4516
+ const map = __getListenerMap(this, capture);
4517
+ typeList.forEach(type => {
4518
+ if (type) {
4519
+ events = map[type];
4520
+ if (events) {
4521
+ index = events.findIndex(item => item.listener === listener);
4522
+ if (index > -1)
4523
+ events.splice(index, 1);
4524
+ if (!events.length)
4525
+ delete map[type];
4526
+ }
4527
+ }
4528
+ });
4506
4529
  }
4507
- });
4530
+ else {
4531
+ const { __bubbleMap: b, __captureMap: c } = this;
4532
+ typeList.forEach(type => {
4533
+ if (b)
4534
+ delete b[type];
4535
+ if (c)
4536
+ delete c[type];
4537
+ });
4538
+ }
4539
+ }
4540
+ else {
4541
+ this.__bubbleMap = this.__captureMap = undefined;
4542
+ }
4508
4543
  },
4509
4544
  on_(type, listener, bind, options) {
4510
4545
  if (bind)
@@ -4771,7 +4806,7 @@ const { setLayout, multiplyParent: multiplyParent$1, translateInner, defaultWorl
4771
4806
  const { toPoint, tempPoint: tempPoint$1 } = AroundHelper;
4772
4807
  const LeafMatrix = {
4773
4808
  __updateWorldMatrix() {
4774
- multiplyParent$1(this.__local || this.__layout, this.parent ? this.parent.__world : defaultWorld, this.__world, !!this.__layout.affectScaleOrRotation, this.__);
4809
+ multiplyParent$1(this.__local || this.__layout, this.parent ? this.parent.__world : defaultWorld, this.__world, !!this.__layout.affectScaleOrRotation, this.__, this.parent && this.parent.__);
4775
4810
  },
4776
4811
  __updateLocalMatrix() {
4777
4812
  if (this.__local) {
@@ -4782,11 +4817,11 @@ const LeafMatrix = {
4782
4817
  layout.scaleChanged = layout.rotationChanged = false;
4783
4818
  }
4784
4819
  }
4785
- local.e = data.x;
4786
- local.f = data.y;
4787
- if (data.around) {
4788
- toPoint(data.around, layout.boxBounds, tempPoint$1);
4789
- translateInner(local, -tempPoint$1.x, -tempPoint$1.y);
4820
+ local.e = data.x + data.offsetX;
4821
+ local.f = data.y + data.offsetY;
4822
+ if (data.around || data.origin) {
4823
+ toPoint(data.around || data.origin, layout.boxBounds, tempPoint$1);
4824
+ translateInner(local, -tempPoint$1.x, -tempPoint$1.y, data.origin);
4790
4825
  }
4791
4826
  }
4792
4827
  this.__layout.matrixChanged = false;
@@ -4892,6 +4927,8 @@ const LeafBounds = {
4892
4927
  if (this.isBranch) {
4893
4928
  if (this.leafer)
4894
4929
  this.leafer.layouter.addExtra(this);
4930
+ if (this.__.flow)
4931
+ this.__updateFlowLayout();
4895
4932
  if (hasParentAutoLayout(this)) {
4896
4933
  updateMatrix$1(this);
4897
4934
  }
@@ -4924,6 +4961,8 @@ const LeafRender = {
4924
4961
  canvas.setWorld(this.__nowWorld = this.__getNowWorld(options));
4925
4962
  canvas.opacity = this.__.opacity;
4926
4963
  if (this.__.__single) {
4964
+ if (this.__.eraser === 'path')
4965
+ return this.__renderEraser(canvas, options);
4927
4966
  const tempCanvas = canvas.getSameCanvas(true, true);
4928
4967
  this.__draw(tempCanvas, options);
4929
4968
  if (this.__worldFlipped) {
@@ -4966,6 +5005,8 @@ const BranchRender = {
4966
5005
  __render(canvas, options) {
4967
5006
  if (this.__worldOpacity) {
4968
5007
  if (this.__.__single) {
5008
+ if (this.__.eraser === 'path')
5009
+ return this.__renderEraser(canvas, options);
4969
5010
  const tempCanvas = canvas.getSameCanvas(false, true);
4970
5011
  this.__renderBranch(tempCanvas, options);
4971
5012
  const nowWorld = this.__getNowWorld(options);
@@ -5105,7 +5146,9 @@ let Leaf = class Leaf {
5105
5146
  setProxyAttr(_attrName, _newValue) { }
5106
5147
  getProxyAttr(_attrName) { return undefined; }
5107
5148
  find(_condition, _options) { return undefined; }
5149
+ findTag(_tag) { return undefined; }
5108
5150
  findOne(_condition, _options) { return undefined; }
5151
+ findId(_id) { return undefined; }
5109
5152
  focus(_value) { }
5110
5153
  forceUpdate(attrName) {
5111
5154
  if (attrName === undefined)
@@ -5127,9 +5170,11 @@ let Leaf = class Leaf {
5127
5170
  __updateLocalStrokeBounds() { }
5128
5171
  __updateLocalRenderBounds() { }
5129
5172
  __updateBoxBounds() { }
5173
+ __updateContentBounds() { }
5130
5174
  __updateStrokeBounds() { }
5131
5175
  __updateRenderBounds() { }
5132
5176
  __updateAutoLayout() { }
5177
+ __updateFlowLayout() { }
5133
5178
  __updateNaturalSize() { }
5134
5179
  __updateStrokeSpread() { return 0; }
5135
5180
  __updateRenderSpread() { return 0; }
@@ -5137,6 +5182,13 @@ let Leaf = class Leaf {
5137
5182
  __updateEraser(value) {
5138
5183
  this.__hasEraser = value ? true : this.children.some(item => item.__.eraser);
5139
5184
  }
5185
+ __renderEraser(canvas, options) {
5186
+ canvas.save();
5187
+ this.__clip(canvas, options);
5188
+ const { renderBounds: r } = this.__layout;
5189
+ canvas.clearRect(r.x, r.y, r.width, r.height);
5190
+ canvas.restore();
5191
+ }
5140
5192
  __updateMask(value) {
5141
5193
  this.__hasMask = value ? true : this.children.some(item => item.__.mask);
5142
5194
  }
@@ -5317,8 +5369,8 @@ let Leaf = class Leaf {
5317
5369
  emit(_type, _event, _capture) { }
5318
5370
  emitEvent(_event, _capture) { }
5319
5371
  hasEvent(_type, _capture) { return false; }
5320
- static changeAttr(attrName, defaultValue) {
5321
- defineDataProcessor(this.prototype, attrName, defaultValue);
5372
+ static changeAttr(attrName, defaultValue, fn) {
5373
+ fn ? this.addAttr(attrName, defaultValue, fn) : defineDataProcessor(this.prototype, attrName, defaultValue);
5322
5374
  }
5323
5375
  static addAttr(attrName, defaultValue, fn) {
5324
5376
  if (!fn)
@@ -6364,8 +6416,11 @@ class Renderer {
6364
6416
  if (!bounds.includes(this.target.__world) || this.needFill || !e.samePixelRatio) {
6365
6417
  this.addBlock(this.canvas.bounds);
6366
6418
  this.target.forceUpdate('surface');
6419
+ return;
6367
6420
  }
6368
6421
  }
6422
+ this.addBlock(new Bounds(0, 0, 1, 1));
6423
+ this.changed = true;
6369
6424
  }
6370
6425
  __onLayoutEnd(event) {
6371
6426
  if (event.data)
@@ -6538,6 +6593,7 @@ class Picker {
6538
6593
  }
6539
6594
 
6540
6595
  const { Yes, NoAndSkip, YesAndSkip } = Answer;
6596
+ const idCondition = {}, classNameCondition = {}, tagCondition = {};
6541
6597
  class Selector {
6542
6598
  constructor(target, userConfig) {
6543
6599
  this.config = {};
@@ -6547,7 +6603,8 @@ class Selector {
6547
6603
  id: (leaf, name) => leaf.id === name ? (this.idMap[name] = leaf, 1) : 0,
6548
6604
  innerId: (leaf, innerId) => leaf.innerId === innerId ? (this.innerIdMap[innerId] = leaf, 1) : 0,
6549
6605
  className: (leaf, name) => leaf.className === name ? 1 : 0,
6550
- tag: (leaf, name) => leaf.__tag === name ? 1 : 0
6606
+ tag: (leaf, name) => leaf.__tag === name ? 1 : 0,
6607
+ tags: (leaf, nameMap) => nameMap[leaf.__tag] ? 1 : 0
6551
6608
  };
6552
6609
  this.target = target;
6553
6610
  if (userConfig)
@@ -6563,12 +6620,25 @@ class Selector {
6563
6620
  case 'string':
6564
6621
  switch (condition[0]) {
6565
6622
  case '#':
6566
- const leaf = this.getById(condition.substring(1), branch);
6567
- return one ? leaf : (leaf ? [leaf] : []);
6623
+ idCondition.id = condition.substring(1), condition = idCondition;
6624
+ break;
6568
6625
  case '.':
6569
- return this.getByMethod(this.methods.className, branch, one, condition.substring(1));
6626
+ classNameCondition.className = condition.substring(1), condition = classNameCondition;
6627
+ break;
6570
6628
  default:
6571
- return this.getByMethod(this.methods.tag, branch, one, condition);
6629
+ tagCondition.tag = condition, condition = tagCondition;
6630
+ }
6631
+ case 'object':
6632
+ if (condition.id !== undefined) {
6633
+ const leaf = this.getById(condition.id, branch);
6634
+ return one ? leaf : (leaf ? [leaf] : []);
6635
+ }
6636
+ else if (condition.tag) {
6637
+ const { tag } = condition, isArray = tag instanceof Array;
6638
+ return this.getByMethod(isArray ? this.methods.tags : this.methods.tag, branch, one, isArray ? DataHelper.toMap(tag) : tag);
6639
+ }
6640
+ else {
6641
+ return this.getByMethod(this.methods.className, branch, one, condition.className);
6572
6642
  }
6573
6643
  case 'function':
6574
6644
  return this.getByMethod(condition, branch, one, options);
@@ -6867,7 +6937,7 @@ class UIData extends LeafData {
6867
6937
  const UnitConvert = {
6868
6938
  number(value, percentRefer) {
6869
6939
  if (typeof value === 'object')
6870
- return value.type === 'percent' ? value.value / 100 * percentRefer : value.value;
6940
+ return value.type === 'percent' ? (value.value > 49 ? value.value / 100 : value.value) * percentRefer : value.value;
6871
6941
  return value;
6872
6942
  }
6873
6943
  };
@@ -7148,7 +7218,9 @@ let UI = UI_1 = class UI extends Leaf {
7148
7218
  }
7149
7219
  createProxyData() { return undefined; }
7150
7220
  find(_condition, _options) { return undefined; }
7221
+ findTag(tag) { return this.find({ tag }); }
7151
7222
  findOne(_condition, _options) { return undefined; }
7223
+ findId(id) { return this.findOne({ id }); }
7152
7224
  getPath(curve, pathForRender) {
7153
7225
  this.__layout.update();
7154
7226
  let path = pathForRender ? this.__.__pathForRender : this.__.path;
@@ -7299,9 +7371,75 @@ __decorate([
7299
7371
  __decorate([
7300
7372
  rotationType(0, true)
7301
7373
  ], UI.prototype, "skewY", void 0);
7374
+ __decorate([
7375
+ positionType(0, true)
7376
+ ], UI.prototype, "offsetX", void 0);
7377
+ __decorate([
7378
+ positionType(0, true)
7379
+ ], UI.prototype, "offsetY", void 0);
7380
+ __decorate([
7381
+ positionType(0, true)
7382
+ ], UI.prototype, "scrollX", void 0);
7383
+ __decorate([
7384
+ positionType(0, true)
7385
+ ], UI.prototype, "scrollY", void 0);
7386
+ __decorate([
7387
+ autoLayoutType()
7388
+ ], UI.prototype, "origin", void 0);
7302
7389
  __decorate([
7303
7390
  autoLayoutType()
7304
7391
  ], UI.prototype, "around", void 0);
7392
+ __decorate([
7393
+ dataType(false)
7394
+ ], UI.prototype, "lazy", void 0);
7395
+ __decorate([
7396
+ naturalBoundsType(1)
7397
+ ], UI.prototype, "pixelRatio", void 0);
7398
+ __decorate([
7399
+ pathInputType()
7400
+ ], UI.prototype, "path", void 0);
7401
+ __decorate([
7402
+ pathType()
7403
+ ], UI.prototype, "windingRule", void 0);
7404
+ __decorate([
7405
+ pathType(true)
7406
+ ], UI.prototype, "closed", void 0);
7407
+ __decorate([
7408
+ autoLayoutType(false)
7409
+ ], UI.prototype, "flow", void 0);
7410
+ __decorate([
7411
+ boundsType(0)
7412
+ ], UI.prototype, "padding", void 0);
7413
+ __decorate([
7414
+ boundsType(0)
7415
+ ], UI.prototype, "gap", void 0);
7416
+ __decorate([
7417
+ boundsType('top-left')
7418
+ ], UI.prototype, "align", void 0);
7419
+ __decorate([
7420
+ boundsType(false)
7421
+ ], UI.prototype, "wrap", void 0);
7422
+ __decorate([
7423
+ boundsType('box')
7424
+ ], UI.prototype, "itemBox", void 0);
7425
+ __decorate([
7426
+ boundsType(true)
7427
+ ], UI.prototype, "inFlow", void 0);
7428
+ __decorate([
7429
+ boundsType()
7430
+ ], UI.prototype, "autoWidth", void 0);
7431
+ __decorate([
7432
+ boundsType()
7433
+ ], UI.prototype, "autoHeight", void 0);
7434
+ __decorate([
7435
+ boundsType()
7436
+ ], UI.prototype, "autoBox", void 0);
7437
+ __decorate([
7438
+ boundsType()
7439
+ ], UI.prototype, "widthRange", void 0);
7440
+ __decorate([
7441
+ boundsType()
7442
+ ], UI.prototype, "heightRange", void 0);
7305
7443
  __decorate([
7306
7444
  dataType(false)
7307
7445
  ], UI.prototype, "draggable", void 0);
@@ -7311,9 +7449,6 @@ __decorate([
7311
7449
  __decorate([
7312
7450
  dataType(false)
7313
7451
  ], UI.prototype, "editable", void 0);
7314
- __decorate([
7315
- dataType('size')
7316
- ], UI.prototype, "editSize", void 0);
7317
7452
  __decorate([
7318
7453
  hitType(true)
7319
7454
  ], UI.prototype, "hittable", void 0);
@@ -7368,21 +7503,6 @@ __decorate([
7368
7503
  __decorate([
7369
7504
  strokeType(10)
7370
7505
  ], UI.prototype, "miterLimit", void 0);
7371
- __decorate([
7372
- dataType(false)
7373
- ], UI.prototype, "lazy", void 0);
7374
- __decorate([
7375
- naturalBoundsType(1)
7376
- ], UI.prototype, "pixelRatio", void 0);
7377
- __decorate([
7378
- pathInputType()
7379
- ], UI.prototype, "path", void 0);
7380
- __decorate([
7381
- pathType()
7382
- ], UI.prototype, "windingRule", void 0);
7383
- __decorate([
7384
- pathType(true)
7385
- ], UI.prototype, "closed", void 0);
7386
7506
  __decorate([
7387
7507
  arrowType('none')
7388
7508
  ], UI.prototype, "startArrow", void 0);
@@ -7616,9 +7736,6 @@ let Leafer = Leafer_1 = class Leafer extends Group {
7616
7736
  const data = DataHelper.copyAttrs({}, size, canvasSizeAttrs);
7617
7737
  Object.keys(data).forEach(key => this[key] = data[key]);
7618
7738
  }
7619
- forceFullRender() {
7620
- this.forceRender();
7621
- }
7622
7739
  forceRender(bounds) {
7623
7740
  this.renderer.addBlock(bounds ? new Bounds(bounds) : this.canvas.bounds);
7624
7741
  if (this.viewReady)
@@ -7696,7 +7813,7 @@ let Leafer = Leafer_1 = class Leafer extends Group {
7696
7813
  this.canvas.backgroundColor = newValue;
7697
7814
  }
7698
7815
  else {
7699
- this.forceFullRender();
7816
+ this.forceRender();
7700
7817
  }
7701
7818
  }
7702
7819
  __onCreated() {
@@ -7907,6 +8024,8 @@ let Box = class Box extends Group {
7907
8024
  else {
7908
8025
  this.__updateRectBoxBounds();
7909
8026
  }
8027
+ if (data.flow)
8028
+ this.__updateContentBounds();
7910
8029
  }
7911
8030
  __updateStrokeBounds() { }
7912
8031
  __updateRenderBounds() {
@@ -8316,7 +8435,7 @@ Canvas = __decorate([
8316
8435
  registerUI()
8317
8436
  ], Canvas);
8318
8437
 
8319
- const { copyAndSpread, includes, spread, setList } = BoundsHelper;
8438
+ const { copyAndSpread, includes, isSame: isSame$1, spread, setList } = BoundsHelper;
8320
8439
  let Text = class Text extends UI {
8321
8440
  get __tag() { return 'Text'; }
8322
8441
  get editInner() { return 'TextEditor'; }
@@ -8389,7 +8508,7 @@ let Text = class Text extends UI {
8389
8508
  if (italic)
8390
8509
  b.width += fontSize * 0.16;
8391
8510
  const contentBounds = includes(b, bounds) ? b : bounds;
8392
- if (contentBounds !== layout.contentBounds) {
8511
+ if (!isSame$1(contentBounds, layout.contentBounds)) {
8393
8512
  layout.contentBounds = contentBounds;
8394
8513
  layout.renderChanged = true;
8395
8514
  setList(data.__textBoxBounds = {}, [b, bounds]);
@@ -8417,9 +8536,6 @@ __decorate([
8417
8536
  __decorate([
8418
8537
  boundsType(0)
8419
8538
  ], Text.prototype, "height", void 0);
8420
- __decorate([
8421
- boundsType(0)
8422
- ], Text.prototype, "padding", void 0);
8423
8539
  __decorate([
8424
8540
  surfaceType('#000000')
8425
8541
  ], Text.prototype, "fill", void 0);
@@ -8548,7 +8664,7 @@ function penPathType() {
8548
8664
  };
8549
8665
  }
8550
8666
 
8551
- const version = "1.0.0-rc.21";
8667
+ const version = "1.0.0-rc.23";
8552
8668
 
8553
8669
  let App = class App extends Leafer {
8554
8670
  get __tag() { return 'App'; }
@@ -8642,8 +8758,10 @@ let App = class App extends Leafer {
8642
8758
  this.renderer.update();
8643
8759
  }
8644
8760
  __render(canvas, options) {
8645
- if (options.matrix)
8646
- canvas.setWorld(options.matrix);
8761
+ if (options.matrix) {
8762
+ const { a, b, c, d, e, f } = options.matrix;
8763
+ canvas.setTransform(a, b, c, d, e, f);
8764
+ }
8647
8765
  this.children.forEach(leafer => canvas.copyWorld(leafer.canvas));
8648
8766
  }
8649
8767
  __onResize(event) {
@@ -10367,7 +10485,7 @@ function shape(ui, current, options) {
10367
10485
  }
10368
10486
  else {
10369
10487
  const { renderShapeSpread: spread } = ui.__layout;
10370
- const worldClipBounds = getIntersectData(spread ? getSpread(current.bounds, spread * scaleX, spread * scaleY) : current.bounds, nowWorld);
10488
+ const worldClipBounds = getIntersectData(spread ? getSpread(current.bounds, scaleX === scaleY ? spread * scaleX : [spread * scaleY, spread * scaleX]) : current.bounds, nowWorld);
10371
10489
  fitMatrix = current.bounds.getFitMatrix(worldClipBounds);
10372
10490
  let { a: fitScaleX, d: fitScaleY } = fitMatrix;
10373
10491
  if (fitMatrix.a < 1) {
@@ -10467,10 +10585,10 @@ function clipMode(data, box, x, y, scaleX, scaleY, rotation) {
10467
10585
  rotate(transform, rotation);
10468
10586
  data.transform = transform;
10469
10587
  }
10470
- function repeatMode(data, box, width, height, x, y, scaleX, scaleY, rotation, around) {
10588
+ function repeatMode(data, box, width, height, x, y, scaleX, scaleY, rotation, align) {
10471
10589
  const transform = get$4();
10472
10590
  if (rotation) {
10473
- if (around === 'center') {
10591
+ if (align === 'center') {
10474
10592
  rotateOfOuter$2(transform, { x: width / 2, y: height / 2 }, rotation);
10475
10593
  }
10476
10594
  else {
@@ -10503,12 +10621,12 @@ function createData(leafPaint, image, paint, box) {
10503
10621
  let { width, height } = image;
10504
10622
  if (paint.padding)
10505
10623
  box = tempBox.set(box).shrink(paint.padding);
10506
- const { opacity, mode, around, offset, scale, size, rotation, blendMode, repeat } = paint;
10624
+ const { opacity, mode, align, offset, scale, size, rotation, blendMode, repeat } = paint;
10507
10625
  const sameBox = box.width === width && box.height === height;
10508
10626
  if (blendMode)
10509
10627
  leafPaint.blendMode = blendMode;
10510
10628
  const data = leafPaint.data = { mode };
10511
- const swapSize = around !== 'center' && (rotation || 0) % 180 === 90;
10629
+ const swapSize = align !== 'center' && (rotation || 0) % 180 === 90;
10512
10630
  const swapWidth = swapSize ? height : width, swapHeight = swapSize ? width : height;
10513
10631
  let x = 0, y = 0, scaleX, scaleY;
10514
10632
  if (!mode || mode === 'cover' || mode === 'fit') {
@@ -10526,11 +10644,11 @@ function createData(leafPaint, image, paint, box) {
10526
10644
  scaleX = typeof scale === 'number' ? scale : scale.x;
10527
10645
  scaleY = typeof scale === 'number' ? scale : scale.y;
10528
10646
  }
10529
- if (around) {
10647
+ if (align) {
10530
10648
  const imageBounds = { x, y, width: swapWidth, height: swapHeight };
10531
10649
  if (scaleX)
10532
10650
  imageBounds.width *= scaleX, imageBounds.height *= scaleY;
10533
- AroundHelper.toPoint(around, box, tempPoint, true, imageBounds);
10651
+ AlignHelper.toPoint(align, imageBounds, box, tempPoint, true);
10534
10652
  x += tempPoint.x, y += tempPoint.y;
10535
10653
  }
10536
10654
  if (offset)
@@ -10547,7 +10665,7 @@ function createData(leafPaint, image, paint, box) {
10547
10665
  break;
10548
10666
  case 'repeat':
10549
10667
  if (!sameBox || scaleX || rotation)
10550
- repeatMode(data, box, width, height, x, y, scaleX, scaleY, rotation, around);
10668
+ repeatMode(data, box, width, height, x, y, scaleX, scaleY, rotation, align);
10551
10669
  if (!repeat)
10552
10670
  data.repeat = 'repeat';
10553
10671
  break;
@@ -11464,11 +11582,13 @@ function clipText(drawData, style) {
11464
11582
  const { rows, overflow } = drawData;
11465
11583
  let { textOverflow } = style;
11466
11584
  rows.splice(overflow);
11467
- if (textOverflow !== 'hide') {
11468
- if (textOverflow === 'ellipsis')
11585
+ if (textOverflow && textOverflow !== 'show') {
11586
+ if (textOverflow === 'hide')
11587
+ textOverflow = '';
11588
+ else if (textOverflow === 'ellipsis')
11469
11589
  textOverflow = '...';
11470
11590
  let char, charRight;
11471
- const ellipsisWidth = Platform.canvas.measureText(textOverflow).width;
11591
+ const ellipsisWidth = textOverflow ? Platform.canvas.measureText(textOverflow).width : 0;
11472
11592
  const right = style.x + style.width - ellipsisWidth;
11473
11593
  const list = style.textWrap === 'none' ? rows : [rows[overflow - 1]];
11474
11594
  list.forEach(row => {
@@ -11636,8 +11756,12 @@ const ExportModule = {
11636
11756
  let renderBounds, trimBounds, scaleX = 1, scaleY = 1;
11637
11757
  const { worldTransform, isLeafer, isFrame } = leaf;
11638
11758
  const { slice, trim, onCanvas } = options;
11639
- const scale = options.scale || 1;
11640
- const pixelRatio = options.pixelRatio || 1;
11759
+ let scale = options.scale || 1;
11760
+ let pixelRatio = options.pixelRatio || 1;
11761
+ if (leaf.isApp) {
11762
+ scale *= pixelRatio;
11763
+ pixelRatio = leaf.app.pixelRatio;
11764
+ }
11641
11765
  const screenshot = options.screenshot || leaf.isApp;
11642
11766
  const fill = (isLeafer && screenshot) ? (options.fill === undefined ? leaf.fill : options.fill) : options.fill;
11643
11767
  const needFill = FileHelper.isOpaqueImage(filename) || fill, matrix = new Matrix();
@@ -11805,4 +11929,4 @@ LeaferCanvas.prototype.updateViewSize = function () {
11805
11929
  }
11806
11930
  };
11807
11931
 
11808
- export { AnimateEvent, Answer, App, AroundHelper, AutoBounds, BezierHelper, Bounds, BoundsHelper, Box, BoxData, Branch, BranchHelper, BranchRender, Canvas, CanvasData, CanvasManager, ChildEvent, ColorConvert, Creator, Cursor, DataHelper, Debug, Direction4, Direction9, DragEvent, DropEvent, Effect, Ellipse, EllipseData, EllipseHelper, Event, EventCreator, Export, FileHelper, Frame, FrameData, Group, GroupData, HitCanvasManager, Image, ImageData, ImageEvent, ImageManager, IncrementId, Interaction, InteractionBase, InteractionHelper, KeyEvent, Keyboard, LayoutEvent, Layouter, Leaf, LeafBounds, LeafBoundsHelper, LeafData, LeafDataProxy, LeafEventer, LeafHelper, LeafLayout, LeafLevelList, LeafList, LeafMatrix, LeafRender, Leafer, LeaferCanvas, LeaferCanvasBase, LeaferData, LeaferEvent, LeaferImage, LeaferTypeCreator, Line, LineData, MathHelper, Matrix, MatrixHelper, MoveEvent, MultiTouchHelper, NeedConvertToCanvasCommandMap, OneRadian, PI2, PI_2, Paint, PaintGradient, PaintImage, Path, PathArrow, PathBounds, PathCommandDataHelper, PathCommandMap, PathConvert, PathCorner, PathCreator, PathData, PathDrawer, PathHelper, PathNumberCommandLengthMap, PathNumberCommandMap, Pen, PenData, Platform, Point, PointHelper, PointerButton, PointerEvent, Polygon, PolygonData, PropertyEvent, Rect, RectData, RectHelper, RectRender, RenderEvent, Renderer, ResizeEvent, RotateEvent, Run, Selector, Star, StarData, State, StringNumberMap, SwipeEvent, TaskItem, TaskProcessor, Text, TextConvert, TextData, TwoPointBoundsHelper, UI, UIBounds, UICreator, UIData, UIEvent, UIRender, UnitConvert, WaitHelper, WatchEvent, Watcher, ZoomEvent, affectRenderBoundsType, affectStrokeBoundsType, arrowType, attr, autoLayoutType, boundsType, canvasPatch, canvasSizeAttrs, cursorType, dataProcessor, dataType, decorateLeafAttr, defineDataProcessor, defineKey, defineLeafAttr, doBoundsType, doStrokeType, effectType, emptyData, eraserType, getBoundsData, getDescriptor, getMatrixData, getPointData, hitType, layoutProcessor, maskType, naturalBoundsType, opacityType, pathInputType, pathType, pen, positionType, registerUI, registerUIEvent, resizeType, rewrite, rewriteAble, rotationType, scaleType, sortType, stateType, strokeType, surfaceType, tempBounds$1 as tempBounds, tempMatrix, tempPoint$3 as tempPoint, useCanvas, useModule, version, zoomLayerType };
11932
+ export { AlignHelper, AnimateEvent, Answer, App, AroundHelper, AutoBounds, BezierHelper, Bounds, BoundsHelper, Box, BoxData, Branch, BranchHelper, BranchRender, Canvas, CanvasData, CanvasManager, ChildEvent, ColorConvert, Creator, Cursor, DataHelper, Debug, Direction4, Direction9, DragEvent, DropEvent, Effect, Ellipse, EllipseData, EllipseHelper, Event, EventCreator, Export, FileHelper, Frame, FrameData, Group, GroupData, HitCanvasManager, Image, ImageData, ImageEvent, ImageManager, IncrementId, Interaction, InteractionBase, InteractionHelper, KeyEvent, Keyboard, LayoutEvent, Layouter, Leaf, LeafBounds, LeafBoundsHelper, LeafData, LeafDataProxy, LeafEventer, LeafHelper, LeafLayout, LeafLevelList, LeafList, LeafMatrix, LeafRender, Leafer, LeaferCanvas, LeaferCanvasBase, LeaferData, LeaferEvent, LeaferImage, LeaferTypeCreator, Line, LineData, MathHelper, Matrix, MatrixHelper, MoveEvent, MultiTouchHelper, NeedConvertToCanvasCommandMap, OneRadian, PI2, PI_2, Paint, PaintGradient, PaintImage, Path, PathArrow, PathBounds, PathCommandDataHelper, PathCommandMap, PathConvert, PathCorner, PathCreator, PathData, PathDrawer, PathHelper, PathNumberCommandLengthMap, PathNumberCommandMap, Pen, PenData, Platform, Point, PointHelper, PointerButton, PointerEvent, Polygon, PolygonData, PropertyEvent, Rect, RectData, RectHelper, RectRender, RenderEvent, Renderer, ResizeEvent, RotateEvent, Run, Selector, Star, StarData, State, StringNumberMap, SwipeEvent, TaskItem, TaskProcessor, Text, TextConvert, TextData, TwoPointBoundsHelper, UI, UIBounds, UICreator, UIData, UIEvent, UIRender, UnitConvert, WaitHelper, WatchEvent, Watcher, ZoomEvent, affectRenderBoundsType, affectStrokeBoundsType, arrowType, attr, autoLayoutType, boundsType, canvasPatch, canvasSizeAttrs, cursorType, dataProcessor, dataType, decorateLeafAttr, defineDataProcessor, defineKey, defineLeafAttr, doBoundsType, doStrokeType, effectType, emptyData, eraserType, getBoundsData, getDescriptor, getMatrixData, getPointData, hitType, layoutProcessor, maskType, naturalBoundsType, opacityType, pathInputType, pathType, pen, positionType, registerUI, registerUIEvent, resizeType, rewrite, rewriteAble, rotationType, scaleType, sortType, stateType, strokeType, surfaceType, tempBounds$1 as tempBounds, tempMatrix, tempPoint$3 as tempPoint, useCanvas, useModule, version, zoomLayerType };