leafer-draw 1.2.2 → 1.3.0
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 +15 -200
- package/dist/web.esm.js +16 -201
- package/dist/web.esm.min.js +1 -1
- package/dist/web.js +107 -286
- package/dist/web.min.cjs +1 -1
- package/dist/web.min.js +1 -1
- package/dist/web.module.js +107 -286
- package/dist/web.module.min.js +1 -1
- package/package.json +2 -2
package/dist/web.module.js
CHANGED
|
@@ -765,8 +765,8 @@ const TwoPointBoundsHelper = {
|
|
|
765
765
|
t.maxY = y > t.maxY ? y : t.maxY;
|
|
766
766
|
},
|
|
767
767
|
addBounds(t, x, y, width, height) {
|
|
768
|
-
addPoint$
|
|
769
|
-
addPoint$
|
|
768
|
+
addPoint$3(t, x, y);
|
|
769
|
+
addPoint$3(t, x + width, y + height);
|
|
770
770
|
},
|
|
771
771
|
copy(t, pb) {
|
|
772
772
|
t.minX = pb.minX;
|
|
@@ -787,9 +787,9 @@ const TwoPointBoundsHelper = {
|
|
|
787
787
|
setBounds.height = t.maxY - t.minY;
|
|
788
788
|
}
|
|
789
789
|
};
|
|
790
|
-
const { addPoint: addPoint$
|
|
790
|
+
const { addPoint: addPoint$3 } = TwoPointBoundsHelper;
|
|
791
791
|
|
|
792
|
-
const { tempPointBounds: tempPointBounds$1, setPoint: setPoint$
|
|
792
|
+
const { tempPointBounds: tempPointBounds$1, setPoint: setPoint$2, addPoint: addPoint$2, toBounds: toBounds$3 } = TwoPointBoundsHelper;
|
|
793
793
|
const { toOuterPoint: toOuterPoint$2 } = MatrixHelper;
|
|
794
794
|
const { float, fourNumber } = MathHelper;
|
|
795
795
|
const { floor, ceil: ceil$2 } = Math;
|
|
@@ -905,17 +905,17 @@ const BoundsHelper = {
|
|
|
905
905
|
point.x = t.x;
|
|
906
906
|
point.y = t.y;
|
|
907
907
|
toOuterPoint$2(matrix, point, toPoint$5);
|
|
908
|
-
setPoint$
|
|
908
|
+
setPoint$2(tempPointBounds$1, toPoint$5.x, toPoint$5.y);
|
|
909
909
|
point.x = t.x + t.width;
|
|
910
910
|
toOuterPoint$2(matrix, point, toPoint$5);
|
|
911
|
-
addPoint$
|
|
911
|
+
addPoint$2(tempPointBounds$1, toPoint$5.x, toPoint$5.y);
|
|
912
912
|
point.y = t.y + t.height;
|
|
913
913
|
toOuterPoint$2(matrix, point, toPoint$5);
|
|
914
|
-
addPoint$
|
|
914
|
+
addPoint$2(tempPointBounds$1, toPoint$5.x, toPoint$5.y);
|
|
915
915
|
point.x = t.x;
|
|
916
916
|
toOuterPoint$2(matrix, point, toPoint$5);
|
|
917
|
-
addPoint$
|
|
918
|
-
toBounds$
|
|
917
|
+
addPoint$2(tempPointBounds$1, toPoint$5.x, toPoint$5.y);
|
|
918
|
+
toBounds$3(tempPointBounds$1, to);
|
|
919
919
|
}
|
|
920
920
|
},
|
|
921
921
|
toInnerOf(t, matrix, to) {
|
|
@@ -1005,8 +1005,8 @@ const BoundsHelper = {
|
|
|
1005
1005
|
B.reset(t);
|
|
1006
1006
|
},
|
|
1007
1007
|
setPoints(t, points) {
|
|
1008
|
-
points.forEach((point, index) => index === 0 ? setPoint$
|
|
1009
|
-
toBounds$
|
|
1008
|
+
points.forEach((point, index) => index === 0 ? setPoint$2(tempPointBounds$1, point.x, point.y) : addPoint$2(tempPointBounds$1, point.x, point.y));
|
|
1009
|
+
toBounds$3(tempPointBounds$1, t);
|
|
1010
1010
|
},
|
|
1011
1011
|
setPoint(t, point) {
|
|
1012
1012
|
B.set(t, point.x, point.y);
|
|
@@ -1374,7 +1374,7 @@ function getNameList(name) {
|
|
|
1374
1374
|
}
|
|
1375
1375
|
const D$4 = Debug;
|
|
1376
1376
|
|
|
1377
|
-
const debug$
|
|
1377
|
+
const debug$e = Debug.get('RunTime');
|
|
1378
1378
|
const Run = {
|
|
1379
1379
|
currentId: 0,
|
|
1380
1380
|
currentName: '',
|
|
@@ -1392,7 +1392,7 @@ const Run = {
|
|
|
1392
1392
|
const time = R.idMap[id], name = R.nameMap[id];
|
|
1393
1393
|
const duration = microsecond ? (performance.now() - time) / 1000 : Date.now() - time;
|
|
1394
1394
|
R.idMap[id] = R.nameMap[id] = R.nameToIdMap[name] = undefined;
|
|
1395
|
-
debug$
|
|
1395
|
+
debug$e.log(name, duration, 'ms');
|
|
1396
1396
|
},
|
|
1397
1397
|
endOfName(name, microsecond) {
|
|
1398
1398
|
const id = R.nameToIdMap[name];
|
|
@@ -1402,34 +1402,37 @@ const Run = {
|
|
|
1402
1402
|
};
|
|
1403
1403
|
const R = Run;
|
|
1404
1404
|
|
|
1405
|
+
const check = [];
|
|
1405
1406
|
const Plugin = {
|
|
1406
1407
|
list: {},
|
|
1407
|
-
add(name) {
|
|
1408
|
+
add(name, ...needPlugins) {
|
|
1408
1409
|
this.list[name] = true;
|
|
1410
|
+
check.push(...needPlugins);
|
|
1409
1411
|
},
|
|
1410
|
-
|
|
1412
|
+
has(name, tip) {
|
|
1411
1413
|
const rs = this.list[name];
|
|
1412
1414
|
if (!rs && tip)
|
|
1413
1415
|
this.need(name);
|
|
1414
1416
|
return rs;
|
|
1415
1417
|
},
|
|
1416
1418
|
need(name) {
|
|
1417
|
-
console.error('need plugin: @leafer-in/' + name);
|
|
1419
|
+
console.error('need plugin: ' + (name.includes('-x') ? '' : '@leafer-in/') + name);
|
|
1418
1420
|
}
|
|
1419
1421
|
};
|
|
1422
|
+
setTimeout(() => check.forEach(name => Plugin.has(name, true)));
|
|
1420
1423
|
|
|
1421
|
-
const debug$
|
|
1424
|
+
const debug$d = Debug.get('UICreator');
|
|
1422
1425
|
const UICreator = {
|
|
1423
1426
|
list: {},
|
|
1424
1427
|
register(UI) {
|
|
1425
1428
|
const { __tag: tag } = UI.prototype;
|
|
1426
1429
|
if (list$1[tag])
|
|
1427
|
-
debug$
|
|
1430
|
+
debug$d.repeat(tag);
|
|
1428
1431
|
list$1[tag] = UI;
|
|
1429
1432
|
},
|
|
1430
1433
|
get(tag, data, x, y, width, height) {
|
|
1431
1434
|
if (!list$1[tag])
|
|
1432
|
-
debug$
|
|
1435
|
+
debug$d.error('not register ' + tag);
|
|
1433
1436
|
const ui = new list$1[tag](data);
|
|
1434
1437
|
if (x !== undefined) {
|
|
1435
1438
|
ui.x = x;
|
|
@@ -1445,7 +1448,7 @@ const UICreator = {
|
|
|
1445
1448
|
};
|
|
1446
1449
|
const { list: list$1 } = UICreator;
|
|
1447
1450
|
|
|
1448
|
-
const debug$
|
|
1451
|
+
const debug$c = Debug.get('EventCreator');
|
|
1449
1452
|
const EventCreator = {
|
|
1450
1453
|
nameList: {},
|
|
1451
1454
|
register(Event) {
|
|
@@ -1453,7 +1456,7 @@ const EventCreator = {
|
|
|
1453
1456
|
Object.keys(Event).forEach(key => {
|
|
1454
1457
|
name = Event[key];
|
|
1455
1458
|
if (typeof name === 'string')
|
|
1456
|
-
nameList[name] && debug$
|
|
1459
|
+
nameList[name] && debug$c.repeat(name), nameList[name] = Event;
|
|
1457
1460
|
});
|
|
1458
1461
|
},
|
|
1459
1462
|
changeName(oldName, newName) {
|
|
@@ -2342,7 +2345,7 @@ const RectHelper = {
|
|
|
2342
2345
|
};
|
|
2343
2346
|
|
|
2344
2347
|
const { sin: sin$3, cos: cos$3, atan2: atan2$1, ceil: ceil$1, abs: abs$3, PI: PI$2, sqrt: sqrt$1, pow } = Math;
|
|
2345
|
-
const { setPoint: setPoint$
|
|
2348
|
+
const { setPoint: setPoint$1, addPoint: addPoint$1 } = TwoPointBoundsHelper;
|
|
2346
2349
|
const { set, toNumberPoints } = PointHelper;
|
|
2347
2350
|
const { M: M$5, L: L$6, C: C$5, Q: Q$4, Z: Z$5 } = PathCommandMap;
|
|
2348
2351
|
const tempPoint$2 = {};
|
|
@@ -2418,8 +2421,8 @@ const BezierHelper = {
|
|
|
2418
2421
|
if (data)
|
|
2419
2422
|
data.push(L$6, x1, y1);
|
|
2420
2423
|
if (setPointBounds) {
|
|
2421
|
-
setPoint$
|
|
2422
|
-
addPoint$
|
|
2424
|
+
setPoint$1(setPointBounds, fromX, fromY);
|
|
2425
|
+
addPoint$1(setPointBounds, x1, y1);
|
|
2423
2426
|
}
|
|
2424
2427
|
if (setStartPoint)
|
|
2425
2428
|
set(setStartPoint, fromX, fromY);
|
|
@@ -2471,7 +2474,7 @@ const BezierHelper = {
|
|
|
2471
2474
|
if (data)
|
|
2472
2475
|
data.push(data.length ? L$6 : M$5, fromX, fromY);
|
|
2473
2476
|
if (setPointBounds)
|
|
2474
|
-
setPoint$
|
|
2477
|
+
setPoint$1(setPointBounds, fromX, fromY);
|
|
2475
2478
|
if (setStartPoint)
|
|
2476
2479
|
set(setStartPoint, fromX, fromY);
|
|
2477
2480
|
for (let i = 0; i < parts; i++) {
|
|
@@ -2533,11 +2536,11 @@ const BezierHelper = {
|
|
|
2533
2536
|
if (0 < t2 && t2 < 1)
|
|
2534
2537
|
tList.push(t2);
|
|
2535
2538
|
}
|
|
2536
|
-
addMode ? addPoint$
|
|
2537
|
-
addPoint$
|
|
2539
|
+
addMode ? addPoint$1(pointBounds, fromX, fromY) : setPoint$1(pointBounds, fromX, fromY);
|
|
2540
|
+
addPoint$1(pointBounds, toX, toY);
|
|
2538
2541
|
for (let i = 0, len = tList.length; i < len; i++) {
|
|
2539
2542
|
getPointAndSet(tList[i], fromX, fromY, x1, y1, x2, y2, toX, toY, tempPoint$2);
|
|
2540
|
-
addPoint$
|
|
2543
|
+
addPoint$1(pointBounds, tempPoint$2.x, tempPoint$2.y);
|
|
2541
2544
|
}
|
|
2542
2545
|
},
|
|
2543
2546
|
getPointAndSet(t, fromX, fromY, x1, y1, x2, y2, toX, toY, setPoint) {
|
|
@@ -2609,7 +2612,7 @@ const EllipseHelper = {
|
|
|
2609
2612
|
const { M: M$4, m, L: L$5, l, H, h, V, v, C: C$4, c, S, s, Q: Q$3, q, T, t, A, a, Z: Z$4, z, N: N$3, D: D$3, X: X$3, G: G$3, F: F$4, O: O$3, P: P$3, U: U$3 } = PathCommandMap;
|
|
2610
2613
|
const { rect: rect$2, roundRect: roundRect$2, arcTo: arcTo$3, arc: arc$3, ellipse: ellipse$4, quadraticCurveTo: quadraticCurveTo$1 } = BezierHelper;
|
|
2611
2614
|
const { ellipticalArc } = EllipseHelper;
|
|
2612
|
-
const debug$
|
|
2615
|
+
const debug$b = Debug.get('PathConvert');
|
|
2613
2616
|
const setEndPoint$1 = {};
|
|
2614
2617
|
const PathConvert = {
|
|
2615
2618
|
current: { dot: 0 },
|
|
@@ -2850,7 +2853,7 @@ const PathConvert = {
|
|
|
2850
2853
|
i += 6;
|
|
2851
2854
|
break;
|
|
2852
2855
|
default:
|
|
2853
|
-
debug$
|
|
2856
|
+
debug$b.error(`command: ${command} [index:${i}]`, old);
|
|
2854
2857
|
return data;
|
|
2855
2858
|
}
|
|
2856
2859
|
lastCommand = command;
|
|
@@ -3075,7 +3078,7 @@ class PathCreator {
|
|
|
3075
3078
|
}
|
|
3076
3079
|
|
|
3077
3080
|
const { M: M$2, L: L$3, C: C$2, Q: Q$1, Z: Z$2, N: N$1, D: D$1, X: X$1, G: G$1, F: F$2, O: O$1, P: P$1, U: U$1 } = PathCommandMap;
|
|
3078
|
-
const debug$
|
|
3081
|
+
const debug$a = Debug.get('PathDrawer');
|
|
3079
3082
|
const PathDrawer = {
|
|
3080
3083
|
drawPathByData(drawer, data) {
|
|
3081
3084
|
if (!data)
|
|
@@ -3138,7 +3141,7 @@ const PathDrawer = {
|
|
|
3138
3141
|
i += 6;
|
|
3139
3142
|
break;
|
|
3140
3143
|
default:
|
|
3141
|
-
debug$
|
|
3144
|
+
debug$a.error(`command: ${command} [index:${i}]`, data);
|
|
3142
3145
|
return;
|
|
3143
3146
|
}
|
|
3144
3147
|
}
|
|
@@ -3147,8 +3150,8 @@ const PathDrawer = {
|
|
|
3147
3150
|
|
|
3148
3151
|
const { M: M$1, L: L$2, C: C$1, Q, Z: Z$1, N, D, X, G, F: F$1, O, P, U } = PathCommandMap;
|
|
3149
3152
|
const { toTwoPointBounds, toTwoPointBoundsByQuadraticCurve, arcTo: arcTo$1, arc, ellipse: ellipse$1 } = BezierHelper;
|
|
3150
|
-
const { addPointBounds, copy: copy$7, addPoint
|
|
3151
|
-
const debug$
|
|
3153
|
+
const { addPointBounds, copy: copy$7, addPoint, setPoint, addBounds, toBounds: toBounds$2 } = TwoPointBoundsHelper;
|
|
3154
|
+
const debug$9 = Debug.get('PathBounds');
|
|
3152
3155
|
let radius, radiusX, radiusY;
|
|
3153
3156
|
const tempPointBounds = {};
|
|
3154
3157
|
const setPointBounds = {};
|
|
@@ -3156,21 +3159,21 @@ const setEndPoint = {};
|
|
|
3156
3159
|
const PathBounds = {
|
|
3157
3160
|
toBounds(data, setBounds) {
|
|
3158
3161
|
PathBounds.toTwoPointBounds(data, setPointBounds);
|
|
3159
|
-
toBounds$
|
|
3162
|
+
toBounds$2(setPointBounds, setBounds);
|
|
3160
3163
|
},
|
|
3161
3164
|
toTwoPointBounds(data, setPointBounds) {
|
|
3162
3165
|
if (!data || !data.length)
|
|
3163
|
-
return setPoint
|
|
3166
|
+
return setPoint(setPointBounds, 0, 0);
|
|
3164
3167
|
let i = 0, x = 0, y = 0, x1, y1, toX, toY, command;
|
|
3165
3168
|
const len = data.length;
|
|
3166
3169
|
while (i < len) {
|
|
3167
3170
|
command = data[i];
|
|
3168
3171
|
if (i === 0) {
|
|
3169
3172
|
if (command === Z$1 || command === C$1 || command === Q) {
|
|
3170
|
-
setPoint
|
|
3173
|
+
setPoint(setPointBounds, x, y);
|
|
3171
3174
|
}
|
|
3172
3175
|
else {
|
|
3173
|
-
setPoint
|
|
3176
|
+
setPoint(setPointBounds, data[i + 1], data[i + 2]);
|
|
3174
3177
|
}
|
|
3175
3178
|
}
|
|
3176
3179
|
switch (command) {
|
|
@@ -3178,7 +3181,7 @@ const PathBounds = {
|
|
|
3178
3181
|
case L$2:
|
|
3179
3182
|
x = data[i + 1];
|
|
3180
3183
|
y = data[i + 2];
|
|
3181
|
-
addPoint
|
|
3184
|
+
addPoint(setPointBounds, x, y);
|
|
3182
3185
|
i += 3;
|
|
3183
3186
|
break;
|
|
3184
3187
|
case C$1:
|
|
@@ -3256,7 +3259,7 @@ const PathBounds = {
|
|
|
3256
3259
|
i += 6;
|
|
3257
3260
|
break;
|
|
3258
3261
|
default:
|
|
3259
|
-
debug$
|
|
3262
|
+
debug$9.error(`command: ${command} [index:${i}]`, data);
|
|
3260
3263
|
return;
|
|
3261
3264
|
}
|
|
3262
3265
|
}
|
|
@@ -3372,7 +3375,7 @@ const FileHelper = {
|
|
|
3372
3375
|
const F = FileHelper;
|
|
3373
3376
|
F.opacityTypes.forEach(type => F.upperCaseTypeMap[type] = type.toUpperCase());
|
|
3374
3377
|
|
|
3375
|
-
const debug$
|
|
3378
|
+
const debug$8 = Debug.get('TaskProcessor');
|
|
3376
3379
|
class TaskItem {
|
|
3377
3380
|
constructor(task) {
|
|
3378
3381
|
this.parallel = true;
|
|
@@ -3387,7 +3390,7 @@ class TaskItem {
|
|
|
3387
3390
|
yield this.task();
|
|
3388
3391
|
}
|
|
3389
3392
|
catch (error) {
|
|
3390
|
-
debug$
|
|
3393
|
+
debug$8.error(error);
|
|
3391
3394
|
}
|
|
3392
3395
|
});
|
|
3393
3396
|
}
|
|
@@ -4074,7 +4077,7 @@ function defineDataProcessor(target, key, defaultValue) {
|
|
|
4074
4077
|
defineKey(data, key, property);
|
|
4075
4078
|
}
|
|
4076
4079
|
|
|
4077
|
-
const debug$
|
|
4080
|
+
const debug$7 = new Debug('rewrite');
|
|
4078
4081
|
const list = [];
|
|
4079
4082
|
const excludeNames = ['destroy', 'constructor'];
|
|
4080
4083
|
function rewrite(method) {
|
|
@@ -4091,7 +4094,7 @@ function doRewrite(error) {
|
|
|
4091
4094
|
if (list.length) {
|
|
4092
4095
|
list.forEach(item => {
|
|
4093
4096
|
if (error)
|
|
4094
|
-
debug$
|
|
4097
|
+
debug$7.error(item.name, '需在Class上装饰@rewriteAble()');
|
|
4095
4098
|
item.run();
|
|
4096
4099
|
});
|
|
4097
4100
|
list.length = 0;
|
|
@@ -4808,7 +4811,6 @@ class LayoutEvent extends Event {
|
|
|
4808
4811
|
}
|
|
4809
4812
|
}
|
|
4810
4813
|
}
|
|
4811
|
-
LayoutEvent.CHECK_UPDATE = 'layout.check_update';
|
|
4812
4814
|
LayoutEvent.REQUEST = 'layout.request';
|
|
4813
4815
|
LayoutEvent.START = 'layout.start';
|
|
4814
4816
|
LayoutEvent.BEFORE = 'layout.before';
|
|
@@ -5003,13 +5005,13 @@ const { on, on_, off, off_, once, emit: emit$1, emitEvent, hasEvent, destroy } =
|
|
|
5003
5005
|
const LeafEventer = { on, on_, off, off_, once, emit: emit$1, emitEvent, hasEvent, destroyEventer: destroy };
|
|
5004
5006
|
|
|
5005
5007
|
const { isFinite } = Number;
|
|
5006
|
-
const debug$
|
|
5008
|
+
const debug$6 = Debug.get('setAttr');
|
|
5007
5009
|
const LeafDataProxy = {
|
|
5008
5010
|
__setAttr(name, newValue, checkFiniteNumber) {
|
|
5009
5011
|
if (this.leaferIsCreated) {
|
|
5010
5012
|
const oldValue = this.__.__getInput(name);
|
|
5011
5013
|
if (checkFiniteNumber && !isFinite(newValue) && newValue !== undefined) {
|
|
5012
|
-
debug$
|
|
5014
|
+
debug$6.warn(this.innerName, name, newValue);
|
|
5013
5015
|
newValue = undefined;
|
|
5014
5016
|
}
|
|
5015
5017
|
if (typeof newValue === 'object' || oldValue !== newValue) {
|
|
@@ -5079,7 +5081,7 @@ const LeafMatrix = {
|
|
|
5079
5081
|
const { updateMatrix: updateMatrix$1, updateAllMatrix: updateAllMatrix$2 } = LeafHelper;
|
|
5080
5082
|
const { updateBounds: updateBounds$1 } = BranchHelper;
|
|
5081
5083
|
const { toOuterOf: toOuterOf$1, copyAndSpread: copyAndSpread$1, copy: copy$4 } = BoundsHelper;
|
|
5082
|
-
const { toBounds: toBounds$
|
|
5084
|
+
const { toBounds: toBounds$1 } = PathBounds;
|
|
5083
5085
|
const LeafBounds = {
|
|
5084
5086
|
__updateWorldBounds() {
|
|
5085
5087
|
toOuterOf$1(this.__layout.renderBounds, this.__world, this.__world);
|
|
@@ -5161,7 +5163,7 @@ const LeafBounds = {
|
|
|
5161
5163
|
const b = this.__layout.boxBounds;
|
|
5162
5164
|
const data = this.__;
|
|
5163
5165
|
if (data.__pathInputed) {
|
|
5164
|
-
toBounds$
|
|
5166
|
+
toBounds$1(data.path, b);
|
|
5165
5167
|
}
|
|
5166
5168
|
else {
|
|
5167
5169
|
b.x = 0;
|
|
@@ -5709,7 +5711,7 @@ Leaf = __decorate([
|
|
|
5709
5711
|
const { setListWithFn } = BoundsHelper;
|
|
5710
5712
|
const { sort } = BranchHelper;
|
|
5711
5713
|
const { localBoxBounds, localStrokeBounds, localRenderBounds, maskLocalBoxBounds, maskLocalStrokeBounds, maskLocalRenderBounds } = LeafBoundsHelper;
|
|
5712
|
-
const debug$
|
|
5714
|
+
const debug$5 = new Debug('Branch');
|
|
5713
5715
|
let Branch = class Branch extends Leaf {
|
|
5714
5716
|
__updateStrokeSpread() {
|
|
5715
5717
|
const { children } = this;
|
|
@@ -5751,7 +5753,7 @@ let Branch = class Branch extends Leaf {
|
|
|
5751
5753
|
}
|
|
5752
5754
|
add(child, index) {
|
|
5753
5755
|
if (child === this || child.destroyed)
|
|
5754
|
-
return debug$
|
|
5756
|
+
return debug$5.warn('add self or destroyed');
|
|
5755
5757
|
const noIndex = index === undefined;
|
|
5756
5758
|
if (!child.__) {
|
|
5757
5759
|
if (child instanceof Array)
|
|
@@ -6005,9 +6007,9 @@ class LeafLevelList {
|
|
|
6005
6007
|
}
|
|
6006
6008
|
}
|
|
6007
6009
|
|
|
6008
|
-
const version = "1.
|
|
6010
|
+
const version = "1.3.0";
|
|
6009
6011
|
|
|
6010
|
-
const debug$
|
|
6012
|
+
const debug$4 = Debug.get('LeaferCanvas');
|
|
6011
6013
|
class LeaferCanvas extends LeaferCanvasBase {
|
|
6012
6014
|
set zIndex(zIndex) {
|
|
6013
6015
|
const { style } = this.view;
|
|
@@ -6079,7 +6081,7 @@ class LeaferCanvas extends LeaferCanvasBase {
|
|
|
6079
6081
|
}
|
|
6080
6082
|
}
|
|
6081
6083
|
else {
|
|
6082
|
-
debug$
|
|
6084
|
+
debug$4.error(`no id: ${inputView}`);
|
|
6083
6085
|
this.__createView();
|
|
6084
6086
|
}
|
|
6085
6087
|
}
|
|
@@ -6117,7 +6119,7 @@ class LeaferCanvas extends LeaferCanvasBase {
|
|
|
6117
6119
|
}
|
|
6118
6120
|
else {
|
|
6119
6121
|
this.checkAutoBounds(this.view);
|
|
6120
|
-
debug$
|
|
6122
|
+
debug$4.warn('no parent');
|
|
6121
6123
|
}
|
|
6122
6124
|
}
|
|
6123
6125
|
catch (_a) {
|
|
@@ -6453,7 +6455,7 @@ class LayoutBlockData {
|
|
|
6453
6455
|
}
|
|
6454
6456
|
|
|
6455
6457
|
const { updateAllMatrix, updateAllChange } = LeafHelper;
|
|
6456
|
-
const debug$
|
|
6458
|
+
const debug$3 = Debug.get('Layouter');
|
|
6457
6459
|
class Layouter {
|
|
6458
6460
|
constructor(target, userConfig) {
|
|
6459
6461
|
this.totalTimes = 0;
|
|
@@ -6488,7 +6490,7 @@ class Layouter {
|
|
|
6488
6490
|
target.emitEvent(new LayoutEvent(LayoutEvent.END, this.layoutedBlocks, this.times));
|
|
6489
6491
|
}
|
|
6490
6492
|
catch (e) {
|
|
6491
|
-
debug$
|
|
6493
|
+
debug$3.error(e);
|
|
6492
6494
|
}
|
|
6493
6495
|
this.layoutedBlocks = null;
|
|
6494
6496
|
}
|
|
@@ -6502,9 +6504,9 @@ class Layouter {
|
|
|
6502
6504
|
}
|
|
6503
6505
|
layoutOnce() {
|
|
6504
6506
|
if (this.layouting)
|
|
6505
|
-
return debug$
|
|
6507
|
+
return debug$3.warn('layouting');
|
|
6506
6508
|
if (this.times > 3)
|
|
6507
|
-
return debug$
|
|
6509
|
+
return debug$3.warn('layout max times');
|
|
6508
6510
|
this.times++;
|
|
6509
6511
|
this.totalTimes++;
|
|
6510
6512
|
this.layouting = true;
|
|
@@ -6608,7 +6610,7 @@ class Layouter {
|
|
|
6608
6610
|
}
|
|
6609
6611
|
}
|
|
6610
6612
|
|
|
6611
|
-
const debug$
|
|
6613
|
+
const debug$2 = Debug.get('Renderer');
|
|
6612
6614
|
class Renderer {
|
|
6613
6615
|
get needFill() { return !!(!this.canvas.allowBackgroundColor && this.config.fill); }
|
|
6614
6616
|
constructor(target, canvas, userConfig) {
|
|
@@ -6646,7 +6648,7 @@ class Renderer {
|
|
|
6646
6648
|
const { target } = this;
|
|
6647
6649
|
this.times = 0;
|
|
6648
6650
|
this.totalBounds = new Bounds();
|
|
6649
|
-
debug$
|
|
6651
|
+
debug$2.log(target.innerName, '--->');
|
|
6650
6652
|
try {
|
|
6651
6653
|
if (!target.isApp)
|
|
6652
6654
|
target.app.emit(RenderEvent.CHILD_START, target);
|
|
@@ -6657,9 +6659,9 @@ class Renderer {
|
|
|
6657
6659
|
}
|
|
6658
6660
|
catch (e) {
|
|
6659
6661
|
this.rendering = false;
|
|
6660
|
-
debug$
|
|
6662
|
+
debug$2.error(e);
|
|
6661
6663
|
}
|
|
6662
|
-
debug$
|
|
6664
|
+
debug$2.log('-------------|');
|
|
6663
6665
|
}
|
|
6664
6666
|
renderAgain() {
|
|
6665
6667
|
if (this.rendering) {
|
|
@@ -6671,9 +6673,9 @@ class Renderer {
|
|
|
6671
6673
|
}
|
|
6672
6674
|
renderOnce(callback) {
|
|
6673
6675
|
if (this.rendering)
|
|
6674
|
-
return debug$
|
|
6676
|
+
return debug$2.warn('rendering');
|
|
6675
6677
|
if (this.times > 3)
|
|
6676
|
-
return debug$
|
|
6678
|
+
return debug$2.warn('render max times');
|
|
6677
6679
|
this.times++;
|
|
6678
6680
|
this.totalTimes++;
|
|
6679
6681
|
this.rendering = true;
|
|
@@ -6710,7 +6712,7 @@ class Renderer {
|
|
|
6710
6712
|
partRender() {
|
|
6711
6713
|
const { canvas, updateBlocks: list } = this;
|
|
6712
6714
|
if (!list)
|
|
6713
|
-
return debug$
|
|
6715
|
+
return debug$2.warn('PartRender: need update attr');
|
|
6714
6716
|
this.mergeBlocks();
|
|
6715
6717
|
list.forEach(block => { if (canvas.bounds.hit(block) && !block.isEmpty())
|
|
6716
6718
|
this.clipRender(block); });
|
|
@@ -6813,7 +6815,7 @@ class Renderer {
|
|
|
6813
6815
|
empty = (!leaf.__world.width || !leaf.__world.height);
|
|
6814
6816
|
if (empty) {
|
|
6815
6817
|
if (!leaf.isLeafer)
|
|
6816
|
-
debug$
|
|
6818
|
+
debug$2.tip(leaf.innerName, ': empty');
|
|
6817
6819
|
empty = (!leaf.isBranch || leaf.isBranchLeaf);
|
|
6818
6820
|
}
|
|
6819
6821
|
return empty;
|
|
@@ -6915,7 +6917,7 @@ const Transition = {
|
|
|
6915
6917
|
|
|
6916
6918
|
const { parse, objectToCanvasData } = PathConvert;
|
|
6917
6919
|
const emptyPaint = {};
|
|
6918
|
-
const debug$
|
|
6920
|
+
const debug$1 = Debug.get('UIData');
|
|
6919
6921
|
class UIData extends LeafData {
|
|
6920
6922
|
get scale() { const { scaleX, scaleY } = this; return scaleX !== scaleY ? { x: scaleX, y: scaleY } : scaleX; }
|
|
6921
6923
|
get __strokeWidth() {
|
|
@@ -6952,7 +6954,7 @@ class UIData extends LeafData {
|
|
|
6952
6954
|
if (value < 0) {
|
|
6953
6955
|
this._width = -value;
|
|
6954
6956
|
this.__leaf.scaleX *= -1;
|
|
6955
|
-
debug$
|
|
6957
|
+
debug$1.warn('width < 0, instead -scaleX ', this);
|
|
6956
6958
|
}
|
|
6957
6959
|
else
|
|
6958
6960
|
this._width = value;
|
|
@@ -6961,7 +6963,7 @@ class UIData extends LeafData {
|
|
|
6961
6963
|
if (value < 0) {
|
|
6962
6964
|
this._height = -value;
|
|
6963
6965
|
this.__leaf.scaleY *= -1;
|
|
6964
|
-
debug$
|
|
6966
|
+
debug$1.warn('height < 0, instead -scaleY', this);
|
|
6965
6967
|
}
|
|
6966
6968
|
else
|
|
6967
6969
|
this._height = value;
|
|
@@ -7338,25 +7340,27 @@ let UI = UI_1 = class UI extends Leaf {
|
|
|
7338
7340
|
}
|
|
7339
7341
|
reset(_data) { }
|
|
7340
7342
|
set(data, transition) {
|
|
7341
|
-
if (
|
|
7342
|
-
if (transition
|
|
7343
|
-
|
|
7344
|
-
|
|
7345
|
-
|
|
7343
|
+
if (data) {
|
|
7344
|
+
if (transition) {
|
|
7345
|
+
if (transition === 'temp') {
|
|
7346
|
+
this.lockNormalStyle = true;
|
|
7347
|
+
Object.assign(this, data);
|
|
7348
|
+
this.lockNormalStyle = false;
|
|
7349
|
+
}
|
|
7350
|
+
else
|
|
7351
|
+
this.animate(data, transition);
|
|
7346
7352
|
}
|
|
7347
7353
|
else
|
|
7348
|
-
|
|
7354
|
+
Object.assign(this, data);
|
|
7349
7355
|
}
|
|
7350
|
-
else
|
|
7351
|
-
Object.assign(this, data);
|
|
7352
7356
|
}
|
|
7353
7357
|
get(name) {
|
|
7354
7358
|
return typeof name === 'string' ? this.__.__getInput(name) : this.__.__getInputData(name);
|
|
7355
7359
|
}
|
|
7356
7360
|
createProxyData() { return undefined; }
|
|
7357
|
-
find(_condition, _options) { return
|
|
7361
|
+
find(_condition, _options) { return Plugin.need('find'); }
|
|
7358
7362
|
findTag(tag) { return this.find({ tag }); }
|
|
7359
|
-
findOne(_condition, _options) { return
|
|
7363
|
+
findOne(_condition, _options) { return Plugin.need('find'); }
|
|
7360
7364
|
findId(id) { return this.findOne({ id }); }
|
|
7361
7365
|
getPath(curve, pathForRender) {
|
|
7362
7366
|
this.__layout.update();
|
|
@@ -7408,9 +7412,9 @@ let UI = UI_1 = class UI extends Leaf {
|
|
|
7408
7412
|
animate(_keyframe, _options, _type, _isTemp) {
|
|
7409
7413
|
return Plugin.need('animate');
|
|
7410
7414
|
}
|
|
7411
|
-
killAnimate(_type) { }
|
|
7412
|
-
export(
|
|
7413
|
-
return
|
|
7415
|
+
killAnimate(_type, _killStyle) { }
|
|
7416
|
+
export(_filename, _options) {
|
|
7417
|
+
return Plugin.need('export');
|
|
7414
7418
|
}
|
|
7415
7419
|
clone(data) {
|
|
7416
7420
|
const json = this.toJSON();
|
|
@@ -7656,16 +7660,18 @@ let Group = class Group extends UI {
|
|
|
7656
7660
|
this.children = [];
|
|
7657
7661
|
}
|
|
7658
7662
|
set(data, transition) {
|
|
7659
|
-
if (data
|
|
7660
|
-
|
|
7661
|
-
|
|
7662
|
-
|
|
7663
|
-
|
|
7664
|
-
|
|
7665
|
-
|
|
7663
|
+
if (data) {
|
|
7664
|
+
if (data.children) {
|
|
7665
|
+
const { children } = data;
|
|
7666
|
+
delete data.children;
|
|
7667
|
+
this.children ? this.clear() : this.__setBranch();
|
|
7668
|
+
super.set(data, transition);
|
|
7669
|
+
children.forEach(child => this.add(child));
|
|
7670
|
+
data.children = children;
|
|
7671
|
+
}
|
|
7672
|
+
else
|
|
7673
|
+
super.set(data, transition);
|
|
7666
7674
|
}
|
|
7667
|
-
else
|
|
7668
|
-
super.set(data, transition);
|
|
7669
7675
|
}
|
|
7670
7676
|
toJSON(options) {
|
|
7671
7677
|
const data = super.toJSON(options);
|
|
@@ -7697,7 +7703,7 @@ Group = __decorate([
|
|
|
7697
7703
|
], Group);
|
|
7698
7704
|
|
|
7699
7705
|
var Leafer_1;
|
|
7700
|
-
const debug
|
|
7706
|
+
const debug = Debug.get('Leafer');
|
|
7701
7707
|
let Leafer = Leafer_1 = class Leafer extends Group {
|
|
7702
7708
|
get __tag() { return 'Leafer'; }
|
|
7703
7709
|
get isApp() { return false; }
|
|
@@ -7862,7 +7868,7 @@ let Leafer = Leafer_1 = class Leafer extends Group {
|
|
|
7862
7868
|
if (this.canvas) {
|
|
7863
7869
|
if (canvasSizeAttrs.includes(attrName)) {
|
|
7864
7870
|
if (!newValue)
|
|
7865
|
-
debug
|
|
7871
|
+
debug.warn(attrName + ' is 0');
|
|
7866
7872
|
this.__changeCanvasSize(attrName, newValue);
|
|
7867
7873
|
}
|
|
7868
7874
|
else if (attrName === 'fill') {
|
|
@@ -8003,9 +8009,6 @@ let Leafer = Leafer_1 = class Leafer extends Group {
|
|
|
8003
8009
|
this.canvas && this.canvas.updateClientBounds();
|
|
8004
8010
|
}
|
|
8005
8011
|
receiveEvent(_event) { }
|
|
8006
|
-
__checkUpdateLayout() {
|
|
8007
|
-
this.__layout.update();
|
|
8008
|
-
}
|
|
8009
8012
|
emitLeafer(type) {
|
|
8010
8013
|
this.emitEvent(new LeaferEvent(type, this));
|
|
8011
8014
|
}
|
|
@@ -8016,7 +8019,7 @@ let Leafer = Leafer_1 = class Leafer extends Group {
|
|
|
8016
8019
|
this.once(LayoutEvent.END, () => this.__onReady());
|
|
8017
8020
|
this.once(RenderEvent.START, () => this.__onCreated());
|
|
8018
8021
|
this.once(RenderEvent.END, () => this.__onViewReady());
|
|
8019
|
-
this.__eventIds.push(this.on_(WatchEvent.DATA, this.__onWatchData, this), this.on_(RenderEvent.NEXT, this.__onNextRender, this)
|
|
8022
|
+
this.__eventIds.push(this.on_(WatchEvent.DATA, this.__onWatchData, this), this.on_(RenderEvent.NEXT, this.__onNextRender, this));
|
|
8020
8023
|
}
|
|
8021
8024
|
__removeListenEvents() {
|
|
8022
8025
|
this.off_(this.__eventIds);
|
|
@@ -8047,7 +8050,7 @@ let Leafer = Leafer_1 = class Leafer extends Group {
|
|
|
8047
8050
|
setTimeout(() => { ImageManager.clearRecycled(); }, 100);
|
|
8048
8051
|
}
|
|
8049
8052
|
catch (e) {
|
|
8050
|
-
debug
|
|
8053
|
+
debug.error(e);
|
|
8051
8054
|
}
|
|
8052
8055
|
}
|
|
8053
8056
|
};
|
|
@@ -8276,7 +8279,7 @@ Ellipse = __decorate([
|
|
|
8276
8279
|
|
|
8277
8280
|
const { moveTo: moveTo$2, lineTo: lineTo$2, drawPoints: drawPoints$1 } = PathCommandDataHelper;
|
|
8278
8281
|
const { rotate: rotate$1, getAngle: getAngle$1, getDistance: getDistance$2, defaultPoint } = PointHelper;
|
|
8279
|
-
const { toBounds
|
|
8282
|
+
const { toBounds } = PathBounds;
|
|
8280
8283
|
let Line = class Line extends UI {
|
|
8281
8284
|
get __tag() { return 'Line'; }
|
|
8282
8285
|
get toPoint() {
|
|
@@ -8320,7 +8323,7 @@ let Line = class Line extends UI {
|
|
|
8320
8323
|
}
|
|
8321
8324
|
__updateBoxBounds() {
|
|
8322
8325
|
if (this.points) {
|
|
8323
|
-
toBounds
|
|
8326
|
+
toBounds(this.__.__pathForRender, this.__layout.boxBounds);
|
|
8324
8327
|
}
|
|
8325
8328
|
else
|
|
8326
8329
|
super.__updateBoxBounds();
|
|
@@ -8672,6 +8675,9 @@ __decorate([
|
|
|
8672
8675
|
__decorate([
|
|
8673
8676
|
boundsType(0)
|
|
8674
8677
|
], Text.prototype, "paraSpacing", void 0);
|
|
8678
|
+
__decorate([
|
|
8679
|
+
boundsType('x')
|
|
8680
|
+
], Text.prototype, "writingMode", void 0);
|
|
8675
8681
|
__decorate([
|
|
8676
8682
|
boundsType('left')
|
|
8677
8683
|
], Text.prototype, "textAlign", void 0);
|
|
@@ -10236,197 +10242,12 @@ const ColorConvertModule = {
|
|
|
10236
10242
|
string
|
|
10237
10243
|
};
|
|
10238
10244
|
|
|
10239
|
-
const { setPoint, addPoint, toBounds } = TwoPointBoundsHelper;
|
|
10240
|
-
function getTrimBounds(canvas) {
|
|
10241
|
-
const { width, height } = canvas.view;
|
|
10242
|
-
const { data } = canvas.context.getImageData(0, 0, width, height);
|
|
10243
|
-
let x, y, pointBounds, index = 0;
|
|
10244
|
-
for (let i = 0; i < data.length; i += 4) {
|
|
10245
|
-
if (data[i + 3] !== 0) {
|
|
10246
|
-
x = index % width;
|
|
10247
|
-
y = (index - x) / width;
|
|
10248
|
-
pointBounds ? addPoint(pointBounds, x, y) : setPoint(pointBounds = {}, x, y);
|
|
10249
|
-
}
|
|
10250
|
-
index++;
|
|
10251
|
-
}
|
|
10252
|
-
const bounds = new Bounds();
|
|
10253
|
-
toBounds(pointBounds, bounds);
|
|
10254
|
-
return bounds.scale(1 / canvas.pixelRatio).ceil();
|
|
10255
|
-
}
|
|
10256
|
-
|
|
10257
|
-
const ExportModule = {
|
|
10258
|
-
export(leaf, filename, options) {
|
|
10259
|
-
this.running = true;
|
|
10260
|
-
const fileType = FileHelper.fileType(filename);
|
|
10261
|
-
const isDownload = filename.includes('.');
|
|
10262
|
-
options = FileHelper.getExportOptions(options);
|
|
10263
|
-
return addTask((success) => new Promise((resolve) => {
|
|
10264
|
-
const over = (result) => {
|
|
10265
|
-
success(result);
|
|
10266
|
-
resolve();
|
|
10267
|
-
this.running = false;
|
|
10268
|
-
};
|
|
10269
|
-
const { toURL } = Platform;
|
|
10270
|
-
const { download } = Platform.origin;
|
|
10271
|
-
if (fileType === 'json') {
|
|
10272
|
-
isDownload && download(toURL(JSON.stringify(leaf.toJSON(options.json)), 'text'), filename);
|
|
10273
|
-
return over({ data: isDownload ? true : leaf.toJSON(options.json) });
|
|
10274
|
-
}
|
|
10275
|
-
if (fileType === 'svg') {
|
|
10276
|
-
isDownload && download(toURL(leaf.toSVG(), 'svg'), filename);
|
|
10277
|
-
return over({ data: isDownload ? true : leaf.toSVG() });
|
|
10278
|
-
}
|
|
10279
|
-
const { leafer } = leaf;
|
|
10280
|
-
if (leafer) {
|
|
10281
|
-
checkLazy(leaf);
|
|
10282
|
-
leafer.waitViewCompleted(() => __awaiter(this, void 0, void 0, function* () {
|
|
10283
|
-
let renderBounds, trimBounds, scaleX = 1, scaleY = 1;
|
|
10284
|
-
const { worldTransform, isLeafer, isFrame } = leaf;
|
|
10285
|
-
const { slice, trim, onCanvas } = options;
|
|
10286
|
-
const smooth = options.smooth === undefined ? leafer.config.smooth : options.smooth;
|
|
10287
|
-
const contextSettings = options.contextSettings || leafer.config.contextSettings;
|
|
10288
|
-
const screenshot = options.screenshot || leaf.isApp;
|
|
10289
|
-
const fill = (isLeafer && screenshot) ? (options.fill === undefined ? leaf.fill : options.fill) : options.fill;
|
|
10290
|
-
const needFill = FileHelper.isOpaqueImage(filename) || fill, matrix = new Matrix();
|
|
10291
|
-
if (screenshot) {
|
|
10292
|
-
renderBounds = screenshot === true ? (isLeafer ? leafer.canvas.bounds : leaf.worldRenderBounds) : screenshot;
|
|
10293
|
-
}
|
|
10294
|
-
else {
|
|
10295
|
-
let relative = options.relative || (isLeafer ? 'inner' : 'local');
|
|
10296
|
-
scaleX = worldTransform.scaleX;
|
|
10297
|
-
scaleY = worldTransform.scaleY;
|
|
10298
|
-
switch (relative) {
|
|
10299
|
-
case 'inner':
|
|
10300
|
-
matrix.set(worldTransform);
|
|
10301
|
-
break;
|
|
10302
|
-
case 'local':
|
|
10303
|
-
matrix.set(worldTransform).divide(leaf.localTransform);
|
|
10304
|
-
scaleX /= leaf.scaleX;
|
|
10305
|
-
scaleY /= leaf.scaleY;
|
|
10306
|
-
break;
|
|
10307
|
-
case 'world':
|
|
10308
|
-
scaleX = 1;
|
|
10309
|
-
scaleY = 1;
|
|
10310
|
-
break;
|
|
10311
|
-
case 'page':
|
|
10312
|
-
relative = leaf.leafer;
|
|
10313
|
-
default:
|
|
10314
|
-
matrix.set(worldTransform).divide(leaf.getTransform(relative));
|
|
10315
|
-
const l = relative.worldTransform;
|
|
10316
|
-
scaleX /= scaleX / l.scaleX;
|
|
10317
|
-
scaleY /= scaleY / l.scaleY;
|
|
10318
|
-
}
|
|
10319
|
-
renderBounds = leaf.getBounds('render', relative);
|
|
10320
|
-
}
|
|
10321
|
-
const scaleData = { scaleX: 1, scaleY: 1 };
|
|
10322
|
-
MathHelper.getScaleData(options.scale, options.size, renderBounds, scaleData);
|
|
10323
|
-
let pixelRatio = options.pixelRatio || 1;
|
|
10324
|
-
if (leaf.isApp) {
|
|
10325
|
-
scaleData.scaleX *= pixelRatio;
|
|
10326
|
-
scaleData.scaleY *= pixelRatio;
|
|
10327
|
-
pixelRatio = leaf.app.pixelRatio;
|
|
10328
|
-
}
|
|
10329
|
-
const { x, y, width, height } = new Bounds(renderBounds).scale(scaleData.scaleX, scaleData.scaleY);
|
|
10330
|
-
const renderOptions = { matrix: matrix.scale(1 / scaleData.scaleX, 1 / scaleData.scaleY).invert().translate(-x, -y).withScale(1 / scaleX * scaleData.scaleX, 1 / scaleY * scaleData.scaleY) };
|
|
10331
|
-
let canvas = Creator.canvas({ width: Math.round(width), height: Math.round(height), pixelRatio, smooth, contextSettings });
|
|
10332
|
-
let sliceLeaf;
|
|
10333
|
-
if (slice) {
|
|
10334
|
-
sliceLeaf = leaf;
|
|
10335
|
-
sliceLeaf.__worldOpacity = 0;
|
|
10336
|
-
leaf = leafer;
|
|
10337
|
-
renderOptions.bounds = canvas.bounds;
|
|
10338
|
-
}
|
|
10339
|
-
canvas.save();
|
|
10340
|
-
if (isFrame && fill !== undefined) {
|
|
10341
|
-
const oldFill = leaf.get('fill');
|
|
10342
|
-
leaf.fill = '';
|
|
10343
|
-
leaf.__render(canvas, renderOptions);
|
|
10344
|
-
leaf.fill = oldFill;
|
|
10345
|
-
}
|
|
10346
|
-
else {
|
|
10347
|
-
leaf.__render(canvas, renderOptions);
|
|
10348
|
-
}
|
|
10349
|
-
canvas.restore();
|
|
10350
|
-
if (sliceLeaf)
|
|
10351
|
-
sliceLeaf.__updateWorldOpacity();
|
|
10352
|
-
if (trim) {
|
|
10353
|
-
trimBounds = getTrimBounds(canvas);
|
|
10354
|
-
const old = canvas, { width, height } = trimBounds;
|
|
10355
|
-
const config = { x: 0, y: 0, width, height, pixelRatio };
|
|
10356
|
-
canvas = Creator.canvas(config);
|
|
10357
|
-
canvas.copyWorld(old, trimBounds, config);
|
|
10358
|
-
}
|
|
10359
|
-
if (needFill)
|
|
10360
|
-
canvas.fillWorld(canvas.bounds, fill || '#FFFFFF', 'destination-over');
|
|
10361
|
-
if (onCanvas)
|
|
10362
|
-
onCanvas(canvas);
|
|
10363
|
-
const data = filename === 'canvas' ? canvas : yield canvas.export(filename, options);
|
|
10364
|
-
over({ data, width: canvas.pixelWidth, height: canvas.pixelHeight, renderBounds, trimBounds });
|
|
10365
|
-
}));
|
|
10366
|
-
}
|
|
10367
|
-
else {
|
|
10368
|
-
over({ data: false });
|
|
10369
|
-
}
|
|
10370
|
-
}));
|
|
10371
|
-
}
|
|
10372
|
-
};
|
|
10373
|
-
let tasker;
|
|
10374
|
-
function addTask(task) {
|
|
10375
|
-
if (!tasker)
|
|
10376
|
-
tasker = new TaskProcessor();
|
|
10377
|
-
return new Promise((resolve) => {
|
|
10378
|
-
tasker.add(() => __awaiter(this, void 0, void 0, function* () { return yield task(resolve); }), { parallel: false });
|
|
10379
|
-
});
|
|
10380
|
-
}
|
|
10381
|
-
function checkLazy(leaf) {
|
|
10382
|
-
if (leaf.__.__needComputePaint)
|
|
10383
|
-
leaf.__.__computePaint();
|
|
10384
|
-
if (leaf.isBranch)
|
|
10385
|
-
leaf.children.forEach(child => checkLazy(child));
|
|
10386
|
-
}
|
|
10387
|
-
|
|
10388
|
-
const canvas = LeaferCanvasBase.prototype;
|
|
10389
|
-
const debug = Debug.get('@leafer-ui/export');
|
|
10390
|
-
canvas.export = function (filename, options) {
|
|
10391
|
-
const { quality, blob } = FileHelper.getExportOptions(options);
|
|
10392
|
-
if (filename.includes('.'))
|
|
10393
|
-
return this.saveAs(filename, quality);
|
|
10394
|
-
else if (blob)
|
|
10395
|
-
return this.toBlob(filename, quality);
|
|
10396
|
-
else
|
|
10397
|
-
return this.toDataURL(filename, quality);
|
|
10398
|
-
};
|
|
10399
|
-
canvas.toBlob = function (type, quality) {
|
|
10400
|
-
return new Promise((resolve) => {
|
|
10401
|
-
Platform.origin.canvasToBolb(this.view, type, quality).then((blob) => {
|
|
10402
|
-
resolve(blob);
|
|
10403
|
-
}).catch((e) => {
|
|
10404
|
-
debug.error(e);
|
|
10405
|
-
resolve(null);
|
|
10406
|
-
});
|
|
10407
|
-
});
|
|
10408
|
-
};
|
|
10409
|
-
canvas.toDataURL = function (type, quality) {
|
|
10410
|
-
return Platform.origin.canvasToDataURL(this.view, type, quality);
|
|
10411
|
-
};
|
|
10412
|
-
canvas.saveAs = function (filename, quality) {
|
|
10413
|
-
return new Promise((resolve) => {
|
|
10414
|
-
Platform.origin.canvasSaveAs(this.view, filename, quality).then(() => {
|
|
10415
|
-
resolve(true);
|
|
10416
|
-
}).catch((e) => {
|
|
10417
|
-
debug.error(e);
|
|
10418
|
-
resolve(false);
|
|
10419
|
-
});
|
|
10420
|
-
});
|
|
10421
|
-
};
|
|
10422
|
-
|
|
10423
10245
|
Object.assign(TextConvert, TextConvertModule);
|
|
10424
10246
|
Object.assign(ColorConvert, ColorConvertModule);
|
|
10425
10247
|
Object.assign(Paint, PaintModule);
|
|
10426
10248
|
Object.assign(PaintImage, PaintImageModule);
|
|
10427
10249
|
Object.assign(PaintGradient, PaintGradientModule);
|
|
10428
10250
|
Object.assign(Effect, EffectModule);
|
|
10429
|
-
Object.assign(Export, ExportModule);
|
|
10430
10251
|
|
|
10431
10252
|
useCanvas();
|
|
10432
10253
|
|