leafer-draw 1.0.2 → 1.0.4
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.
- package/dist/web.cjs +34 -21
- package/dist/web.esm.js +35 -22
- package/dist/web.esm.min.js +1 -1
- package/dist/web.js +390 -352
- package/dist/web.min.cjs +1 -1
- package/dist/web.min.js +1 -1
- package/dist/web.module.js +387 -349
- package/dist/web.module.min.js +1 -1
- package/package.json +2 -2
package/dist/web.module.js
CHANGED
|
@@ -119,11 +119,18 @@ const MathHelper = {
|
|
|
119
119
|
scaleData.scaleX = (typeof size === 'number' ? size : size.width) / originSize.width;
|
|
120
120
|
scaleData.scaleY = (typeof size === 'number' ? size : size.height) / originSize.height;
|
|
121
121
|
}
|
|
122
|
-
else if (scale)
|
|
123
|
-
scaleData
|
|
124
|
-
scaleData.scaleY = typeof scale === 'number' ? scale : scale.y;
|
|
125
|
-
}
|
|
122
|
+
else if (scale)
|
|
123
|
+
MathHelper.assignScale(scaleData, scale);
|
|
126
124
|
return scaleData;
|
|
125
|
+
},
|
|
126
|
+
assignScale(scaleData, scale) {
|
|
127
|
+
if (typeof scale === 'number') {
|
|
128
|
+
scaleData.scaleX = scaleData.scaleY = scale;
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
scaleData.scaleX = scale.x;
|
|
132
|
+
scaleData.scaleY = scale.y;
|
|
133
|
+
}
|
|
127
134
|
}
|
|
128
135
|
};
|
|
129
136
|
const OneRadian = PI$4 / 180;
|
|
@@ -1255,7 +1262,6 @@ const AroundHelper = {
|
|
|
1255
1262
|
tempPoint: {},
|
|
1256
1263
|
get: get$4,
|
|
1257
1264
|
toPoint(around, bounds, to, onlySize, pointBounds) {
|
|
1258
|
-
to || (to = {});
|
|
1259
1265
|
const point = get$4(around);
|
|
1260
1266
|
to.x = point.x;
|
|
1261
1267
|
to.y = point.y;
|
|
@@ -1390,6 +1396,10 @@ const Run = {
|
|
|
1390
1396
|
};
|
|
1391
1397
|
const R = Run;
|
|
1392
1398
|
|
|
1399
|
+
function needPlugin(name) {
|
|
1400
|
+
console.error('need plugin: @leafer-in/' + name);
|
|
1401
|
+
}
|
|
1402
|
+
|
|
1393
1403
|
const debug$d = Debug.get('UICreator');
|
|
1394
1404
|
const UICreator = {
|
|
1395
1405
|
list: {},
|
|
@@ -1652,6 +1662,9 @@ var Answer;
|
|
|
1652
1662
|
Answer[Answer["YesAndSkip"] = 3] = "YesAndSkip";
|
|
1653
1663
|
})(Answer || (Answer = {}));
|
|
1654
1664
|
const emptyData = {};
|
|
1665
|
+
function isNull(value) {
|
|
1666
|
+
return value === undefined || value === null;
|
|
1667
|
+
}
|
|
1655
1668
|
|
|
1656
1669
|
/******************************************************************************
|
|
1657
1670
|
Copyright (c) Microsoft Corporation.
|
|
@@ -2417,7 +2430,7 @@ const BezierHelper = {
|
|
|
2417
2430
|
let startY = y = rotationSin * radiusX * startCos + rotationCos * radiusY * startSin;
|
|
2418
2431
|
let fromX = cx + x, fromY = cy + y;
|
|
2419
2432
|
if (data)
|
|
2420
|
-
data.push(L$6, fromX, fromY);
|
|
2433
|
+
data.push(data.length ? L$6 : M$5, fromX, fromY);
|
|
2421
2434
|
if (setPointBounds)
|
|
2422
2435
|
setPoint$2(setPointBounds, fromX, fromY);
|
|
2423
2436
|
if (setStartPoint)
|
|
@@ -3086,8 +3099,7 @@ const PathBounds = {
|
|
|
3086
3099
|
toTwoPointBounds(data, setPointBounds) {
|
|
3087
3100
|
if (!data || !data.length)
|
|
3088
3101
|
return setPoint$1(setPointBounds, 0, 0);
|
|
3089
|
-
let command;
|
|
3090
|
-
let i = 0, x = 0, y = 0, x1, y1, toX, toY;
|
|
3102
|
+
let i = 0, x = 0, y = 0, x1, y1, toX, toY, command;
|
|
3091
3103
|
const len = data.length;
|
|
3092
3104
|
while (i < len) {
|
|
3093
3105
|
command = data[i];
|
|
@@ -3743,7 +3755,7 @@ function autoLayoutType(defaultValue) {
|
|
|
3743
3755
|
set(value) {
|
|
3744
3756
|
if (this.__setAttr(key, value)) {
|
|
3745
3757
|
this.__layout.matrixChanged || this.__layout.matrixChange();
|
|
3746
|
-
this.__hasAutoLayout = !!
|
|
3758
|
+
this.__hasAutoLayout = !!(this.origin || this.around || this.flow);
|
|
3747
3759
|
if (!this.__local)
|
|
3748
3760
|
this.__layout.createLocal();
|
|
3749
3761
|
}
|
|
@@ -3836,14 +3848,25 @@ function visibleType(defaultValue) {
|
|
|
3836
3848
|
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
3837
3849
|
set(value) {
|
|
3838
3850
|
const oldValue = this.visible;
|
|
3839
|
-
if (
|
|
3840
|
-
|
|
3841
|
-
|
|
3842
|
-
|
|
3851
|
+
if (oldValue === true && value === 0) {
|
|
3852
|
+
if (this.animationOut)
|
|
3853
|
+
return this.__runAnimation('out', () => doVisible(this, key, value, oldValue));
|
|
3854
|
+
}
|
|
3855
|
+
else if (oldValue === 0 && value === true) {
|
|
3856
|
+
if (this.animation)
|
|
3857
|
+
this.__runAnimation('in');
|
|
3843
3858
|
}
|
|
3859
|
+
doVisible(this, key, value, oldValue);
|
|
3844
3860
|
}
|
|
3845
3861
|
}));
|
|
3846
3862
|
}
|
|
3863
|
+
function doVisible(leaf, key, value, oldValue) {
|
|
3864
|
+
if (leaf.__setAttr(key, value)) {
|
|
3865
|
+
leaf.__layout.opacityChanged || leaf.__layout.opacityChange();
|
|
3866
|
+
if (oldValue === 0 || value === 0)
|
|
3867
|
+
doBoundsType(leaf);
|
|
3868
|
+
}
|
|
3869
|
+
}
|
|
3847
3870
|
function sortType(defaultValue) {
|
|
3848
3871
|
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
3849
3872
|
set(value) {
|
|
@@ -3927,7 +3950,16 @@ function defineDataProcessor(target, key, defaultValue) {
|
|
|
3927
3950
|
if (defaultValue === undefined) {
|
|
3928
3951
|
property.get = function () { return this[computedKey]; };
|
|
3929
3952
|
}
|
|
3930
|
-
else if (
|
|
3953
|
+
else if (typeof defaultValue === 'object') {
|
|
3954
|
+
const { clone } = DataHelper;
|
|
3955
|
+
property.get = function () {
|
|
3956
|
+
let v = this[computedKey];
|
|
3957
|
+
if (v === undefined)
|
|
3958
|
+
this[computedKey] = v = clone(defaultValue);
|
|
3959
|
+
return v;
|
|
3960
|
+
};
|
|
3961
|
+
}
|
|
3962
|
+
if (key === 'width') {
|
|
3931
3963
|
property.get = function () {
|
|
3932
3964
|
const v = this[computedKey];
|
|
3933
3965
|
if (v === undefined) {
|
|
@@ -4451,15 +4483,16 @@ class LeafLayout {
|
|
|
4451
4483
|
}
|
|
4452
4484
|
getLayoutBounds(type, relative = 'world', unscale) {
|
|
4453
4485
|
const { leaf } = this;
|
|
4454
|
-
let point, matrix, bounds = this.getInnerBounds(type);
|
|
4486
|
+
let point, matrix, layoutBounds, bounds = this.getInnerBounds(type);
|
|
4455
4487
|
switch (relative) {
|
|
4456
4488
|
case 'world':
|
|
4457
4489
|
point = leaf.getWorldPoint(bounds);
|
|
4458
4490
|
matrix = leaf.__world;
|
|
4459
4491
|
break;
|
|
4460
4492
|
case 'local':
|
|
4493
|
+
const { scaleX, scaleY, rotation, skewX, skewY } = leaf.__;
|
|
4494
|
+
layoutBounds = { scaleX, scaleY, rotation, skewX, skewY };
|
|
4461
4495
|
point = leaf.getLocalPointByInner(bounds);
|
|
4462
|
-
matrix = leaf.__localMatrix;
|
|
4463
4496
|
break;
|
|
4464
4497
|
case 'inner':
|
|
4465
4498
|
point = bounds;
|
|
@@ -4471,7 +4504,8 @@ class LeafLayout {
|
|
|
4471
4504
|
point = leaf.getWorldPoint(bounds, relative);
|
|
4472
4505
|
matrix = getRelativeWorld$1(leaf, relative, true);
|
|
4473
4506
|
}
|
|
4474
|
-
|
|
4507
|
+
if (!layoutBounds)
|
|
4508
|
+
layoutBounds = MatrixHelper.getLayout(matrix);
|
|
4475
4509
|
copy$5(layoutBounds, bounds);
|
|
4476
4510
|
PointHelper.copy(layoutBounds, point);
|
|
4477
4511
|
if (unscale) {
|
|
@@ -4594,144 +4628,6 @@ class LeafLayout {
|
|
|
4594
4628
|
destroy() { }
|
|
4595
4629
|
}
|
|
4596
4630
|
|
|
4597
|
-
const empty = {};
|
|
4598
|
-
const LeafEventer = {
|
|
4599
|
-
on(type, listener, options) {
|
|
4600
|
-
let capture, once;
|
|
4601
|
-
if (options) {
|
|
4602
|
-
if (options === 'once') {
|
|
4603
|
-
once = true;
|
|
4604
|
-
}
|
|
4605
|
-
else if (typeof options === 'boolean') {
|
|
4606
|
-
capture = options;
|
|
4607
|
-
}
|
|
4608
|
-
else {
|
|
4609
|
-
capture = options.capture;
|
|
4610
|
-
once = options.once;
|
|
4611
|
-
}
|
|
4612
|
-
}
|
|
4613
|
-
let events;
|
|
4614
|
-
const map = __getListenerMap(this, capture, true);
|
|
4615
|
-
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4616
|
-
const item = once ? { listener, once } : { listener };
|
|
4617
|
-
typeList.forEach(type => {
|
|
4618
|
-
if (type) {
|
|
4619
|
-
events = map[type];
|
|
4620
|
-
if (events) {
|
|
4621
|
-
if (events.findIndex(item => item.listener === listener) === -1)
|
|
4622
|
-
events.push(item);
|
|
4623
|
-
}
|
|
4624
|
-
else {
|
|
4625
|
-
map[type] = [item];
|
|
4626
|
-
}
|
|
4627
|
-
}
|
|
4628
|
-
});
|
|
4629
|
-
},
|
|
4630
|
-
off(type, listener, options) {
|
|
4631
|
-
if (type) {
|
|
4632
|
-
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4633
|
-
if (listener) {
|
|
4634
|
-
let capture;
|
|
4635
|
-
if (options)
|
|
4636
|
-
capture = typeof options === 'boolean' ? options : (options === 'once' ? false : options.capture);
|
|
4637
|
-
let events, index;
|
|
4638
|
-
const map = __getListenerMap(this, capture);
|
|
4639
|
-
typeList.forEach(type => {
|
|
4640
|
-
if (type) {
|
|
4641
|
-
events = map[type];
|
|
4642
|
-
if (events) {
|
|
4643
|
-
index = events.findIndex(item => item.listener === listener);
|
|
4644
|
-
if (index > -1)
|
|
4645
|
-
events.splice(index, 1);
|
|
4646
|
-
if (!events.length)
|
|
4647
|
-
delete map[type];
|
|
4648
|
-
}
|
|
4649
|
-
}
|
|
4650
|
-
});
|
|
4651
|
-
}
|
|
4652
|
-
else {
|
|
4653
|
-
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4654
|
-
typeList.forEach(type => {
|
|
4655
|
-
if (b)
|
|
4656
|
-
delete b[type];
|
|
4657
|
-
if (c)
|
|
4658
|
-
delete c[type];
|
|
4659
|
-
});
|
|
4660
|
-
}
|
|
4661
|
-
}
|
|
4662
|
-
else {
|
|
4663
|
-
this.__bubbleMap = this.__captureMap = undefined;
|
|
4664
|
-
}
|
|
4665
|
-
},
|
|
4666
|
-
on_(type, listener, bind, options) {
|
|
4667
|
-
if (bind)
|
|
4668
|
-
listener = listener.bind(bind);
|
|
4669
|
-
this.on(type, listener, options);
|
|
4670
|
-
return { type, current: this, listener, options };
|
|
4671
|
-
},
|
|
4672
|
-
off_(id) {
|
|
4673
|
-
if (!id)
|
|
4674
|
-
return;
|
|
4675
|
-
const list = id instanceof Array ? id : [id];
|
|
4676
|
-
list.forEach(item => item.current.off(item.type, item.listener, item.options));
|
|
4677
|
-
list.length = 0;
|
|
4678
|
-
},
|
|
4679
|
-
once(type, listener, capture) {
|
|
4680
|
-
this.on(type, listener, { once: true, capture });
|
|
4681
|
-
},
|
|
4682
|
-
emit(type, event, capture) {
|
|
4683
|
-
if (!event && EventCreator.has(type))
|
|
4684
|
-
event = EventCreator.get(type, { type, target: this, current: this });
|
|
4685
|
-
const map = __getListenerMap(this, capture);
|
|
4686
|
-
const list = map[type];
|
|
4687
|
-
if (list) {
|
|
4688
|
-
let item;
|
|
4689
|
-
for (let i = 0, len = list.length; i < len; i++) {
|
|
4690
|
-
item = list[i];
|
|
4691
|
-
item.listener(event);
|
|
4692
|
-
if (item.once) {
|
|
4693
|
-
this.off(type, item.listener, capture);
|
|
4694
|
-
i--, len--;
|
|
4695
|
-
}
|
|
4696
|
-
if (event && event.isStopNow)
|
|
4697
|
-
break;
|
|
4698
|
-
}
|
|
4699
|
-
}
|
|
4700
|
-
this.syncEventer && this.syncEventer.emitEvent(event, capture);
|
|
4701
|
-
},
|
|
4702
|
-
emitEvent(event, capture) {
|
|
4703
|
-
event.current = this;
|
|
4704
|
-
this.emit(event.type, event, capture);
|
|
4705
|
-
},
|
|
4706
|
-
hasEvent(type, capture) {
|
|
4707
|
-
if (this.syncEventer && this.syncEventer.hasEvent(type, capture))
|
|
4708
|
-
return true;
|
|
4709
|
-
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4710
|
-
const hasB = b && b[type], hasC = c && c[type];
|
|
4711
|
-
return !!(capture === undefined ? (hasB || hasC) : (capture ? hasC : hasB));
|
|
4712
|
-
},
|
|
4713
|
-
};
|
|
4714
|
-
function __getListenerMap(eventer, capture, create) {
|
|
4715
|
-
if (capture) {
|
|
4716
|
-
const { __captureMap: c } = eventer;
|
|
4717
|
-
if (c) {
|
|
4718
|
-
return c;
|
|
4719
|
-
}
|
|
4720
|
-
else {
|
|
4721
|
-
return create ? eventer.__captureMap = {} : empty;
|
|
4722
|
-
}
|
|
4723
|
-
}
|
|
4724
|
-
else {
|
|
4725
|
-
const { __bubbleMap: b } = eventer;
|
|
4726
|
-
if (b) {
|
|
4727
|
-
return b;
|
|
4728
|
-
}
|
|
4729
|
-
else {
|
|
4730
|
-
return create ? eventer.__bubbleMap = {} : empty;
|
|
4731
|
-
}
|
|
4732
|
-
}
|
|
4733
|
-
}
|
|
4734
|
-
|
|
4735
4631
|
class Event {
|
|
4736
4632
|
constructor(type, target) {
|
|
4737
4633
|
this.bubbles = false;
|
|
@@ -4766,7 +4662,10 @@ class ChildEvent extends Event {
|
|
|
4766
4662
|
}
|
|
4767
4663
|
ChildEvent.ADD = 'child.add';
|
|
4768
4664
|
ChildEvent.REMOVE = 'child.remove';
|
|
4769
|
-
ChildEvent.
|
|
4665
|
+
ChildEvent.CREATED = 'created';
|
|
4666
|
+
ChildEvent.MOUNTED = 'mounted';
|
|
4667
|
+
ChildEvent.UNMOUNTED = 'unmounted';
|
|
4668
|
+
ChildEvent.DESTROY = 'destroy';
|
|
4770
4669
|
|
|
4771
4670
|
class PropertyEvent extends Event {
|
|
4772
4671
|
constructor(type, target, attrName, oldValue, newValue) {
|
|
@@ -4844,10 +4743,6 @@ LayoutEvent.AFTER = 'layout.after';
|
|
|
4844
4743
|
LayoutEvent.AGAIN = 'layout.again';
|
|
4845
4744
|
LayoutEvent.END = 'layout.end';
|
|
4846
4745
|
|
|
4847
|
-
class AnimateEvent extends Event {
|
|
4848
|
-
}
|
|
4849
|
-
AnimateEvent.FRAME = 'animate.frame';
|
|
4850
|
-
|
|
4851
4746
|
class RenderEvent extends Event {
|
|
4852
4747
|
constructor(type, times, bounds, options) {
|
|
4853
4748
|
super(type);
|
|
@@ -4880,6 +4775,157 @@ LeaferEvent.STOP = 'leafer.stop';
|
|
|
4880
4775
|
LeaferEvent.RESTART = 'leafer.restart';
|
|
4881
4776
|
LeaferEvent.END = 'leafer.end';
|
|
4882
4777
|
|
|
4778
|
+
const empty = {};
|
|
4779
|
+
class Eventer {
|
|
4780
|
+
set event(map) { this.on(map); }
|
|
4781
|
+
on(type, listener, options) {
|
|
4782
|
+
if (!listener) {
|
|
4783
|
+
let event, map = type;
|
|
4784
|
+
for (let key in map)
|
|
4785
|
+
event = map[key], event instanceof Array ? this.on(key, event[0], event[1]) : this.on(key, event);
|
|
4786
|
+
return;
|
|
4787
|
+
}
|
|
4788
|
+
let capture, once;
|
|
4789
|
+
if (options) {
|
|
4790
|
+
if (options === 'once') {
|
|
4791
|
+
once = true;
|
|
4792
|
+
}
|
|
4793
|
+
else if (typeof options === 'boolean') {
|
|
4794
|
+
capture = options;
|
|
4795
|
+
}
|
|
4796
|
+
else {
|
|
4797
|
+
capture = options.capture;
|
|
4798
|
+
once = options.once;
|
|
4799
|
+
}
|
|
4800
|
+
}
|
|
4801
|
+
let events;
|
|
4802
|
+
const map = __getListenerMap(this, capture, true);
|
|
4803
|
+
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4804
|
+
const item = once ? { listener, once } : { listener };
|
|
4805
|
+
typeList.forEach(type => {
|
|
4806
|
+
if (type) {
|
|
4807
|
+
events = map[type];
|
|
4808
|
+
if (events) {
|
|
4809
|
+
if (events.findIndex(item => item.listener === listener) === -1)
|
|
4810
|
+
events.push(item);
|
|
4811
|
+
}
|
|
4812
|
+
else {
|
|
4813
|
+
map[type] = [item];
|
|
4814
|
+
}
|
|
4815
|
+
}
|
|
4816
|
+
});
|
|
4817
|
+
}
|
|
4818
|
+
off(type, listener, options) {
|
|
4819
|
+
if (type) {
|
|
4820
|
+
const typeList = typeof type === 'string' ? type.split(' ') : type;
|
|
4821
|
+
if (listener) {
|
|
4822
|
+
let capture;
|
|
4823
|
+
if (options)
|
|
4824
|
+
capture = typeof options === 'boolean' ? options : (options === 'once' ? false : options.capture);
|
|
4825
|
+
let events, index;
|
|
4826
|
+
const map = __getListenerMap(this, capture);
|
|
4827
|
+
typeList.forEach(type => {
|
|
4828
|
+
if (type) {
|
|
4829
|
+
events = map[type];
|
|
4830
|
+
if (events) {
|
|
4831
|
+
index = events.findIndex(item => item.listener === listener);
|
|
4832
|
+
if (index > -1)
|
|
4833
|
+
events.splice(index, 1);
|
|
4834
|
+
if (!events.length)
|
|
4835
|
+
delete map[type];
|
|
4836
|
+
}
|
|
4837
|
+
}
|
|
4838
|
+
});
|
|
4839
|
+
}
|
|
4840
|
+
else {
|
|
4841
|
+
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4842
|
+
typeList.forEach(type => {
|
|
4843
|
+
if (b)
|
|
4844
|
+
delete b[type];
|
|
4845
|
+
if (c)
|
|
4846
|
+
delete c[type];
|
|
4847
|
+
});
|
|
4848
|
+
}
|
|
4849
|
+
}
|
|
4850
|
+
else {
|
|
4851
|
+
this.__bubbleMap = this.__captureMap = undefined;
|
|
4852
|
+
}
|
|
4853
|
+
}
|
|
4854
|
+
on_(type, listener, bind, options) {
|
|
4855
|
+
if (bind)
|
|
4856
|
+
listener = listener.bind(bind);
|
|
4857
|
+
this.on(type, listener, options);
|
|
4858
|
+
return { type, current: this, listener, options };
|
|
4859
|
+
}
|
|
4860
|
+
off_(id) {
|
|
4861
|
+
if (!id)
|
|
4862
|
+
return;
|
|
4863
|
+
const list = id instanceof Array ? id : [id];
|
|
4864
|
+
list.forEach(item => item.current.off(item.type, item.listener, item.options));
|
|
4865
|
+
list.length = 0;
|
|
4866
|
+
}
|
|
4867
|
+
once(type, listener, capture) {
|
|
4868
|
+
this.on(type, listener, { once: true, capture });
|
|
4869
|
+
}
|
|
4870
|
+
emit(type, event, capture) {
|
|
4871
|
+
if (!event && EventCreator.has(type))
|
|
4872
|
+
event = EventCreator.get(type, { type, target: this, current: this });
|
|
4873
|
+
const map = __getListenerMap(this, capture);
|
|
4874
|
+
const list = map[type];
|
|
4875
|
+
if (list) {
|
|
4876
|
+
let item;
|
|
4877
|
+
for (let i = 0, len = list.length; i < len; i++) {
|
|
4878
|
+
item = list[i];
|
|
4879
|
+
item.listener(event);
|
|
4880
|
+
if (item.once) {
|
|
4881
|
+
this.off(type, item.listener, capture);
|
|
4882
|
+
i--, len--;
|
|
4883
|
+
}
|
|
4884
|
+
if (event && event.isStopNow)
|
|
4885
|
+
break;
|
|
4886
|
+
}
|
|
4887
|
+
}
|
|
4888
|
+
this.syncEventer && this.syncEventer.emitEvent(event, capture);
|
|
4889
|
+
}
|
|
4890
|
+
emitEvent(event, capture) {
|
|
4891
|
+
event.current = this;
|
|
4892
|
+
this.emit(event.type, event, capture);
|
|
4893
|
+
}
|
|
4894
|
+
hasEvent(type, capture) {
|
|
4895
|
+
if (this.syncEventer && this.syncEventer.hasEvent(type, capture))
|
|
4896
|
+
return true;
|
|
4897
|
+
const { __bubbleMap: b, __captureMap: c } = this;
|
|
4898
|
+
const hasB = b && b[type], hasC = c && c[type];
|
|
4899
|
+
return !!(capture === undefined ? (hasB || hasC) : (capture ? hasC : hasB));
|
|
4900
|
+
}
|
|
4901
|
+
destroy() {
|
|
4902
|
+
this.__captureMap = this.__bubbleMap = this.syncEventer = null;
|
|
4903
|
+
}
|
|
4904
|
+
}
|
|
4905
|
+
function __getListenerMap(eventer, capture, create) {
|
|
4906
|
+
if (capture) {
|
|
4907
|
+
const { __captureMap: c } = eventer;
|
|
4908
|
+
if (c) {
|
|
4909
|
+
return c;
|
|
4910
|
+
}
|
|
4911
|
+
else {
|
|
4912
|
+
return create ? eventer.__captureMap = {} : empty;
|
|
4913
|
+
}
|
|
4914
|
+
}
|
|
4915
|
+
else {
|
|
4916
|
+
const { __bubbleMap: b } = eventer;
|
|
4917
|
+
if (b) {
|
|
4918
|
+
return b;
|
|
4919
|
+
}
|
|
4920
|
+
else {
|
|
4921
|
+
return create ? eventer.__bubbleMap = {} : empty;
|
|
4922
|
+
}
|
|
4923
|
+
}
|
|
4924
|
+
}
|
|
4925
|
+
|
|
4926
|
+
const { on, on_, off, off_, once, emit: emit$1, emitEvent, hasEvent, destroy } = Eventer.prototype;
|
|
4927
|
+
const LeafEventer = { on, on_, off, off_, once, emit: emit$1, emitEvent, hasEvent, destroyEventer: destroy };
|
|
4928
|
+
|
|
4883
4929
|
const { isFinite } = Number;
|
|
4884
4930
|
const debug$6 = Debug.get('setAttr');
|
|
4885
4931
|
const LeafDataProxy = {
|
|
@@ -4891,9 +4937,7 @@ const LeafDataProxy = {
|
|
|
4891
4937
|
newValue = undefined;
|
|
4892
4938
|
}
|
|
4893
4939
|
if (typeof newValue === 'object' || oldValue !== newValue) {
|
|
4894
|
-
this.
|
|
4895
|
-
if (this.__proxyData)
|
|
4896
|
-
this.setProxyAttr(name, newValue);
|
|
4940
|
+
this.__realSetAttr(name, newValue);
|
|
4897
4941
|
const { CHANGE } = PropertyEvent;
|
|
4898
4942
|
const event = new PropertyEvent(CHANGE, this, name, oldValue, newValue);
|
|
4899
4943
|
if (this.isLeafer) {
|
|
@@ -4911,12 +4955,18 @@ const LeafDataProxy = {
|
|
|
4911
4955
|
}
|
|
4912
4956
|
}
|
|
4913
4957
|
else {
|
|
4914
|
-
this.
|
|
4915
|
-
if (this.__proxyData)
|
|
4916
|
-
this.setProxyAttr(name, newValue);
|
|
4958
|
+
this.__realSetAttr(name, newValue);
|
|
4917
4959
|
return true;
|
|
4918
4960
|
}
|
|
4919
4961
|
},
|
|
4962
|
+
__realSetAttr(name, newValue) {
|
|
4963
|
+
const data = this.__;
|
|
4964
|
+
data[name] = newValue;
|
|
4965
|
+
if (this.__proxyData)
|
|
4966
|
+
this.setProxyAttr(name, newValue);
|
|
4967
|
+
if (data.normalStyle)
|
|
4968
|
+
this.lockNormalStyle || data.normalStyle[name] === undefined || (data.normalStyle[name] = newValue);
|
|
4969
|
+
},
|
|
4920
4970
|
__getAttr(name) {
|
|
4921
4971
|
if (this.__proxyData)
|
|
4922
4972
|
return this.getProxyAttr(name);
|
|
@@ -5019,6 +5069,8 @@ const LeafBounds = {
|
|
|
5019
5069
|
layout.boundsChanged = false;
|
|
5020
5070
|
},
|
|
5021
5071
|
__updateLocalBoxBounds() {
|
|
5072
|
+
if (this.__hasMotionPath)
|
|
5073
|
+
this.__updateMotionPath();
|
|
5022
5074
|
if (this.__hasAutoLayout)
|
|
5023
5075
|
this.__updateAutoLayout();
|
|
5024
5076
|
toOuterOf$1(this.__layout.boxBounds, this.__local, this.__local);
|
|
@@ -5171,7 +5223,7 @@ const BranchRender = {
|
|
|
5171
5223
|
const { LEAF, create } = IncrementId;
|
|
5172
5224
|
const { toInnerPoint, toOuterPoint, multiplyParent } = MatrixHelper;
|
|
5173
5225
|
const { toOuterOf } = BoundsHelper;
|
|
5174
|
-
const { copy: copy$3 } = PointHelper;
|
|
5226
|
+
const { copy: copy$3, move } = PointHelper;
|
|
5175
5227
|
const { moveLocal, zoomOfLocal, rotateOfLocal, skewOfLocal, moveWorld, zoomOfWorld, rotateOfWorld, skewOfWorld, transform, transformWorld, setTransform, getFlipTransform, getLocalOrigin, getRelativeWorld, drop } = LeafHelper;
|
|
5176
5228
|
let Leaf = class Leaf {
|
|
5177
5229
|
get tag() { return this.__tag; }
|
|
@@ -5198,13 +5250,16 @@ let Leaf = class Leaf {
|
|
|
5198
5250
|
get __ignoreHitWorld() { return (this.__hasMask || this.__hasEraser) && this.__.hitChildren; }
|
|
5199
5251
|
get __inLazyBounds() { const { leafer } = this; return leafer && leafer.created && leafer.lazyBounds.hit(this.__world); }
|
|
5200
5252
|
get pathInputed() { return this.__.__pathInputed; }
|
|
5201
|
-
set event(map) {
|
|
5202
|
-
event = map[key], event instanceof Array ? this.on(key, event[0], event[1]) : this.on(key, event); }
|
|
5253
|
+
set event(map) { this.on(map); }
|
|
5203
5254
|
constructor(data) {
|
|
5204
5255
|
this.innerId = create(LEAF);
|
|
5205
5256
|
this.reset(data);
|
|
5257
|
+
if (this.__bubbleMap)
|
|
5258
|
+
this.__emitLifeEvent(ChildEvent.CREATED);
|
|
5206
5259
|
}
|
|
5207
5260
|
reset(data) {
|
|
5261
|
+
if (this.leafer)
|
|
5262
|
+
this.leafer.forceRender(this.__world);
|
|
5208
5263
|
this.__world = { a: 1, b: 0, c: 0, d: 1, e: 0, f: 0, x: 0, y: 0, width: 0, height: 0, scaleX: 1, scaleY: 1 };
|
|
5209
5264
|
if (data !== null)
|
|
5210
5265
|
this.__local = { a: 1, b: 0, c: 0, d: 1, e: 0, f: 0, x: 0, y: 0, width: 0, height: 0 };
|
|
@@ -5226,12 +5281,12 @@ let Leaf = class Leaf {
|
|
|
5226
5281
|
waitParent(item, bind) {
|
|
5227
5282
|
if (bind)
|
|
5228
5283
|
item = item.bind(bind);
|
|
5229
|
-
this.parent ? item() :
|
|
5284
|
+
this.parent ? item() : this.on(ChildEvent.ADD, item, 'once');
|
|
5230
5285
|
}
|
|
5231
5286
|
waitLeafer(item, bind) {
|
|
5232
5287
|
if (bind)
|
|
5233
5288
|
item = item.bind(bind);
|
|
5234
|
-
this.leafer ? item() :
|
|
5289
|
+
this.leafer ? item() : this.on(ChildEvent.MOUNTED, item, 'once');
|
|
5235
5290
|
}
|
|
5236
5291
|
nextRender(item, bind, off) {
|
|
5237
5292
|
this.leafer ? this.leafer.nextRender(item, bind, off) : this.waitLeafer(() => this.leafer.nextRender(item, bind, off));
|
|
@@ -5240,18 +5295,21 @@ let Leaf = class Leaf {
|
|
|
5240
5295
|
this.nextRender(item, null, 'off');
|
|
5241
5296
|
}
|
|
5242
5297
|
__bindLeafer(leafer) {
|
|
5243
|
-
if (this.isLeafer)
|
|
5244
|
-
|
|
5245
|
-
leafer = this;
|
|
5246
|
-
}
|
|
5298
|
+
if (this.isLeafer && leafer !== null)
|
|
5299
|
+
leafer = this;
|
|
5247
5300
|
if (this.leafer && !leafer)
|
|
5248
5301
|
this.leafer.leafs--;
|
|
5249
5302
|
this.leafer = leafer;
|
|
5250
5303
|
if (leafer) {
|
|
5251
5304
|
leafer.leafs++;
|
|
5252
5305
|
this.__level = this.parent ? this.parent.__level + 1 : 1;
|
|
5253
|
-
if (this.
|
|
5254
|
-
|
|
5306
|
+
if (this.animation)
|
|
5307
|
+
this.__runAnimation('in');
|
|
5308
|
+
if (this.__bubbleMap)
|
|
5309
|
+
this.__emitLifeEvent(ChildEvent.MOUNTED);
|
|
5310
|
+
}
|
|
5311
|
+
else {
|
|
5312
|
+
this.__emitLifeEvent(ChildEvent.UNMOUNTED);
|
|
5255
5313
|
}
|
|
5256
5314
|
if (this.isBranch) {
|
|
5257
5315
|
const { children } = this;
|
|
@@ -5260,7 +5318,7 @@ let Leaf = class Leaf {
|
|
|
5260
5318
|
}
|
|
5261
5319
|
}
|
|
5262
5320
|
}
|
|
5263
|
-
set(_data) { }
|
|
5321
|
+
set(_data, _isTemp) { }
|
|
5264
5322
|
get(_name) { return undefined; }
|
|
5265
5323
|
setAttr(name, value) { this[name] = value; }
|
|
5266
5324
|
getAttr(name) { return this[name]; }
|
|
@@ -5285,6 +5343,7 @@ let Leaf = class Leaf {
|
|
|
5285
5343
|
findOne(_condition, _options) { return undefined; }
|
|
5286
5344
|
findId(_id) { return undefined; }
|
|
5287
5345
|
focus(_value) { }
|
|
5346
|
+
updateState() { }
|
|
5288
5347
|
updateLayout() {
|
|
5289
5348
|
this.__layout.update();
|
|
5290
5349
|
}
|
|
@@ -5392,11 +5451,24 @@ let Leaf = class Leaf {
|
|
|
5392
5451
|
if (relative)
|
|
5393
5452
|
relative.worldToInner(to ? to : inner, null, distance);
|
|
5394
5453
|
}
|
|
5454
|
+
getBoxPoint(world, relative, distance, change) {
|
|
5455
|
+
return this.getBoxPointByInner(this.getInnerPoint(world, relative, distance, change), null, null, true);
|
|
5456
|
+
}
|
|
5457
|
+
getBoxPointByInner(inner, _relative, _distance, change) {
|
|
5458
|
+
const point = change ? inner : Object.assign({}, inner), { x, y } = this.boxBounds;
|
|
5459
|
+
move(point, -x, -y);
|
|
5460
|
+
return point;
|
|
5461
|
+
}
|
|
5395
5462
|
getInnerPoint(world, relative, distance, change) {
|
|
5396
5463
|
const point = change ? world : {};
|
|
5397
5464
|
this.worldToInner(world, point, distance, relative);
|
|
5398
5465
|
return point;
|
|
5399
5466
|
}
|
|
5467
|
+
getInnerPointByBox(box, _relative, _distance, change) {
|
|
5468
|
+
const point = change ? box : Object.assign({}, box), { x, y } = this.boxBounds;
|
|
5469
|
+
move(point, x, y);
|
|
5470
|
+
return point;
|
|
5471
|
+
}
|
|
5400
5472
|
getInnerPointByLocal(local, _relative, distance, change) {
|
|
5401
5473
|
return this.getInnerPoint(local, this.parent, distance, change);
|
|
5402
5474
|
}
|
|
@@ -5408,20 +5480,23 @@ let Leaf = class Leaf {
|
|
|
5408
5480
|
getLocalPointByInner(inner, _relative, distance, change) {
|
|
5409
5481
|
return this.getWorldPoint(inner, this.parent, distance, change);
|
|
5410
5482
|
}
|
|
5483
|
+
getPagePoint(world, relative, distance, change) {
|
|
5484
|
+
const layer = this.leafer ? this.leafer.zoomLayer : this;
|
|
5485
|
+
return layer.getInnerPoint(world, relative, distance, change);
|
|
5486
|
+
}
|
|
5411
5487
|
getWorldPoint(inner, relative, distance, change) {
|
|
5412
5488
|
const point = change ? inner : {};
|
|
5413
5489
|
this.innerToWorld(inner, point, distance, relative);
|
|
5414
5490
|
return point;
|
|
5415
5491
|
}
|
|
5492
|
+
getWorldPointByBox(box, relative, distance, change) {
|
|
5493
|
+
return this.getWorldPoint(this.getInnerPointByBox(box, null, null, change), relative, distance, true);
|
|
5494
|
+
}
|
|
5416
5495
|
getWorldPointByLocal(local, relative, distance, change) {
|
|
5417
5496
|
const point = change ? local : {};
|
|
5418
5497
|
this.localToWorld(local, point, distance, relative);
|
|
5419
5498
|
return point;
|
|
5420
5499
|
}
|
|
5421
|
-
getPagePoint(world, relative, distance, change) {
|
|
5422
|
-
const layer = this.leafer ? this.leafer.zoomLayer : this;
|
|
5423
|
-
return layer.getInnerPoint(world, relative, distance, change);
|
|
5424
|
-
}
|
|
5425
5500
|
getWorldPointByPage(page, relative, distance, change) {
|
|
5426
5501
|
const layer = this.leafer ? this.leafer.zoomLayer : this;
|
|
5427
5502
|
return layer.getWorldPoint(page, relative, distance, change);
|
|
@@ -5490,6 +5565,17 @@ let Leaf = class Leaf {
|
|
|
5490
5565
|
__drawRenderPath(_canvas) { }
|
|
5491
5566
|
__updatePath() { }
|
|
5492
5567
|
__updateRenderPath() { }
|
|
5568
|
+
getMotionPathData() {
|
|
5569
|
+
return needPlugin('path');
|
|
5570
|
+
}
|
|
5571
|
+
getMotionPoint(_motionDistance) {
|
|
5572
|
+
return needPlugin('path');
|
|
5573
|
+
}
|
|
5574
|
+
getMotionTotal() {
|
|
5575
|
+
return 0;
|
|
5576
|
+
}
|
|
5577
|
+
__updateMotionPath() { }
|
|
5578
|
+
__runAnimation(_type, _complete) { }
|
|
5493
5579
|
__updateSortChildren() { }
|
|
5494
5580
|
add(_child, _index) { }
|
|
5495
5581
|
remove(_child, destroy) {
|
|
@@ -5515,6 +5601,10 @@ let Leaf = class Leaf {
|
|
|
5515
5601
|
fn = boundsType;
|
|
5516
5602
|
fn(defaultValue)(this.prototype, attrName);
|
|
5517
5603
|
}
|
|
5604
|
+
__emitLifeEvent(type) {
|
|
5605
|
+
if (this.hasEvent(type))
|
|
5606
|
+
this.emitEvent(new ChildEvent(type, this, this.parent));
|
|
5607
|
+
}
|
|
5518
5608
|
destroy() {
|
|
5519
5609
|
if (!this.destroyed) {
|
|
5520
5610
|
const { parent } = this;
|
|
@@ -5522,11 +5612,10 @@ let Leaf = class Leaf {
|
|
|
5522
5612
|
this.remove();
|
|
5523
5613
|
if (this.children)
|
|
5524
5614
|
this.removeAll(true);
|
|
5525
|
-
|
|
5526
|
-
this.emitEvent(new ChildEvent(ChildEvent.DESTROY, this, parent));
|
|
5615
|
+
this.__emitLifeEvent(ChildEvent.DESTROY);
|
|
5527
5616
|
this.__.destroy();
|
|
5528
5617
|
this.__layout.destroy();
|
|
5529
|
-
this.
|
|
5618
|
+
this.destroyEventer();
|
|
5530
5619
|
this.destroyed = true;
|
|
5531
5620
|
}
|
|
5532
5621
|
}
|
|
@@ -5592,8 +5681,8 @@ let Branch = class Branch extends Leaf {
|
|
|
5592
5681
|
this.__.__childBranchNumber = (this.__.__childBranchNumber || 0) + 1;
|
|
5593
5682
|
child.__layout.boxChanged || child.__layout.boxChange();
|
|
5594
5683
|
child.__layout.matrixChanged || child.__layout.matrixChange();
|
|
5595
|
-
if (child.
|
|
5596
|
-
|
|
5684
|
+
if (child.__bubbleMap)
|
|
5685
|
+
child.__emitLifeEvent(ChildEvent.ADD);
|
|
5597
5686
|
if (this.leafer) {
|
|
5598
5687
|
child.__bindLeafer(this.leafer);
|
|
5599
5688
|
if (this.leafer.created)
|
|
@@ -5606,16 +5695,10 @@ let Branch = class Branch extends Leaf {
|
|
|
5606
5695
|
}
|
|
5607
5696
|
remove(child, destroy) {
|
|
5608
5697
|
if (child) {
|
|
5609
|
-
|
|
5610
|
-
|
|
5611
|
-
|
|
5612
|
-
|
|
5613
|
-
this.__.__childBranchNumber = (this.__.__childBranchNumber || 1) - 1;
|
|
5614
|
-
this.__preRemove();
|
|
5615
|
-
this.__realRemoveChild(child);
|
|
5616
|
-
if (destroy)
|
|
5617
|
-
child.destroy();
|
|
5618
|
-
}
|
|
5698
|
+
if (child.animationOut)
|
|
5699
|
+
child.__runAnimation('out', () => this.__remove(child, destroy));
|
|
5700
|
+
else
|
|
5701
|
+
this.__remove(child, destroy);
|
|
5619
5702
|
}
|
|
5620
5703
|
else if (child === undefined) {
|
|
5621
5704
|
super.remove(null, destroy);
|
|
@@ -5637,6 +5720,18 @@ let Branch = class Branch extends Leaf {
|
|
|
5637
5720
|
clear() {
|
|
5638
5721
|
this.removeAll(true);
|
|
5639
5722
|
}
|
|
5723
|
+
__remove(child, destroy) {
|
|
5724
|
+
const index = this.children.indexOf(child);
|
|
5725
|
+
if (index > -1) {
|
|
5726
|
+
this.children.splice(index, 1);
|
|
5727
|
+
if (child.isBranch)
|
|
5728
|
+
this.__.__childBranchNumber = (this.__.__childBranchNumber || 1) - 1;
|
|
5729
|
+
this.__preRemove();
|
|
5730
|
+
this.__realRemoveChild(child);
|
|
5731
|
+
if (destroy)
|
|
5732
|
+
child.destroy();
|
|
5733
|
+
}
|
|
5734
|
+
}
|
|
5640
5735
|
__preRemove() {
|
|
5641
5736
|
if (this.__hasMask)
|
|
5642
5737
|
this.__updateMask();
|
|
@@ -5646,6 +5741,7 @@ let Branch = class Branch extends Leaf {
|
|
|
5646
5741
|
this.__layout.affectChildrenSort && this.__layout.childrenSortChange();
|
|
5647
5742
|
}
|
|
5648
5743
|
__realRemoveChild(child) {
|
|
5744
|
+
child.__emitLifeEvent(ChildEvent.REMOVE);
|
|
5649
5745
|
child.parent = null;
|
|
5650
5746
|
if (this.leafer) {
|
|
5651
5747
|
child.__bindLeafer(null);
|
|
@@ -5658,8 +5754,6 @@ let Branch = class Branch extends Leaf {
|
|
|
5658
5754
|
}
|
|
5659
5755
|
__emitChildEvent(type, child) {
|
|
5660
5756
|
const event = new ChildEvent(type, child, this);
|
|
5661
|
-
if (child.hasEvent(type))
|
|
5662
|
-
child.emitEvent(event);
|
|
5663
5757
|
if (this.hasEvent(type) && !this.isLeafer)
|
|
5664
5758
|
this.emitEvent(event);
|
|
5665
5759
|
this.leafer.emitEvent(event);
|
|
@@ -5822,8 +5916,7 @@ class LeafLevelList {
|
|
|
5822
5916
|
}
|
|
5823
5917
|
}
|
|
5824
5918
|
|
|
5825
|
-
const version = "1.0.
|
|
5826
|
-
const inviteCode = {};
|
|
5919
|
+
const version = "1.0.4";
|
|
5827
5920
|
|
|
5828
5921
|
const debug$5 = Debug.get('LeaferCanvas');
|
|
5829
5922
|
class LeaferCanvas extends LeaferCanvasBase {
|
|
@@ -6223,9 +6316,13 @@ function updateBounds(boundsList) {
|
|
|
6223
6316
|
});
|
|
6224
6317
|
}
|
|
6225
6318
|
function updateChange(updateList) {
|
|
6319
|
+
let layout;
|
|
6226
6320
|
updateList.list.forEach(leaf => {
|
|
6227
|
-
|
|
6321
|
+
layout = leaf.__layout;
|
|
6322
|
+
if (layout.opacityChanged)
|
|
6228
6323
|
updateAllWorldOpacity(leaf);
|
|
6324
|
+
if (layout.stateStyleChanged)
|
|
6325
|
+
setTimeout(() => layout.stateStyleChanged && leaf.updateState());
|
|
6229
6326
|
leaf.__updateChange();
|
|
6230
6327
|
});
|
|
6231
6328
|
}
|
|
@@ -6591,7 +6688,6 @@ class Renderer {
|
|
|
6591
6688
|
Platform.requestRender(() => {
|
|
6592
6689
|
this.FPS = Math.min(60, Math.ceil(1000 / (Date.now() - startTime)));
|
|
6593
6690
|
if (this.running) {
|
|
6594
|
-
this.target.emit(AnimateEvent.FRAME);
|
|
6595
6691
|
if (this.changed && this.canvas.view)
|
|
6596
6692
|
this.render();
|
|
6597
6693
|
this.target.emit(RenderEvent.NEXT);
|
|
@@ -6665,36 +6761,6 @@ Object.assign(Creator, {
|
|
|
6665
6761
|
});
|
|
6666
6762
|
Platform.layout = Layouter.fullLayout;
|
|
6667
6763
|
|
|
6668
|
-
const TextConvert = {};
|
|
6669
|
-
const ColorConvert = {};
|
|
6670
|
-
const PathArrow = {};
|
|
6671
|
-
const Paint = {};
|
|
6672
|
-
const PaintImage = {};
|
|
6673
|
-
const PaintGradient = {};
|
|
6674
|
-
const Effect = {};
|
|
6675
|
-
const Export = {};
|
|
6676
|
-
const State = {};
|
|
6677
|
-
|
|
6678
|
-
function stateType(defaultValue) {
|
|
6679
|
-
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
6680
|
-
set(value) {
|
|
6681
|
-
this.__setAttr(key, value);
|
|
6682
|
-
this.waitLeafer(() => { if (State.setStyle)
|
|
6683
|
-
State.setStyle(this, key + 'Style', value); });
|
|
6684
|
-
}
|
|
6685
|
-
}));
|
|
6686
|
-
}
|
|
6687
|
-
function arrowType(defaultValue) {
|
|
6688
|
-
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
6689
|
-
set(value) {
|
|
6690
|
-
if (this.__setAttr(key, value)) {
|
|
6691
|
-
const data = this.__;
|
|
6692
|
-
data.__useArrow = data.startArrow !== 'none' || data.endArrow !== 'none';
|
|
6693
|
-
doStrokeType(this);
|
|
6694
|
-
}
|
|
6695
|
-
}
|
|
6696
|
-
}));
|
|
6697
|
-
}
|
|
6698
6764
|
function effectType(defaultValue) {
|
|
6699
6765
|
return decorateLeafAttr(defaultValue, (key) => attr({
|
|
6700
6766
|
set(value) {
|
|
@@ -6729,10 +6795,33 @@ function zoomLayerType() {
|
|
|
6729
6795
|
};
|
|
6730
6796
|
}
|
|
6731
6797
|
|
|
6798
|
+
const TextConvert = {};
|
|
6799
|
+
const ColorConvert = {};
|
|
6800
|
+
const PathArrow = {};
|
|
6801
|
+
const Paint = {};
|
|
6802
|
+
const PaintImage = {};
|
|
6803
|
+
const PaintGradient = {};
|
|
6804
|
+
const Effect = {};
|
|
6805
|
+
const Export = {};
|
|
6806
|
+
const State = {
|
|
6807
|
+
setStyleName(_leaf, _styleName, _value) { return needPlugin('state'); },
|
|
6808
|
+
set(_leaf, _stateName) { return needPlugin('state'); }
|
|
6809
|
+
};
|
|
6810
|
+
const Transition = {
|
|
6811
|
+
list: {},
|
|
6812
|
+
register(attrName, fn) {
|
|
6813
|
+
Transition.list[attrName] = fn;
|
|
6814
|
+
},
|
|
6815
|
+
get(attrName) {
|
|
6816
|
+
return Transition.list[attrName];
|
|
6817
|
+
}
|
|
6818
|
+
};
|
|
6819
|
+
|
|
6732
6820
|
const { parse } = PathConvert;
|
|
6733
6821
|
const emptyPaint = {};
|
|
6734
6822
|
const debug$2 = Debug.get('UIData');
|
|
6735
6823
|
class UIData extends LeafData {
|
|
6824
|
+
get scale() { const { scaleX, scaleY } = this; return scaleX !== scaleY ? { x: scaleX, y: scaleY } : scaleX; }
|
|
6736
6825
|
get __strokeWidth() {
|
|
6737
6826
|
const { strokeWidth, strokeWidthFixed } = this;
|
|
6738
6827
|
if (strokeWidthFixed) {
|
|
@@ -6751,9 +6840,10 @@ class UIData extends LeafData {
|
|
|
6751
6840
|
get __autoSide() { return !this._width || !this._height; }
|
|
6752
6841
|
get __autoSize() { return !this._width && !this._height; }
|
|
6753
6842
|
setVisible(value) {
|
|
6754
|
-
if (this.__leaf.leafer)
|
|
6755
|
-
this.__leaf.leafer.watcher.hasVisible = true;
|
|
6756
6843
|
this._visible = value;
|
|
6844
|
+
const { leafer } = this.__leaf;
|
|
6845
|
+
if (leafer)
|
|
6846
|
+
leafer.watcher.hasVisible = true;
|
|
6757
6847
|
}
|
|
6758
6848
|
setWidth(value) {
|
|
6759
6849
|
if (value < 0) {
|
|
@@ -6944,7 +7034,7 @@ class ImageData extends RectData {
|
|
|
6944
7034
|
__setImageFill(value) {
|
|
6945
7035
|
if (this.__leaf.image)
|
|
6946
7036
|
this.__leaf.image = null;
|
|
6947
|
-
this.fill = value ? { type: 'image', mode: '
|
|
7037
|
+
this.fill = value ? { type: 'image', mode: 'stretch', url: value } : undefined;
|
|
6948
7038
|
}
|
|
6949
7039
|
__getData() {
|
|
6950
7040
|
const data = super.__getData();
|
|
@@ -7134,19 +7224,8 @@ var UI_1;
|
|
|
7134
7224
|
let UI = UI_1 = class UI extends Leaf {
|
|
7135
7225
|
get app() { return this.leafer && this.leafer.app; }
|
|
7136
7226
|
get isFrame() { return false; }
|
|
7137
|
-
set scale(value) {
|
|
7138
|
-
|
|
7139
|
-
this.scaleX = this.scaleY = value;
|
|
7140
|
-
}
|
|
7141
|
-
else {
|
|
7142
|
-
this.scaleX = value.x;
|
|
7143
|
-
this.scaleY = value.y;
|
|
7144
|
-
}
|
|
7145
|
-
}
|
|
7146
|
-
get scale() {
|
|
7147
|
-
const { scaleX, scaleY } = this;
|
|
7148
|
-
return scaleX !== scaleY ? { x: scaleX, y: scaleY } : scaleX;
|
|
7149
|
-
}
|
|
7227
|
+
set scale(value) { MathHelper.assignScale(this, value); }
|
|
7228
|
+
get scale() { return this.__.scale; }
|
|
7150
7229
|
get pen() {
|
|
7151
7230
|
const { path } = this.__;
|
|
7152
7231
|
pen.set(this.path = path || []);
|
|
@@ -7161,8 +7240,15 @@ let UI = UI_1 = class UI extends Leaf {
|
|
|
7161
7240
|
super(data);
|
|
7162
7241
|
}
|
|
7163
7242
|
reset(_data) { }
|
|
7164
|
-
set(data) {
|
|
7165
|
-
|
|
7243
|
+
set(data, isTemp) {
|
|
7244
|
+
if (isTemp) {
|
|
7245
|
+
this.lockNormalStyle = true;
|
|
7246
|
+
Object.assign(this, data);
|
|
7247
|
+
this.lockNormalStyle = false;
|
|
7248
|
+
}
|
|
7249
|
+
else {
|
|
7250
|
+
Object.assign(this, data);
|
|
7251
|
+
}
|
|
7166
7252
|
}
|
|
7167
7253
|
get(name) {
|
|
7168
7254
|
return typeof name === 'string' ? this.__.__getInput(name) : this.__.__getInputData(name);
|
|
@@ -7225,11 +7311,18 @@ let UI = UI_1 = class UI extends Leaf {
|
|
|
7225
7311
|
drawer.rect(x, y, width, height);
|
|
7226
7312
|
}
|
|
7227
7313
|
}
|
|
7314
|
+
animate(_keyframe, _options, _type, _isTemp) {
|
|
7315
|
+
return needPlugin('animate');
|
|
7316
|
+
}
|
|
7317
|
+
killAnimate(_type) { }
|
|
7228
7318
|
export(filename, options) {
|
|
7229
7319
|
return Export.export(this, filename, options);
|
|
7230
7320
|
}
|
|
7231
|
-
clone() {
|
|
7232
|
-
|
|
7321
|
+
clone(data) {
|
|
7322
|
+
const json = this.toJSON();
|
|
7323
|
+
if (data)
|
|
7324
|
+
Object.assign(json, data);
|
|
7325
|
+
return UI_1.one(json);
|
|
7233
7326
|
}
|
|
7234
7327
|
static one(data, x, y, width, height) {
|
|
7235
7328
|
return UICreator.get(data.tag || this.prototype.__tag, data, x, y, width, height);
|
|
@@ -7245,6 +7338,8 @@ let UI = UI_1 = class UI extends Leaf {
|
|
|
7245
7338
|
static setEditInner(_editorName) { }
|
|
7246
7339
|
destroy() {
|
|
7247
7340
|
this.fill = this.stroke = null;
|
|
7341
|
+
if (this.__animate)
|
|
7342
|
+
this.killAnimate();
|
|
7248
7343
|
super.destroy();
|
|
7249
7344
|
}
|
|
7250
7345
|
};
|
|
@@ -7272,12 +7367,6 @@ __decorate([
|
|
|
7272
7367
|
__decorate([
|
|
7273
7368
|
visibleType(true)
|
|
7274
7369
|
], UI.prototype, "visible", void 0);
|
|
7275
|
-
__decorate([
|
|
7276
|
-
stateType(false)
|
|
7277
|
-
], UI.prototype, "selected", void 0);
|
|
7278
|
-
__decorate([
|
|
7279
|
-
stateType(false)
|
|
7280
|
-
], UI.prototype, "disabled", void 0);
|
|
7281
7370
|
__decorate([
|
|
7282
7371
|
surfaceType(false)
|
|
7283
7372
|
], UI.prototype, "locked", void 0);
|
|
@@ -7350,45 +7439,9 @@ __decorate([
|
|
|
7350
7439
|
__decorate([
|
|
7351
7440
|
pathType(true)
|
|
7352
7441
|
], UI.prototype, "closed", void 0);
|
|
7353
|
-
__decorate([
|
|
7354
|
-
autoLayoutType(false)
|
|
7355
|
-
], UI.prototype, "flow", void 0);
|
|
7356
7442
|
__decorate([
|
|
7357
7443
|
boundsType(0)
|
|
7358
7444
|
], UI.prototype, "padding", void 0);
|
|
7359
|
-
__decorate([
|
|
7360
|
-
boundsType(0)
|
|
7361
|
-
], UI.prototype, "gap", void 0);
|
|
7362
|
-
__decorate([
|
|
7363
|
-
boundsType('top-left')
|
|
7364
|
-
], UI.prototype, "flowAlign", void 0);
|
|
7365
|
-
__decorate([
|
|
7366
|
-
boundsType(false)
|
|
7367
|
-
], UI.prototype, "flowWrap", void 0);
|
|
7368
|
-
__decorate([
|
|
7369
|
-
boundsType('box')
|
|
7370
|
-
], UI.prototype, "itemBox", void 0);
|
|
7371
|
-
__decorate([
|
|
7372
|
-
boundsType(true)
|
|
7373
|
-
], UI.prototype, "inFlow", void 0);
|
|
7374
|
-
__decorate([
|
|
7375
|
-
boundsType()
|
|
7376
|
-
], UI.prototype, "autoWidth", void 0);
|
|
7377
|
-
__decorate([
|
|
7378
|
-
boundsType()
|
|
7379
|
-
], UI.prototype, "autoHeight", void 0);
|
|
7380
|
-
__decorate([
|
|
7381
|
-
boundsType()
|
|
7382
|
-
], UI.prototype, "lockRatio", void 0);
|
|
7383
|
-
__decorate([
|
|
7384
|
-
boundsType()
|
|
7385
|
-
], UI.prototype, "autoBox", void 0);
|
|
7386
|
-
__decorate([
|
|
7387
|
-
boundsType()
|
|
7388
|
-
], UI.prototype, "widthRange", void 0);
|
|
7389
|
-
__decorate([
|
|
7390
|
-
boundsType()
|
|
7391
|
-
], UI.prototype, "heightRange", void 0);
|
|
7392
7445
|
__decorate([
|
|
7393
7446
|
dataType(false)
|
|
7394
7447
|
], UI.prototype, "draggable", void 0);
|
|
@@ -7452,12 +7505,6 @@ __decorate([
|
|
|
7452
7505
|
__decorate([
|
|
7453
7506
|
strokeType(10)
|
|
7454
7507
|
], UI.prototype, "miterLimit", void 0);
|
|
7455
|
-
__decorate([
|
|
7456
|
-
arrowType('none')
|
|
7457
|
-
], UI.prototype, "startArrow", void 0);
|
|
7458
|
-
__decorate([
|
|
7459
|
-
arrowType('none')
|
|
7460
|
-
], UI.prototype, "endArrow", void 0);
|
|
7461
7508
|
__decorate([
|
|
7462
7509
|
pathType(0)
|
|
7463
7510
|
], UI.prototype, "cornerRadius", void 0);
|
|
@@ -7479,24 +7526,6 @@ __decorate([
|
|
|
7479
7526
|
__decorate([
|
|
7480
7527
|
effectType()
|
|
7481
7528
|
], UI.prototype, "grayscale", void 0);
|
|
7482
|
-
__decorate([
|
|
7483
|
-
dataType()
|
|
7484
|
-
], UI.prototype, "normalStyle", void 0);
|
|
7485
|
-
__decorate([
|
|
7486
|
-
dataType()
|
|
7487
|
-
], UI.prototype, "hoverStyle", void 0);
|
|
7488
|
-
__decorate([
|
|
7489
|
-
dataType()
|
|
7490
|
-
], UI.prototype, "pressStyle", void 0);
|
|
7491
|
-
__decorate([
|
|
7492
|
-
dataType()
|
|
7493
|
-
], UI.prototype, "focusStyle", void 0);
|
|
7494
|
-
__decorate([
|
|
7495
|
-
dataType()
|
|
7496
|
-
], UI.prototype, "selectedStyle", void 0);
|
|
7497
|
-
__decorate([
|
|
7498
|
-
dataType()
|
|
7499
|
-
], UI.prototype, "disabledStyle", void 0);
|
|
7500
7529
|
__decorate([
|
|
7501
7530
|
dataType({})
|
|
7502
7531
|
], UI.prototype, "data", void 0);
|
|
@@ -7523,7 +7552,7 @@ let Group = class Group extends UI {
|
|
|
7523
7552
|
if (!this.children)
|
|
7524
7553
|
this.children = [];
|
|
7525
7554
|
}
|
|
7526
|
-
set(data) {
|
|
7555
|
+
set(data, isTemp) {
|
|
7527
7556
|
if (data.children) {
|
|
7528
7557
|
const { children } = data;
|
|
7529
7558
|
delete data.children;
|
|
@@ -7533,7 +7562,7 @@ let Group = class Group extends UI {
|
|
|
7533
7562
|
else {
|
|
7534
7563
|
this.clear();
|
|
7535
7564
|
}
|
|
7536
|
-
super.set(data);
|
|
7565
|
+
super.set(data, isTemp);
|
|
7537
7566
|
let child;
|
|
7538
7567
|
children.forEach(childData => {
|
|
7539
7568
|
child = childData.__ ? childData : UICreator.get(childData.tag, childData);
|
|
@@ -7542,7 +7571,7 @@ let Group = class Group extends UI {
|
|
|
7542
7571
|
data.children = children;
|
|
7543
7572
|
}
|
|
7544
7573
|
else {
|
|
7545
|
-
super.set(data);
|
|
7574
|
+
super.set(data, isTemp);
|
|
7546
7575
|
}
|
|
7547
7576
|
}
|
|
7548
7577
|
toJSON(options) {
|
|
@@ -7869,7 +7898,7 @@ let Leafer = Leafer_1 = class Leafer extends Group {
|
|
|
7869
7898
|
}
|
|
7870
7899
|
}
|
|
7871
7900
|
zoom(_zoomType, _padding, _fixedScale) {
|
|
7872
|
-
return
|
|
7901
|
+
return needPlugin('view');
|
|
7873
7902
|
}
|
|
7874
7903
|
getValidMove(moveX, moveY) { return { x: moveX, y: moveY }; }
|
|
7875
7904
|
getValidScale(changeScale) { return changeScale; }
|
|
@@ -8392,19 +8421,18 @@ let Canvas = class Canvas extends Rect {
|
|
|
8392
8421
|
this.paint();
|
|
8393
8422
|
}
|
|
8394
8423
|
paint() {
|
|
8395
|
-
this.
|
|
8424
|
+
this.forceRender();
|
|
8396
8425
|
}
|
|
8397
8426
|
__drawAfterFill(canvas, _options) {
|
|
8398
|
-
const
|
|
8399
|
-
|
|
8400
|
-
if (this.__.cornerRadius || this.pathInputed) {
|
|
8427
|
+
const { width, height, cornerRadius } = this.__, { view } = this.canvas;
|
|
8428
|
+
if (cornerRadius || this.pathInputed) {
|
|
8401
8429
|
canvas.save();
|
|
8402
8430
|
canvas.clip();
|
|
8403
|
-
canvas.drawImage(
|
|
8431
|
+
canvas.drawImage(view, 0, 0, view.width, view.height, 0, 0, width, height);
|
|
8404
8432
|
canvas.restore();
|
|
8405
8433
|
}
|
|
8406
8434
|
else {
|
|
8407
|
-
canvas.drawImage(
|
|
8435
|
+
canvas.drawImage(view, 0, 0, view.width, view.height, 0, 0, width, height);
|
|
8408
8436
|
}
|
|
8409
8437
|
}
|
|
8410
8438
|
__updateSize() {
|
|
@@ -9043,6 +9071,8 @@ function getPatternData(paint, box, image) {
|
|
|
9043
9071
|
let { width, height } = image;
|
|
9044
9072
|
if (paint.padding)
|
|
9045
9073
|
box = tempBox.set(box).shrink(paint.padding);
|
|
9074
|
+
if (paint.mode === 'strench')
|
|
9075
|
+
paint.mode = 'stretch';
|
|
9046
9076
|
const { opacity, mode, align, offset, scale, size, rotation, repeat } = paint;
|
|
9047
9077
|
const sameBox = box.width === width && box.height === height;
|
|
9048
9078
|
const data = { mode };
|
|
@@ -9071,7 +9101,7 @@ function getPatternData(paint, box, image) {
|
|
|
9071
9101
|
if (offset)
|
|
9072
9102
|
x += offset.x, y += offset.y;
|
|
9073
9103
|
switch (mode) {
|
|
9074
|
-
case '
|
|
9104
|
+
case 'stretch':
|
|
9075
9105
|
if (!sameBox)
|
|
9076
9106
|
width = box.width, height = box.height;
|
|
9077
9107
|
break;
|
|
@@ -9098,7 +9128,7 @@ function getPatternData(paint, box, image) {
|
|
|
9098
9128
|
translate(data.transform, box.x, box.y);
|
|
9099
9129
|
}
|
|
9100
9130
|
}
|
|
9101
|
-
if (scaleX && mode !== '
|
|
9131
|
+
if (scaleX && mode !== 'stretch') {
|
|
9102
9132
|
data.scaleX = scaleX;
|
|
9103
9133
|
data.scaleY = scaleY;
|
|
9104
9134
|
}
|
|
@@ -9202,7 +9232,7 @@ const { get: get$1, scale, copy: copy$1 } = MatrixHelper;
|
|
|
9202
9232
|
const { ceil, abs: abs$1 } = Math;
|
|
9203
9233
|
function createPattern(ui, paint, pixelRatio) {
|
|
9204
9234
|
let { scaleX, scaleY } = ImageManager.patternLocked ? ui.__world : ui.__nowWorld;
|
|
9205
|
-
const id = scaleX + '-' + scaleY;
|
|
9235
|
+
const id = scaleX + '-' + scaleY + '-' + pixelRatio;
|
|
9206
9236
|
if (paint.patternId !== id && !ui.destroyed) {
|
|
9207
9237
|
scaleX = abs$1(scaleX);
|
|
9208
9238
|
scaleY = abs$1(scaleY);
|
|
@@ -9264,7 +9294,8 @@ function createPattern(ui, paint, pixelRatio) {
|
|
|
9264
9294
|
const { abs } = Math;
|
|
9265
9295
|
function checkImage(ui, canvas, paint, allowPaint) {
|
|
9266
9296
|
const { scaleX, scaleY } = ImageManager.patternLocked ? ui.__world : ui.__nowWorld;
|
|
9267
|
-
|
|
9297
|
+
const { pixelRatio } = canvas;
|
|
9298
|
+
if (!paint.data || (paint.patternId === scaleX + '-' + scaleY + '-' + pixelRatio && !Export.running)) {
|
|
9268
9299
|
return false;
|
|
9269
9300
|
}
|
|
9270
9301
|
else {
|
|
@@ -9272,8 +9303,8 @@ function checkImage(ui, canvas, paint, allowPaint) {
|
|
|
9272
9303
|
if (allowPaint) {
|
|
9273
9304
|
if (!data.repeat) {
|
|
9274
9305
|
let { width, height } = data;
|
|
9275
|
-
width *= abs(scaleX) *
|
|
9276
|
-
height *= abs(scaleY) *
|
|
9306
|
+
width *= abs(scaleX) * pixelRatio;
|
|
9307
|
+
height *= abs(scaleY) * pixelRatio;
|
|
9277
9308
|
if (data.scaleX) {
|
|
9278
9309
|
width *= data.scaleX;
|
|
9279
9310
|
height *= data.scaleY;
|
|
@@ -9299,14 +9330,14 @@ function checkImage(ui, canvas, paint, allowPaint) {
|
|
|
9299
9330
|
}
|
|
9300
9331
|
else {
|
|
9301
9332
|
if (!paint.style || paint.sync || Export.running) {
|
|
9302
|
-
createPattern(ui, paint,
|
|
9333
|
+
createPattern(ui, paint, pixelRatio);
|
|
9303
9334
|
}
|
|
9304
9335
|
else {
|
|
9305
9336
|
if (!paint.patternTask) {
|
|
9306
9337
|
paint.patternTask = ImageManager.patternTasker.add(() => __awaiter(this, void 0, void 0, function* () {
|
|
9307
9338
|
paint.patternTask = null;
|
|
9308
9339
|
if (canvas.bounds.hit(ui.__nowWorld))
|
|
9309
|
-
createPattern(ui, paint,
|
|
9340
|
+
createPattern(ui, paint, pixelRatio);
|
|
9310
9341
|
ui.forceUpdate('surface');
|
|
9311
9342
|
}), 300);
|
|
9312
9343
|
}
|
|
@@ -9370,14 +9401,16 @@ function linearGradient(paint, box) {
|
|
|
9370
9401
|
return data;
|
|
9371
9402
|
}
|
|
9372
9403
|
function applyStops(gradient, stops, opacity) {
|
|
9373
|
-
|
|
9374
|
-
|
|
9375
|
-
|
|
9376
|
-
|
|
9377
|
-
|
|
9378
|
-
|
|
9379
|
-
|
|
9380
|
-
|
|
9404
|
+
if (stops) {
|
|
9405
|
+
let stop;
|
|
9406
|
+
for (let i = 0, len = stops.length; i < len; i++) {
|
|
9407
|
+
stop = stops[i];
|
|
9408
|
+
if (typeof stop === 'string') {
|
|
9409
|
+
gradient.addColorStop(i / (len - 1), ColorConvert.string(stop, opacity));
|
|
9410
|
+
}
|
|
9411
|
+
else {
|
|
9412
|
+
gradient.addColorStop(stop.offset, ColorConvert.string(stop.color, opacity));
|
|
9413
|
+
}
|
|
9381
9414
|
}
|
|
9382
9415
|
}
|
|
9383
9416
|
}
|
|
@@ -10133,10 +10166,15 @@ const TextConvertModule = {
|
|
|
10133
10166
|
};
|
|
10134
10167
|
|
|
10135
10168
|
function string(color, opacity) {
|
|
10136
|
-
|
|
10137
|
-
|
|
10169
|
+
const doOpacity = typeof opacity === 'number' && opacity !== 1;
|
|
10170
|
+
if (typeof color === 'string') {
|
|
10171
|
+
if (doOpacity && ColorConvert.object)
|
|
10172
|
+
color = ColorConvert.object(color);
|
|
10173
|
+
else
|
|
10174
|
+
return color;
|
|
10175
|
+
}
|
|
10138
10176
|
let a = color.a === undefined ? 1 : color.a;
|
|
10139
|
-
if (
|
|
10177
|
+
if (doOpacity)
|
|
10140
10178
|
a *= opacity;
|
|
10141
10179
|
const rgb = color.r + ',' + color.g + ',' + color.b;
|
|
10142
10180
|
return a === 1 ? 'rgb(' + rgb + ')' : 'rgba(' + rgb + ',' + a + ')';
|
|
@@ -10343,4 +10381,4 @@ Object.assign(Export, ExportModule);
|
|
|
10343
10381
|
|
|
10344
10382
|
useCanvas();
|
|
10345
10383
|
|
|
10346
|
-
export { AlignHelper,
|
|
10384
|
+
export { AlignHelper, Answer, AroundHelper, AutoBounds, BezierHelper, Bounds, BoundsHelper, Box, BoxData, Branch, BranchHelper, BranchRender, Canvas, CanvasData, CanvasManager, ChildEvent, ColorConvert, Creator, DataHelper, Debug, Direction4, Direction9, Effect, Ellipse, EllipseData, EllipseHelper, Event, EventCreator, Eventer, Export, FileHelper, Frame, FrameData, Group, GroupData, Image$1 as Image, ImageData, ImageEvent, ImageManager, IncrementId, LayoutEvent, Layouter, Leaf, LeafBounds, LeafBoundsHelper, LeafData, LeafDataProxy, LeafEventer, LeafHelper, LeafLayout, LeafLevelList, LeafList, LeafMatrix, LeafRender, Leafer, LeaferCanvas, LeaferCanvasBase, LeaferData, LeaferEvent, LeaferImage, Line, LineData, MathHelper, Matrix, MatrixHelper, MyImage, 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, Polygon, PolygonData, PropertyEvent, Rect, RectData, RectHelper, RectRender, RenderEvent, Renderer, ResizeEvent, Run, Star, StarData, State, StringNumberMap, TaskItem, TaskProcessor, Text, TextConvert, TextData, Transition, TwoPointBoundsHelper, UI, UIBounds, UICreator, UIData, UIRender, UnitConvert, WaitHelper, WatchEvent, Watcher, affectRenderBoundsType, affectStrokeBoundsType, attr, autoLayoutType, boundsType, canvasPatch, canvasSizeAttrs, cursorType, dataProcessor, dataType, decorateLeafAttr, defineDataProcessor, defineKey, defineLeafAttr, doBoundsType, doStrokeType, effectType, emptyData, eraserType, getBoundsData, getDescriptor, getMatrixData, getPointData, hitType, isNull, layoutProcessor, maskType, naturalBoundsType, needPlugin, opacityType, pathInputType, pathType, pen, positionType, registerUI, registerUIEvent, resizeType, rewrite, rewriteAble, rotationType, scaleType, sortType, strokeType, surfaceType, tempBounds$1 as tempBounds, tempMatrix, tempPoint$3 as tempPoint, useCanvas, useModule, version, visibleType, zoomLayerType };
|