@meta2d/core 1.0.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.
Files changed (202) hide show
  1. package/index.d.ts +9 -0
  2. package/index.js +10 -0
  3. package/index.js.map +1 -0
  4. package/package.json +39 -0
  5. package/src/canvas/canvas.d.ts +399 -0
  6. package/src/canvas/canvas.js +5920 -0
  7. package/src/canvas/canvas.js.map +1 -0
  8. package/src/canvas/canvasImage.d.ts +25 -0
  9. package/src/canvas/canvasImage.js +343 -0
  10. package/src/canvas/canvasImage.js.map +1 -0
  11. package/src/canvas/index.d.ts +2 -0
  12. package/src/canvas/index.js +3 -0
  13. package/src/canvas/index.js.map +1 -0
  14. package/src/canvas/magnifierCanvas.d.ts +20 -0
  15. package/src/canvas/magnifierCanvas.js +99 -0
  16. package/src/canvas/magnifierCanvas.js.map +1 -0
  17. package/src/canvas/offscreen.d.ts +2 -0
  18. package/src/canvas/offscreen.js +14 -0
  19. package/src/canvas/offscreen.js.map +1 -0
  20. package/src/core.d.ts +348 -0
  21. package/src/core.js +2465 -0
  22. package/src/core.js.map +1 -0
  23. package/src/data.d.ts +34 -0
  24. package/src/data.js +83 -0
  25. package/src/data.js.map +1 -0
  26. package/src/diagrams/arrow.d.ts +4 -0
  27. package/src/diagrams/arrow.js +47 -0
  28. package/src/diagrams/arrow.js.map +1 -0
  29. package/src/diagrams/circle.d.ts +2 -0
  30. package/src/diagrams/circle.js +9 -0
  31. package/src/diagrams/circle.js.map +1 -0
  32. package/src/diagrams/cloud.d.ts +2 -0
  33. package/src/diagrams/cloud.js +12 -0
  34. package/src/diagrams/cloud.js.map +1 -0
  35. package/src/diagrams/cube.d.ts +2 -0
  36. package/src/diagrams/cube.js +70 -0
  37. package/src/diagrams/cube.js.map +1 -0
  38. package/src/diagrams/diamond.d.ts +2 -0
  39. package/src/diagrams/diamond.js +13 -0
  40. package/src/diagrams/diamond.js.map +1 -0
  41. package/src/diagrams/file.d.ts +2 -0
  42. package/src/diagrams/file.js +18 -0
  43. package/src/diagrams/file.js.map +1 -0
  44. package/src/diagrams/gif.d.ts +5 -0
  45. package/src/diagrams/gif.js +80 -0
  46. package/src/diagrams/gif.js.map +1 -0
  47. package/src/diagrams/hexagon.d.ts +2 -0
  48. package/src/diagrams/hexagon.js +55 -0
  49. package/src/diagrams/hexagon.js.map +1 -0
  50. package/src/diagrams/iframe.d.ts +5 -0
  51. package/src/diagrams/iframe.js +52 -0
  52. package/src/diagrams/iframe.js.map +1 -0
  53. package/src/diagrams/index.d.ts +67 -0
  54. package/src/diagrams/index.js +72 -0
  55. package/src/diagrams/index.js.map +1 -0
  56. package/src/diagrams/line/curve.d.ts +16 -0
  57. package/src/diagrams/line/curve.js +233 -0
  58. package/src/diagrams/line/curve.js.map +1 -0
  59. package/src/diagrams/line/index.d.ts +4 -0
  60. package/src/diagrams/line/index.js +5 -0
  61. package/src/diagrams/line/index.js.map +1 -0
  62. package/src/diagrams/line/line.d.ts +42 -0
  63. package/src/diagrams/line/line.js +419 -0
  64. package/src/diagrams/line/line.js.map +1 -0
  65. package/src/diagrams/line/polyline.d.ts +10 -0
  66. package/src/diagrams/line/polyline.js +622 -0
  67. package/src/diagrams/line/polyline.js.map +1 -0
  68. package/src/diagrams/line/smooth.d.ts +3 -0
  69. package/src/diagrams/line/smooth.js +174 -0
  70. package/src/diagrams/line/smooth.js.map +1 -0
  71. package/src/diagrams/message.d.ts +2 -0
  72. package/src/diagrams/message.js +15 -0
  73. package/src/diagrams/message.js.map +1 -0
  74. package/src/diagrams/mindLine.d.ts +3 -0
  75. package/src/diagrams/mindLine.js +31 -0
  76. package/src/diagrams/mindLine.js.map +1 -0
  77. package/src/diagrams/mindNode.d.ts +3 -0
  78. package/src/diagrams/mindNode.js +189 -0
  79. package/src/diagrams/mindNode.js.map +1 -0
  80. package/src/diagrams/pentagon.d.ts +3 -0
  81. package/src/diagrams/pentagon.js +46 -0
  82. package/src/diagrams/pentagon.js.map +1 -0
  83. package/src/diagrams/pentagram.d.ts +3 -0
  84. package/src/diagrams/pentagram.js +77 -0
  85. package/src/diagrams/pentagram.js.map +1 -0
  86. package/src/diagrams/people.d.ts +2 -0
  87. package/src/diagrams/people.js +19 -0
  88. package/src/diagrams/people.js.map +1 -0
  89. package/src/diagrams/rectangle.d.ts +3 -0
  90. package/src/diagrams/rectangle.js +26 -0
  91. package/src/diagrams/rectangle.js.map +1 -0
  92. package/src/diagrams/svg/parse.d.ts +15 -0
  93. package/src/diagrams/svg/parse.js +326 -0
  94. package/src/diagrams/svg/parse.js.map +1 -0
  95. package/src/diagrams/svgPath.d.ts +2 -0
  96. package/src/diagrams/svgPath.js +30 -0
  97. package/src/diagrams/svgPath.js.map +1 -0
  98. package/src/diagrams/triangle.d.ts +3 -0
  99. package/src/diagrams/triangle.js +41 -0
  100. package/src/diagrams/triangle.js.map +1 -0
  101. package/src/diagrams/video.d.ts +5 -0
  102. package/src/diagrams/video.js +143 -0
  103. package/src/diagrams/video.js.map +1 -0
  104. package/src/event/event.d.ts +45 -0
  105. package/src/event/event.js +17 -0
  106. package/src/event/event.js.map +1 -0
  107. package/src/event/index.d.ts +1 -0
  108. package/src/event/index.js +2 -0
  109. package/src/event/index.js.map +1 -0
  110. package/src/map/index.d.ts +1 -0
  111. package/src/map/index.js +2 -0
  112. package/src/map/index.js.map +1 -0
  113. package/src/map/map.d.ts +20 -0
  114. package/src/map/map.js +143 -0
  115. package/src/map/map.js.map +1 -0
  116. package/src/options.d.ts +70 -0
  117. package/src/options.js +61 -0
  118. package/src/options.js.map +1 -0
  119. package/src/pen/arrow.d.ts +4 -0
  120. package/src/pen/arrow.js +186 -0
  121. package/src/pen/arrow.js.map +1 -0
  122. package/src/pen/index.d.ts +5 -0
  123. package/src/pen/index.js +6 -0
  124. package/src/pen/index.js.map +1 -0
  125. package/src/pen/math.d.ts +28 -0
  126. package/src/pen/math.js +304 -0
  127. package/src/pen/math.js.map +1 -0
  128. package/src/pen/model.d.ts +354 -0
  129. package/src/pen/model.js +172 -0
  130. package/src/pen/model.js.map +1 -0
  131. package/src/pen/render.d.ts +132 -0
  132. package/src/pen/render.js +1908 -0
  133. package/src/pen/render.js.map +1 -0
  134. package/src/pen/text.d.ts +7 -0
  135. package/src/pen/text.js +311 -0
  136. package/src/pen/text.js.map +1 -0
  137. package/src/pen/utils.d.ts +2 -0
  138. package/src/pen/utils.js +41 -0
  139. package/src/pen/utils.js.map +1 -0
  140. package/src/point/index.d.ts +1 -0
  141. package/src/point/index.js +2 -0
  142. package/src/point/index.js.map +1 -0
  143. package/src/point/point.d.ts +53 -0
  144. package/src/point/point.js +119 -0
  145. package/src/point/point.js.map +1 -0
  146. package/src/rect/index.d.ts +1 -0
  147. package/src/rect/index.js +2 -0
  148. package/src/rect/index.js.map +1 -0
  149. package/src/rect/rect.d.ts +49 -0
  150. package/src/rect/rect.js +446 -0
  151. package/src/rect/rect.js.map +1 -0
  152. package/src/rect/triangle.d.ts +2 -0
  153. package/src/rect/triangle.js +10 -0
  154. package/src/rect/triangle.js.map +1 -0
  155. package/src/scroll/index.d.ts +1 -0
  156. package/src/scroll/index.js +2 -0
  157. package/src/scroll/index.js.map +1 -0
  158. package/src/scroll/scroll.d.ts +32 -0
  159. package/src/scroll/scroll.js +193 -0
  160. package/src/scroll/scroll.js.map +1 -0
  161. package/src/store/global.d.ts +25 -0
  162. package/src/store/global.js +18 -0
  163. package/src/store/global.js.map +1 -0
  164. package/src/store/index.d.ts +2 -0
  165. package/src/store/index.js +3 -0
  166. package/src/store/index.js.map +1 -0
  167. package/src/store/store.d.ts +104 -0
  168. package/src/store/store.js +73 -0
  169. package/src/store/store.js.map +1 -0
  170. package/src/tooltip/index.d.ts +1 -0
  171. package/src/tooltip/index.js +2 -0
  172. package/src/tooltip/index.js.map +1 -0
  173. package/src/tooltip/tooltip.d.ts +40 -0
  174. package/src/tooltip/tooltip.js +162 -0
  175. package/src/tooltip/tooltip.js.map +1 -0
  176. package/src/utils/browser.d.ts +1 -0
  177. package/src/utils/browser.js +4 -0
  178. package/src/utils/browser.js.map +1 -0
  179. package/src/utils/clone.d.ts +8 -0
  180. package/src/utils/clone.js +73 -0
  181. package/src/utils/clone.js.map +1 -0
  182. package/src/utils/color.d.ts +3 -0
  183. package/src/utils/color.js +126 -0
  184. package/src/utils/color.js.map +1 -0
  185. package/src/utils/error.d.ts +2 -0
  186. package/src/utils/error.js +6 -0
  187. package/src/utils/error.js.map +1 -0
  188. package/src/utils/file.d.ts +2 -0
  189. package/src/utils/file.js +84 -0
  190. package/src/utils/file.js.map +1 -0
  191. package/src/utils/index.d.ts +7 -0
  192. package/src/utils/index.js +8 -0
  193. package/src/utils/index.js.map +1 -0
  194. package/src/utils/math.d.ts +18 -0
  195. package/src/utils/math.js +141 -0
  196. package/src/utils/math.js.map +1 -0
  197. package/src/utils/padding.d.ts +7 -0
  198. package/src/utils/padding.js +47 -0
  199. package/src/utils/padding.js.map +1 -0
  200. package/src/utils/uuid.d.ts +4 -0
  201. package/src/utils/uuid.js +13 -0
  202. package/src/utils/uuid.js.map +1 -0
@@ -0,0 +1,304 @@
1
+ var __values = (this && this.__values) || function(o) {
2
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
3
+ if (m) return m.call(o);
4
+ if (o && typeof o.length === "number") return {
5
+ next: function () {
6
+ if (o && i >= o.length) o = void 0;
7
+ return { value: o && o[i++], done: !o };
8
+ }
9
+ };
10
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
11
+ };
12
+ var __read = (this && this.__read) || function (o, n) {
13
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
14
+ if (!m) return o;
15
+ var i = m.call(o), r, ar = [], e;
16
+ try {
17
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
18
+ }
19
+ catch (error) { e = { error: error }; }
20
+ finally {
21
+ try {
22
+ if (r && !r.done && (m = i["return"])) m.call(i);
23
+ }
24
+ finally { if (e) throw e.error; }
25
+ }
26
+ return ar;
27
+ };
28
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
29
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
30
+ if (ar || !(i in from)) {
31
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
32
+ ar[i] = from[i];
33
+ }
34
+ }
35
+ return to.concat(ar || Array.prototype.slice.call(from));
36
+ };
37
+ import { PenType } from '.';
38
+ import { calcCenter, expandRect, rectInFourAngRect, rectToPoints, } from '../rect';
39
+ import { deepClone } from '../utils';
40
+ export function calcAnchorDock(store, e, curAnchor) {
41
+ var e_1, _a;
42
+ var xDock;
43
+ var yDock;
44
+ var x = Infinity;
45
+ var y = Infinity;
46
+ var size = 8;
47
+ var _loop_1 = function (pen) {
48
+ if (pen.calculative.inView === false) {
49
+ return "continue";
50
+ }
51
+ // 得到图形的全部点
52
+ var points = getPointsByPen(pen);
53
+ points.forEach(function (pt) {
54
+ if (pt === e || pt === curAnchor) {
55
+ return;
56
+ }
57
+ var distance = (pen.calculative.worldRect.center.x - e.x) *
58
+ (pen.calculative.worldRect.center.x - e.x) +
59
+ (pen.calculative.worldRect.center.y - e.y) *
60
+ (pen.calculative.worldRect.center.y - e.y);
61
+ var disX = Math.abs(pt.x - e.x);
62
+ if (disX > 0 && disX < size && distance < x) {
63
+ xDock = {
64
+ x: Math.round(pt.x) + 0.5,
65
+ y: Math.round(pt.y) + 0.5,
66
+ prev: {
67
+ x: Math.round(e.x) + 0.5,
68
+ y: Math.round(e.y) + 0.5,
69
+ },
70
+ step: pt.x - e.x,
71
+ };
72
+ x = distance;
73
+ }
74
+ var disY = Math.abs(pt.y - e.y);
75
+ if (disY > 0 && disY < size && distance < y) {
76
+ yDock = {
77
+ x: Math.round(pt.x) + 0.5,
78
+ y: Math.round(pt.y) + 0.5,
79
+ prev: {
80
+ x: Math.round(e.x) + 0.5,
81
+ y: Math.round(e.y) + 0.5,
82
+ },
83
+ step: pt.y - e.y,
84
+ };
85
+ y = distance;
86
+ }
87
+ });
88
+ };
89
+ try {
90
+ for (var _b = __values(store.data.pens), _c = _b.next(); !_c.done; _c = _b.next()) {
91
+ var pen = _c.value;
92
+ _loop_1(pen);
93
+ }
94
+ }
95
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
96
+ finally {
97
+ try {
98
+ if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
99
+ }
100
+ finally { if (e_1) throw e_1.error; }
101
+ }
102
+ return {
103
+ xDock: xDock,
104
+ yDock: yDock,
105
+ };
106
+ }
107
+ export function calcMoveDock(store, rect, pens, offset) {
108
+ // 找到 points ,深拷贝一下,不影响原值
109
+ var activePoints = [];
110
+ if (pens.length === 1) {
111
+ activePoints = deepClone(getPointsByPen(pens[0]));
112
+ activePoints.forEach(function (point) {
113
+ point.x += offset.x;
114
+ point.y += offset.y;
115
+ });
116
+ }
117
+ else {
118
+ calcCenter(rect);
119
+ activePoints = __spreadArray([rect.center], __read(rectToPoints(rect)), false);
120
+ }
121
+ return calcDockByPoints(store, activePoints, rect, true);
122
+ }
123
+ /**
124
+ * 得到画笔的全部点
125
+ * 线 即全部的 worldAnchors
126
+ * 图形 即全部的 worldAnchors ,加上边缘四个点以及中心点
127
+ * @param pen 画笔
128
+ */
129
+ export function getPointsByPen(pen) {
130
+ if (!pen.type) {
131
+ var outerPoints = rectToPoints(pen.calculative.worldRect);
132
+ calcCenter(pen.calculative.worldRect);
133
+ return __spreadArray(__spreadArray(__spreadArray([], __read(pen.calculative.worldAnchors), false), __read(outerPoints), false), [
134
+ pen.calculative.worldRect.center,
135
+ ], false);
136
+ }
137
+ else if (pen.type === PenType.Line) {
138
+ return pen.calculative.worldAnchors;
139
+ }
140
+ }
141
+ export function calcResizeDock(store, rect, pens, resizeIndex) {
142
+ var activePoints = rectToPoints(rect);
143
+ return calcDockByPoints(store, activePoints, rect);
144
+ }
145
+ /**
146
+ * 通过当前 活动层 的所有点 计算 dock
147
+ * @param activePoints 活动层 的所有点
148
+ * @param rect 当前区域
149
+ * @param calcActive 是否与 活动层画笔 的点进行计算
150
+ */
151
+ function calcDockByPoints(store, activePoints, rect, calcActive) {
152
+ if (calcActive === void 0) { calcActive = false; }
153
+ var xDock;
154
+ var yDock;
155
+ var minCloseX = Infinity;
156
+ var minCloseY = Infinity;
157
+ // 临近范围
158
+ var closeSize = 10;
159
+ var paddingRect = expandRect(rect, closeSize);
160
+ store.data.pens.forEach(function (pen) {
161
+ var e_2, _a, e_3, _b;
162
+ var _c = pen.calculative, inView = _c.inView, worldRect = _c.worldRect, active = _c.active;
163
+ if (inView === false ||
164
+ (!calcActive && active) || // 如果不计算活动层,则过滤掉活动层
165
+ rectInFourAngRect(paddingRect, worldRect) || // 水平和垂直方向 无重合
166
+ (pen.type &&
167
+ store.active.some(function (active) { return isConnectLine(store, active, pen); }))) {
168
+ return;
169
+ }
170
+ // 得到图形的全部点
171
+ var points = getPointsByPen(pen);
172
+ if (!points) {
173
+ return;
174
+ }
175
+ try {
176
+ // 比对 points 中的点,必须找出最近的点,不可提前跳出
177
+ for (var points_1 = __values(points), points_1_1 = points_1.next(); !points_1_1.done; points_1_1 = points_1.next()) {
178
+ var point = points_1_1.value;
179
+ try {
180
+ for (var activePoints_1 = (e_3 = void 0, __values(activePoints)), activePoints_1_1 = activePoints_1.next(); !activePoints_1_1.done; activePoints_1_1 = activePoints_1.next()) {
181
+ var activePoint = activePoints_1_1.value;
182
+ var stepX = point.x - activePoint.x;
183
+ var stepY = point.y - activePoint.y;
184
+ var absStepX = Math.abs(stepX);
185
+ var absStepY = Math.abs(stepY);
186
+ if (!rect.center) {
187
+ rect.center = {
188
+ x: rect.x + rect.width / 2,
189
+ y: rect.y + rect.height / 2,
190
+ };
191
+ }
192
+ if (absStepX < closeSize && absStepX < minCloseX) {
193
+ xDock = {
194
+ x: Math.round(point.x) + 0.5,
195
+ y: Math.round(point.y) + 0.5,
196
+ step: stepX,
197
+ prev: {
198
+ x: Math.round(activePoint.x) + 0.5,
199
+ y: Math.round(activePoint.y) + 0.5,
200
+ },
201
+ penId: pen.id,
202
+ anchorId: activePoint.id,
203
+ dockAnchorId: point.id,
204
+ };
205
+ minCloseX = absStepX;
206
+ }
207
+ if (absStepY < closeSize && absStepY < minCloseY) {
208
+ yDock = {
209
+ x: Math.round(point.x) + 0.5,
210
+ y: Math.round(point.y) + 0.5,
211
+ step: stepY,
212
+ prev: {
213
+ x: Math.round(activePoint.x) + 0.5,
214
+ y: Math.round(activePoint.y) + 0.5,
215
+ },
216
+ penId: pen.id,
217
+ anchorId: activePoint.id,
218
+ dockAnchorId: point.id,
219
+ };
220
+ minCloseY = absStepY;
221
+ }
222
+ }
223
+ }
224
+ catch (e_3_1) { e_3 = { error: e_3_1 }; }
225
+ finally {
226
+ try {
227
+ if (activePoints_1_1 && !activePoints_1_1.done && (_b = activePoints_1.return)) _b.call(activePoints_1);
228
+ }
229
+ finally { if (e_3) throw e_3.error; }
230
+ }
231
+ }
232
+ }
233
+ catch (e_2_1) { e_2 = { error: e_2_1 }; }
234
+ finally {
235
+ try {
236
+ if (points_1_1 && !points_1_1.done && (_a = points_1.return)) _a.call(points_1);
237
+ }
238
+ finally { if (e_2) throw e_2.error; }
239
+ }
240
+ });
241
+ return {
242
+ xDock: xDock,
243
+ yDock: yDock,
244
+ };
245
+ }
246
+ /**
247
+ * 判断 line 是否是 active 的连接线(并且计算子节点)
248
+ * @param store
249
+ * @param active 本次计算的画笔
250
+ * @param line 连线
251
+ * @returns
252
+ */
253
+ function isConnectLine(store, active, line) {
254
+ var e_4, _a, e_5, _b;
255
+ if (!line.type) {
256
+ return false;
257
+ }
258
+ if (Array.isArray(active === null || active === void 0 ? void 0 : active.connectedLines)) {
259
+ try {
260
+ for (var _c = __values(active === null || active === void 0 ? void 0 : active.connectedLines), _d = _c.next(); !_d.done; _d = _c.next()) {
261
+ var cline = _d.value;
262
+ if (cline.lineId === line.id) {
263
+ return true;
264
+ }
265
+ }
266
+ }
267
+ catch (e_4_1) { e_4 = { error: e_4_1 }; }
268
+ finally {
269
+ try {
270
+ if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
271
+ }
272
+ finally { if (e_4) throw e_4.error; }
273
+ }
274
+ }
275
+ // 考虑子节点
276
+ if (Array.isArray(active === null || active === void 0 ? void 0 : active.children)) {
277
+ try {
278
+ for (var _e = __values(active.children), _f = _e.next(); !_f.done; _f = _e.next()) {
279
+ var id = _f.value;
280
+ var child = store.pens[id];
281
+ if (isConnectLine(store, child, line)) {
282
+ return true;
283
+ }
284
+ }
285
+ }
286
+ catch (e_5_1) { e_5 = { error: e_5_1 }; }
287
+ finally {
288
+ try {
289
+ if (_f && !_f.done && (_b = _e.return)) _b.call(_e);
290
+ }
291
+ finally { if (e_5) throw e_5.error; }
292
+ }
293
+ }
294
+ return false;
295
+ }
296
+ /**
297
+ * 是否近似于 num
298
+ * @param num
299
+ */
300
+ export function isEqual(source, target) {
301
+ // @ts-ignore
302
+ return source.toFixed(12) == target;
303
+ }
304
+ //# sourceMappingURL=math.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"math.js","sourceRoot":"","sources":["../../../../packages/core/src/pen/math.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,354 @@
1
+ import { Point } from '../point';
2
+ import { Rect } from '../rect';
3
+ import { Event } from '../event';
4
+ import { Canvas } from '../canvas';
5
+ export declare enum PenType {
6
+ Node = 0,
7
+ Line = 1
8
+ }
9
+ export declare enum LockState {
10
+ None = 0,
11
+ DisableEdit = 1,
12
+ DisableMove = 2,
13
+ DisableScale = 3,
14
+ DisableMoveScale = 4,
15
+ Disable = 10
16
+ }
17
+ export declare enum AnchorMode {
18
+ Default = 0,
19
+ In = 1,
20
+ Out = 2
21
+ }
22
+ export declare enum Gradient {
23
+ None = 0,
24
+ Linear = 1,
25
+ Radial = 2
26
+ }
27
+ export declare const needCalcTextRectProps: string[];
28
+ export declare const needSetPenProps: string[];
29
+ export declare const needPatchFlagsPenRectProps: string[];
30
+ export declare const needCalcIconRectProps: string[];
31
+ export interface ConnectLine {
32
+ lineId: string;
33
+ lineAnchor: string;
34
+ anchor: string;
35
+ }
36
+ export declare type TextAlign = 'left' | 'center' | 'right';
37
+ export declare type TextBaseline = 'top' | 'middle' | 'bottom';
38
+ export declare type WhiteSpace = 'nowrap' | 'pre-line' | 'break-all' | '';
39
+ export declare type IValue = Pen & Partial<ChartData> & Partial<Record<'tag' | 'newId', string>> & {
40
+ [key: string]: any;
41
+ };
42
+ export declare type Dropdown = string | IValue;
43
+ export declare enum LineAnimateType {
44
+ Normal = 0,
45
+ Beads = 1,
46
+ Dot = 2
47
+ }
48
+ export interface Pen extends Rect {
49
+ id?: string;
50
+ tags?: string[];
51
+ parentId?: string;
52
+ type?: PenType;
53
+ name?: string;
54
+ lineName?: string;
55
+ borderRadius?: number;
56
+ visible?: boolean;
57
+ locked?: LockState;
58
+ close?: boolean;
59
+ length?: number;
60
+ title?: string;
61
+ titleFnJs?: string;
62
+ titleFn?: (pen: Pen) => string;
63
+ lineWidth?: number;
64
+ borderWidth?: number;
65
+ borderColor?: string;
66
+ globalAlpha?: number;
67
+ lineDash?: number[];
68
+ lineDashOffset?: number;
69
+ color?: string;
70
+ background?: string;
71
+ anchorColor?: string;
72
+ hoverAnchorColor?: string;
73
+ hoverColor?: string;
74
+ hoverBackground?: string;
75
+ activeColor?: string;
76
+ activeBackground?: string;
77
+ bkType?: Gradient;
78
+ gradientFromColor?: string;
79
+ gradientToColor?: string;
80
+ gradientAngle?: number;
81
+ gradientRadius?: number;
82
+ strokeType?: Gradient;
83
+ lineGradientFromColor?: string;
84
+ lineGradientToColor?: string;
85
+ lineGradientAngle?: number;
86
+ lineCap?: CanvasLineCap;
87
+ lineJoin?: CanvasLineJoin;
88
+ shadowColor?: string;
89
+ shadowBlur?: number;
90
+ shadowOffsetX?: number;
91
+ shadowOffsetY?: number;
92
+ textHasShadow?: boolean;
93
+ text?: string;
94
+ textWidth?: number;
95
+ textHeight?: number;
96
+ textLeft?: number;
97
+ textTop?: number;
98
+ textColor?: string;
99
+ hoverTextColor?: string;
100
+ activeTextColor?: string;
101
+ fontFamily?: string;
102
+ fontSize?: number;
103
+ lineHeight?: number;
104
+ fontStyle?: string;
105
+ fontWeight?: string;
106
+ textAlign?: TextAlign;
107
+ textBaseline?: TextBaseline;
108
+ textBackground?: string;
109
+ whiteSpace?: WhiteSpace;
110
+ ellipsis?: boolean;
111
+ image?: string;
112
+ icon?: string;
113
+ iconRotate?: number;
114
+ iconWidth?: number;
115
+ iconHeight?: number;
116
+ iconTop?: number;
117
+ iconLeft?: number;
118
+ iconColor?: string;
119
+ iconFamily?: string;
120
+ iconWeight?: string;
121
+ iconSize?: number;
122
+ iconAlign?: 'top' | 'bottom' | 'left' | 'right' | 'left-top' | 'right-top' | 'left-bottom' | 'right-bottom' | 'center';
123
+ imageRatio?: boolean;
124
+ disableInput?: boolean;
125
+ disableRotate?: boolean;
126
+ disableSize?: boolean;
127
+ disableAnchor?: boolean;
128
+ paddingTop?: number;
129
+ paddingBottom?: number;
130
+ paddingLeft?: number;
131
+ paddingRight?: number;
132
+ backgroundImage?: string;
133
+ strokeImage?: string;
134
+ children?: string[];
135
+ anchors?: Point[];
136
+ anchorRadius?: number;
137
+ anchorBackground?: string;
138
+ pathId?: string;
139
+ path?: string;
140
+ fromArrow?: string;
141
+ toArrow?: string;
142
+ fromArrowSize?: number;
143
+ toArrowSize?: number;
144
+ fromArrowColor?: string;
145
+ toArrowColor?: string;
146
+ autoFrom?: boolean;
147
+ autoTo?: boolean;
148
+ connectedLines?: ConnectLine[];
149
+ animateCycle?: number;
150
+ nextAnimate?: string;
151
+ autoPlay?: boolean;
152
+ playLoop?: boolean;
153
+ duration?: number;
154
+ linear?: boolean;
155
+ scale?: number;
156
+ animateSpan?: number;
157
+ animateColor?: string;
158
+ animateLineDash?: number[];
159
+ animateReverse?: boolean;
160
+ keepAnimateState?: boolean;
161
+ lineAnimateType?: LineAnimateType;
162
+ frames?: Pen[];
163
+ animateList?: Pen[][];
164
+ input?: boolean;
165
+ dropdownList?: Dropdown[];
166
+ events?: Event[];
167
+ iframe?: string;
168
+ video?: string;
169
+ audio?: string;
170
+ progress?: number;
171
+ progressColor?: string;
172
+ verticalProgress?: boolean;
173
+ externElement?: boolean;
174
+ autoPolyline?: boolean;
175
+ flipX?: boolean;
176
+ flipY?: boolean;
177
+ fillTexts?: string[];
178
+ hiddenText?: boolean;
179
+ keepDecimal?: number;
180
+ showChild?: number;
181
+ animateDotSize?: number;
182
+ isRuleLine?: boolean;
183
+ isBottom?: boolean;
184
+ form?: FormItem[];
185
+ lockedOnCombine?: LockState;
186
+ calculative?: {
187
+ x?: number;
188
+ y?: number;
189
+ width?: number;
190
+ height?: number;
191
+ borderRadius?: number;
192
+ progress?: number;
193
+ progressColor?: string;
194
+ worldRect?: Rect;
195
+ worldAnchors?: Point[];
196
+ worldIconRect?: Rect;
197
+ worldTextRect?: Rect;
198
+ textDrawRect?: Rect;
199
+ svgRect?: Rect;
200
+ initRect?: Rect;
201
+ rotate?: number;
202
+ lineWidth?: number;
203
+ borderWidth?: number;
204
+ borderColor?: string;
205
+ globalAlpha?: number;
206
+ lineDash?: number[];
207
+ lineDashOffset?: number;
208
+ color?: string;
209
+ background?: string;
210
+ bkType?: number;
211
+ gradientFromColor?: string;
212
+ gradientToColor?: string;
213
+ gradientAngle?: number;
214
+ gradientRadius?: number;
215
+ strokeType?: Gradient;
216
+ lineGradientFromColor?: string;
217
+ lineGradientToColor?: string;
218
+ lineGradientAngle?: number;
219
+ shadowColor?: string;
220
+ shadowBlur?: number;
221
+ shadowOffsetX?: number;
222
+ shadowOffsetY?: number;
223
+ textHasShadow?: boolean;
224
+ tempText?: string;
225
+ text?: string;
226
+ textWidth?: number;
227
+ textHeight?: number;
228
+ textLeft?: number;
229
+ textTop?: number;
230
+ textColor?: string;
231
+ fontFamily?: string;
232
+ fontSize?: number;
233
+ lineHeight?: number;
234
+ fontStyle?: string;
235
+ fontWeight?: string;
236
+ textBackground?: string;
237
+ iconSize?: number;
238
+ icon?: string;
239
+ iconRotate?: number;
240
+ iconWidth?: number;
241
+ iconHeight?: number;
242
+ iconTop?: number;
243
+ iconLeft?: number;
244
+ iconColor?: string;
245
+ iconFamily?: string;
246
+ iconWeight?: string;
247
+ paddingTop?: number;
248
+ paddingBottom?: number;
249
+ paddingLeft?: number;
250
+ paddingRight?: number;
251
+ textLines?: string[];
252
+ textLineWidths?: number[];
253
+ image?: string;
254
+ img?: HTMLImageElement;
255
+ imgNaturalWidth?: number;
256
+ imgNaturalHeight?: number;
257
+ backgroundImage?: string;
258
+ strokeImage?: string;
259
+ backgroundImg?: HTMLImageElement;
260
+ strokeImg?: HTMLImageElement;
261
+ active?: boolean;
262
+ hover?: boolean;
263
+ isDock?: boolean;
264
+ pencil?: boolean;
265
+ activeAnchor?: Point;
266
+ patchFlags?: boolean;
267
+ visible?: boolean;
268
+ inView?: boolean;
269
+ drawlineH?: boolean;
270
+ hasImage?: boolean;
271
+ imageDrawed?: boolean;
272
+ isBottom?: boolean;
273
+ scale?: number;
274
+ start?: number;
275
+ duration?: number;
276
+ end?: number;
277
+ frameIndex?: number;
278
+ frameStart?: number;
279
+ frameEnd?: number;
280
+ frameDuration?: number;
281
+ animatePos?: number;
282
+ cycleIndex?: number;
283
+ pause?: number;
284
+ layer?: number;
285
+ canvas?: Canvas;
286
+ iframe?: string;
287
+ video?: string;
288
+ audio?: string;
289
+ media?: HTMLMediaElement;
290
+ flipX?: boolean;
291
+ flipY?: boolean;
292
+ h?: boolean;
293
+ hiddenText?: boolean;
294
+ keepDecimal?: number;
295
+ showChild?: number;
296
+ animateDotSize?: number;
297
+ zIndex?: number;
298
+ onended?: (pen: Pen) => void;
299
+ singleton?: any;
300
+ };
301
+ prevFrame?: Pen;
302
+ onAdd?: (pen: Pen) => void;
303
+ onValue?: (pen: Pen) => void;
304
+ onBeforeValue?: (pen: Pen, value: ChartData) => any;
305
+ onDestroy?: (pen: Pen) => void;
306
+ onMove?: (pen: Pen) => void;
307
+ onResize?: (pen: Pen) => void;
308
+ onRotate?: (pen: Pen) => void;
309
+ onClick?: (pen: Pen, e: Point) => void;
310
+ onMouseEnter?: (pen: Pen, e: Point) => void;
311
+ onMouseLeave?: (pen: Pen, e: Point) => void;
312
+ onMouseDown?: (pen: Pen, e: Point) => void;
313
+ onMouseMove?: (pen: Pen, e: Point) => void;
314
+ onMouseUp?: (pen: Pen, e: Point) => void;
315
+ onShowInput?: (pen: Pen, e: Point) => void;
316
+ onInput?: (pen: Pen, text: string) => void;
317
+ onChangeId?: (pen: Pen, oldId: string, newId: string) => void;
318
+ onBinds?: (pen: Pen, values: IValue[], formItem: FormItem) => IValue;
319
+ onStartVideo?: (pen: Pen) => void;
320
+ onPauseVideo?: (pen: Pen) => void;
321
+ onStopVideo?: (pen: Pen) => void;
322
+ }
323
+ export interface FormItem {
324
+ key: string;
325
+ /**
326
+ * 单属性绑定单变量 或 绑定多变量
327
+ * 为数组时,顺序不重要
328
+ */
329
+ dataIds?: BindId | BindId[];
330
+ }
331
+ export declare type BindId = {
332
+ dataId: string;
333
+ name: string;
334
+ };
335
+ /**
336
+ * 图表追加或替换数据,只关注数据
337
+ */
338
+ export interface ChartData {
339
+ dataX: any | any[];
340
+ dataY: any | any[];
341
+ /**
342
+ * @deprecated 旧版本,未来移除该属性
343
+ */
344
+ overwrite?: boolean;
345
+ }
346
+ /**
347
+ * dom 类型的 图形
348
+ */
349
+ export declare const isDomShapes: string[];
350
+ export declare const formatAttrs: Set<string>;
351
+ /**
352
+ * 清空 pen 的 生命周期
353
+ */
354
+ export declare function clearLifeCycle(pen: Pen): void;