build-dxf 0.0.48 → 0.0.49
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/package.json +1 -1
- package/src/build.js +1641 -1213
- package/src/index.css +1 -1
- package/src/index3.js +975 -927
- package/src/utils/CommandManager/CommandFlow.d.ts +2 -0
- package/src/utils/DxfSystem/plugin/Editor/components/CommandFlow/CommandFlowComponent.d.ts +1 -1
- package/src/utils/DxfSystem/plugin/Editor/components/CommandFlow/DrawLine.d.ts +7 -0
- package/src/utils/DxfSystem/type.d.ts +9 -1
- package/src/utils/DxfSystem/utils/DoubleWallHelper.d.ts +0 -1
- package/src/utils/DxfSystem/utils/LineGroupType.d.ts +81 -0
- package/src/utils/DxfSystem/utils/findClosedPolygons01.d.ts +4 -17
- package/src/utils/DxfSystem/utils/findDiscretePointLine.d.ts +1 -1
- package/src/utils/DxfSystem/utils/findLargestCircle.d.ts +14 -0
- package/src/utils/DxfSystem/utils/index.d.ts +11 -0
- package/src/utils/DxfSystem/utils/mergeSmallestCircle.d.ts +14 -0
- package/src/utils/DxfSystem/utils/recomputedWindow.d.ts +5 -0
- package/src/utils/DxfSystem/utils/smallestCircle.d.ts +6 -0
- package/src/utils/LineIndexGenerator.d.ts +3 -1
- package/src/utils/LineSegment.d.ts +16 -1
- package/src/utils/Map.d.ts +3 -0
- package/src/utils/Point.d.ts +1 -0
- package/src/utils/PointVirtualGrid/index.d.ts +5 -4
- package/src/utils/Polygon.d.ts +26 -0
- package/src/utils/UndirectedGraph.d.ts +39 -9
- package/src/utils/index.d.ts +17 -0
- package/src/utils/DxfSystem/utils/BoundExtOld.d.ts +0 -16
- package/src/utils/DxfSystem/utils/TrajectoryHelper.d.ts +0 -29
- package/src/utils/DxfSystem/utils/findClosedPolygons.d.ts +0 -22
- package/src/utils/Path.d.ts +0 -6
package/src/index3.js
CHANGED
|
@@ -1,73 +1,73 @@
|
|
|
1
|
-
import * as
|
|
2
|
-
import { i as
|
|
3
|
-
import { C as
|
|
1
|
+
import * as p from "three";
|
|
2
|
+
import { i as Ct, n as bt, r as Xe, t as $e, c as Pe, d as Et, e as xt, f as Be, g as G, _ as et, u as At, h as we, j as Ne, w as Lt, k as Mt, l as It, p as kt, m as Dt, o as Pt, T as Re, q as ze, s as Bt, v as St, x as Oe, y as De, z as Ie, A as Ft, B as Kt, L as Ce, D as Nt, b as Qe, E as ce, S as Rt } from "./selectLocalFile.js";
|
|
3
|
+
import { C as Se, P as A, L as N, B as tt, E as nt, b as Te, Q as Ve, c as je, d as zt, u as Ot, A as Qt, r as _e, W as Tt, T as Vt, V as jt } from "./build.js";
|
|
4
4
|
import "clipper-lib";
|
|
5
5
|
import "dxf-writer";
|
|
6
|
-
import { watch as
|
|
6
|
+
import { watch as J, ref as P, defineComponent as pe, computed as D, createElementBlock as K, openBlock as k, normalizeClass as j, unref as f, renderSlot as Ee, createVNode as O, Transition as xe, withCtx as V, withDirectives as ot, createElementVNode as M, normalizeStyle as Fe, createTextVNode as te, toDisplayString as me, vShow as st, shallowReactive as _t, onMounted as at, createBlock as fe, createCommentVNode as H, resolveDynamicComponent as Gt, Fragment as ye, withModifiers as Ut, nextTick as be, isVNode as it, render as Ge, toRaw as Jt, onUnmounted as Ht, renderList as ke, createStaticVNode as Wt, TransitionGroup as qt, createApp as Zt } from "vue";
|
|
7
7
|
import "three/addons/controls/OrbitControls.js";
|
|
8
|
-
function
|
|
8
|
+
function rt(c) {
|
|
9
9
|
var e;
|
|
10
|
-
const t =
|
|
10
|
+
const t = Xe(c);
|
|
11
11
|
return (e = t?.$el) != null ? e : t;
|
|
12
12
|
}
|
|
13
|
-
const
|
|
14
|
-
function
|
|
15
|
-
let e, t, n,
|
|
16
|
-
if (
|
|
17
|
-
return
|
|
13
|
+
const dt = Pe ? window : void 0;
|
|
14
|
+
function Yt(...c) {
|
|
15
|
+
let e, t, n, o;
|
|
16
|
+
if (Ct(c[0]) || Array.isArray(c[0]) ? ([t, n, o] = c, e = dt) : [e, t, n, o] = c, !e)
|
|
17
|
+
return bt;
|
|
18
18
|
Array.isArray(t) || (t = [t]), Array.isArray(n) || (n = [n]);
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
},
|
|
22
|
-
a(),
|
|
19
|
+
const s = [], a = () => {
|
|
20
|
+
s.forEach((l) => l()), s.length = 0;
|
|
21
|
+
}, d = (l, m, g, w) => (l.addEventListener(m, g, w), () => l.removeEventListener(m, g, w)), r = J(() => [rt(e), Xe(o)], ([l, m]) => {
|
|
22
|
+
a(), l && s.push(...t.flatMap((g) => n.map((w) => d(l, g, w, m))));
|
|
23
23
|
}, { immediate: !0, flush: "post" }), i = () => {
|
|
24
24
|
r(), a();
|
|
25
25
|
};
|
|
26
|
-
return
|
|
26
|
+
return $e(i), i;
|
|
27
27
|
}
|
|
28
|
-
function
|
|
29
|
-
const t =
|
|
30
|
-
return n(),
|
|
28
|
+
function Xt(c, e = !1) {
|
|
29
|
+
const t = P(), n = () => t.value = !!c();
|
|
30
|
+
return n(), Et(n, e), t;
|
|
31
31
|
}
|
|
32
|
-
const
|
|
33
|
-
|
|
34
|
-
var
|
|
32
|
+
const Ue = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof global < "u" ? global : typeof self < "u" ? self : {}, Je = "__vueuse_ssr_handlers__";
|
|
33
|
+
Ue[Je] = Ue[Je] || {};
|
|
34
|
+
var He = Object.getOwnPropertySymbols, $t = Object.prototype.hasOwnProperty, en = Object.prototype.propertyIsEnumerable, tn = (c, e) => {
|
|
35
35
|
var t = {};
|
|
36
36
|
for (var n in c)
|
|
37
|
-
|
|
38
|
-
if (c != null &&
|
|
39
|
-
for (var n of
|
|
40
|
-
e.indexOf(n) < 0 &&
|
|
37
|
+
$t.call(c, n) && e.indexOf(n) < 0 && (t[n] = c[n]);
|
|
38
|
+
if (c != null && He)
|
|
39
|
+
for (var n of He(c))
|
|
40
|
+
e.indexOf(n) < 0 && en.call(c, n) && (t[n] = c[n]);
|
|
41
41
|
return t;
|
|
42
42
|
};
|
|
43
|
-
function
|
|
44
|
-
const n = t, { window:
|
|
43
|
+
function nn(c, e, t = {}) {
|
|
44
|
+
const n = t, { window: o = dt } = n, s = tn(n, ["window"]);
|
|
45
45
|
let a;
|
|
46
|
-
const
|
|
46
|
+
const d = Xt(() => o && "ResizeObserver" in o), r = () => {
|
|
47
47
|
a && (a.disconnect(), a = void 0);
|
|
48
|
-
}, i =
|
|
49
|
-
r(),
|
|
50
|
-
}, { immediate: !0, flush: "post" }),
|
|
48
|
+
}, i = J(() => rt(c), (m) => {
|
|
49
|
+
r(), d.value && o && m && (a = new ResizeObserver(e), a.observe(m, s));
|
|
50
|
+
}, { immediate: !0, flush: "post" }), l = () => {
|
|
51
51
|
r(), i();
|
|
52
52
|
};
|
|
53
|
-
return
|
|
54
|
-
isSupported:
|
|
55
|
-
stop:
|
|
53
|
+
return $e(l), {
|
|
54
|
+
isSupported: d,
|
|
55
|
+
stop: l
|
|
56
56
|
};
|
|
57
57
|
}
|
|
58
|
-
var
|
|
58
|
+
var We;
|
|
59
59
|
(function(c) {
|
|
60
60
|
c.UP = "UP", c.RIGHT = "RIGHT", c.DOWN = "DOWN", c.LEFT = "LEFT", c.NONE = "NONE";
|
|
61
|
-
})(
|
|
62
|
-
var
|
|
61
|
+
})(We || (We = {}));
|
|
62
|
+
var on = Object.defineProperty, qe = Object.getOwnPropertySymbols, sn = Object.prototype.hasOwnProperty, an = Object.prototype.propertyIsEnumerable, Ze = (c, e, t) => e in c ? on(c, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : c[e] = t, rn = (c, e) => {
|
|
63
63
|
for (var t in e || (e = {}))
|
|
64
|
-
|
|
65
|
-
if (
|
|
66
|
-
for (var t of
|
|
67
|
-
|
|
64
|
+
sn.call(e, t) && Ze(c, t, e[t]);
|
|
65
|
+
if (qe)
|
|
66
|
+
for (var t of qe(e))
|
|
67
|
+
an.call(e, t) && Ze(c, t, e[t]);
|
|
68
68
|
return c;
|
|
69
69
|
};
|
|
70
|
-
const
|
|
70
|
+
const dn = {
|
|
71
71
|
easeInSine: [0.12, 0, 0.39, 0],
|
|
72
72
|
easeOutSine: [0.61, 1, 0.88, 1],
|
|
73
73
|
easeInOutSine: [0.37, 0, 0.63, 1],
|
|
@@ -93,12 +93,12 @@ const en = {
|
|
|
93
93
|
easeOutBack: [0.34, 1.56, 0.64, 1],
|
|
94
94
|
easeInOutBack: [0.68, -0.6, 0.32, 1.6]
|
|
95
95
|
};
|
|
96
|
-
|
|
97
|
-
linear:
|
|
98
|
-
},
|
|
99
|
-
const
|
|
96
|
+
rn({
|
|
97
|
+
linear: xt
|
|
98
|
+
}, dn);
|
|
99
|
+
const ln = (c) => c, cn = {
|
|
100
100
|
esc: "Escape"
|
|
101
|
-
},
|
|
101
|
+
}, mn = Be({
|
|
102
102
|
value: {
|
|
103
103
|
type: [String, Number],
|
|
104
104
|
default: ""
|
|
@@ -120,59 +120,59 @@ const tn = (c) => c, nn = {
|
|
|
120
120
|
},
|
|
121
121
|
color: String,
|
|
122
122
|
badgeStyle: {
|
|
123
|
-
type:
|
|
123
|
+
type: G([String, Object, Array])
|
|
124
124
|
},
|
|
125
125
|
offset: {
|
|
126
|
-
type:
|
|
126
|
+
type: G(Array),
|
|
127
127
|
default: [0, 0]
|
|
128
128
|
},
|
|
129
129
|
badgeClass: {
|
|
130
130
|
type: String
|
|
131
131
|
}
|
|
132
|
-
}),
|
|
132
|
+
}), hn = pe({
|
|
133
133
|
name: "ElBadge"
|
|
134
|
-
}),
|
|
135
|
-
...
|
|
136
|
-
props:
|
|
134
|
+
}), un = /* @__PURE__ */ pe({
|
|
135
|
+
...hn,
|
|
136
|
+
props: mn,
|
|
137
137
|
setup(c, { expose: e }) {
|
|
138
|
-
const t = c, n =
|
|
139
|
-
var a,
|
|
138
|
+
const t = c, n = At("badge"), o = D(() => t.isDot ? "" : we(t.value) && we(t.max) ? t.max < t.value ? `${t.max}+` : `${t.value}` : `${t.value}`), s = D(() => {
|
|
139
|
+
var a, d, r, i, l;
|
|
140
140
|
return [
|
|
141
141
|
{
|
|
142
142
|
backgroundColor: t.color,
|
|
143
|
-
marginRight:
|
|
144
|
-
marginTop:
|
|
143
|
+
marginRight: Ne(-((d = (a = t.offset) == null ? void 0 : a[0]) != null ? d : 0)),
|
|
144
|
+
marginTop: Ne((i = (r = t.offset) == null ? void 0 : r[1]) != null ? i : 0)
|
|
145
145
|
},
|
|
146
|
-
(
|
|
146
|
+
(l = t.badgeStyle) != null ? l : {}
|
|
147
147
|
];
|
|
148
148
|
});
|
|
149
149
|
return e({
|
|
150
|
-
content:
|
|
151
|
-
}), (a,
|
|
152
|
-
class:
|
|
150
|
+
content: o
|
|
151
|
+
}), (a, d) => (k(), K("div", {
|
|
152
|
+
class: j(f(n).b())
|
|
153
153
|
}, [
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
name: `${
|
|
154
|
+
Ee(a.$slots, "default"),
|
|
155
|
+
O(xe, {
|
|
156
|
+
name: `${f(n).namespace.value}-zoom-in-center`,
|
|
157
157
|
persisted: ""
|
|
158
158
|
}, {
|
|
159
|
-
default:
|
|
160
|
-
|
|
161
|
-
class:
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
159
|
+
default: V(() => [
|
|
160
|
+
ot(M("sup", {
|
|
161
|
+
class: j([
|
|
162
|
+
f(n).e("content"),
|
|
163
|
+
f(n).em("content", a.type),
|
|
164
|
+
f(n).is("fixed", !!a.$slots.default),
|
|
165
|
+
f(n).is("dot", a.isDot),
|
|
166
|
+
f(n).is("hide-zero", !a.showZero && t.value === 0),
|
|
167
167
|
a.badgeClass
|
|
168
168
|
]),
|
|
169
|
-
style:
|
|
169
|
+
style: Fe(f(s))
|
|
170
170
|
}, [
|
|
171
|
-
|
|
172
|
-
|
|
171
|
+
Ee(a.$slots, "content", { value: f(o) }, () => [
|
|
172
|
+
te(me(f(o)), 1)
|
|
173
173
|
])
|
|
174
174
|
], 6), [
|
|
175
|
-
[
|
|
175
|
+
[st, !a.hidden && (f(o) || a.isDot || a.$slots.content)]
|
|
176
176
|
])
|
|
177
177
|
]),
|
|
178
178
|
_: 3
|
|
@@ -180,63 +180,63 @@ const tn = (c) => c, nn = {
|
|
|
180
180
|
], 2));
|
|
181
181
|
}
|
|
182
182
|
});
|
|
183
|
-
var
|
|
184
|
-
const
|
|
183
|
+
var pn = /* @__PURE__ */ et(un, [["__file", "badge.vue"]]);
|
|
184
|
+
const gn = Lt(pn), vn = Be({
|
|
185
185
|
a11y: {
|
|
186
186
|
type: Boolean,
|
|
187
187
|
default: !0
|
|
188
188
|
},
|
|
189
189
|
locale: {
|
|
190
|
-
type:
|
|
190
|
+
type: G(Object)
|
|
191
191
|
},
|
|
192
|
-
size:
|
|
192
|
+
size: It,
|
|
193
193
|
button: {
|
|
194
|
-
type:
|
|
194
|
+
type: G(Object)
|
|
195
195
|
},
|
|
196
196
|
card: {
|
|
197
|
-
type:
|
|
197
|
+
type: G(Object)
|
|
198
198
|
},
|
|
199
199
|
dialog: {
|
|
200
|
-
type:
|
|
200
|
+
type: G(Object)
|
|
201
201
|
},
|
|
202
202
|
link: {
|
|
203
|
-
type:
|
|
203
|
+
type: G(Object)
|
|
204
204
|
},
|
|
205
205
|
experimentalFeatures: {
|
|
206
|
-
type:
|
|
206
|
+
type: G(Object)
|
|
207
207
|
},
|
|
208
208
|
keyboardNavigation: {
|
|
209
209
|
type: Boolean,
|
|
210
210
|
default: !0
|
|
211
211
|
},
|
|
212
212
|
message: {
|
|
213
|
-
type:
|
|
213
|
+
type: G(Object)
|
|
214
214
|
},
|
|
215
215
|
zIndex: Number,
|
|
216
216
|
namespace: {
|
|
217
217
|
type: String,
|
|
218
218
|
default: "el"
|
|
219
219
|
},
|
|
220
|
-
...
|
|
220
|
+
...Mt
|
|
221
221
|
}), T = {};
|
|
222
|
-
|
|
222
|
+
pe({
|
|
223
223
|
name: "ElConfigProvider",
|
|
224
|
-
props:
|
|
224
|
+
props: vn,
|
|
225
225
|
setup(c, { slots: e }) {
|
|
226
|
-
const t =
|
|
227
|
-
return
|
|
228
|
-
var
|
|
229
|
-
Object.assign(T, (
|
|
230
|
-
}, { immediate: !0, deep: !0 }), () =>
|
|
226
|
+
const t = kt(c);
|
|
227
|
+
return J(() => c.message, (n) => {
|
|
228
|
+
var o, s;
|
|
229
|
+
Object.assign(T, (s = (o = t?.value) == null ? void 0 : o.message) != null ? s : {}, n ?? {});
|
|
230
|
+
}, { immediate: !0, deep: !0 }), () => Ee(e, "default", { config: t?.value });
|
|
231
231
|
}
|
|
232
232
|
});
|
|
233
|
-
const
|
|
233
|
+
const lt = [
|
|
234
234
|
"primary",
|
|
235
235
|
"success",
|
|
236
236
|
"info",
|
|
237
237
|
"warning",
|
|
238
238
|
"error"
|
|
239
|
-
],
|
|
239
|
+
], R = ln({
|
|
240
240
|
customClass: "",
|
|
241
241
|
dangerouslyUseHTMLString: !1,
|
|
242
242
|
duration: 3e3,
|
|
@@ -252,270 +252,270 @@ const it = [
|
|
|
252
252
|
grouping: !1,
|
|
253
253
|
repeatNum: 1,
|
|
254
254
|
appendTo: Pe ? document.body : void 0
|
|
255
|
-
}),
|
|
255
|
+
}), fn = Be({
|
|
256
256
|
customClass: {
|
|
257
257
|
type: String,
|
|
258
|
-
default:
|
|
258
|
+
default: R.customClass
|
|
259
259
|
},
|
|
260
260
|
dangerouslyUseHTMLString: {
|
|
261
261
|
type: Boolean,
|
|
262
|
-
default:
|
|
262
|
+
default: R.dangerouslyUseHTMLString
|
|
263
263
|
},
|
|
264
264
|
duration: {
|
|
265
265
|
type: Number,
|
|
266
|
-
default:
|
|
266
|
+
default: R.duration
|
|
267
267
|
},
|
|
268
268
|
icon: {
|
|
269
|
-
type:
|
|
270
|
-
default:
|
|
269
|
+
type: Dt,
|
|
270
|
+
default: R.icon
|
|
271
271
|
},
|
|
272
272
|
id: {
|
|
273
273
|
type: String,
|
|
274
|
-
default:
|
|
274
|
+
default: R.id
|
|
275
275
|
},
|
|
276
276
|
message: {
|
|
277
|
-
type:
|
|
277
|
+
type: G([
|
|
278
278
|
String,
|
|
279
279
|
Object,
|
|
280
280
|
Function
|
|
281
281
|
]),
|
|
282
|
-
default:
|
|
282
|
+
default: R.message
|
|
283
283
|
},
|
|
284
284
|
onClose: {
|
|
285
|
-
type:
|
|
286
|
-
default:
|
|
285
|
+
type: G(Function),
|
|
286
|
+
default: R.onClose
|
|
287
287
|
},
|
|
288
288
|
showClose: {
|
|
289
289
|
type: Boolean,
|
|
290
|
-
default:
|
|
290
|
+
default: R.showClose
|
|
291
291
|
},
|
|
292
292
|
type: {
|
|
293
293
|
type: String,
|
|
294
|
-
values:
|
|
295
|
-
default:
|
|
294
|
+
values: lt,
|
|
295
|
+
default: R.type
|
|
296
296
|
},
|
|
297
297
|
plain: {
|
|
298
298
|
type: Boolean,
|
|
299
|
-
default:
|
|
299
|
+
default: R.plain
|
|
300
300
|
},
|
|
301
301
|
offset: {
|
|
302
302
|
type: Number,
|
|
303
|
-
default:
|
|
303
|
+
default: R.offset
|
|
304
304
|
},
|
|
305
305
|
zIndex: {
|
|
306
306
|
type: Number,
|
|
307
|
-
default:
|
|
307
|
+
default: R.zIndex
|
|
308
308
|
},
|
|
309
309
|
grouping: {
|
|
310
310
|
type: Boolean,
|
|
311
|
-
default:
|
|
311
|
+
default: R.grouping
|
|
312
312
|
},
|
|
313
313
|
repeatNum: {
|
|
314
314
|
type: Number,
|
|
315
|
-
default:
|
|
315
|
+
default: R.repeatNum
|
|
316
316
|
}
|
|
317
|
-
}),
|
|
317
|
+
}), yn = {
|
|
318
318
|
destroy: () => !0
|
|
319
|
-
},
|
|
320
|
-
const e =
|
|
319
|
+
}, U = _t([]), wn = (c) => {
|
|
320
|
+
const e = U.findIndex((o) => o.id === c), t = U[e];
|
|
321
321
|
let n;
|
|
322
|
-
return e > 0 && (n =
|
|
323
|
-
},
|
|
324
|
-
const { prev: e } =
|
|
322
|
+
return e > 0 && (n = U[e - 1]), { current: t, prev: n };
|
|
323
|
+
}, Cn = (c) => {
|
|
324
|
+
const { prev: e } = wn(c);
|
|
325
325
|
return e ? e.vm.exposed.bottom.value : 0;
|
|
326
|
-
},
|
|
326
|
+
}, bn = (c, e) => U.findIndex((n) => n.id === c) > 0 ? 16 : e, En = pe({
|
|
327
327
|
name: "ElMessage"
|
|
328
|
-
}),
|
|
329
|
-
...
|
|
330
|
-
props:
|
|
331
|
-
emits:
|
|
328
|
+
}), xn = /* @__PURE__ */ pe({
|
|
329
|
+
...En,
|
|
330
|
+
props: fn,
|
|
331
|
+
emits: yn,
|
|
332
332
|
setup(c, { expose: e, emit: t }) {
|
|
333
|
-
const n = c, { Close:
|
|
334
|
-
let
|
|
335
|
-
const
|
|
336
|
-
const
|
|
337
|
-
return { [a.bm("icon",
|
|
338
|
-
}),
|
|
339
|
-
top: `${
|
|
333
|
+
const n = c, { Close: o } = Bt, s = P(!1), { ns: a, zIndex: d } = Pt("message"), { currentZIndex: r, nextZIndex: i } = d, l = P(), m = P(!1), g = P(0);
|
|
334
|
+
let w;
|
|
335
|
+
const h = D(() => n.type ? n.type === "error" ? "danger" : n.type : "info"), C = D(() => {
|
|
336
|
+
const E = n.type;
|
|
337
|
+
return { [a.bm("icon", E)]: E && Re[E] };
|
|
338
|
+
}), v = D(() => n.icon || Re[n.type] || ""), x = D(() => Cn(n.id)), L = D(() => bn(n.id, n.offset) + x.value), B = D(() => g.value + L.value), $ = D(() => ({
|
|
339
|
+
top: `${L.value}px`,
|
|
340
340
|
zIndex: r.value
|
|
341
341
|
}));
|
|
342
|
-
function
|
|
343
|
-
n.duration !== 0 && ({ stop:
|
|
344
|
-
|
|
342
|
+
function ee() {
|
|
343
|
+
n.duration !== 0 && ({ stop: w } = St(() => {
|
|
344
|
+
Q();
|
|
345
345
|
}, n.duration));
|
|
346
346
|
}
|
|
347
|
-
function
|
|
348
|
-
|
|
347
|
+
function _() {
|
|
348
|
+
w?.();
|
|
349
349
|
}
|
|
350
|
-
function
|
|
351
|
-
m.value = !1,
|
|
352
|
-
var
|
|
353
|
-
|
|
350
|
+
function Q() {
|
|
351
|
+
m.value = !1, be(() => {
|
|
352
|
+
var E;
|
|
353
|
+
s.value || ((E = n.onClose) == null || E.call(n), t("destroy"));
|
|
354
354
|
});
|
|
355
355
|
}
|
|
356
|
-
function
|
|
357
|
-
|
|
356
|
+
function W({ code: E }) {
|
|
357
|
+
E === cn.esc && Q();
|
|
358
358
|
}
|
|
359
|
-
return
|
|
360
|
-
|
|
361
|
-
}),
|
|
362
|
-
|
|
363
|
-
}),
|
|
364
|
-
|
|
359
|
+
return at(() => {
|
|
360
|
+
ee(), i(), m.value = !0;
|
|
361
|
+
}), J(() => n.repeatNum, () => {
|
|
362
|
+
_(), ee();
|
|
363
|
+
}), Yt(document, "keydown", W), nn(l, () => {
|
|
364
|
+
g.value = l.value.getBoundingClientRect().height;
|
|
365
365
|
}), e({
|
|
366
366
|
visible: m,
|
|
367
|
-
bottom:
|
|
368
|
-
close:
|
|
369
|
-
}), (
|
|
370
|
-
name:
|
|
371
|
-
onBeforeEnter: (
|
|
372
|
-
onBeforeLeave:
|
|
373
|
-
onAfterLeave: (
|
|
367
|
+
bottom: B,
|
|
368
|
+
close: Q
|
|
369
|
+
}), (E, q) => (k(), fe(xe, {
|
|
370
|
+
name: f(a).b("fade"),
|
|
371
|
+
onBeforeEnter: (F) => s.value = !0,
|
|
372
|
+
onBeforeLeave: E.onClose,
|
|
373
|
+
onAfterLeave: (F) => E.$emit("destroy"),
|
|
374
374
|
persisted: ""
|
|
375
375
|
}, {
|
|
376
|
-
default:
|
|
377
|
-
|
|
378
|
-
id:
|
|
376
|
+
default: V(() => [
|
|
377
|
+
ot(M("div", {
|
|
378
|
+
id: E.id,
|
|
379
379
|
ref_key: "messageRef",
|
|
380
|
-
ref:
|
|
381
|
-
class:
|
|
382
|
-
|
|
383
|
-
{ [
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
380
|
+
ref: l,
|
|
381
|
+
class: j([
|
|
382
|
+
f(a).b(),
|
|
383
|
+
{ [f(a).m(E.type)]: E.type },
|
|
384
|
+
f(a).is("closable", E.showClose),
|
|
385
|
+
f(a).is("plain", E.plain),
|
|
386
|
+
E.customClass
|
|
387
387
|
]),
|
|
388
|
-
style:
|
|
388
|
+
style: Fe(f($)),
|
|
389
389
|
role: "alert",
|
|
390
|
-
onMouseenter:
|
|
391
|
-
onMouseleave:
|
|
390
|
+
onMouseenter: _,
|
|
391
|
+
onMouseleave: ee
|
|
392
392
|
}, [
|
|
393
|
-
|
|
393
|
+
E.repeatNum > 1 ? (k(), fe(f(gn), {
|
|
394
394
|
key: 0,
|
|
395
|
-
value:
|
|
396
|
-
type:
|
|
397
|
-
class:
|
|
398
|
-
}, null, 8, ["value", "type", "class"])) :
|
|
399
|
-
v
|
|
395
|
+
value: E.repeatNum,
|
|
396
|
+
type: f(h),
|
|
397
|
+
class: j(f(a).e("badge"))
|
|
398
|
+
}, null, 8, ["value", "type", "class"])) : H("v-if", !0),
|
|
399
|
+
f(v) ? (k(), fe(f(ze), {
|
|
400
400
|
key: 1,
|
|
401
|
-
class:
|
|
401
|
+
class: j([f(a).e("icon"), f(C)])
|
|
402
402
|
}, {
|
|
403
|
-
default:
|
|
404
|
-
(
|
|
403
|
+
default: V(() => [
|
|
404
|
+
(k(), fe(Gt(f(v))))
|
|
405
405
|
]),
|
|
406
406
|
_: 1
|
|
407
|
-
}, 8, ["class"])) :
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
class:
|
|
413
|
-
innerHTML:
|
|
407
|
+
}, 8, ["class"])) : H("v-if", !0),
|
|
408
|
+
Ee(E.$slots, "default", {}, () => [
|
|
409
|
+
E.dangerouslyUseHTMLString ? (k(), K(ye, { key: 1 }, [
|
|
410
|
+
H(" Caution here, message could've been compromised, never use user's input as message "),
|
|
411
|
+
M("p", {
|
|
412
|
+
class: j(f(a).e("content")),
|
|
413
|
+
innerHTML: E.message
|
|
414
414
|
}, null, 10, ["innerHTML"])
|
|
415
|
-
], 2112)) : (
|
|
415
|
+
], 2112)) : (k(), K("p", {
|
|
416
416
|
key: 0,
|
|
417
|
-
class:
|
|
418
|
-
},
|
|
417
|
+
class: j(f(a).e("content"))
|
|
418
|
+
}, me(E.message), 3))
|
|
419
419
|
]),
|
|
420
|
-
|
|
420
|
+
E.showClose ? (k(), fe(f(ze), {
|
|
421
421
|
key: 2,
|
|
422
|
-
class:
|
|
423
|
-
onClick:
|
|
422
|
+
class: j(f(a).e("closeBtn")),
|
|
423
|
+
onClick: Ut(Q, ["stop"])
|
|
424
424
|
}, {
|
|
425
|
-
default:
|
|
426
|
-
|
|
425
|
+
default: V(() => [
|
|
426
|
+
O(f(o))
|
|
427
427
|
]),
|
|
428
428
|
_: 1
|
|
429
|
-
}, 8, ["class", "onClick"])) :
|
|
429
|
+
}, 8, ["class", "onClick"])) : H("v-if", !0)
|
|
430
430
|
], 46, ["id"]), [
|
|
431
|
-
[
|
|
431
|
+
[st, m.value]
|
|
432
432
|
])
|
|
433
433
|
]),
|
|
434
434
|
_: 3
|
|
435
435
|
}, 8, ["name", "onBeforeEnter", "onBeforeLeave", "onAfterLeave"]));
|
|
436
436
|
}
|
|
437
437
|
});
|
|
438
|
-
var
|
|
439
|
-
let
|
|
440
|
-
const
|
|
441
|
-
const e = !c ||
|
|
442
|
-
...
|
|
438
|
+
var An = /* @__PURE__ */ et(xn, [["__file", "message.vue"]]);
|
|
439
|
+
let Ln = 1;
|
|
440
|
+
const ct = (c) => {
|
|
441
|
+
const e = !c || Oe(c) || it(c) || De(c) ? { message: c } : c, t = {
|
|
442
|
+
...R,
|
|
443
443
|
...e
|
|
444
444
|
};
|
|
445
445
|
if (!t.appendTo)
|
|
446
446
|
t.appendTo = document.body;
|
|
447
|
-
else if (
|
|
447
|
+
else if (Oe(t.appendTo)) {
|
|
448
448
|
let n = document.querySelector(t.appendTo);
|
|
449
|
-
|
|
449
|
+
Ft(n) || (n = document.body), t.appendTo = n;
|
|
450
450
|
}
|
|
451
|
-
return
|
|
452
|
-
},
|
|
453
|
-
const e =
|
|
451
|
+
return Ie(T.grouping) && !t.grouping && (t.grouping = T.grouping), we(T.duration) && t.duration === 3e3 && (t.duration = T.duration), we(T.offset) && t.offset === 16 && (t.offset = T.offset), Ie(T.showClose) && !t.showClose && (t.showClose = T.showClose), Ie(T.plain) && !t.plain && (t.plain = T.plain), t;
|
|
452
|
+
}, Mn = (c) => {
|
|
453
|
+
const e = U.indexOf(c);
|
|
454
454
|
if (e === -1)
|
|
455
455
|
return;
|
|
456
|
-
|
|
456
|
+
U.splice(e, 1);
|
|
457
457
|
const { handler: t } = c;
|
|
458
458
|
t.close();
|
|
459
|
-
},
|
|
460
|
-
const n = `message_${
|
|
459
|
+
}, In = ({ appendTo: c, ...e }, t) => {
|
|
460
|
+
const n = `message_${Ln++}`, o = e.onClose, s = document.createElement("div"), a = {
|
|
461
461
|
...e,
|
|
462
462
|
id: n,
|
|
463
463
|
onClose: () => {
|
|
464
|
-
|
|
464
|
+
o?.(), Mn(l);
|
|
465
465
|
},
|
|
466
466
|
onDestroy: () => {
|
|
467
|
-
|
|
467
|
+
Ge(null, s);
|
|
468
468
|
}
|
|
469
|
-
},
|
|
470
|
-
default:
|
|
469
|
+
}, d = O(An, a, De(a.message) || it(a.message) ? {
|
|
470
|
+
default: De(a.message) ? a.message : () => a.message
|
|
471
471
|
} : null);
|
|
472
|
-
|
|
473
|
-
const r =
|
|
472
|
+
d.appContext = t || ue._context, Ge(d, s), c.appendChild(s.firstElementChild);
|
|
473
|
+
const r = d.component, l = {
|
|
474
474
|
id: n,
|
|
475
|
-
vnode:
|
|
475
|
+
vnode: d,
|
|
476
476
|
vm: r,
|
|
477
477
|
handler: {
|
|
478
478
|
close: () => {
|
|
479
479
|
r.exposed.close();
|
|
480
480
|
}
|
|
481
481
|
},
|
|
482
|
-
props:
|
|
482
|
+
props: d.component.props
|
|
483
483
|
};
|
|
484
|
-
return
|
|
485
|
-
},
|
|
484
|
+
return l;
|
|
485
|
+
}, ue = (c = {}, e) => {
|
|
486
486
|
if (!Pe)
|
|
487
487
|
return { close: () => {
|
|
488
488
|
} };
|
|
489
|
-
const t =
|
|
490
|
-
if (t.grouping &&
|
|
491
|
-
const
|
|
489
|
+
const t = ct(c);
|
|
490
|
+
if (t.grouping && U.length) {
|
|
491
|
+
const o = U.find(({ vnode: s }) => {
|
|
492
492
|
var a;
|
|
493
|
-
return ((a =
|
|
493
|
+
return ((a = s.props) == null ? void 0 : a.message) === t.message;
|
|
494
494
|
});
|
|
495
|
-
if (
|
|
496
|
-
return
|
|
495
|
+
if (o)
|
|
496
|
+
return o.props.repeatNum += 1, o.props.type = t.type, o.handler;
|
|
497
497
|
}
|
|
498
|
-
if (
|
|
498
|
+
if (we(T.max) && U.length >= T.max)
|
|
499
499
|
return { close: () => {
|
|
500
500
|
} };
|
|
501
|
-
const n =
|
|
502
|
-
return
|
|
501
|
+
const n = In(t, e);
|
|
502
|
+
return U.push(n), n.handler;
|
|
503
503
|
};
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
const n =
|
|
507
|
-
return
|
|
504
|
+
lt.forEach((c) => {
|
|
505
|
+
ue[c] = (e = {}, t) => {
|
|
506
|
+
const n = ct(e);
|
|
507
|
+
return ue({ ...n, type: c }, t);
|
|
508
508
|
};
|
|
509
509
|
});
|
|
510
|
-
function
|
|
511
|
-
const e = [...
|
|
510
|
+
function kn(c) {
|
|
511
|
+
const e = [...U];
|
|
512
512
|
for (const t of e)
|
|
513
513
|
(!c || c === t.props.type) && t.handler.close();
|
|
514
514
|
}
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
const
|
|
518
|
-
class
|
|
515
|
+
ue.closeAll = kn;
|
|
516
|
+
ue._context = null;
|
|
517
|
+
const I = Kt(ue, "$message");
|
|
518
|
+
class z extends Se {
|
|
519
519
|
_renderer;
|
|
520
520
|
get renderer() {
|
|
521
521
|
return this._renderer || (this._renderer = this.parent?.findComponentByName("Renderer")), this._renderer;
|
|
@@ -582,9 +582,9 @@ class O extends Ae {
|
|
|
582
582
|
*/
|
|
583
583
|
createCursor(e) {
|
|
584
584
|
return (t, n) => {
|
|
585
|
-
const
|
|
585
|
+
const o = this.domElement.style.cursor;
|
|
586
586
|
this.domElement.style.cursor = e, this.addEventRecord("clear", () => {
|
|
587
|
-
this.domElement.style.cursor =
|
|
587
|
+
this.domElement.style.cursor = o ?? "default";
|
|
588
588
|
}), t(n);
|
|
589
589
|
};
|
|
590
590
|
}
|
|
@@ -603,40 +603,40 @@ class O extends Ae {
|
|
|
603
603
|
* @returns
|
|
604
604
|
*/
|
|
605
605
|
createPointerMove(e) {
|
|
606
|
-
const t = this.editor, n = new
|
|
607
|
-
let
|
|
608
|
-
const
|
|
609
|
-
const r =
|
|
610
|
-
if (
|
|
611
|
-
const i = Math.abs(r.x -
|
|
612
|
-
i >
|
|
613
|
-
} else if (
|
|
614
|
-
const i =
|
|
615
|
-
i &&
|
|
606
|
+
const t = this.editor, n = new A();
|
|
607
|
+
let o = null, s = null, a = null;
|
|
608
|
+
const d = t.addEventListener("pointerPositionChange", () => {
|
|
609
|
+
const r = A.from(t.pointerPosition);
|
|
610
|
+
if (o && t.eventInput.isKeyDown("shift")) {
|
|
611
|
+
const i = Math.abs(r.x - o.x), l = Math.abs(r.y - o.y);
|
|
612
|
+
i > l ? n.set(r.x, o.y) : n.set(o.x, r.y), e(n, !1);
|
|
613
|
+
} else if (s && a && t.eventInput.isKeyDown("alt")) {
|
|
614
|
+
const i = s.projectPoint(r, !1), l = a.projectPoint(r, !1);
|
|
615
|
+
i && l ? r.distance(i) < r.distance(l) ? n.copy(i) : n.copy(l) : i ? n.copy(i) : l && n.copy(l), e(n, !1);
|
|
616
616
|
} else {
|
|
617
|
-
const { point: i, find:
|
|
618
|
-
n.copy(i), e(n,
|
|
617
|
+
const { point: i, find: l, line: m } = t.renderManager.adsorption();
|
|
618
|
+
n.copy(i), e(n, l, m);
|
|
619
619
|
}
|
|
620
620
|
});
|
|
621
621
|
return {
|
|
622
622
|
destroy() {
|
|
623
|
-
|
|
623
|
+
d();
|
|
624
624
|
},
|
|
625
625
|
setBaseLine(r, i) {
|
|
626
|
-
if (
|
|
627
|
-
const
|
|
626
|
+
if (s = r, o = i, r && i) {
|
|
627
|
+
const l = r.normal();
|
|
628
628
|
a = new N(
|
|
629
|
-
i.clone().add(
|
|
630
|
-
i.clone().add(
|
|
629
|
+
i.clone().add(l.clone().multiplyScalar(10)),
|
|
630
|
+
i.clone().add(l.multiplyScalar(-10))
|
|
631
631
|
);
|
|
632
632
|
} else a = null;
|
|
633
633
|
}
|
|
634
634
|
};
|
|
635
635
|
}
|
|
636
636
|
}
|
|
637
|
-
class
|
|
637
|
+
class mt extends z {
|
|
638
638
|
static name = "DrawLine";
|
|
639
|
-
container = new
|
|
639
|
+
container = new p.Group();
|
|
640
640
|
interruptKeys = ["escape"];
|
|
641
641
|
withdrawalKeys = ["control", "z"];
|
|
642
642
|
shortcutKeys = ["control", "l"];
|
|
@@ -644,53 +644,55 @@ class Cn extends O {
|
|
|
644
644
|
commandName = "draw-line";
|
|
645
645
|
onAddFromParent(e) {
|
|
646
646
|
super.onAddFromParent(e), this.editor.container.add(this.container);
|
|
647
|
-
const t = this.commandManager.addCommandFlow(this.commandName).add(this.createInterrupt()).add(this.createCursor("crosshair")).add(this.selectPoint.bind(this)).add(this.end.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
|
|
647
|
+
const t = this.commandManager.addCommandFlow(this.commandName).add(this.createInterrupt()).add(this.createCursor("crosshair")).add(this.selectPoint.bind(this)).add(this.end.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this)).setLoop(!0);
|
|
648
648
|
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(this.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => this.eventInput.isKeyCombination(this.commandName) && await this.commandManager.start(this.commandName)), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
649
649
|
}
|
|
650
650
|
/** 选择点
|
|
651
651
|
* @param next
|
|
652
652
|
*/
|
|
653
653
|
selectPoint(e) {
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
new
|
|
657
|
-
new
|
|
658
|
-
new
|
|
654
|
+
this.dispatchEvent({ type: "start" });
|
|
655
|
+
let t = this.parent?.findComponentByName("Editor"), n = null, o = null, s = [], a = this.renderer.createCircle(A.zero(), { color: 65280 }), d = t.domContainer.domElement, r = new Ce([], 16711935), i = new Ce([
|
|
656
|
+
new p.Vector3(-1e4, 0, 0),
|
|
657
|
+
new p.Vector3(1e4, 0, 0),
|
|
658
|
+
new p.Vector3(0, -1e4, 0),
|
|
659
|
+
new p.Vector3(0, 1e4, 0)
|
|
659
660
|
], 16711935);
|
|
660
|
-
i.material = new
|
|
661
|
+
i.material = new p.LineDashedMaterial({
|
|
661
662
|
color: 4235007,
|
|
662
663
|
dashSize: 0.1,
|
|
663
664
|
gapSize: 0.1,
|
|
664
665
|
linewidth: 0.1
|
|
665
666
|
}), this.container.add(r);
|
|
666
|
-
const
|
|
667
|
-
r.setPoint(...
|
|
668
|
-
}, m = new
|
|
669
|
-
let
|
|
670
|
-
const
|
|
671
|
-
m.set(
|
|
667
|
+
const l = () => {
|
|
668
|
+
r.setPoint(...s, n, o), i.position.copy(o), this.container.add(i), i.computeLineDistances();
|
|
669
|
+
}, m = new p.Vector3();
|
|
670
|
+
let g;
|
|
671
|
+
const w = this.createPointerMove((h, C, v) => {
|
|
672
|
+
m.set(h.x, h.y, 0), this.dispatchEvent({ type: "pointerMove", point: m }), g = v, C ? (a.position.set(h.x, h.y, 0), this.container.add(a), d.style.cursor = "none") : (a.removeFromParent(), d.style.cursor = "crosshair"), n && o && (l(), o.copy(m));
|
|
672
673
|
});
|
|
673
674
|
this.addEventRecord(
|
|
674
675
|
"clear",
|
|
675
|
-
() =>
|
|
676
|
+
() => w.destroy(),
|
|
676
677
|
t.eventInput.addEventListener("codeChange", async () => {
|
|
677
678
|
if (t.eventInput.isKeyDown("mouse_0")) {
|
|
678
679
|
if (!n) {
|
|
679
|
-
n = m.clone(),
|
|
680
|
+
n = m.clone(), o = m.clone(), l(), w.setBaseLine(g ?? null, A.from(n));
|
|
680
681
|
return;
|
|
681
682
|
}
|
|
682
|
-
|
|
683
|
-
const
|
|
684
|
-
|
|
683
|
+
o = m.clone(), s.push(n.clone(), o.clone());
|
|
684
|
+
const h = new N(A.from(n), A.from(o));
|
|
685
|
+
w.setBaseLine(h, h.end), n.copy(o), l(), this.dispatchEvent({ type: "appendLine", points: s });
|
|
685
686
|
} else if (t.eventInput.isOnlyKeyDowns(this.withdrawalKeys)) {
|
|
686
|
-
if (
|
|
687
|
-
const { point:
|
|
688
|
-
if (
|
|
689
|
-
const
|
|
690
|
-
|
|
687
|
+
if (s.length) {
|
|
688
|
+
const { point: h } = t.renderManager.adsorption();
|
|
689
|
+
if (s.pop(), o?.copy(h), n?.copy(s.pop()), l(), s.length >= 2) {
|
|
690
|
+
const C = new N(A.from(s[s.length - 2]), A.from(s[s.length - 1]));
|
|
691
|
+
w.setBaseLine(C, C.end);
|
|
691
692
|
}
|
|
693
|
+
this.dispatchEvent({ type: "revoke", points: s });
|
|
692
694
|
}
|
|
693
|
-
} else t.eventInput.isKeyDowns(this.confirmKeys) && e(
|
|
695
|
+
} else t.eventInput.isKeyDowns(this.confirmKeys) && e(s);
|
|
694
696
|
}),
|
|
695
697
|
function() {
|
|
696
698
|
r.removeFromParent(), a.removeFromParent(), i.removeFromParent();
|
|
@@ -702,14 +704,14 @@ class Cn extends O {
|
|
|
702
704
|
*/
|
|
703
705
|
end(e, t) {
|
|
704
706
|
const n = [];
|
|
705
|
-
for (let
|
|
706
|
-
n.push(new N(
|
|
707
|
+
for (let o = 0; o < t.length; o += 2)
|
|
708
|
+
n.push(new N(A.from(t[o]), A.from(t[o + 1])));
|
|
707
709
|
e(n);
|
|
708
710
|
}
|
|
709
711
|
/** 执行完成
|
|
710
712
|
*/
|
|
711
713
|
completed(e) {
|
|
712
|
-
this.renderManager.addLines(e), this.renderManager.draw()
|
|
714
|
+
this.renderManager.addLines(e), this.renderManager.draw();
|
|
713
715
|
}
|
|
714
716
|
/** 回滚操作
|
|
715
717
|
* @param data
|
|
@@ -725,9 +727,9 @@ class Cn extends O {
|
|
|
725
727
|
return this.completed(e), e;
|
|
726
728
|
}
|
|
727
729
|
}
|
|
728
|
-
class
|
|
730
|
+
class ht extends z {
|
|
729
731
|
static name = "Default";
|
|
730
|
-
container = new
|
|
732
|
+
container = new p.Group();
|
|
731
733
|
onAddFromParent() {
|
|
732
734
|
const e = this.editor, t = e.commandManager;
|
|
733
735
|
e.container.add(this.container), t.addCommandFlow("default").add(this.start.bind(this)).addEventListener("finally", this.finally.bind(this)), t.addEventListener("startedBefore", (n) => {
|
|
@@ -735,7 +737,7 @@ class dt extends O {
|
|
|
735
737
|
}), t.addEventListener("finally", (n) => n.name !== "default" && t.start("default")), e.eventInput.addCancelDefaultBehavior(() => e.eventInput.isOnlyKeyDowns(["control", "g"]));
|
|
736
738
|
}
|
|
737
739
|
selectLines = [];
|
|
738
|
-
selectLineObject3D = new
|
|
740
|
+
selectLineObject3D = new p.Mesh();
|
|
739
741
|
/** 添加选择的线段
|
|
740
742
|
* @param lineSegment
|
|
741
743
|
*/
|
|
@@ -778,80 +780,81 @@ class dt extends O {
|
|
|
778
780
|
* @param next
|
|
779
781
|
*/
|
|
780
782
|
start() {
|
|
781
|
-
const e = this.editor, t = e.eventInput, n = new
|
|
782
|
-
let
|
|
783
|
-
n.position.z = 1e-3, this.selectLineObject3D.position.z = n.position.z + 1e-3, n.material = new
|
|
783
|
+
const e = this.editor, t = e.eventInput, n = new p.Mesh(), o = e.domContainer.domElement;
|
|
784
|
+
let s = null;
|
|
785
|
+
n.position.z = 1e-3, this.selectLineObject3D.position.z = n.position.z + 1e-3, n.material = new p.MeshBasicMaterial({ color: 55561 });
|
|
784
786
|
const a = () => {
|
|
785
|
-
const r = e.pointerPosition.clone(), i = e.pointerPosition.clone(),
|
|
786
|
-
this.container.add(
|
|
787
|
+
const r = e.pointerPosition.clone(), i = e.pointerPosition.clone(), l = new p.Mesh();
|
|
788
|
+
this.container.add(l), l.position.z = 0.05, l.material = new p.MeshBasicMaterial({
|
|
787
789
|
color: 16777215,
|
|
788
790
|
transparent: !0,
|
|
789
791
|
opacity: 0.5
|
|
790
792
|
});
|
|
791
793
|
const m = () => {
|
|
792
|
-
const
|
|
793
|
-
|
|
794
|
+
const h = Math.min(r.x, i.x), C = Math.max(r.x, i.x), v = Math.min(r.y, i.y), x = Math.max(r.y, i.y), L = [
|
|
795
|
+
h,
|
|
794
796
|
x,
|
|
795
797
|
0,
|
|
796
|
-
|
|
797
|
-
|
|
798
|
+
C,
|
|
799
|
+
v,
|
|
798
800
|
0,
|
|
799
|
-
|
|
801
|
+
C,
|
|
800
802
|
x,
|
|
801
803
|
0,
|
|
802
|
-
|
|
804
|
+
h,
|
|
803
805
|
x,
|
|
804
806
|
0,
|
|
805
|
-
p,
|
|
806
|
-
E,
|
|
807
|
-
0,
|
|
808
807
|
h,
|
|
809
|
-
|
|
808
|
+
v,
|
|
809
|
+
0,
|
|
810
|
+
C,
|
|
811
|
+
v,
|
|
810
812
|
0
|
|
811
813
|
];
|
|
812
|
-
|
|
813
|
-
},
|
|
814
|
+
l.geometry = e.renderManager.createGeometry({ position: L }, L.length / 3);
|
|
815
|
+
}, g = () => {
|
|
814
816
|
i.copy(e.pointerPosition), m();
|
|
815
|
-
},
|
|
816
|
-
document.removeEventListener("mousemove",
|
|
817
|
-
const
|
|
818
|
-
this.removeSelectLineAll(),
|
|
817
|
+
}, w = () => {
|
|
818
|
+
document.removeEventListener("mousemove", g), document.removeEventListener("mouseup", w), l.removeFromParent();
|
|
819
|
+
const h = Math.min(r.x, i.x), C = Math.max(r.x, i.x), v = Math.min(r.y, i.y), x = Math.max(r.y, i.y), L = new tt(h, C, v, x), B = e.renderManager.quadtree.queryBox(L);
|
|
820
|
+
this.removeSelectLineAll(), B.forEach(($) => this.addSelectLine($.line)), this.updateSelectLinesGeometry();
|
|
819
821
|
};
|
|
820
|
-
document.addEventListener("mousemove",
|
|
821
|
-
},
|
|
822
|
+
document.addEventListener("mousemove", g), document.addEventListener("mouseup", w);
|
|
823
|
+
}, d = this.renderer.createText("", new p.Vector3(0, 0, 0), {
|
|
822
824
|
background: "rgba(0,0,0,0.5)",
|
|
823
825
|
padding: "2px",
|
|
824
826
|
borderRadius: "2px"
|
|
825
827
|
}, this.container);
|
|
826
|
-
|
|
828
|
+
d.visible = !1, this.addEventRecord(
|
|
827
829
|
"clear",
|
|
828
830
|
// 注册鼠标指针位置变化事件
|
|
829
831
|
e.addEventListener("pointerPositionChange", () => {
|
|
830
832
|
const { line: r } = e.renderManager.adsorption();
|
|
831
833
|
if (r) {
|
|
832
834
|
const i = r.expandToRectangle(0.025, "bothSides");
|
|
833
|
-
n.geometry = e.renderManager.createGeometry({ position: i.createGeometry() }, 6), this.container.add(n),
|
|
834
|
-
const
|
|
835
|
-
|
|
835
|
+
n.geometry = e.renderManager.createGeometry({ position: i.createGeometry() }, 6), this.container.add(n), o.style.cursor = "pointer", s = r;
|
|
836
|
+
const l = r.center;
|
|
837
|
+
let m = "";
|
|
838
|
+
d.element.innerText = m + parseInt(r.length() * 1e3 + "") + " mm", d.position.set(l.x, l.y, 0), d.visible = !0;
|
|
836
839
|
} else
|
|
837
|
-
n.removeFromParent(),
|
|
840
|
+
n.removeFromParent(), o.style.cursor = "default", s = null, d.visible = !1;
|
|
838
841
|
}),
|
|
839
842
|
t.addEventListener("codeChange", () => {
|
|
840
843
|
if (t.isKeyDown("mouse_0")) {
|
|
841
|
-
if (!
|
|
844
|
+
if (!s) return a();
|
|
842
845
|
if (t.isKeyDown("alt"))
|
|
843
|
-
return this.removeSelectLine(
|
|
844
|
-
t.isKeyDown("control") || this.removeSelectLineAll(), this.addSelectLine(
|
|
846
|
+
return this.removeSelectLine(s);
|
|
847
|
+
t.isKeyDown("control") || this.removeSelectLineAll(), this.addSelectLine(s);
|
|
845
848
|
} else if (t.isKeyDown("mouse_1")) {
|
|
846
|
-
if (!
|
|
847
|
-
this.removeSelectLine(
|
|
849
|
+
if (!s) return;
|
|
850
|
+
this.removeSelectLine(s);
|
|
848
851
|
} else if (t.isKeyDown("mouse_2")) {
|
|
849
|
-
if (!
|
|
850
|
-
this.addSelectLine(
|
|
852
|
+
if (!s) return;
|
|
853
|
+
this.addSelectLine(s);
|
|
851
854
|
} else t.isKeyDowns(["control", "z"]) ? e.commandManager.rollback() : t.isKeyDowns(["control", "y"]) && e.commandManager.revokeRollback();
|
|
852
855
|
}),
|
|
853
856
|
function() {
|
|
854
|
-
n.removeFromParent(),
|
|
857
|
+
n.removeFromParent(), d.removeFromParent();
|
|
855
858
|
}
|
|
856
859
|
);
|
|
857
860
|
}
|
|
@@ -862,12 +865,16 @@ class dt extends O {
|
|
|
862
865
|
this.canceEventRecord("clear"), this.removeSelectLineAll(), this.updateSelectLinesGeometry();
|
|
863
866
|
}
|
|
864
867
|
}
|
|
865
|
-
class
|
|
868
|
+
class Dn extends nt {
|
|
866
869
|
list = [];
|
|
867
870
|
rollbacklist = [];
|
|
868
871
|
revokeRollbacklist = [];
|
|
869
872
|
// 是否写入操作记录
|
|
870
873
|
writeOperationList = !0;
|
|
874
|
+
loop = !1;
|
|
875
|
+
setLoop(e) {
|
|
876
|
+
return this.loop = e, this;
|
|
877
|
+
}
|
|
871
878
|
/**
|
|
872
879
|
*
|
|
873
880
|
* @param operation
|
|
@@ -890,7 +897,7 @@ class En extends $e {
|
|
|
890
897
|
return this.revokeRollbacklist.push(e), this;
|
|
891
898
|
}
|
|
892
899
|
}
|
|
893
|
-
class
|
|
900
|
+
class Pn extends nt {
|
|
894
901
|
commandFlowMap = /* @__PURE__ */ new Map();
|
|
895
902
|
lock = !1;
|
|
896
903
|
abortController = null;
|
|
@@ -917,7 +924,7 @@ class Ln extends $e {
|
|
|
917
924
|
*/
|
|
918
925
|
addCommandFlow(e) {
|
|
919
926
|
if (this.commandFlowMap.has(e)) throw new Error(`${e} 命令已经存在`);
|
|
920
|
-
const t = new
|
|
927
|
+
const t = new Dn();
|
|
921
928
|
return this.commandFlowMap.set(e, t), t;
|
|
922
929
|
}
|
|
923
930
|
executionPromise = null;
|
|
@@ -934,25 +941,25 @@ class Ln extends $e {
|
|
|
934
941
|
currentName: this.currentName
|
|
935
942
|
}), this.executionPromise && await this.executionPromise, this.executionPromise = null, this.lock)
|
|
936
943
|
throw new Error("命令管理器已被 " + this.currentName + " 命令锁定,无法启动新的命令流,请退出或等待命令执行结束");
|
|
937
|
-
const
|
|
938
|
-
if (!
|
|
944
|
+
const o = this.commandFlowMap.get(e);
|
|
945
|
+
if (!o)
|
|
939
946
|
throw new Error(`命令流 ${e} 不存在`);
|
|
940
|
-
this.lock = !0, this.abortController = new AbortController(), this.currentName = e,
|
|
947
|
+
this.lock = !0, this.abortController = new AbortController(), this.currentName = e, o.dispatchEvent({ type: "started" }), this.dispatchEvent({ type: "started", name: e });
|
|
941
948
|
try {
|
|
942
|
-
for (let
|
|
943
|
-
const a =
|
|
944
|
-
if (
|
|
945
|
-
this.resolve =
|
|
949
|
+
for (let s = n; s < o.list.length; s++) {
|
|
950
|
+
const a = o.list[s];
|
|
951
|
+
if (o.dispatchEvent({ type: "executing", index: s }), this.dispatchEvent({ type: "executing", name: e, index: s }), t = await new Promise((d) => {
|
|
952
|
+
this.resolve = d, a(d, t);
|
|
946
953
|
}), this.abortController.signal.aborted) {
|
|
947
|
-
|
|
954
|
+
o.dispatchEvent({ type: "executionInterrupt", index: s }), this.dispatchEvent({ type: "executionInterrupt", name: e, index: s }), this.dispatchEvent({ type: "cancel", name: e });
|
|
948
955
|
break;
|
|
949
956
|
} else
|
|
950
|
-
|
|
957
|
+
o.dispatchEvent({ type: "executionCompleted", index: s, data: t }), this.dispatchEvent({ type: "executionCompleted", name: e, index: s, data: t });
|
|
951
958
|
}
|
|
952
|
-
} catch (
|
|
953
|
-
console.error(
|
|
959
|
+
} catch (s) {
|
|
960
|
+
console.error(s);
|
|
954
961
|
} finally {
|
|
955
|
-
this.abortController && !this.abortController.signal.aborted && (
|
|
962
|
+
this.lock = !1, this.currentName = null, this.abortController && !this.abortController.signal.aborted && (o.dispatchEvent({ type: "completed", data: t }), this.dispatchEvent({ type: "completed", name: e, data: t }), o.writeOperationList && (this.operationList.push({ name: e, data: t }), this.rollbackList.length = 0), o.loop && queueMicrotask(() => this.start(e))), this.abortController = null, o.dispatchEvent({ type: "finally" }), this.dispatchEvent({ type: "finally", name: e }), this.executionResolve && (this.executionResolve(null), this.executionResolve = null);
|
|
956
963
|
}
|
|
957
964
|
return t;
|
|
958
965
|
}
|
|
@@ -970,7 +977,7 @@ class Ln extends $e {
|
|
|
970
977
|
if (!e) return !1;
|
|
971
978
|
const t = this.commandFlowMap.get(e.name);
|
|
972
979
|
if (!t) return !1;
|
|
973
|
-
const n = t.rollbacklist.reduce((
|
|
980
|
+
const n = t.rollbacklist.reduce((o, s) => s(o), e.data);
|
|
974
981
|
return this.dispatchEvent({ type: "rollback", name: e.name }), this.rollbackList.push({
|
|
975
982
|
data: n,
|
|
976
983
|
name: e.name
|
|
@@ -988,7 +995,7 @@ class Ln extends $e {
|
|
|
988
995
|
if (!e) return !1;
|
|
989
996
|
const t = this.commandFlowMap.get(e.name);
|
|
990
997
|
if (!t) return !1;
|
|
991
|
-
const n = t.revokeRollbacklist.reduce((
|
|
998
|
+
const n = t.revokeRollbacklist.reduce((o, s) => s(o), e.data);
|
|
992
999
|
return this.dispatchEvent({ type: "revokeRollback", name: e.name }), this.operationList.push({ name: e.name, data: n }), !0;
|
|
993
1000
|
} catch (e) {
|
|
994
1001
|
throw new Error(`撤回回滚失败:${e}`);
|
|
@@ -1000,65 +1007,65 @@ class Ln extends $e {
|
|
|
1000
1007
|
}, { once: !0 });
|
|
1001
1008
|
}
|
|
1002
1009
|
}
|
|
1003
|
-
const
|
|
1004
|
-
__proto__: null,
|
|
1005
|
-
default: Mn
|
|
1006
|
-
}, Symbol.toStringTag, { value: "Module" })), In = "", mo = "", ut = new p.TextureLoader(), ho = ut.load(co), uo = ut.load(mo);
|
|
1059
|
+
class po extends Se {
|
|
1053
1060
|
static name = "RenderManager";
|
|
1054
|
-
container = new
|
|
1061
|
+
container = new p.Group();
|
|
1055
1062
|
lines = [];
|
|
1056
|
-
pointVirtualGrid = new
|
|
1057
|
-
quadtree = new
|
|
1058
|
-
verticalReferenceLineFlag = new
|
|
1063
|
+
pointVirtualGrid = new Te();
|
|
1064
|
+
quadtree = new Ve(new tt());
|
|
1065
|
+
verticalReferenceLineFlag = new p.Mesh(new p.PlaneGeometry(0.3, 0.3), new p.MeshBasicMaterial({ map: ho, color: 58111, transparent: !0 }));
|
|
1059
1066
|
onAddFromParent() {
|
|
1060
1067
|
const e = this.dxfLineModel;
|
|
1061
|
-
this.editor.container.add(this.container), this.editor.container.add(e.dxfModelGroup), e.dxfLineModel.material = new
|
|
1068
|
+
this.editor.container.add(this.container), this.editor.container.add(e.dxfModelGroup), e.dxfLineModel.material = new p.LineBasicMaterial({
|
|
1062
1069
|
transparent: !0,
|
|
1063
1070
|
opacity: 0.5,
|
|
1064
1071
|
color: 16777215
|
|
@@ -1071,22 +1078,22 @@ class is extends Ae {
|
|
|
1071
1078
|
*/
|
|
1072
1079
|
reset() {
|
|
1073
1080
|
if (this.updatedMode === "self") {
|
|
1074
|
-
const n = this.lines.filter((
|
|
1081
|
+
const n = this.lines.filter((s) => s.userData.isDoor);
|
|
1075
1082
|
this.updatedMode = null;
|
|
1076
|
-
const
|
|
1083
|
+
const o = this.dxf.doorLineSegment.filter((s) => {
|
|
1077
1084
|
for (let a = 0; a < n.length; a++) {
|
|
1078
|
-
const
|
|
1079
|
-
if (
|
|
1085
|
+
const d = n[a];
|
|
1086
|
+
if (d.start.equal(s.start) && d.end.equal(s.end) || d.end.equal(s.start) && d.start.equal(s.end)) return !1;
|
|
1080
1087
|
}
|
|
1081
1088
|
return !0;
|
|
1082
1089
|
});
|
|
1083
|
-
this.addLines(
|
|
1090
|
+
this.addLines(o.map((s) => (s.userData.isDoor = !0, s.userData.doorDirectConnection, s))), this.draw(!1);
|
|
1084
1091
|
return;
|
|
1085
1092
|
} else
|
|
1086
1093
|
this.updatedMode = "dxf";
|
|
1087
|
-
this.pointVirtualGrid = new
|
|
1094
|
+
this.pointVirtualGrid = new Te();
|
|
1088
1095
|
const e = this.dxf.box.clone().expansion(Math.max(this.dxf.box.width, this.dxf.box.height) * 2);
|
|
1089
|
-
(e.width === 0 || e.height === 0) && e.set(-200, -200, 200, 200), this.quadtree = new
|
|
1096
|
+
(e.width === 0 || e.height === 0) && e.set(-200, -200, 200, 200), this.quadtree = new Ve(e), this.lines.length = 0;
|
|
1090
1097
|
const t = this.dxf.getLineSegments();
|
|
1091
1098
|
this.addLines(t), this.draw();
|
|
1092
1099
|
}
|
|
@@ -1109,11 +1116,11 @@ class is extends Ae {
|
|
|
1109
1116
|
for (let t = 0; t < e.length; t++) {
|
|
1110
1117
|
const n = e[t];
|
|
1111
1118
|
this.lines.push(n), this.pointVirtualGrid.insert(n.start, n), this.pointVirtualGrid.insert(n.end, n);
|
|
1112
|
-
const
|
|
1119
|
+
const o = {
|
|
1113
1120
|
line: n,
|
|
1114
1121
|
userData: void 0
|
|
1115
1122
|
};
|
|
1116
|
-
n.userData.quadtreeNode =
|
|
1123
|
+
n.userData.quadtreeNode = o, this.quadtree.insert(o);
|
|
1117
1124
|
}
|
|
1118
1125
|
}
|
|
1119
1126
|
/** 移除线段
|
|
@@ -1132,8 +1139,8 @@ class is extends Ae {
|
|
|
1132
1139
|
for (let t = 0; t < e.length; t++) {
|
|
1133
1140
|
const n = e[t];
|
|
1134
1141
|
n.userData.quadtreeNode && this.quadtree.remove(n.userData.quadtreeNode), this.pointVirtualGrid.remove(n.start), this.pointVirtualGrid.remove(n.end);
|
|
1135
|
-
const
|
|
1136
|
-
this.lines.splice(
|
|
1142
|
+
const o = this.lines.indexOf(n);
|
|
1143
|
+
this.lines.splice(o, 1);
|
|
1137
1144
|
}
|
|
1138
1145
|
this.draw();
|
|
1139
1146
|
}
|
|
@@ -1142,16 +1149,20 @@ class is extends Ae {
|
|
|
1142
1149
|
*/
|
|
1143
1150
|
draw(e = !0) {
|
|
1144
1151
|
this.container.clear();
|
|
1145
|
-
const t = [], n = [], s = [];
|
|
1146
|
-
this.lines.forEach((
|
|
1147
|
-
if (
|
|
1148
|
-
|
|
1149
|
-
|
|
1150
|
-
|
|
1151
|
-
|
|
1152
|
-
|
|
1153
|
-
|
|
1154
|
-
|
|
1152
|
+
const t = [], n = [], o = [], s = [], a = [];
|
|
1153
|
+
if (this.lines.forEach((d) => {
|
|
1154
|
+
if (d.userData.isBayWindow) {
|
|
1155
|
+
d.points.forEach((r) => a.push(r.x, r.y, 0));
|
|
1156
|
+
return;
|
|
1157
|
+
}
|
|
1158
|
+
if (d.points.forEach((r) => {
|
|
1159
|
+
d.userData.isDoor ? n.push(r.x, r.y, 0) : t.push(r.x, r.y, 0);
|
|
1160
|
+
}), d.userData.isDoor && d.userData.doorAutomaticFind && s.push(d.center), d.userData.isWindow && d.userData.drawWindow && d.userData.drawWindow.forEach(({ width: r, p: i }) => {
|
|
1161
|
+
const l = A.from(i), m = d.direction(), g = l.clone().add(m.clone().multiplyScalar(r * 0.5)), w = l.clone().add(m.clone().multiplyScalar(-r * 0.5));
|
|
1162
|
+
o.push(g.x, g.y, 1e-3), o.push(w.x, w.y, 1e-3);
|
|
1163
|
+
}), d.userData.isVerticalReferenceLine) {
|
|
1164
|
+
const r = d.center;
|
|
1165
|
+
this.verticalReferenceLineFlag.position.set(r.x, r.y, 0), this.container.add(this.verticalReferenceLineFlag);
|
|
1155
1166
|
}
|
|
1156
1167
|
}), t.length && this.renderer.createLineSegments({
|
|
1157
1168
|
position: t
|
|
@@ -1161,36 +1172,48 @@ class is extends Ae {
|
|
|
1161
1172
|
position: n
|
|
1162
1173
|
}, n.length / 3, {
|
|
1163
1174
|
color: 16776960
|
|
1164
|
-
}, this.container),
|
|
1165
|
-
position:
|
|
1166
|
-
},
|
|
1175
|
+
}, this.container), o.length && this.renderer.createLineSegments({
|
|
1176
|
+
position: o
|
|
1177
|
+
}, o.length / 3, {
|
|
1167
1178
|
color: 16711935
|
|
1168
|
-
}, this.container),
|
|
1179
|
+
}, this.container), a.length) {
|
|
1180
|
+
const d = this.renderer.createLineSegments({
|
|
1181
|
+
position: a
|
|
1182
|
+
}, a.length / 3, {}, this.container);
|
|
1183
|
+
d.material = new p.LineDashedMaterial({
|
|
1184
|
+
color: 4235007,
|
|
1185
|
+
dashSize: 0.05,
|
|
1186
|
+
gapSize: 0.05,
|
|
1187
|
+
opacity: 0.5,
|
|
1188
|
+
transparent: !0
|
|
1189
|
+
}), d.computeLineDistances();
|
|
1190
|
+
}
|
|
1191
|
+
this.renderer.createCircle(s, { map: uo, size: 0.4, sizeAttenuation: !0, color: 16777215 }, this.container), e && this.synchronizeDxf();
|
|
1169
1192
|
}
|
|
1170
1193
|
/** 获取鼠标当前点, 吸附后的点
|
|
1171
1194
|
* @param point
|
|
1172
1195
|
* @returns
|
|
1173
1196
|
*/
|
|
1174
1197
|
adsorption(e = 0.04, t = this.pointVirtualGrid, n = this.quadtree) {
|
|
1175
|
-
const
|
|
1176
|
-
let a = n.queryCircle(
|
|
1198
|
+
const o = this.parent?.findComponentByName("Editor"), s = A.from(o.pointerPosition);
|
|
1199
|
+
let a = n.queryCircle(s, e);
|
|
1177
1200
|
if (a.length) {
|
|
1178
|
-
let
|
|
1179
|
-
point: r.line.projectPoint(
|
|
1201
|
+
let d = a.map((r) => ({
|
|
1202
|
+
point: r.line.projectPoint(s),
|
|
1180
1203
|
line: r.line
|
|
1181
1204
|
})).filter((r) => !!r.point);
|
|
1182
|
-
if (
|
|
1183
|
-
const r =
|
|
1184
|
-
point: new
|
|
1205
|
+
if (d.sort((r, i) => r.point.distance(s) - i.point.distance(s)), d.length) {
|
|
1206
|
+
const r = d[0].line, i = d[0].point, l = {
|
|
1207
|
+
point: new p.Vector3(i.x, i.y, 0),
|
|
1185
1208
|
find: !0,
|
|
1186
1209
|
mode: "line",
|
|
1187
1210
|
line: r
|
|
1188
1211
|
};
|
|
1189
|
-
return r.start.distance(
|
|
1212
|
+
return r.start.distance(s) < e * 1.5 ? (l.point.set(r.start.x, r.start.y, 0), l.mode = "point") : r.end.distance(s) < e * 1.5 && (l.point.set(r.end.x, r.end.y, 0), l.mode = "point"), l;
|
|
1190
1213
|
}
|
|
1191
1214
|
}
|
|
1192
1215
|
return {
|
|
1193
|
-
point: new
|
|
1216
|
+
point: new p.Vector3(o.pointerPosition.x, o.pointerPosition.y, 0),
|
|
1194
1217
|
find: !1,
|
|
1195
1218
|
line: void 0,
|
|
1196
1219
|
mode: void 0
|
|
@@ -1200,9 +1223,9 @@ class is extends Ae {
|
|
|
1200
1223
|
* @param rectangle
|
|
1201
1224
|
*/
|
|
1202
1225
|
createGeometry(e, t) {
|
|
1203
|
-
const n = new
|
|
1204
|
-
return Object.keys(e).forEach((
|
|
1205
|
-
n.setAttribute("position", new
|
|
1226
|
+
const n = new p.BufferGeometry();
|
|
1227
|
+
return Object.keys(e).forEach((o) => {
|
|
1228
|
+
n.setAttribute("position", new p.BufferAttribute(new Float32Array(e[o]), e[o].length / t));
|
|
1206
1229
|
}), n;
|
|
1207
1230
|
}
|
|
1208
1231
|
/**
|
|
@@ -1210,24 +1233,24 @@ class is extends Ae {
|
|
|
1210
1233
|
*/
|
|
1211
1234
|
toJson() {
|
|
1212
1235
|
return this.lines.map((e) => {
|
|
1213
|
-
const t = e.userData, n = t.drawWindow,
|
|
1236
|
+
const t = e.userData, n = t.drawWindow, o = this.quadtree.queryLineSegment(e).filter((s) => s.line !== e && !s.userData?.isDoor).map((s) => ({ index: this.lines.indexOf(s.line) }));
|
|
1214
1237
|
return {
|
|
1215
|
-
...
|
|
1238
|
+
...je(t),
|
|
1216
1239
|
start: e.start.toJson(this.dxf.originalZAverage),
|
|
1217
1240
|
end: e.end.toJson(this.dxf.originalZAverage),
|
|
1218
|
-
insetionArr:
|
|
1241
|
+
insetionArr: o,
|
|
1219
1242
|
isDoor: t.isDoor,
|
|
1220
1243
|
doorDirectConnection: t.isDoor,
|
|
1221
1244
|
length: e.length(),
|
|
1222
1245
|
isWindow: t.isWindow,
|
|
1223
1246
|
isVerticalReferenceLine: t.isVerticalReferenceLine,
|
|
1224
1247
|
wallWidth: e.userData.wallWidth,
|
|
1225
|
-
drawWindow: n && n.map((
|
|
1226
|
-
...
|
|
1227
|
-
p: { x:
|
|
1228
|
-
width:
|
|
1229
|
-
full:
|
|
1230
|
-
rooftopPz:
|
|
1248
|
+
drawWindow: n && n.map((s) => ({
|
|
1249
|
+
...je(s),
|
|
1250
|
+
p: { x: s.p.x, y: s.p.y, z: s.p.z },
|
|
1251
|
+
width: s.width,
|
|
1252
|
+
full: s.full,
|
|
1253
|
+
rooftopPz: s.rooftopPz
|
|
1231
1254
|
}))
|
|
1232
1255
|
};
|
|
1233
1256
|
});
|
|
@@ -1243,7 +1266,7 @@ class is extends Ae {
|
|
|
1243
1266
|
}
|
|
1244
1267
|
this._timer && clearTimeout(this._timer), this._timer = setTimeout(() => {
|
|
1245
1268
|
this.updatedMode = "self";
|
|
1246
|
-
const e = this.dxf, t = this.toJson(), n = this.parent?.findComponentByType(
|
|
1269
|
+
const e = this.dxf, t = this.toJson(), n = this.parent?.findComponentByType(zt);
|
|
1247
1270
|
n.skipFindDoor = !0, e.set(t).then(() => e.lineOffset());
|
|
1248
1271
|
}, 10);
|
|
1249
1272
|
}
|
|
@@ -1266,55 +1289,55 @@ class is extends Ae {
|
|
|
1266
1289
|
return this.parent?.findComponentByName("DxfLineModel");
|
|
1267
1290
|
}
|
|
1268
1291
|
}
|
|
1269
|
-
class
|
|
1292
|
+
class go extends z {
|
|
1270
1293
|
static name = "DrawDoorLine";
|
|
1271
|
-
container = new
|
|
1294
|
+
container = new p.Group();
|
|
1272
1295
|
interruptKeys = ["escape"];
|
|
1273
1296
|
shortcutKeys = ["control", "m"];
|
|
1274
1297
|
commandName = "draw-door-line";
|
|
1275
1298
|
onAddFromParent(e) {
|
|
1276
1299
|
super.onAddFromParent(e);
|
|
1277
|
-
const t = e.findComponentByName("Editor"), n = t.eventInput,
|
|
1300
|
+
const t = e.findComponentByName("Editor"), n = t.eventInput, o = t.commandManager;
|
|
1278
1301
|
this.editor.container.add(this.container);
|
|
1279
|
-
const
|
|
1280
|
-
n.addKeyCombination(this.commandName, this.shortcutKeys),
|
|
1281
|
-
n.isKeyCombination(this.commandName) && await
|
|
1302
|
+
const s = this.commandManager.addCommandFlow("draw-door-line").add(this.createInterrupt()).add(this.createCursor("no-drop")).add(this.selectPoint.bind(this)).add(this.end.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this)).setLoop(!0);
|
|
1303
|
+
n.addKeyCombination(this.commandName, this.shortcutKeys), s.addEventListener("finally", this.createFinally()), s.addEventListener("completed", (a) => this.completed(a.data)), n.addCancelDefaultBehavior(() => n.isOnlyKeyDowns(this.shortcutKeys)), n.addEventListener("codeChange", async () => {
|
|
1304
|
+
n.isKeyCombination(this.commandName) && await o.start(this.commandName);
|
|
1282
1305
|
});
|
|
1283
1306
|
}
|
|
1284
1307
|
/** 选择点
|
|
1285
1308
|
* @param next
|
|
1286
1309
|
*/
|
|
1287
1310
|
selectPoint(e) {
|
|
1288
|
-
let t = this.parent?.findComponentByName("Editor"), n = null,
|
|
1289
|
-
new
|
|
1290
|
-
new
|
|
1291
|
-
new
|
|
1292
|
-
new
|
|
1311
|
+
let t = this.parent?.findComponentByName("Editor"), n = null, o = this.renderer.createCircle(A.zero(), { color: 65280 }), s = new Ce([], 16711935), a = new Ce([
|
|
1312
|
+
new p.Vector3(-1e4, 0, 0),
|
|
1313
|
+
new p.Vector3(1e4, 0, 0),
|
|
1314
|
+
new p.Vector3(0, -1e4, 0),
|
|
1315
|
+
new p.Vector3(0, 1e4, 0)
|
|
1293
1316
|
], 16711935);
|
|
1294
|
-
a.material = new
|
|
1317
|
+
a.material = new p.LineDashedMaterial({
|
|
1295
1318
|
color: 4235007,
|
|
1296
1319
|
dashSize: 0.1,
|
|
1297
1320
|
gapSize: 0.1,
|
|
1298
1321
|
linewidth: 0.1
|
|
1299
|
-
}), this.container.add(
|
|
1300
|
-
let
|
|
1322
|
+
}), this.container.add(s);
|
|
1323
|
+
let d = null;
|
|
1301
1324
|
this.addEventRecord(
|
|
1302
1325
|
"clear",
|
|
1303
1326
|
t.addEventListener("pointerPositionChange", () => {
|
|
1304
1327
|
const { point: r, find: i } = t.renderManager.adsorption();
|
|
1305
|
-
n &&
|
|
1328
|
+
n && s.setPoint(n, r), this.dispatchEvent({ type: "pointerMove", point: r }), i ? (o.position.set(r.x, r.y, 0), this.container.add(o), this.domElement.style.cursor = "none", d = r.clone()) : (d = null, o.removeFromParent(), this.domElement.style.cursor = "no-drop");
|
|
1306
1329
|
}),
|
|
1307
1330
|
t.eventInput.addEventListener("codeChange", async () => {
|
|
1308
|
-
if (t.eventInput.isKeyDown("mouse_0") &&
|
|
1331
|
+
if (t.eventInput.isKeyDown("mouse_0") && d) {
|
|
1309
1332
|
if (!n) {
|
|
1310
|
-
n =
|
|
1333
|
+
n = d.clone();
|
|
1311
1334
|
return;
|
|
1312
1335
|
}
|
|
1313
|
-
e([n.clone(),
|
|
1336
|
+
e([n.clone(), d.clone()]);
|
|
1314
1337
|
}
|
|
1315
1338
|
}),
|
|
1316
1339
|
function() {
|
|
1317
|
-
|
|
1340
|
+
s.removeFromParent(), o.removeFromParent(), a.removeFromParent();
|
|
1318
1341
|
}
|
|
1319
1342
|
);
|
|
1320
1343
|
}
|
|
@@ -1325,23 +1348,23 @@ class rs extends O {
|
|
|
1325
1348
|
*/
|
|
1326
1349
|
end(e, t) {
|
|
1327
1350
|
const n = [];
|
|
1328
|
-
for (let
|
|
1329
|
-
const
|
|
1351
|
+
for (let o = 0; o < t.length; o += 2) {
|
|
1352
|
+
const s = A.from(t[o]), a = A.from(t[o + 1]), d = this.renderManager.quadtree.queryCircle(s, 1e-3)[0].line, r = this.renderManager.quadtree.queryCircle(a, 1e-3)[0].line;
|
|
1330
1353
|
let i = null;
|
|
1331
|
-
|
|
1332
|
-
oldLine:
|
|
1354
|
+
d === r && (i = {
|
|
1355
|
+
oldLine: d,
|
|
1333
1356
|
newLine1: new N(
|
|
1334
|
-
|
|
1335
|
-
|
|
1357
|
+
d.start,
|
|
1358
|
+
d.start.distance(s) < d.start.distance(a) ? s.clone() : a.clone()
|
|
1336
1359
|
),
|
|
1337
1360
|
newLine2: new N(
|
|
1338
|
-
|
|
1339
|
-
|
|
1361
|
+
d.end,
|
|
1362
|
+
d.end.distance(s) < d.end.distance(a) ? s.clone() : a.clone()
|
|
1340
1363
|
)
|
|
1341
1364
|
});
|
|
1342
|
-
const
|
|
1343
|
-
|
|
1344
|
-
line:
|
|
1365
|
+
const l = new N(s, a);
|
|
1366
|
+
l.userData.isDoor = !0, l.userData.doorDirectConnection = !0, n.push({
|
|
1367
|
+
line: l,
|
|
1345
1368
|
option: i
|
|
1346
1369
|
});
|
|
1347
1370
|
}
|
|
@@ -1352,7 +1375,7 @@ class rs extends O {
|
|
|
1352
1375
|
completed(e) {
|
|
1353
1376
|
e.forEach(({ line: t, option: n }) => {
|
|
1354
1377
|
this.renderManager.addLine(t), n && (this.renderManager.removeLine(n.oldLine), this.renderManager.addLines([n.newLine1, n.newLine2]));
|
|
1355
|
-
}), this.renderManager.draw()
|
|
1378
|
+
}), this.renderManager.draw();
|
|
1356
1379
|
}
|
|
1357
1380
|
/** 回滚操作
|
|
1358
1381
|
* @param data
|
|
@@ -1370,39 +1393,39 @@ class rs extends O {
|
|
|
1370
1393
|
return this.completed(e), e;
|
|
1371
1394
|
}
|
|
1372
1395
|
}
|
|
1373
|
-
class
|
|
1396
|
+
class vo extends z {
|
|
1374
1397
|
static name = "DrawWindow";
|
|
1375
|
-
container = new
|
|
1398
|
+
container = new p.Group();
|
|
1376
1399
|
interruptKeys = ["escape"];
|
|
1377
1400
|
shortcutKeys = ["control", "q"];
|
|
1378
1401
|
commandName = "draw-window-line";
|
|
1379
1402
|
onAddFromParent(e) {
|
|
1380
1403
|
super.onAddFromParent(e), this.editor.container.add(this.container);
|
|
1381
|
-
const t = this.commandManager.addCommandFlow(this.commandName).add(this.createInterrupt()).add(this.createCursor("no-drop")).add(this.selectPointStart.bind(this)).add(this.selectPointEnd.bind(this)).add(this.end.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
|
|
1404
|
+
const t = this.commandManager.addCommandFlow(this.commandName).add(this.createInterrupt()).add(this.createCursor("no-drop")).add(this.selectPointStart.bind(this)).add(this.selectPointEnd.bind(this)).add(this.end.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this)).setLoop(!0);
|
|
1382
1405
|
t.addEventListener("finally", this.createFinally(["selectPointStart"])), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(this.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => this.eventInput.isKeyCombination(this.commandName) && await this.commandManager.start(this.commandName)), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
1383
1406
|
}
|
|
1384
1407
|
/** 选择开始点
|
|
1385
1408
|
* @param next
|
|
1386
1409
|
*/
|
|
1387
1410
|
selectPointStart(e) {
|
|
1388
|
-
let t = null, n = this.renderer.createCircle(
|
|
1411
|
+
let t = null, n = this.renderer.createCircle(A.zero(), { color: 16711935 }), o = null;
|
|
1389
1412
|
this.addEventRecord("selectPointStart").add(this.editor.addEventListener("pointerPositionChange", () => {
|
|
1390
|
-
const { point:
|
|
1391
|
-
this.dispatchEvent({ type: "pointerMove", point:
|
|
1413
|
+
const { point: s, line: a, find: d } = this.editor.renderManager.adsorption();
|
|
1414
|
+
this.dispatchEvent({ type: "pointerMove", point: s }), d ? (this.domElement.style.cursor = "none", n.position.copy(s), o = a, t = s.clone(), this.container.add(n)) : (this.domElement.style.cursor = "no-drop", t = null, n.removeFromParent());
|
|
1392
1415
|
})).add(this.eventInput.addEventListener("codeChange", () => {
|
|
1393
|
-
this.eventInput.isKeyDown("mouse_0") && t && (this.canceEventRecord("selectPointStart"), e({ point: t, line:
|
|
1416
|
+
this.eventInput.isKeyDown("mouse_0") && t && (this.canceEventRecord("selectPointStart"), e({ point: t, line: o }));
|
|
1394
1417
|
})), this.addEventRecord("clear").add(() => n.removeFromParent());
|
|
1395
1418
|
}
|
|
1396
1419
|
/** 选择结束点
|
|
1397
1420
|
* @param next
|
|
1398
1421
|
*/
|
|
1399
1422
|
selectPointEnd(e, { point: t, line: n }) {
|
|
1400
|
-
let
|
|
1401
|
-
this.addEventRecord("clear").add(() =>
|
|
1402
|
-
const { point: a, find:
|
|
1403
|
-
this.dispatchEvent({ type: "pointerMove", point: a }),
|
|
1423
|
+
let o = null, s = this.renderer.createCircle(A.zero(), { color: 16711935 });
|
|
1424
|
+
this.addEventRecord("clear").add(() => s.removeFromParent()).add(this.editor.addEventListener("pointerPositionChange", () => {
|
|
1425
|
+
const { point: a, find: d, line: r } = this.editor.renderManager.adsorption();
|
|
1426
|
+
this.dispatchEvent({ type: "pointerMove", point: a }), d && r === n ? (this.domElement.style.cursor = "none", s.position.copy(a), o = a.clone(), this.container.add(s)) : (this.domElement.style.cursor = "no-drop", o = null, s.removeFromParent());
|
|
1404
1427
|
})).add(this.eventInput.addEventListener("codeChange", () => {
|
|
1405
|
-
this.eventInput.isKeyDown("mouse_0") &&
|
|
1428
|
+
this.eventInput.isKeyDown("mouse_0") && o && e({ line: n, start: t, end: o });
|
|
1406
1429
|
}));
|
|
1407
1430
|
}
|
|
1408
1431
|
/**
|
|
@@ -1410,18 +1433,18 @@ class ds extends O {
|
|
|
1410
1433
|
* @param next
|
|
1411
1434
|
* @param points
|
|
1412
1435
|
*/
|
|
1413
|
-
end(e, { start: t, end: n, line:
|
|
1414
|
-
const
|
|
1436
|
+
end(e, { start: t, end: n, line: o }) {
|
|
1437
|
+
const s = new N(A.from(t), A.from(n)), a = s.center, d = s.length(), r = {
|
|
1415
1438
|
p: { x: a.x, y: a.y, z: 0 },
|
|
1416
|
-
width:
|
|
1417
|
-
full: Math.abs(
|
|
1439
|
+
width: d,
|
|
1440
|
+
full: Math.abs(d - o.length()) < 0.01
|
|
1418
1441
|
};
|
|
1419
|
-
e({ line:
|
|
1442
|
+
e({ line: o, doorDataItem: r });
|
|
1420
1443
|
}
|
|
1421
1444
|
/** 执行完成
|
|
1422
1445
|
*/
|
|
1423
1446
|
completed({ doorDataItem: e, line: t }) {
|
|
1424
|
-
t.userData.isWindow = !0, t.userData.drawWindow || (t.userData.drawWindow = []), t.userData.drawWindow.push(e), this.renderManager.draw()
|
|
1447
|
+
t.userData.isWindow = !0, t.userData.drawWindow || (t.userData.drawWindow = []), t.userData.drawWindow.push(e), this.renderManager.draw();
|
|
1425
1448
|
}
|
|
1426
1449
|
/** 回滚操作
|
|
1427
1450
|
* @param data
|
|
@@ -1429,8 +1452,8 @@ class ds extends O {
|
|
|
1429
1452
|
rollback(e) {
|
|
1430
1453
|
const { doorDataItem: t, line: n } = e;
|
|
1431
1454
|
if (n.userData.drawWindow) {
|
|
1432
|
-
const
|
|
1433
|
-
|
|
1455
|
+
const o = n.userData.drawWindow.indexOf(t);
|
|
1456
|
+
o !== -1 && (n.userData.drawWindow.splice(o, 1), n.userData.drawWindow.length === 0 && (delete n.userData.drawWindow, delete n.userData.isWindow), this.renderManager.draw());
|
|
1434
1457
|
}
|
|
1435
1458
|
return e;
|
|
1436
1459
|
}
|
|
@@ -1442,25 +1465,25 @@ class ds extends O {
|
|
|
1442
1465
|
return this.completed(e), e;
|
|
1443
1466
|
}
|
|
1444
1467
|
}
|
|
1445
|
-
class
|
|
1468
|
+
class he extends z {
|
|
1446
1469
|
static name = "VerticalCorrection";
|
|
1447
|
-
container = new
|
|
1470
|
+
container = new p.Group();
|
|
1448
1471
|
shortcutKeys = ["control", "c"];
|
|
1449
1472
|
shortcutKeys3 = ["shift", "c"];
|
|
1450
1473
|
static commandName = "verticalCorrection";
|
|
1451
1474
|
axisAlignment = !1;
|
|
1452
1475
|
onAddFromParent(e) {
|
|
1453
1476
|
super.onAddFromParent(e), this.editor.container.add(this.container), this.container.position.z = 1e-3;
|
|
1454
|
-
const t = this.commandManager.addCommandFlow(
|
|
1477
|
+
const t = this.commandManager.addCommandFlow(he.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.verticalCorrection.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
|
|
1455
1478
|
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addEventListener("codeChange", async () => {
|
|
1456
|
-
this.eventInput.isOnlyKeyDowns(this.shortcutKeys) ? (this.axisAlignment = !1, this.commandManager.start(
|
|
1479
|
+
this.eventInput.isOnlyKeyDowns(this.shortcutKeys) ? (this.axisAlignment = !1, this.commandManager.start(he.commandName, [...this.default.selectLines])) : this.eventInput.isOnlyKeyDowns(this.shortcutKeys3) && (this.axisAlignment = !0, this.commandManager.start(he.commandName, [...this.default.selectLines]));
|
|
1457
1480
|
}), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
1458
1481
|
}
|
|
1459
1482
|
/**
|
|
1460
1483
|
* 进入命令约束
|
|
1461
1484
|
*/
|
|
1462
1485
|
constraint(e, t) {
|
|
1463
|
-
Array.isArray(t) ? t.length !== 1 ? (
|
|
1486
|
+
Array.isArray(t) ? t.length !== 1 ? (I({ message: "请选择一条线段", type: "warning" }), this.cancel()) : e(t) : (I({ message: "进入命令失败", type: "warning" }), this.cancel());
|
|
1464
1487
|
}
|
|
1465
1488
|
/**
|
|
1466
1489
|
* @param line0
|
|
@@ -1478,46 +1501,46 @@ class le extends O {
|
|
|
1478
1501
|
* @param id
|
|
1479
1502
|
* @returns
|
|
1480
1503
|
*/
|
|
1481
|
-
setLinePoint(e, t, n,
|
|
1504
|
+
setLinePoint(e, t, n, o = "all", s = [], a = Ot()) {
|
|
1482
1505
|
if (e.userData.setLinePointUUid === a) return [];
|
|
1483
1506
|
e.userData.setLinePointUUid = a;
|
|
1484
|
-
let
|
|
1485
|
-
(
|
|
1507
|
+
let d = [], r = [];
|
|
1508
|
+
(o === "start" || o === "all") && (d = this.renderManager.pointVirtualGrid.queryPoint(e.start).filter((g) => g.userData !== e)), (o === "end" || o === "all") && (r = this.renderManager.pointVirtualGrid.queryPoint(e.end).filter((g) => g.userData !== e));
|
|
1486
1509
|
const i = e.clone();
|
|
1487
|
-
let
|
|
1488
|
-
t && (e.start.equal(t) || (
|
|
1510
|
+
let l = "";
|
|
1511
|
+
t && (e.start.equal(t) || (l = "start"), s.push({
|
|
1489
1512
|
point: e.start,
|
|
1490
1513
|
oldPoint: e.start.clone(),
|
|
1491
1514
|
newPoint: t,
|
|
1492
1515
|
line: e
|
|
1493
|
-
}), e.start.copy(t)), n && (e.end.equal(n) || (
|
|
1516
|
+
}), e.start.copy(t)), n && (e.end.equal(n) || (l = l === "start" ? "all" : "end"), s.push({
|
|
1494
1517
|
point: e.end,
|
|
1495
1518
|
oldPoint: e.end.clone(),
|
|
1496
1519
|
newPoint: n,
|
|
1497
1520
|
line: e
|
|
1498
1521
|
}), e.end.copy(n));
|
|
1499
|
-
const m = (
|
|
1500
|
-
|
|
1501
|
-
const { point:
|
|
1522
|
+
const m = (g, w, h) => {
|
|
1523
|
+
g.forEach((C) => {
|
|
1524
|
+
const { point: v, userData: x } = C, L = x.start === v ? "start" : "end";
|
|
1502
1525
|
if (x.directionEqual(i))
|
|
1503
|
-
if (
|
|
1504
|
-
const
|
|
1505
|
-
if (
|
|
1526
|
+
if (L === "start") {
|
|
1527
|
+
const B = e.projectPoint(x.end, !1);
|
|
1528
|
+
if (B) return this.setLinePoint(x, w, B, "end", s, a);
|
|
1506
1529
|
} else {
|
|
1507
|
-
const
|
|
1508
|
-
if (
|
|
1530
|
+
const B = e.projectPoint(x.start, !1);
|
|
1531
|
+
if (B) return this.setLinePoint(x, B, w, "start", s, a);
|
|
1509
1532
|
}
|
|
1510
|
-
(
|
|
1533
|
+
(l === "all" || h === l) && this.setLinePoint(
|
|
1511
1534
|
x,
|
|
1512
|
-
x.start ===
|
|
1513
|
-
x.end ===
|
|
1514
|
-
x.start ===
|
|
1515
|
-
|
|
1535
|
+
x.start === v ? w : x.start,
|
|
1536
|
+
x.end === v ? w : x.end,
|
|
1537
|
+
x.start === v ? "end" : "start",
|
|
1538
|
+
s,
|
|
1516
1539
|
a
|
|
1517
1540
|
);
|
|
1518
1541
|
});
|
|
1519
1542
|
};
|
|
1520
|
-
return m(
|
|
1543
|
+
return m(d, e.start, "start"), m(r, e.end, "end"), [...d, ...r];
|
|
1521
1544
|
}
|
|
1522
1545
|
/** 修正2
|
|
1523
1546
|
* 第一步:确定需要修复的线段
|
|
@@ -1531,72 +1554,72 @@ class le extends O {
|
|
|
1531
1554
|
*/
|
|
1532
1555
|
correction(e, t = [], n = /* @__PURE__ */ new Set()) {
|
|
1533
1556
|
n.add(e);
|
|
1534
|
-
const
|
|
1535
|
-
const [m,
|
|
1536
|
-
return
|
|
1557
|
+
const o = this.renderManager.quadtree.queryLineSegment(e).filter(({ line: i }) => !(i === e || i.userData.isDoor || n.has(i))).map((i) => i.line), s = e.direction(), [a, d] = o.reduce((i, l) => {
|
|
1558
|
+
const [m, g] = i;
|
|
1559
|
+
return l.sameEndpoint(e) ? m.push(l) : g.push(l), i;
|
|
1537
1560
|
}, [[], []]);
|
|
1538
1561
|
a.forEach((i) => {
|
|
1539
|
-
const
|
|
1562
|
+
const l = i.direction(), m = s.angleBetween(l, "angle");
|
|
1540
1563
|
if (Math.abs(90 - m) > 45) return !1;
|
|
1541
|
-
const
|
|
1542
|
-
|
|
1543
|
-
|
|
1544
|
-
),
|
|
1545
|
-
if (
|
|
1564
|
+
const w = e.sameEndpointAsStart(i) ? e.start : e.end, h = i.sameEndpointAsStart(e) ? i.end : i.start, C = new N(
|
|
1565
|
+
h.clone().add(s.clone().multiplyScalar(1)),
|
|
1566
|
+
h.clone().add(s.clone().multiplyScalar(-1))
|
|
1567
|
+
), v = C.projectPoint(w, !1);
|
|
1568
|
+
if (v) {
|
|
1546
1569
|
const x = [];
|
|
1547
1570
|
this.setLinePoint(
|
|
1548
1571
|
i,
|
|
1549
|
-
i.start ===
|
|
1550
|
-
i.end ===
|
|
1551
|
-
i.start ===
|
|
1572
|
+
i.start === h ? v : i.start,
|
|
1573
|
+
i.end === h ? v : i.end,
|
|
1574
|
+
i.start === h ? "start" : "end",
|
|
1552
1575
|
x
|
|
1553
1576
|
), t.push(x);
|
|
1554
1577
|
}
|
|
1555
1578
|
return n.add(i), !1;
|
|
1556
|
-
}),
|
|
1557
|
-
const r = (i,
|
|
1558
|
-
const
|
|
1559
|
-
if (
|
|
1579
|
+
}), s.copy(e.direction());
|
|
1580
|
+
const r = (i, l, m) => {
|
|
1581
|
+
const g = e.projectPoint(l);
|
|
1582
|
+
if (g) i.copy(g);
|
|
1560
1583
|
else {
|
|
1561
|
-
const
|
|
1562
|
-
|
|
1563
|
-
|
|
1564
|
-
),
|
|
1565
|
-
if (
|
|
1566
|
-
const
|
|
1584
|
+
const w = new N(
|
|
1585
|
+
l.clone().add(s.clone().multiplyScalar(1)),
|
|
1586
|
+
l.clone().add(s.clone().multiplyScalar(-1))
|
|
1587
|
+
), h = w.projectPoint(i, !1);
|
|
1588
|
+
if (h) {
|
|
1589
|
+
const C = [];
|
|
1567
1590
|
this.setLinePoint(
|
|
1568
1591
|
m,
|
|
1569
|
-
m.start ===
|
|
1570
|
-
m.end ===
|
|
1571
|
-
m.start ===
|
|
1572
|
-
|
|
1573
|
-
), t.push(
|
|
1592
|
+
m.start === l ? h : m.start,
|
|
1593
|
+
m.end === l ? h : m.end,
|
|
1594
|
+
m.start === l ? "start" : "end",
|
|
1595
|
+
C
|
|
1596
|
+
), t.push(C);
|
|
1574
1597
|
}
|
|
1575
1598
|
}
|
|
1576
1599
|
};
|
|
1577
|
-
return
|
|
1600
|
+
return d.forEach((i) => {
|
|
1578
1601
|
if (e.containsPoint(i.start))
|
|
1579
1602
|
r(i.start, i.end, i);
|
|
1580
1603
|
else if (e.containsPoint(i.end))
|
|
1581
1604
|
r(i.end, i.start, i);
|
|
1582
1605
|
else {
|
|
1583
|
-
const
|
|
1584
|
-
if (
|
|
1606
|
+
const l = e.getIntersection(i);
|
|
1607
|
+
if (l) {
|
|
1585
1608
|
const m = new N(
|
|
1586
|
-
i.start.clone().add(
|
|
1587
|
-
i.start.clone().add(
|
|
1588
|
-
),
|
|
1589
|
-
if (
|
|
1590
|
-
const
|
|
1591
|
-
this.setLinePoint(i,
|
|
1609
|
+
i.start.clone().add(s.clone().multiplyScalar(1)),
|
|
1610
|
+
i.start.clone().add(s.clone().multiplyScalar(-1))
|
|
1611
|
+
), g = m.projectPoint(l, !1);
|
|
1612
|
+
if (g) {
|
|
1613
|
+
const C = [];
|
|
1614
|
+
this.setLinePoint(i, g, i.end, "start", C), t.push(C);
|
|
1592
1615
|
}
|
|
1593
|
-
const
|
|
1594
|
-
i.end.clone().add(
|
|
1595
|
-
i.end.clone().add(
|
|
1596
|
-
),
|
|
1597
|
-
if (
|
|
1598
|
-
const
|
|
1599
|
-
this.setLinePoint(i, i.start,
|
|
1616
|
+
const w = new N(
|
|
1617
|
+
i.end.clone().add(s.clone().multiplyScalar(1)),
|
|
1618
|
+
i.end.clone().add(s.clone().multiplyScalar(-1))
|
|
1619
|
+
), h = w.projectPoint(l, !1);
|
|
1620
|
+
if (h) {
|
|
1621
|
+
const C = [];
|
|
1622
|
+
this.setLinePoint(i, i.start, h, "end", C), t.push(C);
|
|
1600
1623
|
}
|
|
1601
1624
|
}
|
|
1602
1625
|
}
|
|
@@ -1608,7 +1631,7 @@ class le extends O {
|
|
|
1608
1631
|
*/
|
|
1609
1632
|
axisAlignmentCorrection(e) {
|
|
1610
1633
|
const t = [...this.renderManager.lines];
|
|
1611
|
-
return { newLines:
|
|
1634
|
+
return { newLines: Qt.correction(t, e, { groupMethod: "cross", fittingMethod: "max", crossAxistThreshold: 0.08 }), oldLines: t };
|
|
1612
1635
|
}
|
|
1613
1636
|
/** 开始
|
|
1614
1637
|
* @param next
|
|
@@ -1624,11 +1647,11 @@ class le extends O {
|
|
|
1624
1647
|
if (Array.isArray(e)) {
|
|
1625
1648
|
const t = [];
|
|
1626
1649
|
e.forEach((n) => {
|
|
1627
|
-
n.forEach((
|
|
1628
|
-
const { line:
|
|
1629
|
-
|
|
1650
|
+
n.forEach((o) => {
|
|
1651
|
+
const { line: s, newPoint: a, point: d } = o;
|
|
1652
|
+
d.copy(a), this.renderManager.removeLine(s), this.renderManager.addLine(s), s.userData.isWindow && t.push(s);
|
|
1630
1653
|
});
|
|
1631
|
-
}),
|
|
1654
|
+
}), _e(...t);
|
|
1632
1655
|
} else
|
|
1633
1656
|
this.renderManager.removeLines(e.oldLines), this.renderManager.addLines(e.newLines);
|
|
1634
1657
|
this.renderManager.draw();
|
|
@@ -1640,13 +1663,13 @@ class le extends O {
|
|
|
1640
1663
|
if (Array.isArray(e)) {
|
|
1641
1664
|
const t = [];
|
|
1642
1665
|
for (let n = e.length - 1; n >= 0; n--) {
|
|
1643
|
-
const
|
|
1644
|
-
for (let
|
|
1645
|
-
const a = s
|
|
1646
|
-
i.copy(r), this.renderManager.removeLine(
|
|
1666
|
+
const o = e[n];
|
|
1667
|
+
for (let s = o.length - 1; s >= 0; s--) {
|
|
1668
|
+
const a = o[s], { line: d, oldPoint: r, point: i } = a;
|
|
1669
|
+
i.copy(r), this.renderManager.removeLine(d), this.renderManager.addLine(d), d.userData.isWindow && t.push(d);
|
|
1647
1670
|
}
|
|
1648
1671
|
}
|
|
1649
|
-
|
|
1672
|
+
_e(...t);
|
|
1650
1673
|
} else
|
|
1651
1674
|
this.renderManager.removeLines(e.newLines), this.renderManager.addLines(e.oldLines);
|
|
1652
1675
|
return this.renderManager.draw(), e;
|
|
@@ -1659,31 +1682,31 @@ class le extends O {
|
|
|
1659
1682
|
return this.completed(e), e;
|
|
1660
1683
|
}
|
|
1661
1684
|
}
|
|
1662
|
-
class
|
|
1685
|
+
class ne extends z {
|
|
1663
1686
|
static name = "MergeLine";
|
|
1664
1687
|
shortcutKeys = ["control", "g"];
|
|
1665
1688
|
static commandName = "merge-line";
|
|
1666
1689
|
onAddFromParent(e) {
|
|
1667
1690
|
super.onAddFromParent(e);
|
|
1668
|
-
const t = this.commandManager.addCommandFlow(
|
|
1669
|
-
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(
|
|
1670
|
-
this.eventInput.isKeyCombination(
|
|
1691
|
+
const t = this.commandManager.addCommandFlow(ne.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.mergeLines.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
|
|
1692
|
+
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(ne.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
|
|
1693
|
+
this.eventInput.isKeyCombination(ne.commandName) && await this.commandManager.start(ne.commandName, [...this.default.selectLines]);
|
|
1671
1694
|
}), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
1672
1695
|
}
|
|
1673
1696
|
/**
|
|
1674
1697
|
* 进入命令约束
|
|
1675
1698
|
*/
|
|
1676
1699
|
constraint(e, t) {
|
|
1677
|
-
Array.isArray(t) ? t.length < 2 ? (
|
|
1700
|
+
Array.isArray(t) ? t.length < 2 ? (I({ message: "未执行线段合并,请选择至少两条线段", type: "warning" }), this.cancel()) : e(t) : (I({ message: "进入命令失败", type: "warning" }), this.cancel());
|
|
1678
1701
|
}
|
|
1679
1702
|
/** 开始
|
|
1680
1703
|
* @param next
|
|
1681
1704
|
* @todo 合并所有
|
|
1682
1705
|
*/
|
|
1683
1706
|
mergeLines(e, t) {
|
|
1684
|
-
t = t.filter((
|
|
1685
|
-
const { newLines: n, deleteLines:
|
|
1686
|
-
n.length ? (e({ newLines: n, deleteLines:
|
|
1707
|
+
t = t.filter((s) => !s.userData.isDoor);
|
|
1708
|
+
const { newLines: n, deleteLines: o } = N.autoMergeLines(t);
|
|
1709
|
+
n.length ? (e({ newLines: n, deleteLines: o }), I({ message: "已合并", type: "success" })) : (I({ message: "合并失败,未找到共用点", type: "warning" }), this.commandManager.cancel());
|
|
1687
1710
|
}
|
|
1688
1711
|
/** 执行完成
|
|
1689
1712
|
* @param data
|
|
@@ -1706,26 +1729,26 @@ class $ extends O {
|
|
|
1706
1729
|
return this.completed(e), e;
|
|
1707
1730
|
}
|
|
1708
1731
|
}
|
|
1709
|
-
class
|
|
1732
|
+
class oe extends z {
|
|
1710
1733
|
static name = "DeleteSelectLine";
|
|
1711
1734
|
shortcutKeys = ["Delete"];
|
|
1712
1735
|
static commandName = "deleteSelectLine";
|
|
1713
1736
|
onAddFromParent(e) {
|
|
1714
|
-
super.onAddFromParent(e), this.commandManager.addCommandFlow(
|
|
1715
|
-
this.eventInput.isKeyCombination(
|
|
1737
|
+
super.onAddFromParent(e), this.commandManager.addCommandFlow(oe.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.delete.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this)).addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(oe.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
|
|
1738
|
+
this.eventInput.isKeyCombination(oe.commandName) && await this.commandManager.start(oe.commandName, [...this.default.selectLines]);
|
|
1716
1739
|
}), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
1717
1740
|
}
|
|
1718
1741
|
/**
|
|
1719
1742
|
* 进入命令约束
|
|
1720
1743
|
*/
|
|
1721
1744
|
constraint(e, t) {
|
|
1722
|
-
Array.isArray(t) ? t.length === 0 ? (
|
|
1745
|
+
Array.isArray(t) ? t.length === 0 ? (I({ message: "请选择线段", type: "warning" }), this.cancel()) : e(t) : (I({ message: "进入命令失败", type: "warning" }), this.cancel());
|
|
1723
1746
|
}
|
|
1724
1747
|
/** 开始
|
|
1725
1748
|
* @param next
|
|
1726
1749
|
*/
|
|
1727
1750
|
delete(e, t) {
|
|
1728
|
-
t.forEach((n) => this.renderManager.removeLine(n)),
|
|
1751
|
+
t.forEach((n) => this.renderManager.removeLine(n)), I({ message: "删除成功", type: "success" }), e(t);
|
|
1729
1752
|
}
|
|
1730
1753
|
/** 回滚操作
|
|
1731
1754
|
* @param data
|
|
@@ -1741,36 +1764,36 @@ class ee extends O {
|
|
|
1741
1764
|
return e.forEach((t) => this.renderManager.removeLine(t)), e;
|
|
1742
1765
|
}
|
|
1743
1766
|
}
|
|
1744
|
-
class
|
|
1767
|
+
class se extends z {
|
|
1745
1768
|
static name = "ConnectionLine";
|
|
1746
1769
|
shortcutKeys = ["Shift", "L"];
|
|
1747
1770
|
static commandName = "connectionLine";
|
|
1748
1771
|
onAddFromParent(e) {
|
|
1749
1772
|
super.onAddFromParent(e);
|
|
1750
|
-
const t = this.commandManager.addCommandFlow(
|
|
1751
|
-
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(
|
|
1752
|
-
this.eventInput.isKeyCombination(
|
|
1773
|
+
const t = this.commandManager.addCommandFlow(se.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.connection.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
|
|
1774
|
+
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(se.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
|
|
1775
|
+
this.eventInput.isKeyCombination(se.commandName) && await this.commandManager.start(se.commandName, [...this.default.selectLines]);
|
|
1753
1776
|
}), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
1754
1777
|
}
|
|
1755
1778
|
/**
|
|
1756
1779
|
* 进入命令约束
|
|
1757
1780
|
*/
|
|
1758
1781
|
constraint(e, t) {
|
|
1759
|
-
Array.isArray(t) ? t.length !== 2 ? (
|
|
1782
|
+
Array.isArray(t) ? t.length !== 2 ? (I({ message: "请选择2条线段", type: "warning" }), this.cancel()) : e(t) : (I({ message: "进入命令失败", type: "warning" }), this.cancel());
|
|
1760
1783
|
}
|
|
1761
1784
|
/** 连接
|
|
1762
1785
|
* @param next
|
|
1763
1786
|
*/
|
|
1764
1787
|
connection(e, t) {
|
|
1765
|
-
let n,
|
|
1788
|
+
let n, o, s = 1 / 0;
|
|
1766
1789
|
for (let a = 0; a < 2; a++)
|
|
1767
|
-
for (let
|
|
1768
|
-
const r = t[0].points[a], i = t[1].points[
|
|
1769
|
-
|
|
1790
|
+
for (let d = 0; d < 2; d++) {
|
|
1791
|
+
const r = t[0].points[a], i = t[1].points[d], l = r.distance(i);
|
|
1792
|
+
l < s && (n = r, o = i, s = l);
|
|
1770
1793
|
}
|
|
1771
|
-
if (n &&
|
|
1772
|
-
const a = new N(n.clone(),
|
|
1773
|
-
e(a),
|
|
1794
|
+
if (n && o) {
|
|
1795
|
+
const a = new N(n.clone(), o.clone());
|
|
1796
|
+
e(a), I({ message: "连接成功", type: "success" });
|
|
1774
1797
|
} else this.cancel();
|
|
1775
1798
|
}
|
|
1776
1799
|
/** 成功
|
|
@@ -1794,47 +1817,47 @@ class te extends O {
|
|
|
1794
1817
|
return this.completed(e), e;
|
|
1795
1818
|
}
|
|
1796
1819
|
}
|
|
1797
|
-
class
|
|
1820
|
+
class ae extends z {
|
|
1798
1821
|
static name = "IntersectionConnectionLine";
|
|
1799
1822
|
shortcutKeys = ["control", "Shift", "L"];
|
|
1800
1823
|
static commandName = "intersectionConnectionLine";
|
|
1801
1824
|
onAddFromParent(e) {
|
|
1802
1825
|
super.onAddFromParent(e);
|
|
1803
|
-
const t = this.commandManager.addCommandFlow(
|
|
1804
|
-
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(
|
|
1805
|
-
this.eventInput.isKeyCombination(
|
|
1826
|
+
const t = this.commandManager.addCommandFlow(ae.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.connection.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
|
|
1827
|
+
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(ae.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
|
|
1828
|
+
this.eventInput.isKeyCombination(ae.commandName) && await this.commandManager.start(ae.commandName, [...this.default.selectLines]);
|
|
1806
1829
|
}), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
1807
1830
|
}
|
|
1808
1831
|
/**
|
|
1809
1832
|
* 进入命令约束
|
|
1810
1833
|
*/
|
|
1811
1834
|
constraint(e, t) {
|
|
1812
|
-
Array.isArray(t) ? t.length !== 2 ? (
|
|
1835
|
+
Array.isArray(t) ? t.length !== 2 ? (I({ message: "请选择2条线段", type: "warning" }), this.cancel()) : e(t) : (I({ message: "进入命令失败", type: "warning" }), this.cancel());
|
|
1813
1836
|
}
|
|
1814
1837
|
/** 开始
|
|
1815
1838
|
* @param next
|
|
1816
1839
|
*/
|
|
1817
1840
|
connection(e, t) {
|
|
1818
|
-
const n = t[0],
|
|
1819
|
-
if (!
|
|
1820
|
-
const a = n.points.map((
|
|
1821
|
-
n.start.distance(
|
|
1822
|
-
const r = n.points.map((
|
|
1823
|
-
e({ line1: n, line2:
|
|
1841
|
+
const n = t[0], o = t[1], s = t[0].getIntersection(t[1]);
|
|
1842
|
+
if (!s) return;
|
|
1843
|
+
const a = n.points.map((l) => l.clone()), d = o.points.map((l) => l.clone());
|
|
1844
|
+
n.start.distance(s) < n.end.distance(s) ? n.start.copy(s) : n.end.copy(s), o.start.distance(s) < o.end.distance(s) ? o.start.copy(s) : o.end.copy(s);
|
|
1845
|
+
const r = n.points.map((l) => l.clone()), i = o.points.map((l) => l.clone());
|
|
1846
|
+
e({ line1: n, line2: o, oldLine1: a, oldLine2: d, newLine1: r, newLine2: i }), I({ message: "连接成功", type: "success" });
|
|
1824
1847
|
}
|
|
1825
1848
|
/** 执行完成
|
|
1826
1849
|
* @param next
|
|
1827
1850
|
* @param selectLines
|
|
1828
1851
|
*/
|
|
1829
|
-
completed({ line1: e, line2: t, newLine1: n, newLine2:
|
|
1830
|
-
this.renderManager.removeLine(e), this.renderManager.removeLine(t), e.set(...n), t.set(...
|
|
1852
|
+
completed({ line1: e, line2: t, newLine1: n, newLine2: o }) {
|
|
1853
|
+
this.renderManager.removeLine(e), this.renderManager.removeLine(t), e.set(...n), t.set(...o), this.renderManager.addLines([e, t]), this.renderManager.draw();
|
|
1831
1854
|
}
|
|
1832
1855
|
/** 回滚操作
|
|
1833
1856
|
* @param data
|
|
1834
1857
|
*/
|
|
1835
1858
|
rollback(e) {
|
|
1836
|
-
const { line1: t, line2: n, oldLine1:
|
|
1837
|
-
return this.renderManager.removeLine(t), this.renderManager.removeLine(n), t.set(...
|
|
1859
|
+
const { line1: t, line2: n, oldLine1: o, oldLine2: s } = e;
|
|
1860
|
+
return this.renderManager.removeLine(t), this.renderManager.removeLine(n), t.set(...o), n.set(...s), this.renderManager.addLines([t, n]), this.renderManager.draw(), e;
|
|
1838
1861
|
}
|
|
1839
1862
|
/** 撤回回滚
|
|
1840
1863
|
* @param lines
|
|
@@ -1844,34 +1867,34 @@ class ne extends O {
|
|
|
1844
1867
|
return this.completed(e), e;
|
|
1845
1868
|
}
|
|
1846
1869
|
}
|
|
1847
|
-
class
|
|
1870
|
+
class ie extends z {
|
|
1848
1871
|
static name = "DeleteSelectWindow";
|
|
1849
1872
|
shortcutKeys = ["Q", "Delete"];
|
|
1850
1873
|
static commandName = "deleteSelectWindow";
|
|
1851
1874
|
onAddFromParent(e) {
|
|
1852
1875
|
super.onAddFromParent(e);
|
|
1853
|
-
const t = this.commandManager.addCommandFlow(
|
|
1854
|
-
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(
|
|
1855
|
-
this.eventInput.isKeyCombination(
|
|
1876
|
+
const t = this.commandManager.addCommandFlow(ie.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.end.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
|
|
1877
|
+
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(ie.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
|
|
1878
|
+
this.eventInput.isKeyCombination(ie.commandName) && await this.commandManager.start(ie.commandName, [...this.default.selectLines]);
|
|
1856
1879
|
}), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
1857
1880
|
}
|
|
1858
1881
|
/**
|
|
1859
1882
|
* 进入命令约束
|
|
1860
1883
|
*/
|
|
1861
1884
|
constraint(e, t) {
|
|
1862
|
-
Array.isArray(t) ? t.some((n) => n.userData.isWindow) ? e(t) : (
|
|
1885
|
+
Array.isArray(t) ? t.some((n) => n.userData.isWindow) ? e(t) : (I({ message: "请选择有窗户线段", type: "warning" }), this.cancel()) : (I({ message: "进入命令失败", type: "warning" }), this.cancel());
|
|
1863
1886
|
}
|
|
1864
1887
|
/** 开始
|
|
1865
1888
|
* @param next
|
|
1866
1889
|
*/
|
|
1867
1890
|
end(e, t) {
|
|
1868
|
-
let n = !1,
|
|
1869
|
-
t.forEach((
|
|
1870
|
-
|
|
1871
|
-
line:
|
|
1872
|
-
drawDoorData:
|
|
1891
|
+
let n = !1, o = [];
|
|
1892
|
+
t.forEach((s) => {
|
|
1893
|
+
s.userData.isWindow && (o.push({
|
|
1894
|
+
line: s,
|
|
1895
|
+
drawDoorData: s.userData.drawDoorData
|
|
1873
1896
|
}), n = !0);
|
|
1874
|
-
}), n &&
|
|
1897
|
+
}), n && I({ message: "删除窗户成功", type: "success" }), e(o);
|
|
1875
1898
|
}
|
|
1876
1899
|
/**
|
|
1877
1900
|
* 完成
|
|
@@ -1901,16 +1924,16 @@ class se extends O {
|
|
|
1901
1924
|
return this.completed(e), e;
|
|
1902
1925
|
}
|
|
1903
1926
|
}
|
|
1904
|
-
class
|
|
1927
|
+
class re extends z {
|
|
1905
1928
|
static name = "SelectAll";
|
|
1906
|
-
container = new
|
|
1929
|
+
container = new p.Group();
|
|
1907
1930
|
shortcutKeys = ["control", "a"];
|
|
1908
1931
|
static commandName = "selectAll";
|
|
1909
1932
|
onAddFromParent(e) {
|
|
1910
1933
|
super.onAddFromParent(e), this.editor.container.add(this.container), this.container.position.z = 1e-3;
|
|
1911
|
-
const t = this.commandManager.addCommandFlow(
|
|
1912
|
-
t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(
|
|
1913
|
-
this.eventInput.isKeyCombination(
|
|
1934
|
+
const t = this.commandManager.addCommandFlow(re.commandName).add(this.createInterrupt()).add(this.selectAll.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
|
|
1935
|
+
t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(re.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
|
|
1936
|
+
this.eventInput.isKeyCombination(re.commandName) && await this.commandManager.start(re.commandName);
|
|
1914
1937
|
}), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
1915
1938
|
}
|
|
1916
1939
|
/** 开始
|
|
@@ -1938,22 +1961,22 @@ class oe extends O {
|
|
|
1938
1961
|
return this.completed(e), e;
|
|
1939
1962
|
}
|
|
1940
1963
|
}
|
|
1941
|
-
class
|
|
1964
|
+
class de extends z {
|
|
1942
1965
|
static name = "ViewAngle";
|
|
1943
1966
|
shortcutKeys = ["r"];
|
|
1944
1967
|
static commandName = "viewAngle";
|
|
1945
1968
|
onAddFromParent(e) {
|
|
1946
1969
|
super.onAddFromParent(e);
|
|
1947
|
-
const t = this.commandManager.addCommandFlow(
|
|
1948
|
-
t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(
|
|
1949
|
-
this.eventInput.isKeyCombination(
|
|
1970
|
+
const t = this.commandManager.addCommandFlow(de.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.viewAngle.bind(this));
|
|
1971
|
+
t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(de.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
|
|
1972
|
+
this.eventInput.isKeyCombination(de.commandName) && await this.commandManager.start(de.commandName, [...this.default.selectLines]);
|
|
1950
1973
|
}), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
1951
1974
|
}
|
|
1952
1975
|
/**
|
|
1953
1976
|
* 进入命令约束
|
|
1954
1977
|
*/
|
|
1955
1978
|
constraint(e, t) {
|
|
1956
|
-
Array.isArray(t) ? t.length !== 2 || !t[0].sameEndpoint(t[1]) ? (
|
|
1979
|
+
Array.isArray(t) ? t.length !== 2 || !t[0].sameEndpoint(t[1]) ? (I({ message: "请选择两条具有端点相交的线段", type: "warning" }), this.cancel()) : e(t) : (I({ message: "进入命令失败", type: "warning" }), this.cancel());
|
|
1957
1980
|
}
|
|
1958
1981
|
/**
|
|
1959
1982
|
*
|
|
@@ -1961,68 +1984,68 @@ class ae extends O {
|
|
|
1961
1984
|
* @param selectLines
|
|
1962
1985
|
*/
|
|
1963
1986
|
viewAngle(e, t) {
|
|
1964
|
-
const [n,
|
|
1965
|
-
let a,
|
|
1966
|
-
n.sameEndpointAsStart(
|
|
1967
|
-
function m(
|
|
1968
|
-
const
|
|
1969
|
-
let
|
|
1970
|
-
return
|
|
1987
|
+
const [n, o] = t, s = Math.min(n.length() * 0.8, o.length() * 0.8);
|
|
1988
|
+
let a, d, r, i = 0, l = 0;
|
|
1989
|
+
n.sameEndpointAsStart(o) ? (a = n.start, d = n.end) : (a = n.end, d = n.start), o.sameEndpointAsStart(n) ? r = o.end : r = o.start;
|
|
1990
|
+
function m(Q, W) {
|
|
1991
|
+
const E = W.x - Q.x, q = W.y - Q.y;
|
|
1992
|
+
let F = Math.atan2(q, E) * (180 / Math.PI);
|
|
1993
|
+
return F < 0 && (F += 360), F;
|
|
1971
1994
|
}
|
|
1972
|
-
const
|
|
1973
|
-
function x(
|
|
1974
|
-
for (let
|
|
1975
|
-
const
|
|
1976
|
-
|
|
1995
|
+
const g = m(a, d), w = m(a, r), h = Math.min(g, w), C = Math.max(g, w), v = [];
|
|
1996
|
+
function x(Q, W) {
|
|
1997
|
+
for (let E = Q; E <= W; E++) {
|
|
1998
|
+
const q = Math.cos(E * Math.PI / 180) * s + a.x, F = Math.sin(E * Math.PI / 180) * s + a.y, S = Math.cos((E + 1) * Math.PI / 180) * s + a.x, X = Math.sin((E + 1) * Math.PI / 180) * s + a.y;
|
|
1999
|
+
v.push(q, F, 0, S, X, 0);
|
|
1977
2000
|
}
|
|
1978
2001
|
}
|
|
1979
|
-
|
|
1980
|
-
const
|
|
1981
|
-
|
|
1982
|
-
position:
|
|
1983
|
-
},
|
|
1984
|
-
const
|
|
2002
|
+
C - h > 180 ? (x(0, h), x(C, 360), i = 360 - (C - h), l = (C + i / 2) % 360) : (x(h, C), i = C - h, l = h + i / 2);
|
|
2003
|
+
const L = new p.LineSegments();
|
|
2004
|
+
L.geometry = this.renderManager.createGeometry({
|
|
2005
|
+
position: v
|
|
2006
|
+
}, v.length / 3), L.material = new p.LineBasicMaterial({ color: 16711935 }), this.renderManager.container.add(L);
|
|
2007
|
+
const B = Math.cos(l * Math.PI / 180) * s + a.x, $ = Math.sin(l * Math.PI / 180) * s + a.y, ee = this.renderer.createText(Number(i.toFixed(2)), new p.Vector3(B, $, 0), {
|
|
1985
2008
|
textShadow: "0px 0px 2px #000"
|
|
1986
2009
|
}, this.renderManager.container);
|
|
1987
|
-
let
|
|
1988
|
-
this.addEventRecord("clear").add(() =>
|
|
1989
|
-
this.eventInput.isOnlyKeyDown("enter") ? e() : this.eventInput.isOnlyKeyDown("mouse_0") && (
|
|
2010
|
+
let _ = 0;
|
|
2011
|
+
this.addEventRecord("clear").add(() => L.removeFromParent()).add(() => ee.removeFromParent()).add(this.eventInput.addEventListener("codeChange", () => {
|
|
2012
|
+
this.eventInput.isOnlyKeyDown("enter") ? e() : this.eventInput.isOnlyKeyDown("mouse_0") && (_++, _ === 1 ? setTimeout(() => _ = 0, 500) : _ === 2 && (e(), _ = 0));
|
|
1990
2013
|
}));
|
|
1991
2014
|
}
|
|
1992
2015
|
}
|
|
1993
|
-
class
|
|
2016
|
+
class pt extends z {
|
|
1994
2017
|
static name = "ClippingLine";
|
|
1995
|
-
container = new
|
|
2018
|
+
container = new p.Group();
|
|
1996
2019
|
shortcutKeys = ["control", "x"];
|
|
1997
2020
|
commandName = "clippingLine";
|
|
1998
2021
|
static commandName = "clippingLine";
|
|
1999
2022
|
onAddFromParent(e) {
|
|
2000
2023
|
super.onAddFromParent(e), this.editor.container.add(this.container);
|
|
2001
|
-
const t = this.commandManager.addCommandFlow(this.commandName).add(this.createInterrupt()).add(this.createCursor("no-drop")).add(this.selectPointStart.bind(this)).add(this.selectPointEnd.bind(this)).add(this.end.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
|
|
2024
|
+
const t = this.commandManager.addCommandFlow(this.commandName).add(this.createInterrupt()).add(this.createCursor("no-drop")).add(this.selectPointStart.bind(this)).add(this.selectPointEnd.bind(this)).add(this.end.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this)).setLoop(!0);
|
|
2002
2025
|
t.addEventListener("finally", this.createFinally(["selectPointStart"])), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(this.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => this.eventInput.isKeyCombination(this.commandName) && await this.commandManager.start(this.commandName)), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
2003
2026
|
}
|
|
2004
2027
|
/** 选择开始点
|
|
2005
2028
|
* @param next
|
|
2006
2029
|
*/
|
|
2007
2030
|
selectPointStart(e) {
|
|
2008
|
-
let t = null, n = this.renderer.createCircle(
|
|
2031
|
+
let t = null, n = this.renderer.createCircle(A.zero(), { color: 16711935 }), o = null;
|
|
2009
2032
|
this.addEventRecord("selectPointStart").add(this.editor.addEventListener("pointerPositionChange", () => {
|
|
2010
|
-
const { point:
|
|
2011
|
-
this.dispatchEvent({ type: "pointerMove", point:
|
|
2033
|
+
const { point: s, line: a, find: d } = this.editor.renderManager.adsorption();
|
|
2034
|
+
this.dispatchEvent({ type: "pointerMove", point: s }), d ? (this.domElement.style.cursor = "none", n.position.copy(s), o = a, t = s.clone(), this.container.add(n)) : (this.domElement.style.cursor = "no-drop", t = null, n.removeFromParent());
|
|
2012
2035
|
})).add(this.eventInput.addEventListener("codeChange", () => {
|
|
2013
|
-
this.eventInput.isKeyDown("mouse_0") && t && (this.canceEventRecord("selectPointStart"), e({ point: t, line:
|
|
2036
|
+
this.eventInput.isKeyDown("mouse_0") && t && (this.canceEventRecord("selectPointStart"), e({ point: t, line: o }));
|
|
2014
2037
|
})), this.addEventRecord("clear").add(() => n.removeFromParent());
|
|
2015
2038
|
}
|
|
2016
2039
|
/** 选择结束点
|
|
2017
2040
|
* @param next
|
|
2018
2041
|
*/
|
|
2019
2042
|
selectPointEnd(e, { point: t, line: n }) {
|
|
2020
|
-
let
|
|
2021
|
-
this.addEventRecord("clear").add(() =>
|
|
2022
|
-
const { point: a, find:
|
|
2023
|
-
this.dispatchEvent({ type: "pointerMove", point: a }),
|
|
2043
|
+
let o = null, s = this.renderer.createCircle(A.zero(), { color: 16711935 });
|
|
2044
|
+
this.addEventRecord("clear").add(() => s.removeFromParent()).add(this.editor.addEventListener("pointerPositionChange", () => {
|
|
2045
|
+
const { point: a, find: d, line: r } = this.editor.renderManager.adsorption();
|
|
2046
|
+
this.dispatchEvent({ type: "pointerMove", point: a }), d && r === n ? (this.domElement.style.cursor = "none", s.position.copy(a), o = a.clone(), this.container.add(s)) : (this.domElement.style.cursor = "no-drop", o = null, s.removeFromParent());
|
|
2024
2047
|
})).add(this.eventInput.addEventListener("codeChange", () => {
|
|
2025
|
-
this.eventInput.isKeyDown("mouse_0") &&
|
|
2048
|
+
this.eventInput.isKeyDown("mouse_0") && o && e({ line: n, start: t, end: o });
|
|
2026
2049
|
}));
|
|
2027
2050
|
}
|
|
2028
2051
|
/**
|
|
@@ -2030,24 +2053,24 @@ class lt extends O {
|
|
|
2030
2053
|
* @param next
|
|
2031
2054
|
* @param points
|
|
2032
2055
|
*/
|
|
2033
|
-
end(e, { start: t, end: n, line:
|
|
2034
|
-
const
|
|
2056
|
+
end(e, { start: t, end: n, line: o }) {
|
|
2057
|
+
const s = A.from(t), a = A.from(n);
|
|
2035
2058
|
e({
|
|
2036
|
-
oldLine:
|
|
2059
|
+
oldLine: o,
|
|
2037
2060
|
newLine1: new N(
|
|
2038
|
-
|
|
2039
|
-
|
|
2061
|
+
o.start,
|
|
2062
|
+
o.start.distance(s) < o.start.distance(a) ? s.clone() : a.clone()
|
|
2040
2063
|
),
|
|
2041
2064
|
newLine2: new N(
|
|
2042
|
-
|
|
2043
|
-
|
|
2065
|
+
o.end,
|
|
2066
|
+
o.end.distance(s) < o.end.distance(a) ? s.clone() : a.clone()
|
|
2044
2067
|
)
|
|
2045
2068
|
});
|
|
2046
2069
|
}
|
|
2047
2070
|
/** 执行完成
|
|
2048
2071
|
*/
|
|
2049
2072
|
completed(e) {
|
|
2050
|
-
this.renderManager.removeLine(e.oldLine), this.renderManager.addLines([e.newLine1, e.newLine2]), this.renderManager.draw()
|
|
2073
|
+
this.renderManager.removeLine(e.oldLine), this.renderManager.addLines([e.newLine1, e.newLine2]), this.renderManager.draw();
|
|
2051
2074
|
}
|
|
2052
2075
|
/** 回滚操作
|
|
2053
2076
|
* @param data
|
|
@@ -2063,22 +2086,22 @@ class lt extends O {
|
|
|
2063
2086
|
return this.completed(e), e;
|
|
2064
2087
|
}
|
|
2065
2088
|
}
|
|
2066
|
-
class
|
|
2089
|
+
class le extends z {
|
|
2067
2090
|
static name = "VerticalReferenceLine";
|
|
2068
2091
|
shortcutKeys = ["v"];
|
|
2069
2092
|
static commandName = "VerticalReferenceLine";
|
|
2070
2093
|
onAddFromParent(e) {
|
|
2071
2094
|
super.onAddFromParent(e);
|
|
2072
|
-
const t = this.commandManager.addCommandFlow(
|
|
2073
|
-
t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(
|
|
2074
|
-
this.eventInput.isKeyCombination(
|
|
2095
|
+
const t = this.commandManager.addCommandFlow(le.commandName).add(this.createInterrupt()).add(this.constraint.bind(this)).add(this.verticalReferenceLine.bind(this));
|
|
2096
|
+
t.writeOperationList = !1, t.addEventListener("finally", this.createFinally()), this.eventInput.addKeyCombination(le.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => {
|
|
2097
|
+
this.eventInput.isKeyCombination(le.commandName) && await this.commandManager.start(le.commandName, [...this.default.selectLines]);
|
|
2075
2098
|
}), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
2076
2099
|
}
|
|
2077
2100
|
/**
|
|
2078
2101
|
* 进入命令约束
|
|
2079
2102
|
*/
|
|
2080
2103
|
constraint(e, t) {
|
|
2081
|
-
Array.isArray(t) ? t.length !== 1 ? (
|
|
2104
|
+
Array.isArray(t) ? t.length !== 1 ? (I({ message: "请选择一条墙壁线段", type: "warning" }), this.cancel()) : t[0].userData.isDoor ? (I({ message: "请选择一条墙壁线段", type: "warning" }), this.cancel()) : e(t) : (I({ message: "进入命令失败", type: "warning" }), this.cancel());
|
|
2082
2105
|
}
|
|
2083
2106
|
/**
|
|
2084
2107
|
*
|
|
@@ -2091,67 +2114,73 @@ class ie extends O {
|
|
|
2091
2114
|
}), t[0].userData.isVerticalReferenceLine = !0, e(), this.renderManager.draw();
|
|
2092
2115
|
}
|
|
2093
2116
|
}
|
|
2094
|
-
const
|
|
2117
|
+
const fo = {
|
|
2095
2118
|
key: 0,
|
|
2096
2119
|
class: "mt-[5px] text-[#ccc] text-[11px] absolute left-[10px] bottom-[10px] rounded-[8px] min-w-[150px] bg-black/15 p-[10px]"
|
|
2097
|
-
},
|
|
2120
|
+
}, yo = { class: "text-start max-w-[150px]" }, wo = { class: "inline-block ml-[10px] text-[var(--color-primary)]" }, Co = {
|
|
2098
2121
|
key: 0,
|
|
2099
2122
|
class: "p-[5px] max-w-[200px]"
|
|
2100
|
-
},
|
|
2123
|
+
}, bo = { class: "text-[14px] flex flex-col" }, Eo = ["onClick"], xo = { class: "flex flex-row items-center" }, Ao = { class: "flex justify-center items-center size-[20px] bg-[#f0f0f0] rounded-[2px] mr-[10px]" }, Lo = ["src"], Mo = { class: "text-wrap" }, Io = {
|
|
2124
|
+
key: 0,
|
|
2125
|
+
class: "flex items-center gap-[5px]"
|
|
2126
|
+
}, ko = {
|
|
2101
2127
|
key: 1,
|
|
2102
2128
|
class: "text-[#999]"
|
|
2103
|
-
},
|
|
2129
|
+
}, Do = {
|
|
2104
2130
|
style: { "--el-color-primary": "var(--primary-color)" },
|
|
2105
2131
|
class: "flex flex-row items-center justify-between gap-[5px] mt-[10px] text-[10px]"
|
|
2106
|
-
},
|
|
2132
|
+
}, Po = {
|
|
2107
2133
|
key: 0,
|
|
2108
2134
|
class: "flex flex-row items-center flex-wrap justify-between gap-[10px] mt-[10px] text-[10px]"
|
|
2109
|
-
},
|
|
2135
|
+
}, Bo = { class: "flex-wrap border-t-1 border-t-[#eee] mt-[5px] pt-[5px] flex items-center gap-[10px]" }, So = ["onClick", "title"], Fo = ["src"], Ko = /* @__PURE__ */ pe({
|
|
2110
2136
|
__name: "EditorTool",
|
|
2111
2137
|
props: {
|
|
2112
2138
|
dxfSystem: {},
|
|
2113
2139
|
permission: {}
|
|
2114
2140
|
},
|
|
2115
2141
|
setup(c) {
|
|
2116
|
-
function e(
|
|
2117
|
-
const
|
|
2118
|
-
|
|
2142
|
+
function e(b, u, y = g.value.getBoundingClientRect(), Y = w.value.getBoundingClientRect()) {
|
|
2143
|
+
const ge = y.width - Y.width, ve = 0, Me = y.height - Y.height;
|
|
2144
|
+
b = Math.max(0, Math.min(b, ge)), u = Math.max(ve, Math.min(u, Me)), F.value = { left: b, top: u };
|
|
2119
2145
|
}
|
|
2120
|
-
function t(
|
|
2121
|
-
|
|
2146
|
+
function t(b) {
|
|
2147
|
+
C.value !== b.command && (C.value !== "default" && L.commandManager.cancel(), setTimeout(() => L.commandManager.start(b.command)));
|
|
2122
2148
|
}
|
|
2123
|
-
function n(
|
|
2124
|
-
if (
|
|
2125
|
-
localStorage.setItem("lines", JSON.stringify(
|
|
2149
|
+
function n(b) {
|
|
2150
|
+
if (b) {
|
|
2151
|
+
localStorage.setItem("lines", JSON.stringify(b));
|
|
2126
2152
|
try {
|
|
2127
|
-
|
|
2153
|
+
v.Dxf.set(b), v.Dxf.lineOffset();
|
|
2128
2154
|
} catch (u) {
|
|
2129
2155
|
console.log(u);
|
|
2130
2156
|
}
|
|
2131
2157
|
}
|
|
2132
2158
|
}
|
|
2133
|
-
async function
|
|
2134
|
-
const
|
|
2135
|
-
Array.isArray(
|
|
2159
|
+
async function o() {
|
|
2160
|
+
const b = await Rt.json();
|
|
2161
|
+
Array.isArray(b) && (localStorage.removeItem("orbitControls"), n(b));
|
|
2136
2162
|
}
|
|
2137
|
-
function
|
|
2138
|
-
|
|
2139
|
-
|
|
2163
|
+
function s() {
|
|
2164
|
+
_.set("currentKeyDown", "enter"), queueMicrotask(() => _.set("currentKeyUp", "enter"));
|
|
2165
|
+
}
|
|
2166
|
+
function a({ offsetX: b, offsetY: u }) {
|
|
2167
|
+
x.mouseMoveEventProxylock = !0;
|
|
2168
|
+
const y = document.body.style.cursor;
|
|
2140
2169
|
document.body.style.cursor = "move";
|
|
2141
|
-
const
|
|
2142
|
-
const
|
|
2170
|
+
const Y = (ge) => {
|
|
2171
|
+
const ve = g.value.getBoundingClientRect(), Me = w.value.getBoundingClientRect();
|
|
2143
2172
|
e(
|
|
2144
|
-
|
|
2145
|
-
|
|
2146
|
-
|
|
2147
|
-
|
|
2148
|
-
),
|
|
2149
|
-
},
|
|
2150
|
-
document.body.removeEventListener("mousemove",
|
|
2173
|
+
ge.pageX - ve.left - b,
|
|
2174
|
+
ge.pageY - ve.top - u,
|
|
2175
|
+
ve,
|
|
2176
|
+
Me
|
|
2177
|
+
), ge.stopPropagation(), document.body.style.cursor = "move";
|
|
2178
|
+
}, Le = () => {
|
|
2179
|
+
document.body.removeEventListener("mousemove", Y), document.removeEventListener("mouseup", Le), document.body.style.cursor = y, x.mouseMoveEventProxylock = !1;
|
|
2151
2180
|
};
|
|
2152
|
-
document.body.addEventListener("mousemove",
|
|
2181
|
+
document.body.addEventListener("mousemove", Y), document.addEventListener("mouseup", Le);
|
|
2153
2182
|
}
|
|
2154
|
-
const
|
|
2183
|
+
const d = c, r = P(!0), i = P(!0), l = P(!0), m = P(!1), g = P(), w = P(), h = P(!0), C = P(""), v = Jt(d.dxfSystem), x = v.findComponentByType(Nt), L = v.findComponentByType(gt), B = v.findComponentByType(ht), $ = v.findComponentByType(Tt), ee = v.findComponentByType(Vt), _ = v.findComponentByType(jt), Q = v.findComponentByType(mt), W = P(0), E = P(0), q = P(0), F = P({ left: 10, top: 100 }), S = /* @__PURE__ */ Object.assign({ "./assets/images/angle.svg": Sn, "./assets/images/connection.svg": Kn, "./assets/images/cutLine.svg": Rn, "./assets/images/deleteSelectLine.svg": On, "./assets/images/deleteSelectWindow.svg": Tn, "./assets/images/door.svg": jn, "./assets/images/intersectionConnection.svg": Gn, "./assets/images/line.svg": Jn, "./assets/images/mergeLine.svg": Wn, "./assets/images/revokeRollback.svg": Zn, "./assets/images/rollback.svg": Xn, "./assets/images/selectAll.svg": eo, "./assets/images/selectPoint.svg": no, "./assets/images/verticalCorrection.svg": so, "./assets/images/verticalLine.svg": io, "./assets/images/window.svg": lo }), X = P(!1), Z = P(0), Ke = P(!1), Ae = new ResizeObserver(() => e(F.value.left, F.value.top)), vt = [
|
|
2155
2184
|
{ name: "开启绘制线段命令", shortcut: "Ctrl + L" },
|
|
2156
2185
|
{ name: "开启绘制门线命令", shortcut: "Ctrl + M" },
|
|
2157
2186
|
{ name: "开启绘制窗户线命令", shortcut: "Ctrl + Q" },
|
|
@@ -2171,7 +2200,7 @@ const ls = {
|
|
|
2171
2200
|
{ name: "取消命令", shortcut: "Esc" },
|
|
2172
2201
|
{ name: "回滚操作", shortcut: "Ctrl + Z" },
|
|
2173
2202
|
{ name: "取消回滚操作", shortcut: "Ctrl + Y" }
|
|
2174
|
-
],
|
|
2203
|
+
], ft = [
|
|
2175
2204
|
{
|
|
2176
2205
|
command: "default",
|
|
2177
2206
|
name: "默认",
|
|
@@ -2181,356 +2210,375 @@ const ls = {
|
|
|
2181
2210
|
{
|
|
2182
2211
|
command: "draw-line",
|
|
2183
2212
|
name: "绘制线段",
|
|
2184
|
-
src:
|
|
2213
|
+
src: S["./assets/images/line.svg"].default,
|
|
2185
2214
|
show: !0,
|
|
2186
|
-
shortcut: "Ctrl + L"
|
|
2215
|
+
shortcut: "Ctrl + L",
|
|
2216
|
+
confirm: D(() => q.value > 0)
|
|
2187
2217
|
},
|
|
2188
2218
|
{
|
|
2189
2219
|
command: "draw-door-line",
|
|
2190
2220
|
name: "绘制门线",
|
|
2191
2221
|
show: !0,
|
|
2192
|
-
src:
|
|
2222
|
+
src: S["./assets/images/door.svg"].default,
|
|
2193
2223
|
shortcut: "Ctrl + M"
|
|
2194
2224
|
},
|
|
2195
2225
|
{
|
|
2196
2226
|
command: "draw-window-line",
|
|
2197
2227
|
name: "绘制窗户线",
|
|
2198
2228
|
show: !0,
|
|
2199
|
-
src:
|
|
2229
|
+
src: S["./assets/images/window.svg"].default,
|
|
2200
2230
|
shortcut: "Ctrl + Q"
|
|
2201
2231
|
},
|
|
2202
2232
|
{
|
|
2203
2233
|
command: "point",
|
|
2204
2234
|
name: "点修改",
|
|
2205
2235
|
show: !0,
|
|
2206
|
-
src:
|
|
2236
|
+
src: S["./assets/images/selectPoint.svg"].default,
|
|
2207
2237
|
shortcut: "Ctrl + P"
|
|
2208
2238
|
},
|
|
2209
2239
|
{
|
|
2210
|
-
command:
|
|
2240
|
+
command: pt.commandName,
|
|
2211
2241
|
name: "裁剪线段",
|
|
2212
2242
|
show: !0,
|
|
2213
|
-
src:
|
|
2243
|
+
src: S["./assets/images/cutLine.svg"].default,
|
|
2214
2244
|
shortcut: "Ctrl + X"
|
|
2215
2245
|
}
|
|
2216
|
-
],
|
|
2246
|
+
], yt = [
|
|
2217
2247
|
{
|
|
2218
2248
|
command: "",
|
|
2219
2249
|
name: "操作回滚",
|
|
2220
|
-
src:
|
|
2221
|
-
show:
|
|
2250
|
+
src: S["./assets/images/rollback.svg"].default,
|
|
2251
|
+
show: D(() => W.value !== 0),
|
|
2222
2252
|
shortcut: "Ctrl + Z",
|
|
2223
2253
|
action() {
|
|
2224
|
-
|
|
2254
|
+
L.commandManager.rollback();
|
|
2225
2255
|
}
|
|
2226
2256
|
},
|
|
2227
2257
|
{
|
|
2228
2258
|
command: "",
|
|
2229
2259
|
name: "撤销操作回滚",
|
|
2230
|
-
src:
|
|
2231
|
-
show:
|
|
2260
|
+
src: S["./assets/images/revokeRollback.svg"].default,
|
|
2261
|
+
show: D(() => E.value !== 0),
|
|
2232
2262
|
shortcut: "Ctrl + Y",
|
|
2233
2263
|
class: "rotateY-[180deg]",
|
|
2234
2264
|
action() {
|
|
2235
|
-
|
|
2265
|
+
L.commandManager.revokeRollback();
|
|
2236
2266
|
}
|
|
2237
2267
|
},
|
|
2238
2268
|
{
|
|
2239
|
-
command:
|
|
2269
|
+
command: ne.commandName,
|
|
2240
2270
|
name: "合并",
|
|
2241
|
-
src:
|
|
2242
|
-
show:
|
|
2271
|
+
src: S["./assets/images/mergeLine.svg"].default,
|
|
2272
|
+
show: D(() => Z.value === 2),
|
|
2243
2273
|
shortcut: "Ctrl + G"
|
|
2244
2274
|
},
|
|
2245
2275
|
{
|
|
2246
|
-
command:
|
|
2276
|
+
command: se.commandName,
|
|
2247
2277
|
name: "两点连接",
|
|
2248
|
-
show:
|
|
2249
|
-
src:
|
|
2278
|
+
show: D(() => Z.value === 2),
|
|
2279
|
+
src: S["./assets/images/connection.svg"].default,
|
|
2250
2280
|
shortcut: "Shift + L"
|
|
2251
2281
|
},
|
|
2252
2282
|
{
|
|
2253
|
-
command:
|
|
2283
|
+
command: ae.commandName,
|
|
2254
2284
|
name: "延长线交点连接",
|
|
2255
|
-
show:
|
|
2256
|
-
src:
|
|
2285
|
+
show: D(() => Z.value === 2),
|
|
2286
|
+
src: S["./assets/images/intersectionConnection.svg"].default,
|
|
2257
2287
|
shortcut: "Ctrl + Shift + L"
|
|
2258
2288
|
},
|
|
2259
2289
|
{
|
|
2260
|
-
command:
|
|
2290
|
+
command: he.commandName,
|
|
2261
2291
|
name: "线段垂直纠正",
|
|
2262
|
-
show:
|
|
2263
|
-
src:
|
|
2292
|
+
show: D(() => Z.value === 1),
|
|
2293
|
+
src: S["./assets/images/verticalCorrection.svg"].default,
|
|
2264
2294
|
shortcut: `
|
|
2265
2295
|
Ctrl + C 垂直纠正
|
|
2266
2296
|
Shift + C 轴对齐垂直纠正
|
|
2267
2297
|
`
|
|
2268
2298
|
},
|
|
2269
2299
|
{
|
|
2270
|
-
command:
|
|
2300
|
+
command: le.commandName,
|
|
2271
2301
|
name: "y轴垂直基准线",
|
|
2272
|
-
show:
|
|
2273
|
-
() =>
|
|
2302
|
+
show: D(
|
|
2303
|
+
() => Z.value === 1 && !B.selectLines[0].userData.isDoor
|
|
2274
2304
|
),
|
|
2275
|
-
src:
|
|
2305
|
+
src: S["./assets/images/verticalLine.svg"].default,
|
|
2276
2306
|
shortcut: "V"
|
|
2277
2307
|
},
|
|
2278
2308
|
{
|
|
2279
|
-
command:
|
|
2309
|
+
command: de.commandName,
|
|
2280
2310
|
name: "角度显示",
|
|
2281
|
-
show:
|
|
2282
|
-
src:
|
|
2311
|
+
show: D(() => Z.value === 2 && B.selectLines[0].sameEndpoint(B.selectLines[1])),
|
|
2312
|
+
src: S["./assets/images/angle.svg"].default,
|
|
2283
2313
|
shortcut: "r"
|
|
2284
2314
|
},
|
|
2285
2315
|
{
|
|
2286
|
-
command:
|
|
2316
|
+
command: re.commandName,
|
|
2287
2317
|
name: "全选",
|
|
2288
|
-
show:
|
|
2289
|
-
src:
|
|
2318
|
+
show: D(() => Z.value !== L.renderManager.lines.length),
|
|
2319
|
+
src: S["./assets/images/selectAll.svg"].default,
|
|
2290
2320
|
shortcut: "Ctrl + A"
|
|
2291
2321
|
},
|
|
2292
2322
|
{
|
|
2293
|
-
command:
|
|
2323
|
+
command: ie.commandName,
|
|
2294
2324
|
name: "清除窗户",
|
|
2295
|
-
show:
|
|
2296
|
-
src:
|
|
2325
|
+
show: D(() => Ke.value),
|
|
2326
|
+
src: S["./assets/images/deleteSelectWindow.svg"].default,
|
|
2297
2327
|
shortcut: "Q + Delete"
|
|
2298
2328
|
},
|
|
2299
2329
|
{
|
|
2300
|
-
command:
|
|
2330
|
+
command: oe.commandName,
|
|
2301
2331
|
name: "删除",
|
|
2302
|
-
show:
|
|
2303
|
-
src:
|
|
2332
|
+
show: D(() => Z.value > 0),
|
|
2333
|
+
src: S["./assets/images/deleteSelectLine.svg"].default,
|
|
2304
2334
|
shortcut: "Delete"
|
|
2305
2335
|
}
|
|
2306
2336
|
];
|
|
2307
|
-
|
|
2308
|
-
localStorage.setItem("toolBarExpand",
|
|
2309
|
-
}),
|
|
2310
|
-
localStorage.setItem("dxfVisible",
|
|
2311
|
-
}),
|
|
2312
|
-
const
|
|
2313
|
-
|
|
2337
|
+
J(F, () => localStorage.setItem("editorToolPosition", JSON.stringify(F.value))), J(X, () => localStorage.setItem("showShortcutKey", X.value + "")), J(h, () => {
|
|
2338
|
+
localStorage.setItem("toolBarExpand", h.value + ""), h.value && be(() => e(F.value.left, F.value.top));
|
|
2339
|
+
}), J(r, () => v.Variable.set("originalLineVisible", r.value)), J(i, () => {
|
|
2340
|
+
localStorage.setItem("dxfVisible", i.value + ""), v.Variable.set("dxfVisible", i.value);
|
|
2341
|
+
}), J(l, () => v.Variable.set("whiteModelVisible", l.value)), v.Variable.addEventListener("isLook", (b) => m.value = b.value), v.Variable.addEventListener("originalLineVisible", (b) => r.value = b.value), v.Variable.addEventListener("dxfVisible", (b) => i.value = b.value), v.Variable.addEventListener("whiteModelVisible", (b) => l.value = b.value), Q.addEventListener("start", () => q.value = 0), Q.addEventListener("appendLine", (b) => q.value = b.points.length), Q.addEventListener("revoke", (b) => q.value = b.points.length);
|
|
2342
|
+
const wt = L.commandManager.addEventListener("started", (b) => {
|
|
2343
|
+
C.value = b.name;
|
|
2314
2344
|
});
|
|
2315
|
-
return localStorage.getItem("showShortcutKey") && (
|
|
2316
|
-
|
|
2317
|
-
if (
|
|
2318
|
-
const { left:
|
|
2319
|
-
e(
|
|
2345
|
+
return localStorage.getItem("showShortcutKey") && (X.value = localStorage.getItem("showShortcutKey") === "true"), localStorage.getItem("toolBarExpand") && (h.value = localStorage.getItem("toolBarExpand") === "true"), at(() => {
|
|
2346
|
+
w.value.style.display = "none", setTimeout(() => {
|
|
2347
|
+
if (w.value.style.display = "block", localStorage.getItem("editorToolPosition")) {
|
|
2348
|
+
const { left: b, top: u } = JSON.parse(localStorage.getItem("editorToolPosition") ?? "{}");
|
|
2349
|
+
e(b, u), be(() => Ae.observe(g.value));
|
|
2320
2350
|
} else
|
|
2321
|
-
|
|
2322
|
-
}, 100),
|
|
2323
|
-
|
|
2324
|
-
}), ["rollback", "completed", "revokeRollback"].forEach((
|
|
2325
|
-
|
|
2351
|
+
be(() => Ae.observe(g.value));
|
|
2352
|
+
}, 100), B.addEventListener("selectLineChange", () => {
|
|
2353
|
+
Z.value = B.selectLines.length, Ke.value = B.selectLines.some((b) => b.userData.isWindow);
|
|
2354
|
+
}), ["rollback", "completed", "revokeRollback"].forEach((b) => {
|
|
2355
|
+
L.commandManager.addEventListener(b, () => {
|
|
2326
2356
|
setTimeout(() => {
|
|
2327
|
-
|
|
2357
|
+
W.value = L.commandManager.operationList.length, E.value = L.commandManager.rollbackList.length;
|
|
2328
2358
|
});
|
|
2329
2359
|
});
|
|
2330
|
-
}), localStorage.getItem("dxfVisible") && (
|
|
2331
|
-
}),
|
|
2332
|
-
|
|
2333
|
-
}), (
|
|
2360
|
+
}), localStorage.getItem("dxfVisible") && (i.value = localStorage.getItem("dxfVisible") == "true");
|
|
2361
|
+
}), Ht(() => {
|
|
2362
|
+
x.mouseMoveEventProxylock = !1, wt(), Ae.disconnect();
|
|
2363
|
+
}), (b, u) => (k(), K("div", {
|
|
2334
2364
|
ref_key: "elRef",
|
|
2335
|
-
ref:
|
|
2365
|
+
ref: g,
|
|
2336
2366
|
class: "editorTool pointer-events-none overflow-hidden absolute left-0 top-0 w-full h-full z-[20] flex flex-row justify-between p-[5px] box-border select-none pointer-events-[all]"
|
|
2337
2367
|
}, [
|
|
2338
|
-
|
|
2339
|
-
default:
|
|
2340
|
-
|
|
2341
|
-
(
|
|
2368
|
+
O(xe, null, {
|
|
2369
|
+
default: V(() => [
|
|
2370
|
+
X.value ? (k(), K("div", fo, [
|
|
2371
|
+
(k(), K(ye, null, ke(vt, (y) => M("div", {
|
|
2342
2372
|
class: "p-[4px_0px] flex justify-between text-right border-b-1 border-b-[rgba(255,255,255,0.1)] last-of-type:border-b-0",
|
|
2343
|
-
key:
|
|
2373
|
+
key: y.name
|
|
2344
2374
|
}, [
|
|
2345
|
-
|
|
2346
|
-
|
|
2375
|
+
M("p", yo, me(y.name), 1),
|
|
2376
|
+
M("span", wo, me(y.shortcut), 1)
|
|
2347
2377
|
])), 64))
|
|
2348
|
-
])) :
|
|
2378
|
+
])) : H("", !0)
|
|
2349
2379
|
]),
|
|
2350
2380
|
_: 1
|
|
2351
2381
|
}),
|
|
2352
|
-
|
|
2382
|
+
M("div", {
|
|
2353
2383
|
ref_key: "toolBarRef",
|
|
2354
|
-
ref:
|
|
2355
|
-
style:
|
|
2356
|
-
class:
|
|
2357
|
-
onMousedown: u[10] || (u[10] = (
|
|
2384
|
+
ref: w,
|
|
2385
|
+
style: Fe({ left: F.value.left + "px", top: F.value.top + "px" }),
|
|
2386
|
+
class: j(["overflow-hidden pointer-events-auto w-fit max-w-[260px] transition-[border-radius] text-[#333] absolute z-[11] bg-white select-none", { "rounded-[8px] ": h.value }]),
|
|
2387
|
+
onMousedown: u[10] || (u[10] = (y) => y.stopPropagation())
|
|
2358
2388
|
}, [
|
|
2359
|
-
|
|
2360
|
-
onMousedown:
|
|
2361
|
-
class:
|
|
2389
|
+
M("div", {
|
|
2390
|
+
onMousedown: a,
|
|
2391
|
+
class: j([{ "border-b-[#eee] border-b-1": h.value }, "flex flex-row justify-between header text-[14px] font-bold p-[10px 0px]"])
|
|
2362
2392
|
}, [
|
|
2363
|
-
u[12] || (u[12] =
|
|
2364
|
-
|
|
2365
|
-
onMousedown: u[0] || (u[0] = (
|
|
2366
|
-
onClick: u[1] || (u[1] = (
|
|
2393
|
+
u[12] || (u[12] = Wt('<div class="flex flex-row" data-v-f28c0a81><div class="p-[2px_5px] flex items-center pointer-events-none" data-v-f28c0a81><svg fill="#aaa" width="20" height="20" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" data-v-f28c0a81><path d="M341.333333 298.666667a85.333333 85.333333 0 1 0 0-170.666667 85.333333 85.333333 0 0 0 0 170.666667z m0 298.666666a85.333333 85.333333 0 1 0 0-170.666666 85.333333 85.333333 0 0 0 0 170.666666z m85.333334 213.333334a85.333333 85.333333 0 1 1-170.666667 0 85.333333 85.333333 0 0 1 170.666667 0z m256-512a85.333333 85.333333 0 1 0 0-170.666667 85.333333 85.333333 0 0 0 0 170.666667z m85.333333 213.333333a85.333333 85.333333 0 1 1-170.666667 0 85.333333 85.333333 0 0 1 170.666667 0z m-85.333333 384a85.333333 85.333333 0 1 0 0-170.666667 85.333333 85.333333 0 0 0 0 170.666667z" data-v-f28c0a81></path></svg></div><h5 class="flex text-nowrap text-[12px] items-center pointer-events-none" data-v-f28c0a81>绘制工具</h5></div>', 1)),
|
|
2394
|
+
M("div", {
|
|
2395
|
+
onMousedown: u[0] || (u[0] = (y) => y.stopPropagation()),
|
|
2396
|
+
onClick: u[1] || (u[1] = (y) => h.value = !h.value),
|
|
2367
2397
|
class: "cursor-pointer flex items-center p-[0px_5px]"
|
|
2368
2398
|
}, [
|
|
2369
|
-
(
|
|
2399
|
+
(k(), K("svg", {
|
|
2370
2400
|
fill: "#666",
|
|
2371
|
-
class:
|
|
2401
|
+
class: j([{ "rotate-90": h.value }, "transition-all"]),
|
|
2372
2402
|
viewBox: "0 0 1024 1024",
|
|
2373
2403
|
version: "1.1",
|
|
2374
2404
|
xmlns: "http://www.w3.org/2000/svg",
|
|
2375
2405
|
width: "12",
|
|
2376
2406
|
height: "12"
|
|
2377
2407
|
}, u[11] || (u[11] = [
|
|
2378
|
-
|
|
2408
|
+
M("path", { d: "M315.050667 938.666667a60.757333 60.757333 0 0 0 41.813333-16.298667L750.933333 551.338667a53.418667 53.418667 0 0 0 0-78.677334L356.864 101.632a61.696 61.696 0 0 0-83.541333 0 53.418667 53.418667 0 0 0-0.256 78.677333L625.408 512 273.066667 843.690667a53.418667 53.418667 0 0 0 0 78.677333 60.757333 60.757333 0 0 0 41.984 16.298667z" }, null, -1)
|
|
2379
2409
|
]), 2))
|
|
2380
2410
|
], 32)
|
|
2381
2411
|
], 34),
|
|
2382
|
-
|
|
2383
|
-
|
|
2384
|
-
(
|
|
2385
|
-
key:
|
|
2412
|
+
h.value ? (k(), K("div", Co, [
|
|
2413
|
+
M("ul", bo, [
|
|
2414
|
+
(k(), K(ye, null, ke(ft, (y) => (k(), K(ye, {
|
|
2415
|
+
key: y.command
|
|
2386
2416
|
}, [
|
|
2387
|
-
|
|
2417
|
+
y.show ? (k(), K("li", {
|
|
2388
2418
|
key: 0,
|
|
2389
|
-
onClick: (
|
|
2390
|
-
class:
|
|
2391
|
-
"!bg-[var(--primary-color)] text-[#fff]":
|
|
2419
|
+
onClick: (Y) => t(y),
|
|
2420
|
+
class: j([{
|
|
2421
|
+
"!bg-[var(--primary-color)] text-[#fff]": C.value === y.command
|
|
2392
2422
|
// '!cursor-no-drop': currentCommand !== item.command && currentCommand !== 'default',
|
|
2393
2423
|
}, "gap-[10px] text-[12px] hover:bg-[#ddd] transition-all rounded-[6px] p-[5px] flex flex-row items-center justify-between cursor-pointer"])
|
|
2394
2424
|
}, [
|
|
2395
|
-
|
|
2396
|
-
|
|
2397
|
-
|
|
2425
|
+
M("div", xo, [
|
|
2426
|
+
M("div", Ao, [
|
|
2427
|
+
M("img", {
|
|
2398
2428
|
class: "size-[14px]",
|
|
2399
|
-
src:
|
|
2429
|
+
src: y.src,
|
|
2400
2430
|
alt: "",
|
|
2401
2431
|
srcset: ""
|
|
2402
|
-
}, null, 8,
|
|
2432
|
+
}, null, 8, Lo)
|
|
2403
2433
|
]),
|
|
2404
|
-
|
|
2434
|
+
M("span", Mo, me(y.name), 1)
|
|
2405
2435
|
]),
|
|
2406
|
-
|
|
2407
|
-
|
|
2408
|
-
|
|
2409
|
-
|
|
2410
|
-
|
|
2411
|
-
|
|
2412
|
-
|
|
2413
|
-
|
|
2414
|
-
|
|
2415
|
-
|
|
2416
|
-
|
|
2417
|
-
|
|
2418
|
-
|
|
2419
|
-
|
|
2420
|
-
|
|
2421
|
-
|
|
2422
|
-
|
|
2423
|
-
|
|
2424
|
-
|
|
2436
|
+
C.value === y.command ? (k(), K("div", Io, [
|
|
2437
|
+
M("div", {
|
|
2438
|
+
title: "取消命令(Esc)",
|
|
2439
|
+
class: "active:scale-[0.7] transition-all flex items-center justify-center",
|
|
2440
|
+
onClick: u[2] || (u[2] = (Y) => (f(L).cancelCommand(), Y.stopPropagation()))
|
|
2441
|
+
}, u[13] || (u[13] = [
|
|
2442
|
+
M("svg", {
|
|
2443
|
+
fill: "#fff",
|
|
2444
|
+
width: "16",
|
|
2445
|
+
height: "16",
|
|
2446
|
+
viewBox: "0 0 1024 1024",
|
|
2447
|
+
version: "1.1",
|
|
2448
|
+
xmlns: "http://www.w3.org/2000/svg"
|
|
2449
|
+
}, [
|
|
2450
|
+
M("path", { d: "M511.104 0C228.821333 0 0 228.821333 0 511.104c0 282.282667 228.821333 511.104 511.104 511.104 282.282667 0 511.104-228.842667 511.104-511.104C1022.208 228.821333 793.386667 0 511.104 0zM511.104 898.496c-213.973333 0-387.434667-173.44-387.434667-387.413333 0-213.952 173.44-387.413333 387.434667-387.413333 213.952 0 387.392 173.44 387.392 387.413333C898.496 725.056 725.056 898.496 511.104 898.496z" }),
|
|
2451
|
+
M("path", { d: "M236.437333 463.914667l549.333333 0 0 96.874667-549.333333 0 0-96.874667Z" })
|
|
2452
|
+
], -1)
|
|
2453
|
+
])),
|
|
2454
|
+
y.confirm?.value ? (k(), K("div", {
|
|
2455
|
+
key: 0,
|
|
2456
|
+
onClick: s,
|
|
2457
|
+
title: "确认命令(Enter)",
|
|
2458
|
+
class: "active:scale-[0.7] transition-all flex items-center justify-center"
|
|
2459
|
+
}, u[14] || (u[14] = [
|
|
2460
|
+
M("svg", {
|
|
2461
|
+
fill: "#fff",
|
|
2462
|
+
width: "16",
|
|
2463
|
+
height: "16",
|
|
2464
|
+
viewBox: "0 0 1024 1024",
|
|
2465
|
+
version: "1.1",
|
|
2466
|
+
xmlns: "http://www.w3.org/2000/svg"
|
|
2467
|
+
}, [
|
|
2468
|
+
M("path", { d: "M512 1024c-281.6 0-512-230.4-512-512s230.4-512 512-512 512 230.4 512 512-230.4 512-512 512zM512 128C300.8 128 128 300.8 128 512s172.8 384 384 384 384-172.8 384-384-172.8-384-384-384z m-12.8 556.8c-12.8 12.8-32 19.2-51.2 19.2-19.2 0-38.4-6.4-51.2-19.2L275.2 569.6c-25.6-25.6-25.6-70.4 0-96 25.6-25.6 70.4-25.6 96 0L448 544l198.4-204.8c25.6-25.6 70.4-25.6 96 0 25.6 25.6 25.6 70.4 0 96l-243.2 249.6z" })
|
|
2469
|
+
], -1)
|
|
2470
|
+
]))) : H("", !0)
|
|
2471
|
+
])) : y.shortcut ? (k(), K("div", ko, me(y.shortcut), 1)) : H("", !0)
|
|
2472
|
+
], 10, Eo)) : H("", !0)
|
|
2425
2473
|
], 64))), 64))
|
|
2426
2474
|
]),
|
|
2427
|
-
|
|
2428
|
-
|
|
2475
|
+
M("div", Do, [
|
|
2476
|
+
O(f(Qe), {
|
|
2429
2477
|
size: "small",
|
|
2430
|
-
modelValue:
|
|
2431
|
-
"onUpdate:modelValue": u[3] || (u[3] = (
|
|
2478
|
+
modelValue: X.value,
|
|
2479
|
+
"onUpdate:modelValue": u[3] || (u[3] = (y) => X.value = y),
|
|
2432
2480
|
label: "快捷键提示"
|
|
2433
2481
|
}, null, 8, ["modelValue"]),
|
|
2434
|
-
|
|
2482
|
+
O(f(Qe), {
|
|
2435
2483
|
size: "small",
|
|
2436
|
-
modelValue:
|
|
2437
|
-
"onUpdate:modelValue": u[4] || (u[4] = (
|
|
2484
|
+
modelValue: i.value,
|
|
2485
|
+
"onUpdate:modelValue": u[4] || (u[4] = (y) => i.value = y),
|
|
2438
2486
|
label: "dxf"
|
|
2439
2487
|
}, null, 8, ["modelValue"])
|
|
2440
2488
|
]),
|
|
2441
|
-
|
|
2442
|
-
|
|
2489
|
+
b.permission === "admin" ? (k(), K("div", Po, [
|
|
2490
|
+
O(f(ce), {
|
|
2443
2491
|
style: { padding: "5px", "font-size": "10px" },
|
|
2444
2492
|
size: "small",
|
|
2445
2493
|
type: "success",
|
|
2446
|
-
onClick:
|
|
2494
|
+
onClick: o
|
|
2447
2495
|
}, {
|
|
2448
|
-
default:
|
|
2449
|
-
|
|
2496
|
+
default: V(() => u[15] || (u[15] = [
|
|
2497
|
+
te(" 选择文件 ", -1)
|
|
2450
2498
|
])),
|
|
2451
2499
|
_: 1,
|
|
2452
|
-
__: [
|
|
2500
|
+
__: [15]
|
|
2453
2501
|
}),
|
|
2454
|
-
|
|
2502
|
+
O(f(ce), {
|
|
2455
2503
|
style: { padding: "5px", "font-size": "10px" },
|
|
2456
2504
|
size: "small",
|
|
2457
2505
|
type: "primary",
|
|
2458
|
-
onClick: u[5] || (u[5] = (
|
|
2506
|
+
onClick: u[5] || (u[5] = (y) => f(v).Dxf.downloadOriginalData("json.json"))
|
|
2459
2507
|
}, {
|
|
2460
|
-
default:
|
|
2461
|
-
|
|
2508
|
+
default: V(() => u[16] || (u[16] = [
|
|
2509
|
+
te(" 下载Json ", -1)
|
|
2462
2510
|
])),
|
|
2463
2511
|
_: 1,
|
|
2464
|
-
__: [
|
|
2512
|
+
__: [16]
|
|
2465
2513
|
}),
|
|
2466
|
-
|
|
2514
|
+
O(f(ce), {
|
|
2467
2515
|
style: { padding: "5px", "font-size": "10px" },
|
|
2468
2516
|
size: "small",
|
|
2469
2517
|
type: "primary",
|
|
2470
|
-
onClick: u[6] || (u[6] = (
|
|
2518
|
+
onClick: u[6] || (u[6] = (y) => f(v).AngleCorrectionDxf.download("test.dxf"))
|
|
2471
2519
|
}, {
|
|
2472
|
-
default:
|
|
2473
|
-
|
|
2520
|
+
default: V(() => u[17] || (u[17] = [
|
|
2521
|
+
te(" 下载DXF ", -1)
|
|
2474
2522
|
])),
|
|
2475
2523
|
_: 1,
|
|
2476
|
-
__: [
|
|
2524
|
+
__: [17]
|
|
2477
2525
|
}),
|
|
2478
|
-
|
|
2526
|
+
O(f(ce), {
|
|
2479
2527
|
style: { padding: "5px", "font-size": "10px" },
|
|
2480
2528
|
size: "small",
|
|
2481
2529
|
type: "primary",
|
|
2482
|
-
onClick: u[7] || (u[7] = (
|
|
2530
|
+
onClick: u[7] || (u[7] = (y) => f(v).AngleCorrectionDxf.downloadImage("dxf.jpg"))
|
|
2483
2531
|
}, {
|
|
2484
|
-
default:
|
|
2485
|
-
|
|
2532
|
+
default: V(() => u[18] || (u[18] = [
|
|
2533
|
+
te(" 下载JPG ", -1)
|
|
2486
2534
|
])),
|
|
2487
2535
|
_: 1,
|
|
2488
|
-
__: [
|
|
2536
|
+
__: [18]
|
|
2489
2537
|
}),
|
|
2490
|
-
|
|
2538
|
+
O(f(ce), {
|
|
2491
2539
|
style: { padding: "5px", "font-size": "10px" },
|
|
2492
2540
|
size: "small",
|
|
2493
2541
|
type: "primary",
|
|
2494
|
-
onClick: u[8] || (u[8] = (
|
|
2542
|
+
onClick: u[8] || (u[8] = (y) => f($).downloadGltf("test.glb", !0))
|
|
2495
2543
|
}, {
|
|
2496
|
-
default:
|
|
2497
|
-
|
|
2544
|
+
default: V(() => u[19] || (u[19] = [
|
|
2545
|
+
te(" 下载白膜 ", -1)
|
|
2498
2546
|
])),
|
|
2499
2547
|
_: 1,
|
|
2500
|
-
__: [
|
|
2548
|
+
__: [19]
|
|
2501
2549
|
}),
|
|
2502
|
-
|
|
2550
|
+
O(f(ce), {
|
|
2503
2551
|
style: { padding: "5px", "font-size": "10px" },
|
|
2504
2552
|
size: "small",
|
|
2505
2553
|
type: "primary",
|
|
2506
|
-
onClick: u[9] || (u[9] = (
|
|
2554
|
+
onClick: u[9] || (u[9] = (y) => f(ee).download())
|
|
2507
2555
|
}, {
|
|
2508
|
-
default:
|
|
2509
|
-
|
|
2556
|
+
default: V(() => u[20] || (u[20] = [
|
|
2557
|
+
te(" 下载三维家JSON ", -1)
|
|
2510
2558
|
])),
|
|
2511
2559
|
_: 1,
|
|
2512
|
-
__: [
|
|
2560
|
+
__: [20]
|
|
2513
2561
|
})
|
|
2514
|
-
])) :
|
|
2515
|
-
|
|
2516
|
-
default:
|
|
2517
|
-
|
|
2518
|
-
|
|
2519
|
-
default:
|
|
2520
|
-
(
|
|
2521
|
-
onClick: (
|
|
2522
|
-
title: `${
|
|
2523
|
-
class:
|
|
2524
|
-
"opacity-30 bg-[#ccc] !cursor-no-drop active:!scale-[1]": !
|
|
2525
|
-
[
|
|
2562
|
+
])) : H("", !0),
|
|
2563
|
+
O(xe, null, {
|
|
2564
|
+
default: V(() => [
|
|
2565
|
+
M("div", Bo, [
|
|
2566
|
+
O(qt, null, {
|
|
2567
|
+
default: V(() => [
|
|
2568
|
+
(k(), K(ye, null, ke(yt, (y) => M("div", {
|
|
2569
|
+
onClick: (Y) => y.show.value && C.value === "default" && (y.action ? y.action() : f(L).commandManager.start(y.command, [...f(B).selectLines])),
|
|
2570
|
+
title: `${y.name}(${y.shortcut})`,
|
|
2571
|
+
class: j(["size-[20px] flex justify-center items-center relative overflow-hidden active:scale-[0.8] border-1 border-[#ccc] rounded-[4px] transition-all cursor-pointer", {
|
|
2572
|
+
"opacity-30 bg-[#ccc] !cursor-no-drop active:!scale-[1]": !y.show.value || C.value !== "default",
|
|
2573
|
+
[y.class ?? ""]: !0
|
|
2526
2574
|
}]),
|
|
2527
|
-
key:
|
|
2575
|
+
key: y.command
|
|
2528
2576
|
}, [
|
|
2529
|
-
|
|
2577
|
+
M("img", {
|
|
2530
2578
|
class: "size-[14px]",
|
|
2531
|
-
src:
|
|
2532
|
-
}, null, 8,
|
|
2533
|
-
], 10,
|
|
2579
|
+
src: y.src
|
|
2580
|
+
}, null, 8, Fo)
|
|
2581
|
+
], 10, So)), 64))
|
|
2534
2582
|
]),
|
|
2535
2583
|
_: 1
|
|
2536
2584
|
})
|
|
@@ -2538,19 +2586,19 @@ const ls = {
|
|
|
2538
2586
|
]),
|
|
2539
2587
|
_: 1
|
|
2540
2588
|
})
|
|
2541
|
-
])) :
|
|
2589
|
+
])) : H("", !0)
|
|
2542
2590
|
], 38)
|
|
2543
2591
|
], 512));
|
|
2544
2592
|
}
|
|
2545
|
-
}),
|
|
2593
|
+
}), No = (c, e) => {
|
|
2546
2594
|
const t = c.__vccOpts || c;
|
|
2547
|
-
for (const [n,
|
|
2548
|
-
t[n] =
|
|
2595
|
+
for (const [n, o] of e)
|
|
2596
|
+
t[n] = o;
|
|
2549
2597
|
return t;
|
|
2550
|
-
},
|
|
2551
|
-
let
|
|
2598
|
+
}, Ro = /* @__PURE__ */ No(Ko, [["__scopeId", "data-v-f28c0a81"]]);
|
|
2599
|
+
let gt = class extends Se {
|
|
2552
2600
|
static name = "Editor";
|
|
2553
|
-
container = new
|
|
2601
|
+
container = new p.Group();
|
|
2554
2602
|
get renderer() {
|
|
2555
2603
|
return this.parent?.findComponentByName("Renderer");
|
|
2556
2604
|
}
|
|
@@ -2572,8 +2620,8 @@ let ct = class extends Ae {
|
|
|
2572
2620
|
get domContainer() {
|
|
2573
2621
|
return this.parent?.findComponentByName("DomContainer");
|
|
2574
2622
|
}
|
|
2575
|
-
commandManager = new
|
|
2576
|
-
plane = new
|
|
2623
|
+
commandManager = new Pn();
|
|
2624
|
+
plane = new p.Mesh(new p.PlaneGeometry(2e3, 2e3, 2, 2));
|
|
2577
2625
|
app;
|
|
2578
2626
|
domElement = document.createElement("div");
|
|
2579
2627
|
viewPermission;
|
|
@@ -2596,26 +2644,26 @@ let ct = class extends Ae {
|
|
|
2596
2644
|
}
|
|
2597
2645
|
onAddFromParent(e) {
|
|
2598
2646
|
setTimeout(() => this.openEdit(), 10);
|
|
2599
|
-
const t = new
|
|
2647
|
+
const t = new p.GridHelper(200, 100, 6710886, 4473924);
|
|
2600
2648
|
t.rotation.x = Math.PI * 0.5, t.position.z = -0.01, this.container.add(t), this.container.add(this.plane), this.plane.visible = !1;
|
|
2601
2649
|
const n = this.addEventListener("update", () => {
|
|
2602
2650
|
this.domContainer.domElement.parentElement && (this.domContainer.domElement.parentElement.appendChild(this.domElement), this.domContainer.domElement.parentElement.appendChild(this.imgEl), n());
|
|
2603
2651
|
});
|
|
2604
2652
|
setTimeout(() => {
|
|
2605
|
-
this.app =
|
|
2653
|
+
this.app = Zt(Ro, { dxfSystem: this.parent, permission: this.viewPermission }), this.app.mount(this.domElement);
|
|
2606
2654
|
}), e.AngleCorrectionDxf.addEventListener("lineOffset", async () => {
|
|
2607
2655
|
this.imgEl.src && URL.revokeObjectURL(this.imgEl.src), setTimeout(async () => {
|
|
2608
2656
|
this.imgEl.src = URL.createObjectURL(await e.AngleCorrectionDxf.toDxfImageBlob("Centimeters", "image/png", "transparent"));
|
|
2609
2657
|
});
|
|
2610
|
-
}), this.domEventRegister.addEventListener("mousedown", (
|
|
2611
|
-
|
|
2658
|
+
}), this.domEventRegister.addEventListener("mousedown", (o) => {
|
|
2659
|
+
o.x < this.imgWidth + 10 && o.x > 10 && o.y < this.imgWidth && o.y > 10 && Object.assign(this.imgEl.style, {
|
|
2612
2660
|
width: `${Math.min(this.imgWidth * 10, this.renderer.width * 0.9)}px`,
|
|
2613
2661
|
height: `${Math.min(this.imgWidth * 10, this.renderer.height * 0.9)}px`,
|
|
2614
2662
|
background: "rgba(0,0,0,1)",
|
|
2615
2663
|
zIndex: 100
|
|
2616
2664
|
});
|
|
2617
|
-
}), this.domEventRegister.addEventListener("mousemove", (
|
|
2618
|
-
|
|
2665
|
+
}), this.domEventRegister.addEventListener("mousemove", (o) => {
|
|
2666
|
+
o.x < this.imgWidth + 10 && o.x > 10 && o.y < this.imgWidth && o.y > 10 || Object.assign(this.imgEl.style, {
|
|
2619
2667
|
width: `${this.imgWidth}px`,
|
|
2620
2668
|
height: `${this.imgWidth}px`,
|
|
2621
2669
|
background: "rgba(255,255,255,0.2)",
|
|
@@ -2631,27 +2679,27 @@ let ct = class extends Ae {
|
|
|
2631
2679
|
type: "cancelCommand"
|
|
2632
2680
|
});
|
|
2633
2681
|
}
|
|
2634
|
-
coords = new
|
|
2635
|
-
pointerPosition = new
|
|
2682
|
+
coords = new p.Vector2();
|
|
2683
|
+
pointerPosition = new p.Vector2();
|
|
2636
2684
|
_exitEditCallBack;
|
|
2637
2685
|
/**
|
|
2638
2686
|
* 打开编辑器
|
|
2639
2687
|
*/
|
|
2640
2688
|
openEdit() {
|
|
2641
|
-
const e = this.renderer, t = this.domEventRegister, n = this.dxf,
|
|
2642
|
-
this.container.position.z = n.originalZAverage, e.scene.add(this.container),
|
|
2643
|
-
const
|
|
2689
|
+
const e = this.renderer, t = this.domEventRegister, n = this.dxf, o = e.orbitControls, s = e.camera, a = n.box.center, d = e.camera.position.clone(), r = o?.target?.clone(), i = new p.Vector2(), l = new p.Raycaster(), m = this.coords, g = this.pointerPosition;
|
|
2690
|
+
this.container.position.z = n.originalZAverage, e.scene.add(this.container), o && (s.position.set(a.x, a.y, 15), o.target.set(a.x, a.y, 0), o.enableRotate = !1);
|
|
2691
|
+
const w = () => {
|
|
2644
2692
|
e.renderer.getSize(i);
|
|
2645
|
-
const
|
|
2646
|
-
m.set(
|
|
2647
|
-
const
|
|
2648
|
-
|
|
2693
|
+
const h = t.pointer.x / i.x * 2 - 1, C = -(t.pointer.y / i.y * 2 - 1);
|
|
2694
|
+
m.set(h, C), l.setFromCamera(m, e.camera.children.length ? e.camera.children[0] : e.camera);
|
|
2695
|
+
const v = l.intersectObject(this.plane);
|
|
2696
|
+
v.length && (g.copy(v[0].point), this.dispatchEvent({
|
|
2649
2697
|
type: "pointerPositionChange",
|
|
2650
|
-
position:
|
|
2698
|
+
position: g
|
|
2651
2699
|
}));
|
|
2652
2700
|
};
|
|
2653
|
-
t.addEventListener("mousemove",
|
|
2654
|
-
t.removeEventListener("mousemove",
|
|
2701
|
+
t.addEventListener("mousemove", w), this.commandManager.disabled = !1, this.commandManager.start("default"), this._exitEditCallBack = () => {
|
|
2702
|
+
t.removeEventListener("mousemove", w), o && (s.position.copy(d), o.enableRotate = !0, o.target.copy(r));
|
|
2655
2703
|
};
|
|
2656
2704
|
}
|
|
2657
2705
|
/**
|
|
@@ -2664,30 +2712,30 @@ let ct = class extends Ae {
|
|
|
2664
2712
|
this.commandManager.destroy(), super.destroy(), this.exitEdit(), this.renderer.scene.remove(this.container), this.domElement.remove(), this.app?.unmount();
|
|
2665
2713
|
}
|
|
2666
2714
|
};
|
|
2667
|
-
class
|
|
2715
|
+
class zo extends z {
|
|
2668
2716
|
static name = "PointDrag";
|
|
2669
|
-
container = new
|
|
2717
|
+
container = new p.Group();
|
|
2670
2718
|
interruptKeys = ["escape"];
|
|
2671
2719
|
shortcutKeys = ["control", "p"];
|
|
2672
2720
|
commandName = "point";
|
|
2673
2721
|
onAddFromParent(e) {
|
|
2674
2722
|
super.onAddFromParent(e), this.editor.container.add(this.container), this.container.position.z = 1e-3;
|
|
2675
|
-
const t = this.commandManager.addCommandFlow(this.commandName).add(this.createInterrupt()).add(this.createCursor("crosshair")).add(this.selectPoint.bind(this)).add(this.drag.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this));
|
|
2723
|
+
const t = this.commandManager.addCommandFlow(this.commandName).add(this.createInterrupt()).add(this.createCursor("crosshair")).add(this.selectPoint.bind(this)).add(this.drag.bind(this)).addRollback(this.rollback.bind(this)).addRevokeRollback(this.revokeRollback.bind(this)).setLoop(!0);
|
|
2676
2724
|
t.addEventListener("finally", this.createFinally()), t.addEventListener("completed", (n) => this.completed(n.data)), this.eventInput.addKeyCombination(this.commandName, this.shortcutKeys), this.eventInput.addEventListener("codeChange", async () => this.eventInput.isKeyCombination(this.commandName) && await this.commandManager.start(this.commandName)), this.eventInput.addCancelDefaultBehavior(() => this.eventInput.isOnlyKeyDowns(this.shortcutKeys));
|
|
2677
2725
|
}
|
|
2678
2726
|
/** 选择开始点
|
|
2679
2727
|
* @param next
|
|
2680
2728
|
*/
|
|
2681
2729
|
selectPoint(e) {
|
|
2682
|
-
let t = null, n = this.renderer.createCircle(
|
|
2683
|
-
const
|
|
2684
|
-
const { point: a, line:
|
|
2685
|
-
this.dispatchEvent({ type: "pointerMove", point: a }), r && i === "point" ? (this.domElement.style.cursor = "none", n.position.copy(a),
|
|
2730
|
+
let t = null, n = this.renderer.createCircle(A.zero(), { color: 16711935 }), o = null;
|
|
2731
|
+
const s = this.editor.addEventListener("pointerPositionChange", () => {
|
|
2732
|
+
const { point: a, line: d, find: r, mode: i } = this.editor.renderManager.adsorption();
|
|
2733
|
+
this.dispatchEvent({ type: "pointerMove", point: a }), r && i === "point" ? (this.domElement.style.cursor = "none", n.position.copy(a), o = d, t = a.clone(), this.container.add(n)) : (this.domElement.style.cursor = "no-drop", t = null, n.removeFromParent());
|
|
2686
2734
|
});
|
|
2687
|
-
this.addEventRecord("selectPointStart").add(
|
|
2688
|
-
this.eventInput.isKeyDown("mouse_0") && t && (this.canceEventRecord("selectPointStart"), n.material.color.set(65280), e({ point: t, line:
|
|
2735
|
+
this.addEventRecord("selectPointStart").add(s).add(this.eventInput.addEventListener("codeChange", () => {
|
|
2736
|
+
this.eventInput.isKeyDown("mouse_0") && t && (this.canceEventRecord("selectPointStart"), n.material.color.set(65280), e({ point: t, line: o }));
|
|
2689
2737
|
})), this.addEventRecord("clear").add(() => {
|
|
2690
|
-
n.removeFromParent(),
|
|
2738
|
+
n.removeFromParent(), s();
|
|
2691
2739
|
});
|
|
2692
2740
|
}
|
|
2693
2741
|
/** 拖拽点
|
|
@@ -2697,32 +2745,32 @@ class Ps extends O {
|
|
|
2697
2745
|
*/
|
|
2698
2746
|
drag(e, { point: t, line: n }) {
|
|
2699
2747
|
this.domElement.style.cursor = "crosshair";
|
|
2700
|
-
const
|
|
2701
|
-
this.container.add(
|
|
2702
|
-
let { point: i, find:
|
|
2748
|
+
const o = n.start.equal(A.from(t)) ? "start" : "end", s = o == "start" ? new p.Vector3(n.end.x, n.end.y, 0) : new p.Vector3(n.start.x, n.start.y, 0), a = t.clone(), d = new Ce([s, a], 16711935), r = this.renderer.createCircle(A.zero(), { color: 16711935, size: 10 });
|
|
2749
|
+
this.container.add(d), this.addEventRecord("clear").add(this.editor.addEventListener("pointerPositionChange", () => {
|
|
2750
|
+
let { point: i, find: l } = this.editor.renderManager.adsorption(), m = "none";
|
|
2703
2751
|
if (i) {
|
|
2704
2752
|
if (this.dispatchEvent({ type: "pointerMove", point: i }), this.eventInput.isKeyDown("shift")) {
|
|
2705
|
-
const
|
|
2706
|
-
i.set(
|
|
2753
|
+
const g = n.projectPoint(A.from(i), !1);
|
|
2754
|
+
i.set(g?.x ?? i.x, g?.y ?? i.y, 0), l = !0, m = "crosshair";
|
|
2707
2755
|
}
|
|
2708
|
-
|
|
2756
|
+
l ? (r.position.copy(i), this.container.add(r)) : (r.removeFromParent(), m = "crosshair"), a.copy(i), d.setPoint(s, a), this.domElement.style.cursor = m;
|
|
2709
2757
|
}
|
|
2710
2758
|
})).add(this.eventInput.addEventListener("codeChange", () => {
|
|
2711
|
-
this.eventInput.isKeyDown("mouse_0") && (this.canceEventRecord("selectPointStart"), e({ point: a, oldPoint:
|
|
2712
|
-
})).add(() => r.removeFromParent()).add(() =>
|
|
2759
|
+
this.eventInput.isKeyDown("mouse_0") && (this.canceEventRecord("selectPointStart"), e({ point: a, oldPoint: o === "end" ? n.end.clone() : n.start.clone(), line: n, mode: o }));
|
|
2760
|
+
})).add(() => r.removeFromParent()).add(() => d.removeFromParent());
|
|
2713
2761
|
}
|
|
2714
2762
|
/** 执行完成
|
|
2715
2763
|
*/
|
|
2716
2764
|
completed(e) {
|
|
2717
|
-
const { line: t, point: n, mode:
|
|
2718
|
-
this.renderManager.removeLine(t),
|
|
2765
|
+
const { line: t, point: n, mode: o } = e;
|
|
2766
|
+
this.renderManager.removeLine(t), o === "end" ? t.end.set(n.x, n.y) : o === "start" && t.start.set(n.x, n.y), this.renderManager.addLine(t), this.renderManager.draw();
|
|
2719
2767
|
}
|
|
2720
2768
|
/** 回滚操作
|
|
2721
2769
|
* @param data
|
|
2722
2770
|
*/
|
|
2723
2771
|
rollback(e) {
|
|
2724
|
-
const { line: t, oldPoint: n, mode:
|
|
2725
|
-
return
|
|
2772
|
+
const { line: t, oldPoint: n, mode: o } = e;
|
|
2773
|
+
return o === "end" ? t.end.set(n.x, n.y) : o === "start" && t.start.set(n.x, n.y), this.renderManager.addLine(t), this.renderManager.draw(), e;
|
|
2726
2774
|
}
|
|
2727
2775
|
/** 撤回回滚
|
|
2728
2776
|
* @param lines
|
|
@@ -2732,15 +2780,15 @@ class Ps extends O {
|
|
|
2732
2780
|
return this.completed(e), e;
|
|
2733
2781
|
}
|
|
2734
2782
|
}
|
|
2735
|
-
function
|
|
2736
|
-
c.addComponent(new
|
|
2783
|
+
function Ye(c, e = {}) {
|
|
2784
|
+
c.addComponent(new gt(e.viewPermission)), c.addComponent(new po()), c.addComponent(new ht()), c.addComponent(new mt()), c.addComponent(new go()), c.addComponent(new vo()), c.addComponent(new zo()), c.addComponent(new oe()), c.addComponent(new ne()), c.addComponent(new he()), c.addComponent(new se()), c.addComponent(new ae()), c.addComponent(new ie()), c.addComponent(new re()), c.addComponent(new de()), c.addComponent(new le()), c.addComponent(new pt());
|
|
2737
2785
|
}
|
|
2738
|
-
const
|
|
2786
|
+
const Uo = Object.assign(Ye, {
|
|
2739
2787
|
create(c = {}) {
|
|
2740
|
-
return (e) =>
|
|
2788
|
+
return (e) => Ye(e, c);
|
|
2741
2789
|
}
|
|
2742
2790
|
});
|
|
2743
2791
|
export {
|
|
2744
|
-
|
|
2745
|
-
|
|
2792
|
+
Uo as Editor,
|
|
2793
|
+
Ye as Editor_
|
|
2746
2794
|
};
|