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