/*!!** * EIMMODEL V1.0.0 * A WebGL-based 3D Viewer for threejs * http://www.i3vsoft.com/ * Built on 2021-2-25 7:24:06 PM * commitHash 2611d22d * Copyright 2021, 广州君和信息技术有限公司 ***/ ! function (A, e) { "object" == typeof exports && "undefined" != typeof module ? e(exports) : "function" == typeof define && define.amd ? define(["exports"], e) : e((A = A || self).EIMMODEL = {}) }(this, (function (A) { "use strict"; console.log("EIMMODEL Version: 1.0.0"); var e = "undefined" != typeof window ? window : "undefined" != typeof global ? global : "undefined" != typeof self ? self : {}; ! function (A, e) { A(e = { exports: {} }, e.exports) }((function (A) { ! function (e, t) { var i = function () { function A(A) { return "[object Array]" === Object.prototype.toString.call(A) } function e(A, e) { for (var t in e) e.hasOwnProperty(t) && (A[t] = e[t]) } function t(A) { if (!(this instanceof t)) throw new TypeError(this + "is not a promise"); if ("function" != typeof A) throw new TypeError("Promise resolver " + A + " is not a function"); var e = new i; this._resolver = e; try { A((function (A) { e.resolve(A) }), (function (A) { e.reject(A) })) } catch (A) { e.reject(A) } } function i() { this._callbacks = [], this._errbacks = [], this._status = "pending", this._result = null } return e(t.prototype, { then: function (A, e) { var i, o, n = new this.constructor((function (A, e) { i = A, o = e })); return this._resolver._addCallbacks("function" == typeof A ? t._makeCallback(n, i, o, A) : i, "function" == typeof e ? t._makeCallback(n, i, o, e) : o), n }, catch: function (A) { return this.then(void 0, A) } }), t._makeCallback = function (A, e, t, i) { return function (o) { var n; try { n = i(o) } catch (A) { return void t(A) } n !== A ? e(n) : t(new TypeError("Cannot resolve a promise with itself")) } }, t.resolve = function (A) { return A && A.constructor === this ? A : new this((function (e) { e(A) })) }, t.reject = function (A) { var e = new this((function () {})); return e._resolver._result = A, e._resolver._status = "rejected", e }, t.all = function (e) { var t = this; return new t((function (i, o) { if (A(e)) { var n = e.length, r = 0, a = e.length, s = []; if (1 > a) return i(s); for (; a > r; r++) t.resolve(e[r]).then(l(r), o) } else o(new TypeError("Promise.all expects an array of values or promises")); function l(A) { return function (e) { s[A] = e, --n || i(s) } } })) }, t.race = function (e) { var t = this; return new t((function (i, o) { if (A(e)) for (var n = 0, r = e.length; r > n; n++) t.resolve(e[n]).then(i, o); else o(new TypeError("Promise.race expects an array of values or promises")) })) }, t.async = "undefined" != typeof setImmediate ? function (A) { setImmediate(A) } : "undefined" != typeof process && process.nextTick ? process.nextTick : function (A) { setTimeout(A, 0) }, e(i.prototype, { fulfill: function (A) { var e = this._status; "pending" !== e && "accepted" !== e || (this._result = A, this._status = "fulfilled"), "fulfilled" === this._status && (this._notify(this._callbacks, this._result), this._callbacks = [], this._errbacks = null) }, reject: function (A) { var e = this._status; "pending" !== e && "accepted" !== e || (this._result = A, this._status = "rejected"), "rejected" === this._status && (this._notify(this._errbacks, this._result), this._callbacks = null, this._errbacks = []) }, resolve: function (A) { "pending" === this._status && (this._status = "accepted", this._value = A, (this._callbacks && this._callbacks.length || this._errbacks && this._errbacks.length) && this._unwrap(this._value)) }, _unwrap: function (A) { var e, t = this, i = !1; if (!A || "object" != typeof A && "function" != typeof A) t.fulfill(A); else try { "function" == typeof (e = A.then) ? e.call(A, (function (A) { i || (i = !0, t._unwrap(A)) }), (function (A) { i || (i = !0, t.reject(A)) })): t.fulfill(A) } catch (A) { i || t.reject(A) } }, _addCallbacks: function (A, e) { var t = this._callbacks, i = this._errbacks; switch (t && t.push(A), i && i.push(e), this._status) { case "accepted": this._unwrap(this._value); break; case "fulfilled": this.fulfill(this._result); break; case "rejected": this.reject(this._result) } }, _notify: function (A, e) { A.length && t.async((function () { var t, i; for (t = 0, i = A.length; i > t; ++t) A[t](e) })) } }), t.Resolver = i, t }(); A && (A.exports = i), (e = e || self).PromisePolyfill = i, e.Promise || (e.Promise = i) }(e) })); void 0 === Number.EPSILON && (Number.EPSILON = Math.pow(2, -52)), void 0 === Number.isInteger && (Number.isInteger = function (A) { return "number" == typeof A && isFinite(A) && Math.floor(A) === A }), void 0 === Math.sign && (Math.sign = function (A) { return 0 > A ? -1 : A > 0 ? 1 : +A }), "name" in Function.prototype == !1 && Object.defineProperty(Function.prototype, "name", { get: function () { return this.toString().match(/^\s*function\s*([^\(\s]*)/)[1] } }), void 0 === Object.assign && (Object.assign = function (A) { if (null == A) throw new TypeError("Cannot convert undefined or null to object"); for (var e = Object(A), t = 1; arguments.length > t; t++) { var i = arguments[t]; if (null != i) for (var o in i) Object.prototype.hasOwnProperty.call(i, o) && (e[o] = i[o]) } return e }); var t = { LEFT: 0, MIDDLE: 1, RIGHT: 2, ROTATE: 0, DOLLY: 1, PAN: 2 }; function i() {} Object.assign(i.prototype, { addEventListener: function (A, e) { void 0 === this._listeners && (this._listeners = {}); var t = this._listeners; void 0 === t[A] && (t[A] = []), -1 === t[A].indexOf(e) && t[A].push(e) }, hasEventListener: function (A, e) { if (void 0 === this._listeners) return !1; var t = this._listeners; return void 0 !== t[A] && -1 !== t[A].indexOf(e) }, removeEventListener: function (A, e) { if (void 0 !== this._listeners) { var t = this._listeners[A]; if (void 0 !== t) { var i = t.indexOf(e); - 1 !== i && t.splice(i, 1) } } }, dispatchEvent: function (A) { if (void 0 !== this._listeners) { var e = this._listeners[A.type]; if (void 0 !== e) { A.target = this; for (var t = e.slice(0), i = 0, o = t.length; o > i; i++) t[i].call(this, A) } } } }); for (var o = [], n = 0; 256 > n; n++) o[n] = (16 > n ? "0" : "") + n.toString(16); var r, a = { DEG2RAD: Math.PI / 180, RAD2DEG: 180 / Math.PI, generateUUID: function () { var A = 4294967295 * Math.random() | 0, e = 4294967295 * Math.random() | 0, t = 4294967295 * Math.random() | 0, i = 4294967295 * Math.random() | 0; return (o[255 & A] + o[A >> 8 & 255] + o[A >> 16 & 255] + o[A >> 24 & 255] + "-" + o[255 & e] + o[e >> 8 & 255] + "-" + o[e >> 16 & 15 | 64] + o[e >> 24 & 255] + "-" + o[63 & t | 128] + o[t >> 8 & 255] + "-" + o[t >> 16 & 255] + o[t >> 24 & 255] + o[255 & i] + o[i >> 8 & 255] + o[i >> 16 & 255] + o[i >> 24 & 255]).toUpperCase() }, clamp: function (A, e, t) { return Math.max(e, Math.min(t, A)) }, euclideanModulo: function (A, e) { return (A % e + e) % e }, mapLinear: function (A, e, t, i, o) { return i + (A - e) * (o - i) / (t - e) }, lerp: function (A, e, t) { return (1 - t) * A + t * e }, smoothstep: function (A, e, t) { return A > e ? t > A ? (A = (A - e) / (t - e)) * A * (3 - 2 * A) : 1 : 0 }, smootherstep: function (A, e, t) { return A > e ? t > A ? (A = (A - e) / (t - e)) * A * A * (A * (6 * A - 15) + 10) : 1 : 0 }, randInt: function (A, e) { return A + Math.floor(Math.random() * (e - A + 1)) }, randFloat: function (A, e) { return A + Math.random() * (e - A) }, randFloatSpread: function (A) { return A * (.5 - Math.random()) }, degToRad: function (A) { return A * a.DEG2RAD }, radToDeg: function (A) { return A * a.RAD2DEG }, isPowerOfTwo: function (A) { return 0 == (A & A - 1) && 0 !== A }, ceilPowerOfTwo: function (A) { return Math.pow(2, Math.ceil(Math.log(A) / Math.LN2)) }, floorPowerOfTwo: function (A) { return Math.pow(2, Math.floor(Math.log(A) / Math.LN2)) }, setQuaternionFromProperEuler: function (A, e, t, i, o) { var n = Math.cos, r = Math.sin, a = n(t / 2), s = r(t / 2), l = n((e + i) / 2), c = r((e + i) / 2), h = n((e - i) / 2), d = r((e - i) / 2), p = n((i - e) / 2), g = r((i - e) / 2); "XYX" === o ? A.set(a * c, s * h, s * d, a * l) : "YZY" === o ? A.set(s * d, a * c, s * h, a * l) : "ZXZ" === o ? A.set(s * h, s * d, a * c, a * l) : "XZX" === o ? A.set(a * c, s * g, s * p, a * l) : "YXY" === o ? A.set(s * p, a * c, s * g, a * l) : "ZYZ" === o ? A.set(s * g, s * p, a * c, a * l) : console.warn("THREE.MathUtils: .setQuaternionFromProperEuler() encountered an unknown order.") } }; function s(A, e) { this.x = A || 0, this.y = e || 0 } function l() { this.elements = [1, 0, 0, 0, 1, 0, 0, 0, 1], arguments.length > 0 && console.error("THREE.Matrix3: the constructor no longer reads arguments. use .set() instead.") } Object.defineProperties(s.prototype, { width: { get: function () { return this.x }, set: function (A) { this.x = A } }, height: { get: function () { return this.y }, set: function (A) { this.y = A } } }), Object.assign(s.prototype, { isVector2: !0, set: function (A, e) { return this.x = A, this.y = e, this }, setScalar: function (A) { return this.x = A, this.y = A, this }, setX: function (A) { return this.x = A, this }, setY: function (A) { return this.y = A, this }, setComponent: function (A, e) { switch (A) { case 0: this.x = e; break; case 1: this.y = e; break; default: throw new Error("index is out of range: " + A) } return this }, getComponent: function (A) { switch (A) { case 0: return this.x; case 1: return this.y; default: throw new Error("index is out of range: " + A) } }, clone: function () { return new this.constructor(this.x, this.y) }, copy: function (A) { return this.x = A.x, this.y = A.y, this }, add: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead."), this.addVectors(A, e)) : (this.x += A.x, this.y += A.y, this) }, addScalar: function (A) { return this.x += A, this.y += A, this }, addVectors: function (A, e) { return this.x = A.x + e.x, this.y = A.y + e.y, this }, addScaledVector: function (A, e) { return this.x += A.x * e, this.y += A.y * e, this }, sub: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."), this.subVectors(A, e)) : (this.x -= A.x, this.y -= A.y, this) }, subScalar: function (A) { return this.x -= A, this.y -= A, this }, subVectors: function (A, e) { return this.x = A.x - e.x, this.y = A.y - e.y, this }, multiply: function (A) { return this.x *= A.x, this.y *= A.y, this }, multiplyScalar: function (A) { return this.x *= A, this.y *= A, this }, divide: function (A) { return this.x /= A.x, this.y /= A.y, this }, divideScalar: function (A) { return this.multiplyScalar(1 / A) }, applyMatrix3: function (A) { var e = this.x, t = this.y, i = A.elements; return this.x = i[0] * e + i[3] * t + i[6], this.y = i[1] * e + i[4] * t + i[7], this }, min: function (A) { return this.x = Math.min(this.x, A.x), this.y = Math.min(this.y, A.y), this }, max: function (A) { return this.x = Math.max(this.x, A.x), this.y = Math.max(this.y, A.y), this }, clamp: function (A, e) { return this.x = Math.max(A.x, Math.min(e.x, this.x)), this.y = Math.max(A.y, Math.min(e.y, this.y)), this }, clampScalar: function (A, e) { return this.x = Math.max(A, Math.min(e, this.x)), this.y = Math.max(A, Math.min(e, this.y)), this }, clampLength: function (A, e) { var t = this.length(); return this.divideScalar(t || 1).multiplyScalar(Math.max(A, Math.min(e, t))) }, floor: function () { return this.x = Math.floor(this.x), this.y = Math.floor(this.y), this }, ceil: function () { return this.x = Math.ceil(this.x), this.y = Math.ceil(this.y), this }, round: function () { return this.x = Math.round(this.x), this.y = Math.round(this.y), this }, roundToZero: function () { return this.x = 0 > this.x ? Math.ceil(this.x) : Math.floor(this.x), this.y = 0 > this.y ? Math.ceil(this.y) : Math.floor(this.y), this }, negate: function () { return this.x = -this.x, this.y = -this.y, this }, dot: function (A) { return this.x * A.x + this.y * A.y }, cross: function (A) { return this.x * A.y - this.y * A.x }, lengthSq: function () { return this.x * this.x + this.y * this.y }, length: function () { return Math.sqrt(this.x * this.x + this.y * this.y) }, manhattanLength: function () { return Math.abs(this.x) + Math.abs(this.y) }, normalize: function () { return this.divideScalar(this.length() || 1) }, angle: function () { return Math.atan2(-this.y, -this.x) + Math.PI }, distanceTo: function (A) { return Math.sqrt(this.distanceToSquared(A)) }, distanceToSquared: function (A) { var e = this.x - A.x, t = this.y - A.y; return e * e + t * t }, manhattanDistanceTo: function (A) { return Math.abs(this.x - A.x) + Math.abs(this.y - A.y) }, setLength: function (A) { return this.normalize().multiplyScalar(A) }, lerp: function (A, e) { return this.x += (A.x - this.x) * e, this.y += (A.y - this.y) * e, this }, lerpVectors: function (A, e, t) { return this.subVectors(e, A).multiplyScalar(t).add(A) }, equals: function (A) { return A.x === this.x && A.y === this.y }, fromArray: function (A, e) { return void 0 === e && (e = 0), this.x = A[e], this.y = A[e + 1], this }, toArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = this.x, A[e + 1] = this.y, A }, fromBufferAttribute: function (A, e, t) { return void 0 !== t && console.warn("THREE.Vector2: offset has been removed from .fromBufferAttribute()."), this.x = A.getX(e), this.y = A.getY(e), this }, rotateAround: function (A, e) { var t = Math.cos(e), i = Math.sin(e), o = this.x - A.x, n = this.y - A.y; return this.x = o * t - n * i + A.x, this.y = o * i + n * t + A.y, this } }), Object.assign(l.prototype, { isMatrix3: !0, set: function (A, e, t, i, o, n, r, a, s) { var l = this.elements; return l[0] = A, l[1] = i, l[2] = r, l[3] = e, l[4] = o, l[5] = a, l[6] = t, l[7] = n, l[8] = s, this }, identity: function () { return this.set(1, 0, 0, 0, 1, 0, 0, 0, 1), this }, clone: function () { return (new this.constructor).fromArray(this.elements) }, copy: function (A) { var e = this.elements, t = A.elements; return e[0] = t[0], e[1] = t[1], e[2] = t[2], e[3] = t[3], e[4] = t[4], e[5] = t[5], e[6] = t[6], e[7] = t[7], e[8] = t[8], this }, extractBasis: function (A, e, t) { return A.setFromMatrix3Column(this, 0), e.setFromMatrix3Column(this, 1), t.setFromMatrix3Column(this, 2), this }, setFromMatrix4: function (A) { var e = A.elements; return this.set(e[0], e[4], e[8], e[1], e[5], e[9], e[2], e[6], e[10]), this }, multiply: function (A) { return this.multiplyMatrices(this, A) }, premultiply: function (A) { return this.multiplyMatrices(A, this) }, multiplyMatrices: function (A, e) { var t = A.elements, i = e.elements, o = this.elements, n = t[0], r = t[3], a = t[6], s = t[1], l = t[4], c = t[7], h = t[2], d = t[5], p = t[8], g = i[0], u = i[3], f = i[6], m = i[1], C = i[4], y = i[7], v = i[2], I = i[5], E = i[8]; return o[0] = n * g + r * m + a * v, o[3] = n * u + r * C + a * I, o[6] = n * f + r * y + a * E, o[1] = s * g + l * m + c * v, o[4] = s * u + l * C + c * I, o[7] = s * f + l * y + c * E, o[2] = h * g + d * m + p * v, o[5] = h * u + d * C + p * I, o[8] = h * f + d * y + p * E, this }, multiplyScalar: function (A) { var e = this.elements; return e[0] *= A, e[3] *= A, e[6] *= A, e[1] *= A, e[4] *= A, e[7] *= A, e[2] *= A, e[5] *= A, e[8] *= A, this }, determinant: function () { var A = this.elements, e = A[0], t = A[1], i = A[2], o = A[3], n = A[4], r = A[5], a = A[6], s = A[7], l = A[8]; return e * n * l - e * r * s - t * o * l + t * r * a + i * o * s - i * n * a }, getInverse: function (A, e) { void 0 !== e && console.warn("THREE.Matrix3: .getInverse() can no longer be configured to throw on degenerate."); var t = A.elements, i = this.elements, o = t[0], n = t[1], r = t[2], a = t[3], s = t[4], l = t[5], c = t[6], h = t[7], d = t[8], p = d * s - l * h, g = l * c - d * a, u = h * a - s * c, f = o * p + n * g + r * u; if (0 === f) return this.set(0, 0, 0, 0, 0, 0, 0, 0, 0); var m = 1 / f; return i[0] = p * m, i[1] = (r * h - d * n) * m, i[2] = (l * n - r * s) * m, i[3] = g * m, i[4] = (d * o - r * c) * m, i[5] = (r * a - l * o) * m, i[6] = u * m, i[7] = (n * c - h * o) * m, i[8] = (s * o - n * a) * m, this }, transpose: function () { var A, e = this.elements; return A = e[1], e[1] = e[3], e[3] = A, A = e[2], e[2] = e[6], e[6] = A, A = e[5], e[5] = e[7], e[7] = A, this }, getNormalMatrix: function (A) { return this.setFromMatrix4(A).getInverse(this).transpose() }, transposeIntoArray: function (A) { var e = this.elements; return A[0] = e[0], A[1] = e[3], A[2] = e[6], A[3] = e[1], A[4] = e[4], A[5] = e[7], A[6] = e[2], A[7] = e[5], A[8] = e[8], this }, setUvTransform: function (A, e, t, i, o, n, r) { var a = Math.cos(o), s = Math.sin(o); this.set(t * a, t * s, -t * (a * n + s * r) + n + A, -i * s, i * a, -i * (-s * n + a * r) + r + e, 0, 0, 1) }, scale: function (A, e) { var t = this.elements; return t[0] *= A, t[3] *= A, t[6] *= A, t[1] *= e, t[4] *= e, t[7] *= e, this }, rotate: function (A) { var e = Math.cos(A), t = Math.sin(A), i = this.elements, o = i[0], n = i[3], r = i[6], a = i[1], s = i[4], l = i[7]; return i[0] = e * o + t * a, i[3] = e * n + t * s, i[6] = e * r + t * l, i[1] = -t * o + e * a, i[4] = -t * n + e * s, i[7] = -t * r + e * l, this }, translate: function (A, e) { var t = this.elements; return t[0] += A * t[2], t[3] += A * t[5], t[6] += A * t[8], t[1] += e * t[2], t[4] += e * t[5], t[7] += e * t[8], this }, equals: function (A) { for (var e = this.elements, t = A.elements, i = 0; 9 > i; i++) if (e[i] !== t[i]) return !1; return !0 }, fromArray: function (A, e) { void 0 === e && (e = 0); for (var t = 0; 9 > t; t++) this.elements[t] = A[t + e]; return this }, toArray: function (A, e) { void 0 === A && (A = []), void 0 === e && (e = 0); var t = this.elements; return A[e] = t[0], A[e + 1] = t[1], A[e + 2] = t[2], A[e + 3] = t[3], A[e + 4] = t[4], A[e + 5] = t[5], A[e + 6] = t[6], A[e + 7] = t[7], A[e + 8] = t[8], A } }); var c = { getDataURL: function (A) { var e; if ("undefined" == typeof HTMLCanvasElement) return A.src; if (A instanceof HTMLCanvasElement) e = A; else { void 0 === r && (r = document.createElementNS("http://www.w3.org/1999/xhtml", "canvas")), r.width = A.width, r.height = A.height; var t = r.getContext("2d"); A instanceof ImageData ? t.putImageData(A, 0, 0) : t.drawImage(A, 0, 0, A.width, A.height), e = r } return e.width > 2048 || e.height > 2048 ? e.toDataURL("image/jpeg", .6) : e.toDataURL("image/png") } }, h = 0; function d(A, e, t, i, o, n, r, c, p, g) { Object.defineProperty(this, "id", { value: h++ }), this.uuid = a.generateUUID(), this.name = "", this.image = void 0 !== A ? A : d.DEFAULT_IMAGE, this.mipmaps = [], this.mapping = void 0 !== e ? e : d.DEFAULT_MAPPING, this.wrapS = void 0 !== t ? t : 1001, this.wrapT = void 0 !== i ? i : 1001, this.magFilter = void 0 !== o ? o : 1006, this.minFilter = void 0 !== n ? n : 1008, this.anisotropy = void 0 !== p ? p : 1, this.format = void 0 !== r ? r : 1023, this.internalFormat = null, this.type = void 0 !== c ? c : 1009, this.offset = new s(0, 0), this.repeat = new s(1, 1), this.center = new s(0, 0), this.rotation = 0, this.matrixAutoUpdate = !0, this.matrix = new l, this.generateMipmaps = !0, this.premultiplyAlpha = !1, this.flipY = !0, this.unpackAlignment = 4, this.encoding = void 0 !== g ? g : 3e3, this.version = 0, this.onUpdate = null } function p(A, e, t, i) { this.x = A || 0, this.y = e || 0, this.z = t || 0, this.w = void 0 !== i ? i : 1 } function g(A, e, t) { this.width = A, this.height = e, this.scissor = new p(0, 0, A, e), this.scissorTest = !1, this.viewport = new p(0, 0, A, e), this.texture = new d(void 0, (t = t || {}).mapping, t.wrapS, t.wrapT, t.magFilter, t.minFilter, t.format, t.type, t.anisotropy, t.encoding), this.texture.image = {}, this.texture.image.width = A, this.texture.image.height = e, this.texture.generateMipmaps = void 0 !== t.generateMipmaps && t.generateMipmaps, this.texture.minFilter = void 0 !== t.minFilter ? t.minFilter : 1006, this.depthBuffer = void 0 === t.depthBuffer || t.depthBuffer, this.stencilBuffer = void 0 === t.stencilBuffer || t.stencilBuffer, this.depthTexture = void 0 !== t.depthTexture ? t.depthTexture : null } function u(A, e, t) { g.call(this, A, e, t), this.samples = 4 } function f(A, e, t, i) { this._x = A || 0, this._y = e || 0, this._z = t || 0, this._w = void 0 !== i ? i : 1 } d.DEFAULT_IMAGE = void 0, d.DEFAULT_MAPPING = 300, d.prototype = Object.assign(Object.create(i.prototype), { constructor: d, isTexture: !0, updateMatrix: function () { this.matrix.setUvTransform(this.offset.x, this.offset.y, this.repeat.x, this.repeat.y, this.rotation, this.center.x, this.center.y) }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.name = A.name, this.image = A.image, this.mipmaps = A.mipmaps.slice(0), this.mapping = A.mapping, this.wrapS = A.wrapS, this.wrapT = A.wrapT, this.magFilter = A.magFilter, this.minFilter = A.minFilter, this.anisotropy = A.anisotropy, this.format = A.format, this.internalFormat = A.internalFormat, this.type = A.type, this.offset.copy(A.offset), this.repeat.copy(A.repeat), this.center.copy(A.center), this.rotation = A.rotation, this.matrixAutoUpdate = A.matrixAutoUpdate, this.matrix.copy(A.matrix), this.generateMipmaps = A.generateMipmaps, this.premultiplyAlpha = A.premultiplyAlpha, this.flipY = A.flipY, this.unpackAlignment = A.unpackAlignment, this.encoding = A.encoding, this }, toJSON: function (A) { var e = void 0 === A || "string" == typeof A; if (!e && void 0 !== A.textures[this.uuid]) return A.textures[this.uuid]; var t = { metadata: { version: 4.5, type: "Texture", generator: "Texture.toJSON" }, uuid: this.uuid, name: this.name, mapping: this.mapping, repeat: [this.repeat.x, this.repeat.y], offset: [this.offset.x, this.offset.y], center: [this.center.x, this.center.y], rotation: this.rotation, wrap: [this.wrapS, this.wrapT], format: this.format, type: this.type, encoding: this.encoding, minFilter: this.minFilter, magFilter: this.magFilter, anisotropy: this.anisotropy, flipY: this.flipY, premultiplyAlpha: this.premultiplyAlpha, unpackAlignment: this.unpackAlignment }; if (void 0 !== this.image) { var i = this.image; if (void 0 === i.uuid && (i.uuid = a.generateUUID()), !e && void 0 === A.images[i.uuid]) { var o; if (Array.isArray(i)) { o = []; for (var n = 0, r = i.length; r > n; n++) o.push(c.getDataURL(i[n])) } else o = c.getDataURL(i); A.images[i.uuid] = { uuid: i.uuid, url: o } } t.image = i.uuid } return e || (A.textures[this.uuid] = t), t }, dispose: function () { this.dispatchEvent({ type: "dispose" }) }, transformUv: function (A) { if (300 !== this.mapping) return A; if (A.applyMatrix3(this.matrix), 0 > A.x || A.x > 1) switch (this.wrapS) { case 1e3: A.x = A.x - Math.floor(A.x); break; case 1001: A.x = 0 > A.x ? 0 : 1; break; case 1002: A.x = 1 === Math.abs(Math.floor(A.x) % 2) ? Math.ceil(A.x) - A.x : A.x - Math.floor(A.x) } if (0 > A.y || A.y > 1) switch (this.wrapT) { case 1e3: A.y = A.y - Math.floor(A.y); break; case 1001: A.y = 0 > A.y ? 0 : 1; break; case 1002: A.y = 1 === Math.abs(Math.floor(A.y) % 2) ? Math.ceil(A.y) - A.y : A.y - Math.floor(A.y) } return this.flipY && (A.y = 1 - A.y), A } }), Object.defineProperty(d.prototype, "needsUpdate", { set: function (A) { !0 === A && this.version++ } }), Object.defineProperties(p.prototype, { width: { get: function () { return this.z }, set: function (A) { this.z = A } }, height: { get: function () { return this.w }, set: function (A) { this.w = A } } }), Object.assign(p.prototype, { isVector4: !0, set: function (A, e, t, i) { return this.x = A, this.y = e, this.z = t, this.w = i, this }, setScalar: function (A) { return this.x = A, this.y = A, this.z = A, this.w = A, this }, setX: function (A) { return this.x = A, this }, setY: function (A) { return this.y = A, this }, setZ: function (A) { return this.z = A, this }, setW: function (A) { return this.w = A, this }, setComponent: function (A, e) { switch (A) { case 0: this.x = e; break; case 1: this.y = e; break; case 2: this.z = e; break; case 3: this.w = e; break; default: throw new Error("index is out of range: " + A) } return this }, getComponent: function (A) { switch (A) { case 0: return this.x; case 1: return this.y; case 2: return this.z; case 3: return this.w; default: throw new Error("index is out of range: " + A) } }, clone: function () { return new this.constructor(this.x, this.y, this.z, this.w) }, copy: function (A) { return this.x = A.x, this.y = A.y, this.z = A.z, this.w = void 0 !== A.w ? A.w : 1, this }, add: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead."), this.addVectors(A, e)) : (this.x += A.x, this.y += A.y, this.z += A.z, this.w += A.w, this) }, addScalar: function (A) { return this.x += A, this.y += A, this.z += A, this.w += A, this }, addVectors: function (A, e) { return this.x = A.x + e.x, this.y = A.y + e.y, this.z = A.z + e.z, this.w = A.w + e.w, this }, addScaledVector: function (A, e) { return this.x += A.x * e, this.y += A.y * e, this.z += A.z * e, this.w += A.w * e, this }, sub: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."), this.subVectors(A, e)) : (this.x -= A.x, this.y -= A.y, this.z -= A.z, this.w -= A.w, this) }, subScalar: function (A) { return this.x -= A, this.y -= A, this.z -= A, this.w -= A, this }, subVectors: function (A, e) { return this.x = A.x - e.x, this.y = A.y - e.y, this.z = A.z - e.z, this.w = A.w - e.w, this }, multiplyScalar: function (A) { return this.x *= A, this.y *= A, this.z *= A, this.w *= A, this }, applyMatrix4: function (A) { var e = this.x, t = this.y, i = this.z, o = this.w, n = A.elements; return this.x = n[0] * e + n[4] * t + n[8] * i + n[12] * o, this.y = n[1] * e + n[5] * t + n[9] * i + n[13] * o, this.z = n[2] * e + n[6] * t + n[10] * i + n[14] * o, this.w = n[3] * e + n[7] * t + n[11] * i + n[15] * o, this }, divideScalar: function (A) { return this.multiplyScalar(1 / A) }, setAxisAngleFromQuaternion: function (A) { this.w = 2 * Math.acos(A.w); var e = Math.sqrt(1 - A.w * A.w); return 1e-4 > e ? (this.x = 1, this.y = 0, this.z = 0) : (this.x = A.x / e, this.y = A.y / e, this.z = A.z / e), this }, setAxisAngleFromRotationMatrix: function (A) { var e, t, i, o, n = A.elements, r = n[0], a = n[4], s = n[8], l = n[1], c = n[5], h = n[9], d = n[2], p = n[6], g = n[10]; if (.01 > Math.abs(a - l) && .01 > Math.abs(s - d) && .01 > Math.abs(h - p)) { if (.1 > Math.abs(a + l) && .1 > Math.abs(s + d) && .1 > Math.abs(h + p) && .1 > Math.abs(r + c + g - 3)) return this.set(1, 0, 0, 0), this; e = Math.PI; var u = (r + 1) / 2, f = (c + 1) / 2, m = (g + 1) / 2, C = (a + l) / 4, y = (s + d) / 4, v = (h + p) / 4; return u > f && u > m ? .01 > u ? (t = 0, i = .707106781, o = .707106781) : (i = C / (t = Math.sqrt(u)), o = y / t) : f > m ? .01 > f ? (t = .707106781, i = 0, o = .707106781) : (t = C / (i = Math.sqrt(f)), o = v / i) : .01 > m ? (t = .707106781, i = .707106781, o = 0) : (t = y / (o = Math.sqrt(m)), i = v / o), this.set(t, i, o, e), this } var I = Math.sqrt((p - h) * (p - h) + (s - d) * (s - d) + (l - a) * (l - a)); return .001 > Math.abs(I) && (I = 1), this.x = (p - h) / I, this.y = (s - d) / I, this.z = (l - a) / I, this.w = Math.acos((r + c + g - 1) / 2), this }, min: function (A) { return this.x = Math.min(this.x, A.x), this.y = Math.min(this.y, A.y), this.z = Math.min(this.z, A.z), this.w = Math.min(this.w, A.w), this }, max: function (A) { return this.x = Math.max(this.x, A.x), this.y = Math.max(this.y, A.y), this.z = Math.max(this.z, A.z), this.w = Math.max(this.w, A.w), this }, clamp: function (A, e) { return this.x = Math.max(A.x, Math.min(e.x, this.x)), this.y = Math.max(A.y, Math.min(e.y, this.y)), this.z = Math.max(A.z, Math.min(e.z, this.z)), this.w = Math.max(A.w, Math.min(e.w, this.w)), this }, clampScalar: function (A, e) { return this.x = Math.max(A, Math.min(e, this.x)), this.y = Math.max(A, Math.min(e, this.y)), this.z = Math.max(A, Math.min(e, this.z)), this.w = Math.max(A, Math.min(e, this.w)), this }, clampLength: function (A, e) { var t = this.length(); return this.divideScalar(t || 1).multiplyScalar(Math.max(A, Math.min(e, t))) }, floor: function () { return this.x = Math.floor(this.x), this.y = Math.floor(this.y), this.z = Math.floor(this.z), this.w = Math.floor(this.w), this }, ceil: function () { return this.x = Math.ceil(this.x), this.y = Math.ceil(this.y), this.z = Math.ceil(this.z), this.w = Math.ceil(this.w), this }, round: function () { return this.x = Math.round(this.x), this.y = Math.round(this.y), this.z = Math.round(this.z), this.w = Math.round(this.w), this }, roundToZero: function () { return this.x = 0 > this.x ? Math.ceil(this.x) : Math.floor(this.x), this.y = 0 > this.y ? Math.ceil(this.y) : Math.floor(this.y), this.z = 0 > this.z ? Math.ceil(this.z) : Math.floor(this.z), this.w = 0 > this.w ? Math.ceil(this.w) : Math.floor(this.w), this }, negate: function () { return this.x = -this.x, this.y = -this.y, this.z = -this.z, this.w = -this.w, this }, dot: function (A) { return this.x * A.x + this.y * A.y + this.z * A.z + this.w * A.w }, lengthSq: function () { return this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w }, length: function () { return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w) }, manhattanLength: function () { return Math.abs(this.x) + Math.abs(this.y) + Math.abs(this.z) + Math.abs(this.w) }, normalize: function () { return this.divideScalar(this.length() || 1) }, setLength: function (A) { return this.normalize().multiplyScalar(A) }, lerp: function (A, e) { return this.x += (A.x - this.x) * e, this.y += (A.y - this.y) * e, this.z += (A.z - this.z) * e, this.w += (A.w - this.w) * e, this }, lerpVectors: function (A, e, t) { return this.subVectors(e, A).multiplyScalar(t).add(A) }, equals: function (A) { return A.x === this.x && A.y === this.y && A.z === this.z && A.w === this.w }, fromArray: function (A, e) { return void 0 === e && (e = 0), this.x = A[e], this.y = A[e + 1], this.z = A[e + 2], this.w = A[e + 3], this }, toArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = this.x, A[e + 1] = this.y, A[e + 2] = this.z, A[e + 3] = this.w, A }, fromBufferAttribute: function (A, e, t) { return void 0 !== t && console.warn("THREE.Vector4: offset has been removed from .fromBufferAttribute()."), this.x = A.getX(e), this.y = A.getY(e), this.z = A.getZ(e), this.w = A.getW(e), this } }), g.prototype = Object.assign(Object.create(i.prototype), { constructor: g, isWebGLRenderTarget: !0, setSize: function (A, e) { this.width === A && this.height === e || (this.width = A, this.height = e, this.texture.image.width = A, this.texture.image.height = e, this.dispose()), this.viewport.set(0, 0, A, e), this.scissor.set(0, 0, A, e) }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.width = A.width, this.height = A.height, this.viewport.copy(A.viewport), this.texture = A.texture.clone(), this.depthBuffer = A.depthBuffer, this.stencilBuffer = A.stencilBuffer, this.depthTexture = A.depthTexture, this }, dispose: function () { this.dispatchEvent({ type: "dispose" }) } }), u.prototype = Object.assign(Object.create(g.prototype), { constructor: u, isWebGLMultisampleRenderTarget: !0, copy: function (A) { return g.prototype.copy.call(this, A), this.samples = A.samples, this } }), Object.assign(f, { slerp: function (A, e, t, i) { return t.copy(A).slerp(e, i) }, slerpFlat: function (A, e, t, i, o, n, r) { var a = t[i + 0], s = t[i + 1], l = t[i + 2], c = t[i + 3], h = o[n + 0], d = o[n + 1], p = o[n + 2], g = o[n + 3]; if (c !== g || a !== h || s !== d || l !== p) { var u = 1 - r, f = a * h + s * d + l * p + c * g, m = 0 > f ? -1 : 1, C = 1 - f * f; if (C > Number.EPSILON) { var y = Math.sqrt(C), v = Math.atan2(y, f * m); u = Math.sin(u * v) / y, r = Math.sin(r * v) / y } var I = r * m; if (a = a * u + h * I, s = s * u + d * I, l = l * u + p * I, c = c * u + g * I, u === 1 - r) { var E = 1 / Math.sqrt(a * a + s * s + l * l + c * c); a *= E, s *= E, l *= E, c *= E } } A[e] = a, A[e + 1] = s, A[e + 2] = l, A[e + 3] = c } }), Object.defineProperties(f.prototype, { x: { get: function () { return this._x }, set: function (A) { this._x = A, this._onChangeCallback() } }, y: { get: function () { return this._y }, set: function (A) { this._y = A, this._onChangeCallback() } }, z: { get: function () { return this._z }, set: function (A) { this._z = A, this._onChangeCallback() } }, w: { get: function () { return this._w }, set: function (A) { this._w = A, this._onChangeCallback() } } }), Object.assign(f.prototype, { isQuaternion: !0, set: function (A, e, t, i) { return this._x = A, this._y = e, this._z = t, this._w = i, this._onChangeCallback(), this }, clone: function () { return new this.constructor(this._x, this._y, this._z, this._w) }, copy: function (A) { return this._x = A.x, this._y = A.y, this._z = A.z, this._w = A.w, this._onChangeCallback(), this }, setFromEuler: function (A, e) { if (!A || !A.isEuler) throw new Error("THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order."); var t = A._x, i = A._y, o = A._z, n = A.order, r = Math.cos, a = Math.sin, s = r(t / 2), l = r(i / 2), c = r(o / 2), h = a(t / 2), d = a(i / 2), p = a(o / 2); return "XYZ" === n ? (this._x = h * l * c + s * d * p, this._y = s * d * c - h * l * p, this._z = s * l * p + h * d * c, this._w = s * l * c - h * d * p) : "YXZ" === n ? (this._x = h * l * c + s * d * p, this._y = s * d * c - h * l * p, this._z = s * l * p - h * d * c, this._w = s * l * c + h * d * p) : "ZXY" === n ? (this._x = h * l * c - s * d * p, this._y = s * d * c + h * l * p, this._z = s * l * p + h * d * c, this._w = s * l * c - h * d * p) : "ZYX" === n ? (this._x = h * l * c - s * d * p, this._y = s * d * c + h * l * p, this._z = s * l * p - h * d * c, this._w = s * l * c + h * d * p) : "YZX" === n ? (this._x = h * l * c + s * d * p, this._y = s * d * c + h * l * p, this._z = s * l * p - h * d * c, this._w = s * l * c - h * d * p) : "XZY" === n && (this._x = h * l * c - s * d * p, this._y = s * d * c - h * l * p, this._z = s * l * p + h * d * c, this._w = s * l * c + h * d * p), !1 !== e && this._onChangeCallback(), this }, setFromAxisAngle: function (A, e) { var t = e / 2, i = Math.sin(t); return this._x = A.x * i, this._y = A.y * i, this._z = A.z * i, this._w = Math.cos(t), this._onChangeCallback(), this }, setFromRotationMatrix: function (A) { var e, t = A.elements, i = t[0], o = t[4], n = t[8], r = t[1], a = t[5], s = t[9], l = t[2], c = t[6], h = t[10], d = i + a + h; return d > 0 ? (e = .5 / Math.sqrt(d + 1), this._w = .25 / e, this._x = (c - s) * e, this._y = (n - l) * e, this._z = (r - o) * e) : i > a && i > h ? (e = 2 * Math.sqrt(1 + i - a - h), this._w = (c - s) / e, this._x = .25 * e, this._y = (o + r) / e, this._z = (n + l) / e) : a > h ? (e = 2 * Math.sqrt(1 + a - i - h), this._w = (n - l) / e, this._x = (o + r) / e, this._y = .25 * e, this._z = (s + c) / e) : (e = 2 * Math.sqrt(1 + h - i - a), this._w = (r - o) / e, this._x = (n + l) / e, this._y = (s + c) / e, this._z = .25 * e), this._onChangeCallback(), this }, setFromUnitVectors: function (A, e) { var t = A.dot(e) + 1; return 1e-6 > t ? (t = 0, Math.abs(A.x) > Math.abs(A.z) ? (this._x = -A.y, this._y = A.x, this._z = 0, this._w = t) : (this._x = 0, this._y = -A.z, this._z = A.y, this._w = t)) : (this._x = A.y * e.z - A.z * e.y, this._y = A.z * e.x - A.x * e.z, this._z = A.x * e.y - A.y * e.x, this._w = t), this.normalize() }, angleTo: function (A) { return 2 * Math.acos(Math.abs(a.clamp(this.dot(A), -1, 1))) }, rotateTowards: function (A, e) { var t = this.angleTo(A); if (0 === t) return this; var i = Math.min(1, e / t); return this.slerp(A, i), this }, inverse: function () { return this.conjugate() }, conjugate: function () { return this._x *= -1, this._y *= -1, this._z *= -1, this._onChangeCallback(), this }, dot: function (A) { return this._x * A._x + this._y * A._y + this._z * A._z + this._w * A._w }, lengthSq: function () { return this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w }, length: function () { return Math.sqrt(this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w) }, normalize: function () { var A = this.length(); return 0 === A ? (this._x = 0, this._y = 0, this._z = 0, this._w = 1) : (this._x = this._x * (A = 1 / A), this._y = this._y * A, this._z = this._z * A, this._w = this._w * A), this._onChangeCallback(), this }, multiply: function (A, e) { return void 0 !== e ? (console.warn("THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead."), this.multiplyQuaternions(A, e)) : this.multiplyQuaternions(this, A) }, premultiply: function (A) { return this.multiplyQuaternions(A, this) }, multiplyQuaternions: function (A, e) { var t = A._x, i = A._y, o = A._z, n = A._w, r = e._x, a = e._y, s = e._z, l = e._w; return this._x = t * l + n * r + i * s - o * a, this._y = i * l + n * a + o * r - t * s, this._z = o * l + n * s + t * a - i * r, this._w = n * l - t * r - i * a - o * s, this._onChangeCallback(), this }, slerp: function (A, e) { if (0 === e) return this; if (1 === e) return this.copy(A); var t = this._x, i = this._y, o = this._z, n = this._w, r = n * A._w + t * A._x + i * A._y + o * A._z; if (0 > r ? (this._w = -A._w, this._x = -A._x, this._y = -A._y, this._z = -A._z, r = -r) : this.copy(A), r >= 1) return this._w = n, this._x = t, this._y = i, this._z = o, this; var a = 1 - r * r; if (Number.EPSILON >= a) { var s = 1 - e; return this._w = s * n + e * this._w, this._x = s * t + e * this._x, this._y = s * i + e * this._y, this._z = s * o + e * this._z, this.normalize(), this._onChangeCallback(), this } var l = Math.sqrt(a), c = Math.atan2(l, r), h = Math.sin((1 - e) * c) / l, d = Math.sin(e * c) / l; return this._w = n * h + this._w * d, this._x = t * h + this._x * d, this._y = i * h + this._y * d, this._z = o * h + this._z * d, this._onChangeCallback(), this }, equals: function (A) { return A._x === this._x && A._y === this._y && A._z === this._z && A._w === this._w }, fromArray: function (A, e) { return void 0 === e && (e = 0), this._x = A[e], this._y = A[e + 1], this._z = A[e + 2], this._w = A[e + 3], this._onChangeCallback(), this }, toArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = this._x, A[e + 1] = this._y, A[e + 2] = this._z, A[e + 3] = this._w, A }, fromBufferAttribute: function (A, e) { return this._x = A.getX(e), this._y = A.getY(e), this._z = A.getZ(e), this._w = A.getW(e), this }, _onChange: function (A) { return this._onChangeCallback = A, this }, _onChangeCallback: function () {} }); var m = new y, C = new f; function y(A, e, t) { this.x = A || 0, this.y = e || 0, this.z = t || 0 } Object.assign(y.prototype, { isVector3: !0, set: function (A, e, t) { return this.x = A, this.y = e, this.z = t, this }, setScalar: function (A) { return this.x = A, this.y = A, this.z = A, this }, setX: function (A) { return this.x = A, this }, setY: function (A) { return this.y = A, this }, setZ: function (A) { return this.z = A, this }, setComponent: function (A, e) { switch (A) { case 0: this.x = e; break; case 1: this.y = e; break; case 2: this.z = e; break; default: throw new Error("index is out of range: " + A) } return this }, getComponent: function (A) { switch (A) { case 0: return this.x; case 1: return this.y; case 2: return this.z; default: throw new Error("index is out of range: " + A) } }, clone: function () { return new this.constructor(this.x, this.y, this.z) }, copy: function (A) { return this.x = A.x, this.y = A.y, this.z = A.z, this }, add: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead."), this.addVectors(A, e)) : (this.x += A.x, this.y += A.y, this.z += A.z, this) }, addScalar: function (A) { return this.x += A, this.y += A, this.z += A, this }, addVectors: function (A, e) { return this.x = A.x + e.x, this.y = A.y + e.y, this.z = A.z + e.z, this }, addScaledVector: function (A, e) { return this.x += A.x * e, this.y += A.y * e, this.z += A.z * e, this }, sub: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."), this.subVectors(A, e)) : (this.x -= A.x, this.y -= A.y, this.z -= A.z, this) }, subScalar: function (A) { return this.x -= A, this.y -= A, this.z -= A, this }, subVectors: function (A, e) { return this.x = A.x - e.x, this.y = A.y - e.y, this.z = A.z - e.z, this }, multiply: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead."), this.multiplyVectors(A, e)) : (this.x *= A.x, this.y *= A.y, this.z *= A.z, this) }, multiplyScalar: function (A) { return this.x *= A, this.y *= A, this.z *= A, this }, multiplyVectors: function (A, e) { return this.x = A.x * e.x, this.y = A.y * e.y, this.z = A.z * e.z, this }, applyEuler: function (A) { return A && A.isEuler || console.error("THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order."), this.applyQuaternion(C.setFromEuler(A)) }, applyAxisAngle: function (A, e) { return this.applyQuaternion(C.setFromAxisAngle(A, e)) }, applyMatrix3: function (A) { var e = this.x, t = this.y, i = this.z, o = A.elements; return this.x = o[0] * e + o[3] * t + o[6] * i, this.y = o[1] * e + o[4] * t + o[7] * i, this.z = o[2] * e + o[5] * t + o[8] * i, this }, applyNormalMatrix: function (A) { return this.applyMatrix3(A).normalize() }, applyMatrix4: function (A) { var e = this.x, t = this.y, i = this.z, o = A.elements, n = 1 / (o[3] * e + o[7] * t + o[11] * i + o[15]); return this.x = (o[0] * e + o[4] * t + o[8] * i + o[12]) * n, this.y = (o[1] * e + o[5] * t + o[9] * i + o[13]) * n, this.z = (o[2] * e + o[6] * t + o[10] * i + o[14]) * n, this }, applyQuaternion: function (A) { var e = this.x, t = this.y, i = this.z, o = A.x, n = A.y, r = A.z, a = A.w, s = a * e + n * i - r * t, l = a * t + r * e - o * i, c = a * i + o * t - n * e, h = -o * e - n * t - r * i; return this.x = s * a + h * -o + l * -r - c * -n, this.y = l * a + h * -n + c * -o - s * -r, this.z = c * a + h * -r + s * -n - l * -o, this }, project: function (A) { return this.applyMatrix4(A.matrixWorldInverse).applyMatrix4(A.projectionMatrix) }, unproject: function (A) { return this.applyMatrix4(A.projectionMatrixInverse).applyMatrix4(A.matrixWorld) }, transformDirection: function (A) { var e = this.x, t = this.y, i = this.z, o = A.elements; return this.x = o[0] * e + o[4] * t + o[8] * i, this.y = o[1] * e + o[5] * t + o[9] * i, this.z = o[2] * e + o[6] * t + o[10] * i, this.normalize() }, divide: function (A) { return this.x /= A.x, this.y /= A.y, this.z /= A.z, this }, divideScalar: function (A) { return this.multiplyScalar(1 / A) }, min: function (A) { return this.x = Math.min(this.x, A.x), this.y = Math.min(this.y, A.y), this.z = Math.min(this.z, A.z), this }, max: function (A) { return this.x = Math.max(this.x, A.x), this.y = Math.max(this.y, A.y), this.z = Math.max(this.z, A.z), this }, clamp: function (A, e) { return this.x = Math.max(A.x, Math.min(e.x, this.x)), this.y = Math.max(A.y, Math.min(e.y, this.y)), this.z = Math.max(A.z, Math.min(e.z, this.z)), this }, clampScalar: function (A, e) { return this.x = Math.max(A, Math.min(e, this.x)), this.y = Math.max(A, Math.min(e, this.y)), this.z = Math.max(A, Math.min(e, this.z)), this }, clampLength: function (A, e) { var t = this.length(); return this.divideScalar(t || 1).multiplyScalar(Math.max(A, Math.min(e, t))) }, floor: function () { return this.x = Math.floor(this.x), this.y = Math.floor(this.y), this.z = Math.floor(this.z), this }, ceil: function () { return this.x = Math.ceil(this.x), this.y = Math.ceil(this.y), this.z = Math.ceil(this.z), this }, round: function () { return this.x = Math.round(this.x), this.y = Math.round(this.y), this.z = Math.round(this.z), this }, roundToZero: function () { return this.x = 0 > this.x ? Math.ceil(this.x) : Math.floor(this.x), this.y = 0 > this.y ? Math.ceil(this.y) : Math.floor(this.y), this.z = 0 > this.z ? Math.ceil(this.z) : Math.floor(this.z), this }, negate: function () { return this.x = -this.x, this.y = -this.y, this.z = -this.z, this }, dot: function (A) { return this.x * A.x + this.y * A.y + this.z * A.z }, lengthSq: function () { return this.x * this.x + this.y * this.y + this.z * this.z }, length: function () { return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z) }, manhattanLength: function () { return Math.abs(this.x) + Math.abs(this.y) + Math.abs(this.z) }, normalize: function () { return this.divideScalar(this.length() || 1) }, setLength: function (A) { return this.normalize().multiplyScalar(A) }, lerp: function (A, e) { return this.x += (A.x - this.x) * e, this.y += (A.y - this.y) * e, this.z += (A.z - this.z) * e, this }, lerpVectors: function (A, e, t) { return this.subVectors(e, A).multiplyScalar(t).add(A) }, cross: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead."), this.crossVectors(A, e)) : this.crossVectors(this, A) }, crossVectors: function (A, e) { var t = A.x, i = A.y, o = A.z, n = e.x, r = e.y, a = e.z; return this.x = i * a - o * r, this.y = o * n - t * a, this.z = t * r - i * n, this }, projectOnVector: function (A) { var e = A.lengthSq(); if (0 === e) return this.set(0, 0, 0); var t = A.dot(this) / e; return this.copy(A).multiplyScalar(t) }, projectOnPlane: function (A) { return m.copy(this).projectOnVector(A), this.sub(m) }, reflect: function (A) { return this.sub(m.copy(A).multiplyScalar(2 * this.dot(A))) }, angleTo: function (A) { var e = Math.sqrt(this.lengthSq() * A.lengthSq()); if (0 === e) return Math.PI / 2; var t = this.dot(A) / e; return Math.acos(a.clamp(t, -1, 1)) }, distanceTo: function (A) { return Math.sqrt(this.distanceToSquared(A)) }, distanceToSquared: function (A) { var e = this.x - A.x, t = this.y - A.y, i = this.z - A.z; return e * e + t * t + i * i }, manhattanDistanceTo: function (A) { return Math.abs(this.x - A.x) + Math.abs(this.y - A.y) + Math.abs(this.z - A.z) }, setFromSpherical: function (A) { return this.setFromSphericalCoords(A.radius, A.phi, A.theta) }, setFromSphericalCoords: function (A, e, t) { var i = Math.sin(e) * A; return this.x = i * Math.sin(t), this.y = Math.cos(e) * A, this.z = i * Math.cos(t), this }, setFromCylindrical: function (A) { return this.setFromCylindricalCoords(A.radius, A.theta, A.y) }, setFromCylindricalCoords: function (A, e, t) { return this.x = A * Math.sin(e), this.y = t, this.z = A * Math.cos(e), this }, setFromMatrixPosition: function (A) { var e = A.elements; return this.x = e[12], this.y = e[13], this.z = e[14], this }, setFromMatrixScale: function (A) { var e = this.setFromMatrixColumn(A, 0).length(), t = this.setFromMatrixColumn(A, 1).length(), i = this.setFromMatrixColumn(A, 2).length(); return this.x = e, this.y = t, this.z = i, this }, setFromMatrixColumn: function (A, e) { return this.fromArray(A.elements, 4 * e) }, setFromMatrix3Column: function (A, e) { return this.fromArray(A.elements, 3 * e) }, equals: function (A) { return A.x === this.x && A.y === this.y && A.z === this.z }, fromArray: function (A, e) { return void 0 === e && (e = 0), this.x = A[e], this.y = A[e + 1], this.z = A[e + 2], this }, toArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = this.x, A[e + 1] = this.y, A[e + 2] = this.z, A }, fromBufferAttribute: function (A, e, t) { return void 0 !== t && console.warn("THREE.Vector3: offset has been removed from .fromBufferAttribute()."), this.x = A.getX(e), this.y = A.getY(e), this.z = A.getZ(e), this } }); var v = new y, I = new M, E = new y(0, 0, 0), B = new y(1, 1, 1), x = new y, S = new y, w = new y; function M() { this.elements = [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1], arguments.length > 0 && console.error("THREE.Matrix4: the constructor no longer reads arguments. use .set() instead.") } Object.assign(M.prototype, { isMatrix4: !0, set: function (A, e, t, i, o, n, r, a, s, l, c, h, d, p, g, u) { var f = this.elements; return f[0] = A, f[4] = e, f[8] = t, f[12] = i, f[1] = o, f[5] = n, f[9] = r, f[13] = a, f[2] = s, f[6] = l, f[10] = c, f[14] = h, f[3] = d, f[7] = p, f[11] = g, f[15] = u, this }, identity: function () { return this.set(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1), this }, clone: function () { return (new M).fromArray(this.elements) }, copy: function (A) { var e = this.elements, t = A.elements; return e[0] = t[0], e[1] = t[1], e[2] = t[2], e[3] = t[3], e[4] = t[4], e[5] = t[5], e[6] = t[6], e[7] = t[7], e[8] = t[8], e[9] = t[9], e[10] = t[10], e[11] = t[11], e[12] = t[12], e[13] = t[13], e[14] = t[14], e[15] = t[15], this }, copyPosition: function (A) { var e = this.elements, t = A.elements; return e[12] = t[12], e[13] = t[13], e[14] = t[14], this }, extractBasis: function (A, e, t) { return A.setFromMatrixColumn(this, 0), e.setFromMatrixColumn(this, 1), t.setFromMatrixColumn(this, 2), this }, makeBasis: function (A, e, t) { return this.set(A.x, e.x, t.x, 0, A.y, e.y, t.y, 0, A.z, e.z, t.z, 0, 0, 0, 0, 1), this }, extractRotation: function (A) { var e = this.elements, t = A.elements, i = 1 / v.setFromMatrixColumn(A, 0).length(), o = 1 / v.setFromMatrixColumn(A, 1).length(), n = 1 / v.setFromMatrixColumn(A, 2).length(); return e[0] = t[0] * i, e[1] = t[1] * i, e[2] = t[2] * i, e[3] = 0, e[4] = t[4] * o, e[5] = t[5] * o, e[6] = t[6] * o, e[7] = 0, e[8] = t[8] * n, e[9] = t[9] * n, e[10] = t[10] * n, e[11] = 0, e[12] = 0, e[13] = 0, e[14] = 0, e[15] = 1, this }, makeRotationFromEuler: function (A) { A && A.isEuler || console.error("THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order."); var e = this.elements, t = A.x, i = A.y, o = A.z, n = Math.cos(t), r = Math.sin(t), a = Math.cos(i), s = Math.sin(i), l = Math.cos(o), c = Math.sin(o); if ("XYZ" === A.order) { var h = n * l, d = n * c, p = r * l, g = r * c; e[0] = a * l, e[4] = -a * c, e[8] = s, e[1] = d + p * s, e[5] = h - g * s, e[9] = -r * a, e[2] = g - h * s, e[6] = p + d * s, e[10] = n * a } else if ("YXZ" === A.order) { var u = a * c, f = s * l; e[0] = (m = a * l) + (C = s * c) * r, e[4] = f * r - u, e[8] = n * s, e[1] = n * c, e[5] = n * l, e[9] = -r, e[2] = u * r - f, e[6] = C + m * r, e[10] = n * a } else if ("ZXY" === A.order) { var m, C; u = a * c, f = s * l; e[0] = (m = a * l) - (C = s * c) * r, e[4] = -n * c, e[8] = f + u * r, e[1] = u + f * r, e[5] = n * l, e[9] = C - m * r, e[2] = -n * s, e[6] = r, e[10] = n * a } else if ("ZYX" === A.order) { h = n * l, d = n * c, p = r * l, g = r * c; e[0] = a * l, e[4] = p * s - d, e[8] = h * s + g, e[1] = a * c, e[5] = g * s + h, e[9] = d * s - p, e[2] = -s, e[6] = r * a, e[10] = n * a } else if ("YZX" === A.order) { var y = n * a, v = n * s, I = r * a, E = r * s; e[0] = a * l, e[4] = E - y * c, e[8] = I * c + v, e[1] = c, e[5] = n * l, e[9] = -r * l, e[2] = -s * l, e[6] = v * c + I, e[10] = y - E * c } else if ("XZY" === A.order) { y = n * a, v = n * s, I = r * a, E = r * s; e[0] = a * l, e[4] = -c, e[8] = s * l, e[1] = y * c + E, e[5] = n * l, e[9] = v * c - I, e[2] = I * c - v, e[6] = r * l, e[10] = E * c + y } return e[3] = 0, e[7] = 0, e[11] = 0, e[12] = 0, e[13] = 0, e[14] = 0, e[15] = 1, this }, makeRotationFromQuaternion: function (A) { return this.compose(E, A, B) }, lookAt: function (A, e, t) { var i = this.elements; return w.subVectors(A, e), 0 === w.lengthSq() && (w.z = 1), w.normalize(), x.crossVectors(t, w), 0 === x.lengthSq() && (1 === Math.abs(t.z) ? w.x += 1e-4 : w.z += 1e-4, w.normalize(), x.crossVectors(t, w)), x.normalize(), S.crossVectors(w, x), i[0] = x.x, i[4] = S.x, i[8] = w.x, i[1] = x.y, i[5] = S.y, i[9] = w.y, i[2] = x.z, i[6] = S.z, i[10] = w.z, this }, multiply: function (A, e) { return void 0 !== e ? (console.warn("THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead."), this.multiplyMatrices(A, e)) : this.multiplyMatrices(this, A) }, premultiply: function (A) { return this.multiplyMatrices(A, this) }, multiplyMatrices: function (A, e) { var t = A.elements, i = e.elements, o = this.elements, n = t[0], r = t[4], a = t[8], s = t[12], l = t[1], c = t[5], h = t[9], d = t[13], p = t[2], g = t[6], u = t[10], f = t[14], m = t[3], C = t[7], y = t[11], v = t[15], I = i[0], E = i[4], B = i[8], x = i[12], S = i[1], w = i[5], M = i[9], b = i[13], U = i[2], F = i[6], K = i[10], Q = i[14], R = i[3], T = i[7], k = i[11], D = i[15]; return o[0] = n * I + r * S + a * U + s * R, o[4] = n * E + r * w + a * F + s * T, o[8] = n * B + r * M + a * K + s * k, o[12] = n * x + r * b + a * Q + s * D, o[1] = l * I + c * S + h * U + d * R, o[5] = l * E + c * w + h * F + d * T, o[9] = l * B + c * M + h * K + d * k, o[13] = l * x + c * b + h * Q + d * D, o[2] = p * I + g * S + u * U + f * R, o[6] = p * E + g * w + u * F + f * T, o[10] = p * B + g * M + u * K + f * k, o[14] = p * x + g * b + u * Q + f * D, o[3] = m * I + C * S + y * U + v * R, o[7] = m * E + C * w + y * F + v * T, o[11] = m * B + C * M + y * K + v * k, o[15] = m * x + C * b + y * Q + v * D, this }, multiplyScalar: function (A) { var e = this.elements; return e[0] *= A, e[4] *= A, e[8] *= A, e[12] *= A, e[1] *= A, e[5] *= A, e[9] *= A, e[13] *= A, e[2] *= A, e[6] *= A, e[10] *= A, e[14] *= A, e[3] *= A, e[7] *= A, e[11] *= A, e[15] *= A, this }, determinant: function () { var A = this.elements, e = A[0], t = A[4], i = A[8], o = A[12], n = A[1], r = A[5], a = A[9], s = A[13], l = A[2], c = A[6], h = A[10], d = A[14]; return A[3] * (+o * a * c - i * s * c - o * r * h + t * s * h + i * r * d - t * a * d) + A[7] * (+e * a * d - e * s * h + o * n * h - i * n * d + i * s * l - o * a * l) + A[11] * (+e * s * c - e * r * d - o * n * c + t * n * d + o * r * l - t * s * l) + A[15] * (-i * r * l - e * a * c + e * r * h + i * n * c - t * n * h + t * a * l) }, transpose: function () { var A, e = this.elements; return A = e[1], e[1] = e[4], e[4] = A, A = e[2], e[2] = e[8], e[8] = A, A = e[6], e[6] = e[9], e[9] = A, A = e[3], e[3] = e[12], e[12] = A, A = e[7], e[7] = e[13], e[13] = A, A = e[11], e[11] = e[14], e[14] = A, this }, setPosition: function (A, e, t) { var i = this.elements; return A.isVector3 ? (i[12] = A.x, i[13] = A.y, i[14] = A.z) : (i[12] = A, i[13] = e, i[14] = t), this }, getInverse: function (A, e) { void 0 !== e && console.warn("THREE.Matrix4: .getInverse() can no longer be configured to throw on degenerate."); var t = this.elements, i = A.elements, o = i[0], n = i[1], r = i[2], a = i[3], s = i[4], l = i[5], c = i[6], h = i[7], d = i[8], p = i[9], g = i[10], u = i[11], f = i[12], m = i[13], C = i[14], y = i[15], v = p * C * h - m * g * h + m * c * u - l * C * u - p * c * y + l * g * y, I = f * g * h - d * C * h - f * c * u + s * C * u + d * c * y - s * g * y, E = d * m * h - f * p * h + f * l * u - s * m * u - d * l * y + s * p * y, B = f * p * c - d * m * c - f * l * g + s * m * g + d * l * C - s * p * C, x = o * v + n * I + r * E + a * B; if (0 === x) return this.set(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0); var S = 1 / x; return t[0] = v * S, t[1] = (m * g * a - p * C * a - m * r * u + n * C * u + p * r * y - n * g * y) * S, t[2] = (l * C * a - m * c * a + m * r * h - n * C * h - l * r * y + n * c * y) * S, t[3] = (p * c * a - l * g * a - p * r * h + n * g * h + l * r * u - n * c * u) * S, t[4] = I * S, t[5] = (d * C * a - f * g * a + f * r * u - o * C * u - d * r * y + o * g * y) * S, t[6] = (f * c * a - s * C * a - f * r * h + o * C * h + s * r * y - o * c * y) * S, t[7] = (s * g * a - d * c * a + d * r * h - o * g * h - s * r * u + o * c * u) * S, t[8] = E * S, t[9] = (f * p * a - d * m * a - f * n * u + o * m * u + d * n * y - o * p * y) * S, t[10] = (s * m * a - f * l * a + f * n * h - o * m * h - s * n * y + o * l * y) * S, t[11] = (d * l * a - s * p * a - d * n * h + o * p * h + s * n * u - o * l * u) * S, t[12] = B * S, t[13] = (d * m * r - f * p * r + f * n * g - o * m * g - d * n * C + o * p * C) * S, t[14] = (f * l * r - s * m * r - f * n * c + o * m * c + s * n * C - o * l * C) * S, t[15] = (s * p * r - d * l * r + d * n * c - o * p * c - s * n * g + o * l * g) * S, this }, scale: function (A) { var e = this.elements, t = A.x, i = A.y, o = A.z; return e[0] *= t, e[4] *= i, e[8] *= o, e[1] *= t, e[5] *= i, e[9] *= o, e[2] *= t, e[6] *= i, e[10] *= o, e[3] *= t, e[7] *= i, e[11] *= o, this }, getMaxScaleOnAxis: function () { var A = this.elements; return Math.sqrt(Math.max(A[0] * A[0] + A[1] * A[1] + A[2] * A[2], A[4] * A[4] + A[5] * A[5] + A[6] * A[6], A[8] * A[8] + A[9] * A[9] + A[10] * A[10])) }, makeTranslation: function (A, e, t) { return this.set(1, 0, 0, A, 0, 1, 0, e, 0, 0, 1, t, 0, 0, 0, 1), this }, makeRotationX: function (A) { var e = Math.cos(A), t = Math.sin(A); return this.set(1, 0, 0, 0, 0, e, -t, 0, 0, t, e, 0, 0, 0, 0, 1), this }, makeRotationY: function (A) { var e = Math.cos(A), t = Math.sin(A); return this.set(e, 0, t, 0, 0, 1, 0, 0, -t, 0, e, 0, 0, 0, 0, 1), this }, makeRotationZ: function (A) { var e = Math.cos(A), t = Math.sin(A); return this.set(e, -t, 0, 0, t, e, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1), this }, makeRotationAxis: function (A, e) { var t = Math.cos(e), i = Math.sin(e), o = 1 - t, n = A.x, r = A.y, a = A.z, s = o * n, l = o * r; return this.set(s * n + t, s * r - i * a, s * a + i * r, 0, s * r + i * a, l * r + t, l * a - i * n, 0, s * a - i * r, l * a + i * n, o * a * a + t, 0, 0, 0, 0, 1), this }, makeScale: function (A, e, t) { return this.set(A, 0, 0, 0, 0, e, 0, 0, 0, 0, t, 0, 0, 0, 0, 1), this }, makeShear: function (A, e, t) { return this.set(1, e, t, 0, A, 1, t, 0, A, e, 1, 0, 0, 0, 0, 1), this }, compose: function (A, e, t) { var i = this.elements, o = e._x, n = e._y, r = e._z, a = e._w, s = o + o, l = n + n, c = r + r, h = o * s, d = o * l, p = o * c, g = n * l, u = n * c, f = r * c, m = a * s, C = a * l, y = a * c, v = t.x, I = t.y, E = t.z; return i[0] = (1 - (g + f)) * v, i[1] = (d + y) * v, i[2] = (p - C) * v, i[3] = 0, i[4] = (d - y) * I, i[5] = (1 - (h + f)) * I, i[6] = (u + m) * I, i[7] = 0, i[8] = (p + C) * E, i[9] = (u - m) * E, i[10] = (1 - (h + g)) * E, i[11] = 0, i[12] = A.x, i[13] = A.y, i[14] = A.z, i[15] = 1, this }, decompose: function (A, e, t) { var i = this.elements, o = v.set(i[0], i[1], i[2]).length(), n = v.set(i[4], i[5], i[6]).length(), r = v.set(i[8], i[9], i[10]).length(); 0 > this.determinant() && (o = -o), A.x = i[12], A.y = i[13], A.z = i[14], I.copy(this); var a = 1 / o, s = 1 / n, l = 1 / r; return I.elements[0] *= a, I.elements[1] *= a, I.elements[2] *= a, I.elements[4] *= s, I.elements[5] *= s, I.elements[6] *= s, I.elements[8] *= l, I.elements[9] *= l, I.elements[10] *= l, e.setFromRotationMatrix(I), t.x = o, t.y = n, t.z = r, this }, makePerspective: function (A, e, t, i, o, n) { void 0 === n && console.warn("THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs."); var r = this.elements, a = 2 * o / (t - i), s = (e + A) / (e - A), l = (t + i) / (t - i), c = -(n + o) / (n - o), h = -2 * n * o / (n - o); return r[0] = 2 * o / (e - A), r[4] = 0, r[8] = s, r[12] = 0, r[1] = 0, r[5] = a, r[9] = l, r[13] = 0, r[2] = 0, r[6] = 0, r[10] = c, r[14] = h, r[3] = 0, r[7] = 0, r[11] = -1, r[15] = 0, this }, makeOrthographic: function (A, e, t, i, o, n) { var r = this.elements, a = 1 / (e - A), s = 1 / (t - i), l = 1 / (n - o), c = (e + A) * a, h = (t + i) * s, d = (n + o) * l; return r[0] = 2 * a, r[4] = 0, r[8] = 0, r[12] = -c, r[1] = 0, r[5] = 2 * s, r[9] = 0, r[13] = -h, r[2] = 0, r[6] = 0, r[10] = -2 * l, r[14] = -d, r[3] = 0, r[7] = 0, r[11] = 0, r[15] = 1, this }, equals: function (A) { for (var e = this.elements, t = A.elements, i = 0; 16 > i; i++) if (e[i] !== t[i]) return !1; return !0 }, fromArray: function (A, e) { void 0 === e && (e = 0); for (var t = 0; 16 > t; t++) this.elements[t] = A[t + e]; return this }, toArray: function (A, e) { void 0 === A && (A = []), void 0 === e && (e = 0); var t = this.elements; return A[e] = t[0], A[e + 1] = t[1], A[e + 2] = t[2], A[e + 3] = t[3], A[e + 4] = t[4], A[e + 5] = t[5], A[e + 6] = t[6], A[e + 7] = t[7], A[e + 8] = t[8], A[e + 9] = t[9], A[e + 10] = t[10], A[e + 11] = t[11], A[e + 12] = t[12], A[e + 13] = t[13], A[e + 14] = t[14], A[e + 15] = t[15], A } }); var b = new M, U = new f; function F(A, e, t, i) { this._x = A || 0, this._y = e || 0, this._z = t || 0, this._order = i || F.DefaultOrder } function K() { this.mask = 1 } F.RotationOrders = ["XYZ", "YZX", "ZXY", "XZY", "YXZ", "ZYX"], F.DefaultOrder = "XYZ", Object.defineProperties(F.prototype, { x: { get: function () { return this._x }, set: function (A) { this._x = A, this._onChangeCallback() } }, y: { get: function () { return this._y }, set: function (A) { this._y = A, this._onChangeCallback() } }, z: { get: function () { return this._z }, set: function (A) { this._z = A, this._onChangeCallback() } }, order: { get: function () { return this._order }, set: function (A) { this._order = A, this._onChangeCallback() } } }), Object.assign(F.prototype, { isEuler: !0, set: function (A, e, t, i) { return this._x = A, this._y = e, this._z = t, this._order = i || this._order, this._onChangeCallback(), this }, clone: function () { return new this.constructor(this._x, this._y, this._z, this._order) }, copy: function (A) { return this._x = A._x, this._y = A._y, this._z = A._z, this._order = A._order, this._onChangeCallback(), this }, setFromRotationMatrix: function (A, e, t) { var i = a.clamp, o = A.elements, n = o[0], r = o[4], s = o[8], l = o[1], c = o[5], h = o[9], d = o[2], p = o[6], g = o[10]; return "XYZ" === (e = e || this._order) ? (this._y = Math.asin(i(s, -1, 1)), .9999999 > Math.abs(s) ? (this._x = Math.atan2(-h, g), this._z = Math.atan2(-r, n)) : (this._x = Math.atan2(p, c), this._z = 0)) : "YXZ" === e ? (this._x = Math.asin(-i(h, -1, 1)), .9999999 > Math.abs(h) ? (this._y = Math.atan2(s, g), this._z = Math.atan2(l, c)) : (this._y = Math.atan2(-d, n), this._z = 0)) : "ZXY" === e ? (this._x = Math.asin(i(p, -1, 1)), .9999999 > Math.abs(p) ? (this._y = Math.atan2(-d, g), this._z = Math.atan2(-r, c)) : (this._y = 0, this._z = Math.atan2(l, n))) : "ZYX" === e ? (this._y = Math.asin(-i(d, -1, 1)), .9999999 > Math.abs(d) ? (this._x = Math.atan2(p, g), this._z = Math.atan2(l, n)) : (this._x = 0, this._z = Math.atan2(-r, c))) : "YZX" === e ? (this._z = Math.asin(i(l, -1, 1)), .9999999 > Math.abs(l) ? (this._x = Math.atan2(-h, c), this._y = Math.atan2(-d, n)) : (this._x = 0, this._y = Math.atan2(s, g))) : "XZY" === e ? (this._z = Math.asin(-i(r, -1, 1)), .9999999 > Math.abs(r) ? (this._x = Math.atan2(p, c), this._y = Math.atan2(s, n)) : (this._x = Math.atan2(-h, g), this._y = 0)) : console.warn("THREE.Euler: .setFromRotationMatrix() given unsupported order: " + e), this._order = e, !1 !== t && this._onChangeCallback(), this }, setFromQuaternion: function (A, e, t) { return b.makeRotationFromQuaternion(A), this.setFromRotationMatrix(b, e, t) }, setFromVector3: function (A, e) { return this.set(A.x, A.y, A.z, e || this._order) }, reorder: function (A) { return U.setFromEuler(this), this.setFromQuaternion(U, A) }, equals: function (A) { return A._x === this._x && A._y === this._y && A._z === this._z && A._order === this._order }, fromArray: function (A) { return this._x = A[0], this._y = A[1], this._z = A[2], void 0 !== A[3] && (this._order = A[3]), this._onChangeCallback(), this }, toArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = this._x, A[e + 1] = this._y, A[e + 2] = this._z, A[e + 3] = this._order, A }, toVector3: function (A) { return A ? A.set(this._x, this._y, this._z) : new y(this._x, this._y, this._z) }, _onChange: function (A) { return this._onChangeCallback = A, this }, _onChangeCallback: function () {} }), Object.assign(K.prototype, { set: function (A) { this.mask = 1 << A | 0 }, enable: function (A) { this.mask |= 1 << A | 0 }, enableAll: function () { this.mask = -1 }, toggle: function (A) { this.mask ^= 1 << A | 0 }, disable: function (A) { this.mask &= ~(1 << A | 0) }, disableAll: function () { this.mask = 0 }, test: function (A) { return 0 != (this.mask & A.mask) } }); var Q = 0, R = new y, T = new f, k = new M, D = new y, L = new y, N = new y, O = new f, V = new y(1, 0, 0), G = new y(0, 1, 0), P = new y(0, 0, 1), q = { type: "added" }, j = { type: "removed" }; function H() { Object.defineProperty(this, "id", { value: Q++ }), this.uuid = a.generateUUID(), this.name = "", this.type = "Object3D", this.parent = null, this.children = [], this.up = H.DefaultUp.clone(); var A = new y, e = new F, t = new f, i = new y(1, 1, 1); e._onChange((function () { t.setFromEuler(e, !1) })), t._onChange((function () { e.setFromQuaternion(t, void 0, !1) })), Object.defineProperties(this, { position: { configurable: !0, enumerable: !0, value: A }, rotation: { configurable: !0, enumerable: !0, value: e }, quaternion: { configurable: !0, enumerable: !0, value: t }, scale: { configurable: !0, enumerable: !0, value: i }, modelViewMatrix: { value: new M }, normalMatrix: { value: new l } }), this.matrix = new M, this.matrixWorld = new M, this.matrixAutoUpdate = H.DefaultMatrixAutoUpdate, this.matrixWorldNeedsUpdate = !1, this.layers = new K, this.visible = !0, this.castShadow = !1, this.receiveShadow = !1, this.frustumCulled = !0, this.renderOrder = 0, this.userData = {} } function Y() { H.call(this), this.type = "Scene", this.background = null, this.environment = null, this.fog = null, this.overrideMaterial = null, this.autoUpdate = !0, "undefined" != typeof __THREE_DEVTOOLS__ && __THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe", { detail: this })) } H.DefaultUp = new y(0, 1, 0), H.DefaultMatrixAutoUpdate = !0, H.prototype = Object.assign(Object.create(i.prototype), { constructor: H, isObject3D: !0, onBeforeRender: function () {}, onAfterRender: function () {}, applyMatrix4: function (A) { this.matrixAutoUpdate && this.updateMatrix(), this.matrix.premultiply(A), this.matrix.decompose(this.position, this.quaternion, this.scale) }, applyQuaternion: function (A) { return this.quaternion.premultiply(A), this }, setRotationFromAxisAngle: function (A, e) { this.quaternion.setFromAxisAngle(A, e) }, setRotationFromEuler: function (A) { this.quaternion.setFromEuler(A, !0) }, setRotationFromMatrix: function (A) { this.quaternion.setFromRotationMatrix(A) }, setRotationFromQuaternion: function (A) { this.quaternion.copy(A) }, rotateOnAxis: function (A, e) { return T.setFromAxisAngle(A, e), this.quaternion.multiply(T), this }, rotateOnWorldAxis: function (A, e) { return T.setFromAxisAngle(A, e), this.quaternion.premultiply(T), this }, rotateX: function (A) { return this.rotateOnAxis(V, A) }, rotateY: function (A) { return this.rotateOnAxis(G, A) }, rotateZ: function (A) { return this.rotateOnAxis(P, A) }, translateOnAxis: function (A, e) { return R.copy(A).applyQuaternion(this.quaternion), this.position.add(R.multiplyScalar(e)), this }, translateX: function (A) { return this.translateOnAxis(V, A) }, translateY: function (A) { return this.translateOnAxis(G, A) }, translateZ: function (A) { return this.translateOnAxis(P, A) }, localToWorld: function (A) { return A.applyMatrix4(this.matrixWorld) }, worldToLocal: function (A) { return A.applyMatrix4(k.getInverse(this.matrixWorld)) }, lookAt: function (A, e, t) { A.isVector3 ? D.copy(A) : D.set(A, e, t); var i = this.parent; this.updateWorldMatrix(!0, !1), L.setFromMatrixPosition(this.matrixWorld), this.isCamera || this.isLight ? k.lookAt(L, D, this.up) : k.lookAt(D, L, this.up), this.quaternion.setFromRotationMatrix(k), i && (k.extractRotation(i.matrixWorld), T.setFromRotationMatrix(k), this.quaternion.premultiply(T.inverse())) }, add: function (A) { if (arguments.length > 1) { for (var e = 0; arguments.length > e; e++) this.add(arguments[e]); return this } return A === this ? (console.error("THREE.Object3D.add: object can't be added as a child of itself.", A), this) : (A && A.isObject3D ? (null !== A.parent && A.parent.remove(A), A.parent = this, this.children.push(A), A.dispatchEvent(q)) : console.error("THREE.Object3D.add: object not an instance of THREE.Object3D.", A), this) }, remove: function (A) { if (arguments.length > 1) { for (var e = 0; arguments.length > e; e++) this.remove(arguments[e]); return this } var t = this.children.indexOf(A); return -1 !== t && (A.parent = null, this.children.splice(t, 1), A.dispatchEvent(j)), this }, attach: function (A) { return this.updateWorldMatrix(!0, !1), k.getInverse(this.matrixWorld), null !== A.parent && (A.parent.updateWorldMatrix(!0, !1), k.multiply(A.parent.matrixWorld)), A.applyMatrix4(k), A.updateWorldMatrix(!1, !1), this.add(A), this }, getObjectById: function (A) { return this.getObjectByProperty("id", A) }, getObjectByName: function (A) { return this.getObjectByProperty("name", A) }, getObjectByProperty: function (A, e) { if (this[A] === e) return this; for (var t = 0, i = this.children.length; i > t; t++) { var o = this.children[t].getObjectByProperty(A, e); if (void 0 !== o) return o } }, getWorldPosition: function (A) { return void 0 === A && (console.warn("THREE.Object3D: .getWorldPosition() target is now required"), A = new y), this.updateMatrixWorld(!0), A.setFromMatrixPosition(this.matrixWorld) }, getWorldQuaternion: function (A) { return void 0 === A && (console.warn("THREE.Object3D: .getWorldQuaternion() target is now required"), A = new f), this.updateMatrixWorld(!0), this.matrixWorld.decompose(L, A, N), A }, getWorldScale: function (A) { return void 0 === A && (console.warn("THREE.Object3D: .getWorldScale() target is now required"), A = new y), this.updateMatrixWorld(!0), this.matrixWorld.decompose(L, O, A), A }, getWorldDirection: function (A) { void 0 === A && (console.warn("THREE.Object3D: .getWorldDirection() target is now required"), A = new y), this.updateMatrixWorld(!0); var e = this.matrixWorld.elements; return A.set(e[8], e[9], e[10]).normalize() }, raycast: function () {}, traverse: function (A) { A(this); for (var e = this.children, t = 0, i = e.length; i > t; t++) e[t].traverse(A) }, traverseVisible: function (A) { if (!1 !== this.visible) { A(this); for (var e = this.children, t = 0, i = e.length; i > t; t++) e[t].traverseVisible(A) } }, traverseAncestors: function (A) { var e = this.parent; null !== e && (A(e), e.traverseAncestors(A)) }, updateMatrix: function () { this.matrix.compose(this.position, this.quaternion, this.scale), this.matrixWorldNeedsUpdate = !0 }, updateMatrixWorld: function (A) { this.matrixAutoUpdate && this.updateMatrix(), (this.matrixWorldNeedsUpdate || A) && (null === this.parent ? this.matrixWorld.copy(this.matrix) : this.matrixWorld.multiplyMatrices(this.parent.matrixWorld, this.matrix), this.matrixWorldNeedsUpdate = !1, A = !0); for (var e = this.children, t = 0, i = e.length; i > t; t++) e[t].updateMatrixWorld(A) }, updateWorldMatrix: function (A, e) { var t = this.parent; if (!0 === A && null !== t && t.updateWorldMatrix(!0, !1), this.matrixAutoUpdate && this.updateMatrix(), null === this.parent ? this.matrixWorld.copy(this.matrix) : this.matrixWorld.multiplyMatrices(this.parent.matrixWorld, this.matrix), !0 === e) for (var i = this.children, o = 0, n = i.length; n > o; o++) i[o].updateWorldMatrix(!1, !0) }, toJSON: function (A) { var e = void 0 === A || "string" == typeof A, t = {}; e && (A = { geometries: {}, materials: {}, textures: {}, images: {}, shapes: {} }, t.metadata = { version: 4.5, type: "Object", generator: "Object3D.toJSON" }); var i = {}; function o(e, t) { return void 0 === e[t.uuid] && (e[t.uuid] = t.toJSON(A)), t.uuid } if (i.uuid = this.uuid, i.type = this.type, "" !== this.name && (i.name = this.name), !0 === this.castShadow && (i.castShadow = !0), !0 === this.receiveShadow && (i.receiveShadow = !0), !1 === this.visible && (i.visible = !1), !1 === this.frustumCulled && (i.frustumCulled = !1), 0 !== this.renderOrder && (i.renderOrder = this.renderOrder), "{}" !== JSON.stringify(this.userData) && (i.userData = this.userData), i.layers = this.layers.mask, i.matrix = this.matrix.toArray(), !1 === this.matrixAutoUpdate && (i.matrixAutoUpdate = !1), this.isInstancedMesh && (i.type = "InstancedMesh", i.count = this.count, i.instanceMatrix = this.instanceMatrix.toJSON()), this.isMesh || this.isLine || this.isPoints) { i.geometry = o(A.geometries, this.geometry); var n = this.geometry.parameters; if (void 0 !== n && void 0 !== n.shapes) { var r = n.shapes; if (Array.isArray(r)) for (var a = 0, s = r.length; s > a; a++) { o(A.shapes, r[a]) } else o(A.shapes, r) } } if (void 0 !== this.material) if (Array.isArray(this.material)) { var l = []; for (a = 0, s = this.material.length; s > a; a++) l.push(o(A.materials, this.material[a])); i.material = l } else i.material = o(A.materials, this.material); if (this.children.length > 0) { i.children = []; for (a = 0; this.children.length > a; a++) i.children.push(this.children[a].toJSON(A).object) } if (e) { var c = g(A.geometries), h = g(A.materials), d = g(A.textures), p = g(A.images); r = g(A.shapes); c.length > 0 && (t.geometries = c), h.length > 0 && (t.materials = h), d.length > 0 && (t.textures = d), p.length > 0 && (t.images = p), r.length > 0 && (t.shapes = r) } return t.object = i, t; function g(A) { var e = []; for (var t in A) { var i = A[t]; delete i.metadata, e.push(i) } return e } }, clone: function (A) { return (new this.constructor).copy(this, A) }, copy: function (A, e) { if (void 0 === e && (e = !0), this.name = A.name, this.up.copy(A.up), this.position.copy(A.position), this.quaternion.copy(A.quaternion), this.scale.copy(A.scale), this.matrix.copy(A.matrix), this.matrixWorld.copy(A.matrixWorld), this.matrixAutoUpdate = A.matrixAutoUpdate, this.matrixWorldNeedsUpdate = A.matrixWorldNeedsUpdate, this.layers.mask = A.layers.mask, this.visible = A.visible, this.castShadow = A.castShadow, this.receiveShadow = A.receiveShadow, this.frustumCulled = A.frustumCulled, this.renderOrder = A.renderOrder, this.userData = JSON.parse(JSON.stringify(A.userData)), !0 === e) for (var t = 0; A.children.length > t; t++) { this.add(A.children[t].clone()) } return this } }), Y.prototype = Object.assign(Object.create(H.prototype), { constructor: Y, isScene: !0, copy: function (A, e) { return H.prototype.copy.call(this, A, e), null !== A.background && (this.background = A.background.clone()), null !== A.environment && (this.environment = A.environment.clone()), null !== A.fog && (this.fog = A.fog.clone()), null !== A.overrideMaterial && (this.overrideMaterial = A.overrideMaterial.clone()), this.autoUpdate = A.autoUpdate, this.matrixAutoUpdate = A.matrixAutoUpdate, this }, toJSON: function (A) { var e = H.prototype.toJSON.call(this, A); return null !== this.background && (e.object.background = this.background.toJSON(A)), null !== this.environment && (e.object.environment = this.environment.toJSON(A)), null !== this.fog && (e.object.fog = this.fog.toJSON()), e }, dispose: function () { this.dispatchEvent({ type: "dispose" }) } }); var W = [new y, new y, new y, new y, new y, new y, new y, new y], J = new y, z = new aA, Z = new y, X = new y, _ = new y, AA = new y, eA = new y, tA = new y, iA = new y, oA = new y, nA = new y, rA = new y; function aA(A, e) { this.min = void 0 !== A ? A : new y(1 / 0, 1 / 0, 1 / 0), this.max = void 0 !== e ? e : new y(-1 / 0, -1 / 0, -1 / 0) } function sA(A, e, t, i, o) { var n, r; for (n = 0, r = A.length - 3; r >= n; n += 3) { rA.fromArray(A, n); var a = o.x * Math.abs(rA.x) + o.y * Math.abs(rA.y) + o.z * Math.abs(rA.z), s = e.dot(rA), l = t.dot(rA), c = i.dot(rA); if (Math.max(-Math.max(s, l, c), Math.min(s, l, c)) > a) return !1 } return !0 } Object.assign(aA.prototype, { isBox3: !0, set: function (A, e) { return this.min.copy(A), this.max.copy(e), this }, setFromArray: function (A) { for (var e = 1 / 0, t = 1 / 0, i = 1 / 0, o = -1 / 0, n = -1 / 0, r = -1 / 0, a = 0, s = A.length; s > a; a += 3) { var l = A[a], c = A[a + 1], h = A[a + 2]; e > l && (e = l), t > c && (t = c), i > h && (i = h), l > o && (o = l), c > n && (n = c), h > r && (r = h) } return this.min.set(e, t, i), this.max.set(o, n, r), this }, setFromBufferAttribute: function (A) { for (var e = 1 / 0, t = 1 / 0, i = 1 / 0, o = -1 / 0, n = -1 / 0, r = -1 / 0, a = 0, s = A.count; s > a; a++) { var l = A.getX(a), c = A.getY(a), h = A.getZ(a); e > l && (e = l), t > c && (t = c), i > h && (i = h), l > o && (o = l), c > n && (n = c), h > r && (r = h) } return this.min.set(e, t, i), this.max.set(o, n, r), this }, setFromPoints: function (A) { this.makeEmpty(); for (var e = 0, t = A.length; t > e; e++) this.expandByPoint(A[e]); return this }, setFromCenterAndSize: function (A, e) { var t = J.copy(e).multiplyScalar(.5); return this.min.copy(A).sub(t), this.max.copy(A).add(t), this }, setFromObject: function (A) { return this.makeEmpty(), this.expandByObject(A) }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.min.copy(A.min), this.max.copy(A.max), this }, makeEmpty: function () { return this.min.x = this.min.y = this.min.z = 1 / 0, this.max.x = this.max.y = this.max.z = -1 / 0, this }, isEmpty: function () { return this.min.x > this.max.x || this.min.y > this.max.y || this.min.z > this.max.z }, getCenter: function (A) { return void 0 === A && (console.warn("THREE.Box3: .getCenter() target is now required"), A = new y), this.isEmpty() ? A.set(0, 0, 0) : A.addVectors(this.min, this.max).multiplyScalar(.5) }, getSize: function (A) { return void 0 === A && (console.warn("THREE.Box3: .getSize() target is now required"), A = new y), this.isEmpty() ? A.set(0, 0, 0) : A.subVectors(this.max, this.min) }, expandByPoint: function (A) { return this.min.min(A), this.max.max(A), this }, expandByVector: function (A) { return this.min.sub(A), this.max.add(A), this }, expandByScalar: function (A) { return this.min.addScalar(-A), this.max.addScalar(A), this }, expandByObject: function (A) { A.updateWorldMatrix(!1, !1); var e = A.geometry; void 0 !== e && (null === e.boundingBox && e.computeBoundingBox(), z.copy(e.boundingBox), z.applyMatrix4(A.matrixWorld), this.union(z)); for (var t = A.children, i = 0, o = t.length; o > i; i++) this.expandByObject(t[i]); return this }, containsPoint: function (A) { return !(this.min.x > A.x || A.x > this.max.x || this.min.y > A.y || A.y > this.max.y || this.min.z > A.z || A.z > this.max.z) }, containsBox: function (A) { return !(this.min.x > A.min.x || A.max.x > this.max.x || this.min.y > A.min.y || A.max.y > this.max.y || this.min.z > A.min.z || A.max.z > this.max.z) }, getParameter: function (A, e) { return void 0 === e && (console.warn("THREE.Box3: .getParameter() target is now required"), e = new y), e.set((A.x - this.min.x) / (this.max.x - this.min.x), (A.y - this.min.y) / (this.max.y - this.min.y), (A.z - this.min.z) / (this.max.z - this.min.z)) }, intersectsBox: function (A) { return !(this.min.x > A.max.x || A.min.x > this.max.x || this.min.y > A.max.y || A.min.y > this.max.y || this.min.z > A.max.z || A.min.z > this.max.z) }, intersectsSphere: function (A) { return this.clampPoint(A.center, J), J.distanceToSquared(A.center) <= A.radius * A.radius }, intersectsPlane: function (A) { var e, t; return A.normal.x > 0 ? (e = A.normal.x * this.min.x, t = A.normal.x * this.max.x) : (e = A.normal.x * this.max.x, t = A.normal.x * this.min.x), A.normal.y > 0 ? (e += A.normal.y * this.min.y, t += A.normal.y * this.max.y) : (e += A.normal.y * this.max.y, t += A.normal.y * this.min.y), A.normal.z > 0 ? (e += A.normal.z * this.min.z, t += A.normal.z * this.max.z) : (e += A.normal.z * this.max.z, t += A.normal.z * this.min.z), -A.constant >= e && t >= -A.constant }, intersectsTriangle: function (A) { if (this.isEmpty()) return !1; this.getCenter(iA), oA.subVectors(this.max, iA), Z.subVectors(A.a, iA), X.subVectors(A.b, iA), _.subVectors(A.c, iA), AA.subVectors(X, Z), eA.subVectors(_, X), tA.subVectors(Z, _); var e = [0, -AA.z, AA.y, 0, -eA.z, eA.y, 0, -tA.z, tA.y, AA.z, 0, -AA.x, eA.z, 0, -eA.x, tA.z, 0, -tA.x, -AA.y, AA.x, 0, -eA.y, eA.x, 0, -tA.y, tA.x, 0]; return !!sA(e, Z, X, _, oA) && (!!sA(e = [1, 0, 0, 0, 1, 0, 0, 0, 1], Z, X, _, oA) && (nA.crossVectors(AA, eA), sA(e = [nA.x, nA.y, nA.z], Z, X, _, oA))) }, clampPoint: function (A, e) { return void 0 === e && (console.warn("THREE.Box3: .clampPoint() target is now required"), e = new y), e.copy(A).clamp(this.min, this.max) }, distanceToPoint: function (A) { return J.copy(A).clamp(this.min, this.max).sub(A).length() }, getBoundingSphere: function (A) { return void 0 === A && console.error("THREE.Box3: .getBoundingSphere() target is now required"), this.getCenter(A.center), A.radius = .5 * this.getSize(J).length(), A }, intersect: function (A) { return this.min.max(A.min), this.max.min(A.max), this.isEmpty() && this.makeEmpty(), this }, union: function (A) { return this.min.min(A.min), this.max.max(A.max), this }, applyMatrix4: function (A) { return this.isEmpty() || (W[0].set(this.min.x, this.min.y, this.min.z).applyMatrix4(A), W[1].set(this.min.x, this.min.y, this.max.z).applyMatrix4(A), W[2].set(this.min.x, this.max.y, this.min.z).applyMatrix4(A), W[3].set(this.min.x, this.max.y, this.max.z).applyMatrix4(A), W[4].set(this.max.x, this.min.y, this.min.z).applyMatrix4(A), W[5].set(this.max.x, this.min.y, this.max.z).applyMatrix4(A), W[6].set(this.max.x, this.max.y, this.min.z).applyMatrix4(A), W[7].set(this.max.x, this.max.y, this.max.z).applyMatrix4(A), this.setFromPoints(W)), this }, translate: function (A) { return this.min.add(A), this.max.add(A), this }, equals: function (A) { return A.min.equals(this.min) && A.max.equals(this.max) } }); var lA = new aA; function cA(A, e) { this.center = void 0 !== A ? A : new y, this.radius = void 0 !== e ? e : 0 } Object.assign(cA.prototype, { set: function (A, e) { return this.center.copy(A), this.radius = e, this }, setFromPoints: function (A, e) { var t = this.center; void 0 !== e ? t.copy(e) : lA.setFromPoints(A).getCenter(t); for (var i = 0, o = 0, n = A.length; n > o; o++) i = Math.max(i, t.distanceToSquared(A[o])); return this.radius = Math.sqrt(i), this }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.center.copy(A.center), this.radius = A.radius, this }, empty: function () { return 0 >= this.radius }, containsPoint: function (A) { return A.distanceToSquared(this.center) <= this.radius * this.radius }, distanceToPoint: function (A) { return A.distanceTo(this.center) - this.radius }, intersectsSphere: function (A) { var e = this.radius + A.radius; return A.center.distanceToSquared(this.center) <= e * e }, intersectsBox: function (A) { return A.intersectsSphere(this) }, intersectsPlane: function (A) { return Math.abs(A.distanceToPoint(this.center)) <= this.radius }, clampPoint: function (A, e) { var t = this.center.distanceToSquared(A); return void 0 === e && (console.warn("THREE.Sphere: .clampPoint() target is now required"), e = new y), e.copy(A), t > this.radius * this.radius && (e.sub(this.center).normalize(), e.multiplyScalar(this.radius).add(this.center)), e }, getBoundingBox: function (A) { return void 0 === A && (console.warn("THREE.Sphere: .getBoundingBox() target is now required"), A = new aA), A.set(this.center, this.center), A.expandByScalar(this.radius), A }, applyMatrix4: function (A) { return this.center.applyMatrix4(A), this.radius = this.radius * A.getMaxScaleOnAxis(), this }, translate: function (A) { return this.center.add(A), this }, equals: function (A) { return A.center.equals(this.center) && A.radius === this.radius } }); var hA = new y, dA = new y, pA = new y, gA = new y, uA = new y, fA = new y, mA = new y; function CA(A, e) { this.origin = void 0 !== A ? A : new y, this.direction = void 0 !== e ? e : new y(0, 0, -1) } Object.assign(CA.prototype, { set: function (A, e) { return this.origin.copy(A), this.direction.copy(e), this }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.origin.copy(A.origin), this.direction.copy(A.direction), this }, at: function (A, e) { return void 0 === e && (console.warn("THREE.Ray: .at() target is now required"), e = new y), e.copy(this.direction).multiplyScalar(A).add(this.origin) }, lookAt: function (A) { return this.direction.copy(A).sub(this.origin).normalize(), this }, recast: function (A) { return this.origin.copy(this.at(A, hA)), this }, closestPointToPoint: function (A, e) { void 0 === e && (console.warn("THREE.Ray: .closestPointToPoint() target is now required"), e = new y), e.subVectors(A, this.origin); var t = e.dot(this.direction); return 0 > t ? e.copy(this.origin) : e.copy(this.direction).multiplyScalar(t).add(this.origin) }, distanceToPoint: function (A) { return Math.sqrt(this.distanceSqToPoint(A)) }, distanceSqToPoint: function (A) { var e = hA.subVectors(A, this.origin).dot(this.direction); return 0 > e ? this.origin.distanceToSquared(A) : (hA.copy(this.direction).multiplyScalar(e).add(this.origin), hA.distanceToSquared(A)) }, distanceSqToSegment: function (A, e, t, i) { dA.copy(A).add(e).multiplyScalar(.5), pA.copy(e).sub(A).normalize(), gA.copy(this.origin).sub(dA); var o, n, r, a, s = .5 * A.distanceTo(e), l = -this.direction.dot(pA), c = gA.dot(this.direction), h = -gA.dot(pA), d = gA.lengthSq(), p = Math.abs(1 - l * l); if (p > 0) if (n = l * c - h, a = s * p, 0 > (o = l * h - c)) n > -a ? n > a ? r = -(o = Math.max(0, -(l * s + c))) * o + (n = o > 0 ? s : Math.min(Math.max(-s, -h), s)) * (n + 2 * h) + d : (o = 0, r = (n = Math.min(Math.max(-s, -h), s)) * (n + 2 * h) + d) : r = -(o = Math.max(0, -(-l * s + c))) * o + (n = o > 0 ? -s : Math.min(Math.max(-s, -h), s)) * (n + 2 * h) + d; else if (n < -a) n = -s, r = -(o = Math.max(0, -(l * n + c))) * o + n * (n + 2 * h) + d; else if (a < n) n = s, r = -(o = Math.max(0, -(l * n + c))) * o + n * (n + 2 * h) + d; else { var g = 1 / p; r = (o *= g) * (o + l * (n *= g) + 2 * c) + n * (l * o + n + 2 * h) + d } else n = l > 0 ? -s : s, r = -(o = Math.max(0, -(l * n + c))) * o + n * (n + 2 * h) + d; return t && t.copy(this.direction).multiplyScalar(o).add(this.origin), i && i.copy(pA).multiplyScalar(n).add(dA), r }, intersectSphere: function (A, e) { hA.subVectors(A.center, this.origin); var t = hA.dot(this.direction), i = hA.dot(hA) - t * t, o = A.radius * A.radius; if (i > o) return null; var n = Math.sqrt(o - i), r = t - n, a = t + n; return 0 > r && 0 > a ? null : this.at(0 > r ? a : r, e) }, intersectsSphere: function (A) { return this.distanceSqToPoint(A.center) <= A.radius * A.radius }, distanceToPlane: function (A) { var e = A.normal.dot(this.direction); if (0 === e) return 0 === A.distanceToPoint(this.origin) ? 0 : null; var t = -(this.origin.dot(A.normal) + A.constant) / e; return 0 > t ? null : t }, intersectPlane: function (A, e) { var t = this.distanceToPlane(A); return null === t ? null : this.at(t, e) }, intersectsPlane: function (A) { var e = A.distanceToPoint(this.origin); return 0 === e || 0 > A.normal.dot(this.direction) * e }, intersectBox: function (A, e) { var t, i, o, n, r, a, s = 1 / this.direction.x, l = 1 / this.direction.y, c = 1 / this.direction.z, h = this.origin; return 0 > s ? (t = (A.max.x - h.x) * s, i = (A.min.x - h.x) * s) : (t = (A.min.x - h.x) * s, i = (A.max.x - h.x) * s), 0 > l ? (o = (A.max.y - h.y) * l, n = (A.min.y - h.y) * l) : (o = (A.min.y - h.y) * l, n = (A.max.y - h.y) * l), t > n || o > i ? null : ((o > t || t != t) && (t = o), (i > n || i != i) && (i = n), 0 > c ? (r = (A.max.z - h.z) * c, a = (A.min.z - h.z) * c) : (r = (A.min.z - h.z) * c, a = (A.max.z - h.z) * c), t > a || r > i ? null : ((r > t || t != t) && (t = r), (i > a || i != i) && (i = a), 0 > i ? null : this.at(0 > t ? i : t, e))) }, intersectsBox: function (A) { return null !== this.intersectBox(A, hA) }, intersectTriangle: function (A, e, t, i, o) { uA.subVectors(e, A), fA.subVectors(t, A), mA.crossVectors(uA, fA); var n, r = this.direction.dot(mA); if (r > 0) { if (i) return null; n = 1 } else { if (r >= 0) return null; n = -1, r = -r } gA.subVectors(this.origin, A); var a = n * this.direction.dot(fA.crossVectors(gA, fA)); if (0 > a) return null; var s = n * this.direction.dot(uA.cross(gA)); if (0 > s) return null; if (a + s > r) return null; var l = -n * gA.dot(mA); return 0 > l ? null : this.at(l / r, o) }, applyMatrix4: function (A) { return this.origin.applyMatrix4(A), this.direction.transformDirection(A), this }, equals: function (A) { return A.origin.equals(this.origin) && A.direction.equals(this.direction) } }); var yA = new y, vA = new y, IA = new l; function EA(A, e) { this.normal = void 0 !== A ? A : new y(1, 0, 0), this.constant = void 0 !== e ? e : 0 } Object.assign(EA.prototype, { isPlane: !0, set: function (A, e) { return this.normal.copy(A), this.constant = e, this }, setComponents: function (A, e, t, i) { return this.normal.set(A, e, t), this.constant = i, this }, setFromNormalAndCoplanarPoint: function (A, e) { return this.normal.copy(A), this.constant = -e.dot(this.normal), this }, setFromCoplanarPoints: function (A, e, t) { var i = yA.subVectors(t, e).cross(vA.subVectors(A, e)).normalize(); return this.setFromNormalAndCoplanarPoint(i, A), this }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.normal.copy(A.normal), this.constant = A.constant, this }, normalize: function () { var A = 1 / this.normal.length(); return this.normal.multiplyScalar(A), this.constant *= A, this }, negate: function () { return this.constant *= -1, this.normal.negate(), this }, distanceToPoint: function (A) { return this.normal.dot(A) + this.constant }, distanceToSphere: function (A) { return this.distanceToPoint(A.center) - A.radius }, projectPoint: function (A, e) { return void 0 === e && (console.warn("THREE.Plane: .projectPoint() target is now required"), e = new y), e.copy(this.normal).multiplyScalar(-this.distanceToPoint(A)).add(A) }, intersectLine: function (A, e) { void 0 === e && (console.warn("THREE.Plane: .intersectLine() target is now required"), e = new y); var t = A.delta(yA), i = this.normal.dot(t); if (0 === i) return 0 === this.distanceToPoint(A.start) ? e.copy(A.start) : void 0; var o = -(A.start.dot(this.normal) + this.constant) / i; return 0 > o || o > 1 ? void 0 : e.copy(t).multiplyScalar(o).add(A.start) }, intersectsLine: function (A) { var e = this.distanceToPoint(A.start), t = this.distanceToPoint(A.end); return 0 > e && t > 0 || 0 > t && e > 0 }, intersectsBox: function (A) { return A.intersectsPlane(this) }, intersectsSphere: function (A) { return A.intersectsPlane(this) }, coplanarPoint: function (A) { return void 0 === A && (console.warn("THREE.Plane: .coplanarPoint() target is now required"), A = new y), A.copy(this.normal).multiplyScalar(-this.constant) }, applyMatrix4: function (A, e) { var t = e || IA.getNormalMatrix(A), i = this.coplanarPoint(yA).applyMatrix4(A), o = this.normal.applyMatrix3(t).normalize(); return this.constant = -i.dot(o), this }, translate: function (A) { return this.constant -= A.dot(this.normal), this }, equals: function (A) { return A.normal.equals(this.normal) && A.constant === this.constant } }); var BA = new y, xA = new y, SA = new y, wA = new y, MA = new y, bA = new y, UA = new y, FA = new y, KA = new y, QA = new y; function RA(A, e, t) { this.a = void 0 !== A ? A : new y, this.b = void 0 !== e ? e : new y, this.c = void 0 !== t ? t : new y } Object.assign(RA, { getNormal: function (A, e, t, i) { void 0 === i && (console.warn("THREE.Triangle: .getNormal() target is now required"), i = new y), i.subVectors(t, e), BA.subVectors(A, e), i.cross(BA); var o = i.lengthSq(); return o > 0 ? i.multiplyScalar(1 / Math.sqrt(o)) : i.set(0, 0, 0) }, getBarycoord: function (A, e, t, i, o) { BA.subVectors(i, e), xA.subVectors(t, e), SA.subVectors(A, e); var n = BA.dot(BA), r = BA.dot(xA), a = BA.dot(SA), s = xA.dot(xA), l = xA.dot(SA), c = n * s - r * r; if (void 0 === o && (console.warn("THREE.Triangle: .getBarycoord() target is now required"), o = new y), 0 === c) return o.set(-2, -1, -1); var h = 1 / c, d = (s * a - r * l) * h, p = (n * l - r * a) * h; return o.set(1 - d - p, p, d) }, containsPoint: function (A, e, t, i) { return RA.getBarycoord(A, e, t, i, wA), wA.x >= 0 && wA.y >= 0 && 1 >= wA.x + wA.y }, getUV: function (A, e, t, i, o, n, r, a) { return this.getBarycoord(A, e, t, i, wA), a.set(0, 0), a.addScaledVector(o, wA.x), a.addScaledVector(n, wA.y), a.addScaledVector(r, wA.z), a }, isFrontFacing: function (A, e, t, i) { return BA.subVectors(t, e), xA.subVectors(A, e), 0 > BA.cross(xA).dot(i) } }), Object.assign(RA.prototype, { set: function (A, e, t) { return this.a.copy(A), this.b.copy(e), this.c.copy(t), this }, setFromPointsAndIndices: function (A, e, t, i) { return this.a.copy(A[e]), this.b.copy(A[t]), this.c.copy(A[i]), this }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.a.copy(A.a), this.b.copy(A.b), this.c.copy(A.c), this }, getArea: function () { return BA.subVectors(this.c, this.b), xA.subVectors(this.a, this.b), .5 * BA.cross(xA).length() }, getMidpoint: function (A) { return void 0 === A && (console.warn("THREE.Triangle: .getMidpoint() target is now required"), A = new y), A.addVectors(this.a, this.b).add(this.c).multiplyScalar(1 / 3) }, getNormal: function (A) { return RA.getNormal(this.a, this.b, this.c, A) }, getPlane: function (A) { return void 0 === A && (console.warn("THREE.Triangle: .getPlane() target is now required"), A = new EA), A.setFromCoplanarPoints(this.a, this.b, this.c) }, getBarycoord: function (A, e) { return RA.getBarycoord(A, this.a, this.b, this.c, e) }, getUV: function (A, e, t, i, o) { return RA.getUV(A, this.a, this.b, this.c, e, t, i, o) }, containsPoint: function (A) { return RA.containsPoint(A, this.a, this.b, this.c) }, isFrontFacing: function (A) { return RA.isFrontFacing(this.a, this.b, this.c, A) }, intersectsBox: function (A) { return A.intersectsTriangle(this) }, closestPointToPoint: function (A, e) { void 0 === e && (console.warn("THREE.Triangle: .closestPointToPoint() target is now required"), e = new y); var t, i, o = this.a, n = this.b, r = this.c; MA.subVectors(n, o), bA.subVectors(r, o), FA.subVectors(A, o); var a = MA.dot(FA), s = bA.dot(FA); if (0 >= a && 0 >= s) return e.copy(o); KA.subVectors(A, n); var l = MA.dot(KA), c = bA.dot(KA); if (l >= 0 && l >= c) return e.copy(n); var h = a * c - l * s; if (0 >= h && a >= 0 && 0 >= l) return t = a / (a - l), e.copy(o).addScaledVector(MA, t); QA.subVectors(A, r); var d = MA.dot(QA), p = bA.dot(QA); if (p >= 0 && p >= d) return e.copy(r); var g = d * s - a * p; if (0 >= g && s >= 0 && 0 >= p) return i = s / (s - p), e.copy(o).addScaledVector(bA, i); var u = l * p - d * c; if (0 >= u && c - l >= 0 && d - p >= 0) return UA.subVectors(r, n), i = (c - l) / (c - l + (d - p)), e.copy(n).addScaledVector(UA, i); var f = 1 / (u + g + h); return t = g * f, i = h * f, e.copy(o).addScaledVector(MA, t).addScaledVector(bA, i) }, equals: function (A) { return A.a.equals(this.a) && A.b.equals(this.b) && A.c.equals(this.c) } }); var TA = { aliceblue: 15792383, antiquewhite: 16444375, aqua: 65535, aquamarine: 8388564, azure: 15794175, beige: 16119260, bisque: 16770244, black: 0, blanchedalmond: 16772045, blue: 255, blueviolet: 9055202, brown: 10824234, burlywood: 14596231, cadetblue: 6266528, chartreuse: 8388352, chocolate: 13789470, coral: 16744272, cornflowerblue: 6591981, cornsilk: 16775388, crimson: 14423100, cyan: 65535, darkblue: 139, darkcyan: 35723, darkgoldenrod: 12092939, darkgray: 11119017, darkgreen: 25600, darkgrey: 11119017, darkkhaki: 12433259, darkmagenta: 9109643, darkolivegreen: 5597999, darkorange: 16747520, darkorchid: 10040012, darkred: 9109504, darksalmon: 15308410, darkseagreen: 9419919, darkslateblue: 4734347, darkslategray: 3100495, darkslategrey: 3100495, darkturquoise: 52945, darkviolet: 9699539, deeppink: 16716947, deepskyblue: 49151, dimgray: 6908265, dimgrey: 6908265, dodgerblue: 2003199, firebrick: 11674146, floralwhite: 16775920, forestgreen: 2263842, fuchsia: 16711935, gainsboro: 14474460, ghostwhite: 16316671, gold: 16766720, goldenrod: 14329120, gray: 8421504, green: 32768, greenyellow: 11403055, grey: 8421504, honeydew: 15794160, hotpink: 16738740, indianred: 13458524, indigo: 4915330, ivory: 16777200, khaki: 15787660, lavender: 15132410, lavenderblush: 16773365, lawngreen: 8190976, lemonchiffon: 16775885, lightblue: 11393254, lightcoral: 15761536, lightcyan: 14745599, lightgoldenrodyellow: 16448210, lightgray: 13882323, lightgreen: 9498256, lightgrey: 13882323, lightpink: 16758465, lightsalmon: 16752762, lightseagreen: 2142890, lightskyblue: 8900346, lightslategray: 7833753, lightslategrey: 7833753, lightsteelblue: 11584734, lightyellow: 16777184, lime: 65280, limegreen: 3329330, linen: 16445670, magenta: 16711935, maroon: 8388608, mediumaquamarine: 6737322, mediumblue: 205, mediumorchid: 12211667, mediumpurple: 9662683, mediumseagreen: 3978097, mediumslateblue: 8087790, mediumspringgreen: 64154, mediumturquoise: 4772300, mediumvioletred: 13047173, midnightblue: 1644912, mintcream: 16121850, mistyrose: 16770273, moccasin: 16770229, navajowhite: 16768685, navy: 128, oldlace: 16643558, olive: 8421376, olivedrab: 7048739, orange: 16753920, orangered: 16729344, orchid: 14315734, palegoldenrod: 15657130, palegreen: 10025880, paleturquoise: 11529966, palevioletred: 14381203, papayawhip: 16773077, peachpuff: 16767673, peru: 13468991, pink: 16761035, plum: 14524637, powderblue: 11591910, purple: 8388736, rebeccapurple: 6697881, red: 16711680, rosybrown: 12357519, royalblue: 4286945, saddlebrown: 9127187, salmon: 16416882, sandybrown: 16032864, seagreen: 3050327, seashell: 16774638, sienna: 10506797, silver: 12632256, skyblue: 8900331, slateblue: 6970061, slategray: 7372944, slategrey: 7372944, snow: 16775930, springgreen: 65407, steelblue: 4620980, tan: 13808780, teal: 32896, thistle: 14204888, tomato: 16737095, turquoise: 4251856, violet: 15631086, wheat: 16113331, white: 16777215, whitesmoke: 16119285, yellow: 16776960, yellowgreen: 10145074 }, kA = { h: 0, s: 0, l: 0 }, DA = { h: 0, s: 0, l: 0 }; function LA(A, e, t) { return void 0 === e && void 0 === t ? this.set(A) : this.setRGB(A, e, t) } function NA(A, e, t) { return 0 > t && (t += 1), t > 1 && (t -= 1), 1 / 6 > t ? A + 6 * (e - A) * t : .5 > t ? e : 2 / 3 > t ? A + 6 * (e - A) * (2 / 3 - t) : A } function OA(A) { return .04045 > A ? .0773993808 * A : Math.pow(.9478672986 * A + .0521327014, 2.4) } function VA(A) { return .0031308 > A ? 12.92 * A : 1.055 * Math.pow(A, .41666) - .055 } function GA(A, e, t, i, o, n) { this.a = A, this.b = e, this.c = t, this.normal = i && i.isVector3 ? i : new y, this.vertexNormals = Array.isArray(i) ? i : [], this.color = o && o.isColor ? o : new LA, this.vertexColors = Array.isArray(o) ? o : [], this.materialIndex = void 0 !== n ? n : 0 } Object.assign(LA.prototype, { isColor: !0, r: 1, g: 1, b: 1, set: function (A) { return A && A.isColor ? this.copy(A) : "number" == typeof A ? this.setHex(A) : "string" == typeof A && this.setStyle(A), this }, setScalar: function (A) { return this.r = A, this.g = A, this.b = A, this }, setHex: function (A) { return A = Math.floor(A), this.r = (A >> 16 & 255) / 255, this.g = (A >> 8 & 255) / 255, this.b = (255 & A) / 255, this }, setRGB: function (A, e, t) { return this.r = A, this.g = e, this.b = t, this }, setHSL: function (A, e, t) { if (A = a.euclideanModulo(A, 1), e = a.clamp(e, 0, 1), t = a.clamp(t, 0, 1), 0 === e) this.r = this.g = this.b = t; else { var i = t > .5 ? t + e - t * e : t * (1 + e), o = 2 * t - i; this.r = NA(o, i, A + 1 / 3), this.g = NA(o, i, A), this.b = NA(o, i, A - 1 / 3) } return this }, setStyle: function (A) { function e(e) { void 0 !== e && 1 > parseFloat(e) && console.warn("THREE.Color: Alpha component of " + A + " will be ignored.") } var t; if (t = /^((?:rgb|hsl)a?)\(\s*([^\)]*)\)/.exec(A)) { var i, o = t[2]; switch (t[1]) { case "rgb": case "rgba": if (i = /^(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(o)) return this.r = Math.min(255, parseInt(i[1], 10)) / 255, this.g = Math.min(255, parseInt(i[2], 10)) / 255, this.b = Math.min(255, parseInt(i[3], 10)) / 255, e(i[5]), this; if (i = /^(\d+)\%\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(o)) return this.r = Math.min(100, parseInt(i[1], 10)) / 100, this.g = Math.min(100, parseInt(i[2], 10)) / 100, this.b = Math.min(100, parseInt(i[3], 10)) / 100, e(i[5]), this; break; case "hsl": case "hsla": if (i = /^([0-9]*\.?[0-9]+)\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(o)) { var n = parseFloat(i[1]) / 360, r = parseInt(i[2], 10) / 100, a = parseInt(i[3], 10) / 100; return e(i[5]), this.setHSL(n, r, a) } } } else if (t = /^\#([A-Fa-f0-9]+)$/.exec(A)) { var s = t[1], l = s.length; if (3 === l) return this.r = parseInt(s.charAt(0) + s.charAt(0), 16) / 255, this.g = parseInt(s.charAt(1) + s.charAt(1), 16) / 255, this.b = parseInt(s.charAt(2) + s.charAt(2), 16) / 255, this; if (6 === l) return this.r = parseInt(s.charAt(0) + s.charAt(1), 16) / 255, this.g = parseInt(s.charAt(2) + s.charAt(3), 16) / 255, this.b = parseInt(s.charAt(4) + s.charAt(5), 16) / 255, this } return A && A.length > 0 ? this.setColorName(A) : this }, setColorName: function (A) { var e = TA[A]; return void 0 !== e ? this.setHex(e) : console.warn("THREE.Color: Unknown color " + A), this }, clone: function () { return new this.constructor(this.r, this.g, this.b) }, copy: function (A) { return this.r = A.r, this.g = A.g, this.b = A.b, this }, copyGammaToLinear: function (A, e) { return void 0 === e && (e = 2), this.r = Math.pow(A.r, e), this.g = Math.pow(A.g, e), this.b = Math.pow(A.b, e), this }, copyLinearToGamma: function (A, e) { void 0 === e && (e = 2); var t = e > 0 ? 1 / e : 1; return this.r = Math.pow(A.r, t), this.g = Math.pow(A.g, t), this.b = Math.pow(A.b, t), this }, convertGammaToLinear: function (A) { return this.copyGammaToLinear(this, A), this }, convertLinearToGamma: function (A) { return this.copyLinearToGamma(this, A), this }, copySRGBToLinear: function (A) { return this.r = OA(A.r), this.g = OA(A.g), this.b = OA(A.b), this }, copyLinearToSRGB: function (A) { return this.r = VA(A.r), this.g = VA(A.g), this.b = VA(A.b), this }, convertSRGBToLinear: function () { return this.copySRGBToLinear(this), this }, convertLinearToSRGB: function () { return this.copyLinearToSRGB(this), this }, getHex: function () { return 255 * this.r << 16 ^ 255 * this.g << 8 ^ 255 * this.b << 0 }, getHexString: function () { return ("000000" + this.getHex().toString(16)).slice(-6) }, getHSL: function (A) { void 0 === A && (console.warn("THREE.Color: .getHSL() target is now required"), A = { h: 0, s: 0, l: 0 }); var e, t, i = this.r, o = this.g, n = this.b, r = Math.max(i, o, n), a = Math.min(i, o, n), s = (a + r) / 2; if (a === r) e = 0, t = 0; else { var l = r - a; switch (t = s > .5 ? l / (2 - r - a) : l / (r + a), r) { case i: e = (o - n) / l + (n > o ? 6 : 0); break; case o: e = (n - i) / l + 2; break; case n: e = (i - o) / l + 4 } e /= 6 } return A.h = e, A.s = t, A.l = s, A }, getStyle: function () { return "rgb(" + (255 * this.r | 0) + "," + (255 * this.g | 0) + "," + (255 * this.b | 0) + ")" }, offsetHSL: function (A, e, t) { return this.getHSL(kA), kA.h += A, kA.s += e, kA.l += t, this.setHSL(kA.h, kA.s, kA.l), this }, add: function (A) { return this.r += A.r, this.g += A.g, this.b += A.b, this }, addColors: function (A, e) { return this.r = A.r + e.r, this.g = A.g + e.g, this.b = A.b + e.b, this }, addScalar: function (A) { return this.r += A, this.g += A, this.b += A, this }, sub: function (A) { return this.r = Math.max(0, this.r - A.r), this.g = Math.max(0, this.g - A.g), this.b = Math.max(0, this.b - A.b), this }, multiply: function (A) { return this.r *= A.r, this.g *= A.g, this.b *= A.b, this }, multiplyScalar: function (A) { return this.r *= A, this.g *= A, this.b *= A, this }, lerp: function (A, e) { return this.r += (A.r - this.r) * e, this.g += (A.g - this.g) * e, this.b += (A.b - this.b) * e, this }, lerpHSL: function (A, e) { this.getHSL(kA), A.getHSL(DA); var t = a.lerp(kA.h, DA.h, e), i = a.lerp(kA.s, DA.s, e), o = a.lerp(kA.l, DA.l, e); return this.setHSL(t, i, o), this }, equals: function (A) { return A.r === this.r && A.g === this.g && A.b === this.b }, fromArray: function (A, e) { return void 0 === e && (e = 0), this.r = A[e], this.g = A[e + 1], this.b = A[e + 2], this }, toArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = this.r, A[e + 1] = this.g, A[e + 2] = this.b, A }, toJSON: function () { return this.getHex() } }), LA.NAMES = TA, Object.assign(GA.prototype, { clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { this.a = A.a, this.b = A.b, this.c = A.c, this.normal.copy(A.normal), this.color.copy(A.color), this.materialIndex = A.materialIndex; for (var e = 0, t = A.vertexNormals.length; t > e; e++) this.vertexNormals[e] = A.vertexNormals[e].clone(); for (e = 0, t = A.vertexColors.length; t > e; e++) this.vertexColors[e] = A.vertexColors[e].clone(); return this } }); var PA = 0; function qA() { Object.defineProperty(this, "id", { value: PA++ }), this.uuid = a.generateUUID(), this.name = "", this.type = "Material", this.fog = !0, this.blending = 1, this.side = 0, this.flatShading = !1, this.vertexColors = !1, this.opacity = 1, this.transparent = !1, this.blendSrc = 204, this.blendDst = 205, this.blendEquation = 100, this.blendSrcAlpha = null, this.blendDstAlpha = null, this.blendEquationAlpha = null, this.depthFunc = 3, this.depthTest = !0, this.depthWrite = !0, this.stencilWriteMask = 255, this.stencilFunc = 519, this.stencilRef = 0, this.stencilFuncMask = 255, this.stencilFail = 7680, this.stencilZFail = 7680, this.stencilZPass = 7680, this.stencilWrite = !1, this.clippingPlanes = null, this.clipIntersection = !1, this.clipShadows = !1, this.shadowSide = null, this.colorWrite = !0, this.precision = null, this.polygonOffset = !1, this.polygonOffsetFactor = 0, this.polygonOffsetUnits = 0, this.dithering = !1, this.alphaTest = 0, this.premultipliedAlpha = !1, this.visible = !0, this.toneMapped = !0, this.userData = {}, this.version = 0 } function jA(A) { qA.call(this), this.type = "MeshBasicMaterial", this.color = new LA(16777215), this.map = null, this.lightMap = null, this.lightMapIntensity = 1, this.aoMap = null, this.aoMapIntensity = 1, this.specularMap = null, this.alphaMap = null, this.envMap = null, this.combine = 0, this.reflectivity = 1, this.refractionRatio = .98, this.wireframe = !1, this.wireframeLinewidth = 1, this.wireframeLinecap = "round", this.wireframeLinejoin = "round", this.skinning = !1, this.morphTargets = !1, this.setValues(A) } qA.prototype = Object.assign(Object.create(i.prototype), { constructor: qA, isMaterial: !0, onBeforeCompile: function () {}, setValues: function (A) { if (void 0 !== A) for (var e in A) { var t = A[e]; if (void 0 !== t) if ("shading" !== e) { var i = this[e]; void 0 !== i ? i && i.isColor ? i.set(t) : i && i.isVector3 && t && t.isVector3 ? i.copy(t) : this[e] = t : console.warn("THREE." + this.type + ": '" + e + "' is not a property of this material.") } else console.warn("THREE." + this.type + ": .shading has been removed. Use the boolean .flatShading instead."), this.flatShading = 1 === t; else console.warn("THREE.Material: '" + e + "' parameter is undefined.") } }, toJSON: function (A) { var e = void 0 === A || "string" == typeof A; e && (A = { textures: {}, images: {} }); var t = { metadata: { version: 4.5, type: "Material", generator: "Material.toJSON" } }; function i(A) { var e = []; for (var t in A) { var i = A[t]; delete i.metadata, e.push(i) } return e } if (t.uuid = this.uuid, t.type = this.type, "" !== this.name && (t.name = this.name), this.color && this.color.isColor && (t.color = this.color.getHex()), void 0 !== this.roughness && (t.roughness = this.roughness), void 0 !== this.metalness && (t.metalness = this.metalness), this.sheen && this.sheen.isColor && (t.sheen = this.sheen.getHex()), this.emissive && this.emissive.isColor && (t.emissive = this.emissive.getHex()), this.emissiveIntensity && 1 !== this.emissiveIntensity && (t.emissiveIntensity = this.emissiveIntensity), this.specular && this.specular.isColor && (t.specular = this.specular.getHex()), void 0 !== this.shininess && (t.shininess = this.shininess), void 0 !== this.clearcoat && (t.clearcoat = this.clearcoat), void 0 !== this.clearcoatRoughness && (t.clearcoatRoughness = this.clearcoatRoughness), this.clearcoatMap && this.clearcoatMap.isTexture && (t.clearcoatMap = this.clearcoatMap.toJSON(A).uuid), this.clearcoatRoughnessMap && this.clearcoatRoughnessMap.isTexture && (t.clearcoatRoughnessMap = this.clearcoatRoughnessMap.toJSON(A).uuid), this.clearcoatNormalMap && this.clearcoatNormalMap.isTexture && (t.clearcoatNormalMap = this.clearcoatNormalMap.toJSON(A).uuid, t.clearcoatNormalScale = this.clearcoatNormalScale.toArray()), this.map && this.map.isTexture && (t.map = this.map.toJSON(A).uuid), this.matcap && this.matcap.isTexture && (t.matcap = this.matcap.toJSON(A).uuid), this.alphaMap && this.alphaMap.isTexture && (t.alphaMap = this.alphaMap.toJSON(A).uuid), this.lightMap && this.lightMap.isTexture && (t.lightMap = this.lightMap.toJSON(A).uuid), this.aoMap && this.aoMap.isTexture && (t.aoMap = this.aoMap.toJSON(A).uuid, t.aoMapIntensity = this.aoMapIntensity), this.bumpMap && this.bumpMap.isTexture && (t.bumpMap = this.bumpMap.toJSON(A).uuid, t.bumpScale = this.bumpScale), this.normalMap && this.normalMap.isTexture && (t.normalMap = this.normalMap.toJSON(A).uuid, t.normalMapType = this.normalMapType, t.normalScale = this.normalScale.toArray()), this.displacementMap && this.displacementMap.isTexture && (t.displacementMap = this.displacementMap.toJSON(A).uuid, t.displacementScale = this.displacementScale, t.displacementBias = this.displacementBias), this.roughnessMap && this.roughnessMap.isTexture && (t.roughnessMap = this.roughnessMap.toJSON(A).uuid), this.metalnessMap && this.metalnessMap.isTexture && (t.metalnessMap = this.metalnessMap.toJSON(A).uuid), this.emissiveMap && this.emissiveMap.isTexture && (t.emissiveMap = this.emissiveMap.toJSON(A).uuid), this.specularMap && this.specularMap.isTexture && (t.specularMap = this.specularMap.toJSON(A).uuid), this.envMap && this.envMap.isTexture && (t.envMap = this.envMap.toJSON(A).uuid, t.reflectivity = this.reflectivity, t.refractionRatio = this.refractionRatio, void 0 !== this.combine && (t.combine = this.combine), void 0 !== this.envMapIntensity && (t.envMapIntensity = this.envMapIntensity)), this.gradientMap && this.gradientMap.isTexture && (t.gradientMap = this.gradientMap.toJSON(A).uuid), void 0 !== this.size && (t.size = this.size), void 0 !== this.sizeAttenuation && (t.sizeAttenuation = this.sizeAttenuation), 1 !== this.blending && (t.blending = this.blending), !0 === this.flatShading && (t.flatShading = this.flatShading), 0 !== this.side && (t.side = this.side), this.vertexColors && (t.vertexColors = !0), 1 > this.opacity && (t.opacity = this.opacity), !0 === this.transparent && (t.transparent = this.transparent), t.depthFunc = this.depthFunc, t.depthTest = this.depthTest, t.depthWrite = this.depthWrite, t.stencilWrite = this.stencilWrite, t.stencilWriteMask = this.stencilWriteMask, t.stencilFunc = this.stencilFunc, t.stencilRef = this.stencilRef, t.stencilFuncMask = this.stencilFuncMask, t.stencilFail = this.stencilFail, t.stencilZFail = this.stencilZFail, t.stencilZPass = this.stencilZPass, this.rotation && 0 !== this.rotation && (t.rotation = this.rotation), !0 === this.polygonOffset && (t.polygonOffset = !0), 0 !== this.polygonOffsetFactor && (t.polygonOffsetFactor = this.polygonOffsetFactor), 0 !== this.polygonOffsetUnits && (t.polygonOffsetUnits = this.polygonOffsetUnits), this.linewidth && 1 !== this.linewidth && (t.linewidth = this.linewidth), void 0 !== this.dashSize && (t.dashSize = this.dashSize), void 0 !== this.gapSize && (t.gapSize = this.gapSize), void 0 !== this.scale && (t.scale = this.scale), !0 === this.dithering && (t.dithering = !0), this.alphaTest > 0 && (t.alphaTest = this.alphaTest), !0 === this.premultipliedAlpha && (t.premultipliedAlpha = this.premultipliedAlpha), !0 === this.wireframe && (t.wireframe = this.wireframe), this.wireframeLinewidth > 1 && (t.wireframeLinewidth = this.wireframeLinewidth), "round" !== this.wireframeLinecap && (t.wireframeLinecap = this.wireframeLinecap), "round" !== this.wireframeLinejoin && (t.wireframeLinejoin = this.wireframeLinejoin), !0 === this.morphTargets && (t.morphTargets = !0), !0 === this.morphNormals && (t.morphNormals = !0), !0 === this.skinning && (t.skinning = !0), !1 === this.visible && (t.visible = !1), !1 === this.toneMapped && (t.toneMapped = !1), "{}" !== JSON.stringify(this.userData) && (t.userData = this.userData), e) { var o = i(A.textures), n = i(A.images); o.length > 0 && (t.textures = o), n.length > 0 && (t.images = n) } return t }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { this.name = A.name, this.fog = A.fog, this.blending = A.blending, this.side = A.side, this.flatShading = A.flatShading, this.vertexColors = A.vertexColors, this.opacity = A.opacity, this.transparent = A.transparent, this.blendSrc = A.blendSrc, this.blendDst = A.blendDst, this.blendEquation = A.blendEquation, this.blendSrcAlpha = A.blendSrcAlpha, this.blendDstAlpha = A.blendDstAlpha, this.blendEquationAlpha = A.blendEquationAlpha, this.depthFunc = A.depthFunc, this.depthTest = A.depthTest, this.depthWrite = A.depthWrite, this.stencilWriteMask = A.stencilWriteMask, this.stencilFunc = A.stencilFunc, this.stencilRef = A.stencilRef, this.stencilFuncMask = A.stencilFuncMask, this.stencilFail = A.stencilFail, this.stencilZFail = A.stencilZFail, this.stencilZPass = A.stencilZPass, this.stencilWrite = A.stencilWrite; var e = A.clippingPlanes, t = null; if (null !== e) { var i = e.length; t = new Array(i); for (var o = 0; o !== i; ++o) t[o] = e[o].clone() } return this.clippingPlanes = t, this.clipIntersection = A.clipIntersection, this.clipShadows = A.clipShadows, this.shadowSide = A.shadowSide, this.colorWrite = A.colorWrite, this.precision = A.precision, this.polygonOffset = A.polygonOffset, this.polygonOffsetFactor = A.polygonOffsetFactor, this.polygonOffsetUnits = A.polygonOffsetUnits, this.dithering = A.dithering, this.alphaTest = A.alphaTest, this.premultipliedAlpha = A.premultipliedAlpha, this.visible = A.visible, this.toneMapped = A.toneMapped, this.userData = JSON.parse(JSON.stringify(A.userData)), this }, dispose: function () { this.dispatchEvent({ type: "dispose" }) } }), Object.defineProperty(qA.prototype, "needsUpdate", { set: function (A) { !0 === A && this.version++ } }), (jA.prototype = Object.create(qA.prototype)).constructor = jA, jA.prototype.isMeshBasicMaterial = !0, jA.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.color.copy(A.color), this.map = A.map, this.lightMap = A.lightMap, this.lightMapIntensity = A.lightMapIntensity, this.aoMap = A.aoMap, this.aoMapIntensity = A.aoMapIntensity, this.specularMap = A.specularMap, this.alphaMap = A.alphaMap, this.envMap = A.envMap, this.combine = A.combine, this.reflectivity = A.reflectivity, this.refractionRatio = A.refractionRatio, this.wireframe = A.wireframe, this.wireframeLinewidth = A.wireframeLinewidth, this.wireframeLinecap = A.wireframeLinecap, this.wireframeLinejoin = A.wireframeLinejoin, this.skinning = A.skinning, this.morphTargets = A.morphTargets, this }; var HA = new y; function YA(A, e, t) { if (Array.isArray(A)) throw new TypeError("THREE.BufferAttribute: array should be a Typed Array."); this.name = "", this.array = A, this.itemSize = e, this.count = void 0 !== A ? A.length / e : 0, this.normalized = !0 === t, this.usage = 35044, this.updateRange = { offset: 0, count: -1 }, this.version = 0 } function WA(A, e, t) { YA.call(this, new Int8Array(A), e, t) } function JA(A, e, t) { YA.call(this, new Uint8Array(A), e, t) } function zA(A, e, t) { YA.call(this, new Uint8ClampedArray(A), e, t) } function ZA(A, e, t) { YA.call(this, new Int16Array(A), e, t) } function XA(A, e, t) { YA.call(this, new Uint16Array(A), e, t) } function _A(A, e, t) { YA.call(this, new Int32Array(A), e, t) } function $A(A, e, t) { YA.call(this, new Uint32Array(A), e, t) } function Ae(A, e, t) { YA.call(this, new Float32Array(A), e, t) } function ee(A, e, t) { YA.call(this, new Float64Array(A), e, t) } function te() { this.vertices = [], this.normals = [], this.colors = [], this.uvs = [], this.uvs2 = [], this.groups = [], this.morphTargets = {}, this.skinWeights = [], this.skinIndices = [], this.boundingBox = null, this.boundingSphere = null, this.verticesNeedUpdate = !1, this.normalsNeedUpdate = !1, this.colorsNeedUpdate = !1, this.uvsNeedUpdate = !1, this.groupsNeedUpdate = !1 } function ie(A) { if (0 === A.length) return -1 / 0; for (var e = A[0], t = 1, i = A.length; i > t; ++t) A[t] > e && (e = A[t]); return e } Object.defineProperty(YA.prototype, "needsUpdate", { set: function (A) { !0 === A && this.version++ } }), Object.assign(YA.prototype, { isBufferAttribute: !0, onUploadCallback: function () {}, setUsage: function (A) { return this.usage = A, this }, copy: function (A) { return this.name = A.name, this.array = new A.array.constructor(A.array), this.itemSize = A.itemSize, this.count = A.count, this.normalized = A.normalized, this.usage = A.usage, this }, copyAt: function (A, e, t) { A *= this.itemSize, t *= e.itemSize; for (var i = 0, o = this.itemSize; o > i; i++) this.array[A + i] = e.array[t + i]; return this }, copyArray: function (A) { return this.array.set(A), this }, copyColorsArray: function (A) { for (var e = this.array, t = 0, i = 0, o = A.length; o > i; i++) { var n = A[i]; void 0 === n && (console.warn("THREE.BufferAttribute.copyColorsArray(): color is undefined", i), n = new LA), e[t++] = n.r, e[t++] = n.g, e[t++] = n.b } return this }, copyVector2sArray: function (A) { for (var e = this.array, t = 0, i = 0, o = A.length; o > i; i++) { var n = A[i]; void 0 === n && (console.warn("THREE.BufferAttribute.copyVector2sArray(): vector is undefined", i), n = new s), e[t++] = n.x, e[t++] = n.y } return this }, copyVector3sArray: function (A) { for (var e = this.array, t = 0, i = 0, o = A.length; o > i; i++) { var n = A[i]; void 0 === n && (console.warn("THREE.BufferAttribute.copyVector3sArray(): vector is undefined", i), n = new y), e[t++] = n.x, e[t++] = n.y, e[t++] = n.z } return this }, copyVector4sArray: function (A) { for (var e = this.array, t = 0, i = 0, o = A.length; o > i; i++) { var n = A[i]; void 0 === n && (console.warn("THREE.BufferAttribute.copyVector4sArray(): vector is undefined", i), n = new p), e[t++] = n.x, e[t++] = n.y, e[t++] = n.z, e[t++] = n.w } return this }, applyMatrix3: function (A) { for (var e = 0, t = this.count; t > e; e++) HA.x = this.getX(e), HA.y = this.getY(e), HA.z = this.getZ(e), HA.applyMatrix3(A), this.setXYZ(e, HA.x, HA.y, HA.z); return this }, applyMatrix4: function (A) { for (var e = 0, t = this.count; t > e; e++) HA.x = this.getX(e), HA.y = this.getY(e), HA.z = this.getZ(e), HA.applyMatrix4(A), this.setXYZ(e, HA.x, HA.y, HA.z); return this }, applyNormalMatrix: function (A) { for (var e = 0, t = this.count; t > e; e++) HA.x = this.getX(e), HA.y = this.getY(e), HA.z = this.getZ(e), HA.applyNormalMatrix(A), this.setXYZ(e, HA.x, HA.y, HA.z); return this }, transformDirection: function (A) { for (var e = 0, t = this.count; t > e; e++) HA.x = this.getX(e), HA.y = this.getY(e), HA.z = this.getZ(e), HA.transformDirection(A), this.setXYZ(e, HA.x, HA.y, HA.z); return this }, set: function (A, e) { return void 0 === e && (e = 0), this.array.set(A, e), this }, getX: function (A) { return this.array[A * this.itemSize] }, setX: function (A, e) { return this.array[A * this.itemSize] = e, this }, getY: function (A) { return this.array[A * this.itemSize + 1] }, setY: function (A, e) { return this.array[A * this.itemSize + 1] = e, this }, getZ: function (A) { return this.array[A * this.itemSize + 2] }, setZ: function (A, e) { return this.array[A * this.itemSize + 2] = e, this }, getW: function (A) { return this.array[A * this.itemSize + 3] }, setW: function (A, e) { return this.array[A * this.itemSize + 3] = e, this }, setXY: function (A, e, t) { return this.array[(A *= this.itemSize) + 0] = e, this.array[A + 1] = t, this }, setXYZ: function (A, e, t, i) { return this.array[(A *= this.itemSize) + 0] = e, this.array[A + 1] = t, this.array[A + 2] = i, this }, setXYZW: function (A, e, t, i, o) { return this.array[(A *= this.itemSize) + 0] = e, this.array[A + 1] = t, this.array[A + 2] = i, this.array[A + 3] = o, this }, onUpload: function (A) { return this.onUploadCallback = A, this }, clone: function () { return new this.constructor(this.array, this.itemSize).copy(this) }, toJSON: function () { return { itemSize: this.itemSize, type: this.array.constructor.name, array: Array.prototype.slice.call(this.array), normalized: this.normalized } } }), (WA.prototype = Object.create(YA.prototype)).constructor = WA, (JA.prototype = Object.create(YA.prototype)).constructor = JA, (zA.prototype = Object.create(YA.prototype)).constructor = zA, (ZA.prototype = Object.create(YA.prototype)).constructor = ZA, (XA.prototype = Object.create(YA.prototype)).constructor = XA, (_A.prototype = Object.create(YA.prototype)).constructor = _A, ($A.prototype = Object.create(YA.prototype)).constructor = $A, (Ae.prototype = Object.create(YA.prototype)).constructor = Ae, (ee.prototype = Object.create(YA.prototype)).constructor = ee, Object.assign(te.prototype, { computeGroups: function (A) { for (var e, t = [], i = void 0, o = A.faces, n = 0; o.length > n; n++) { var r = o[n]; r.materialIndex !== i && (i = r.materialIndex, void 0 !== e && (e.count = 3 * n - e.start, t.push(e)), e = { start: 3 * n, materialIndex: i }) } void 0 !== e && (e.count = 3 * n - e.start, t.push(e)), this.groups = t }, fromGeometry: function (A) { var e, t = A.faces, i = A.vertices, o = A.faceVertexUvs, n = o[0] && o[0].length > 0, r = o[1] && o[1].length > 0, a = A.morphTargets, l = a.length; if (l > 0) { e = []; for (var c = 0; l > c; c++) e[c] = { name: a[c].name, data: [] }; this.morphTargets.position = e } var h, d = A.morphNormals, p = d.length; if (p > 0) { h = []; for (c = 0; p > c; c++) h[c] = { name: d[c].name, data: [] }; this.morphTargets.normal = h } var g = A.skinIndices, u = A.skinWeights, f = g.length === i.length, m = u.length === i.length; i.length > 0 && 0 === t.length && console.error("THREE.DirectGeometry: Faceless geometries are not supported."); for (c = 0; t.length > c; c++) { var C = t[c]; this.vertices.push(i[C.a], i[C.b], i[C.c]); var y = C.vertexNormals; if (3 === y.length) this.normals.push(y[0], y[1], y[2]); else { var v = C.normal; this.normals.push(v, v, v) } var I, E = C.vertexColors; if (3 === E.length) this.colors.push(E[0], E[1], E[2]); else { var B = C.color; this.colors.push(B, B, B) } if (!0 === n) void 0 !== (I = o[0][c]) ? this.uvs.push(I[0], I[1], I[2]) : (console.warn("THREE.DirectGeometry.fromGeometry(): Undefined vertexUv ", c), this.uvs.push(new s, new s, new s)); if (!0 === r) void 0 !== (I = o[1][c]) ? this.uvs2.push(I[0], I[1], I[2]) : (console.warn("THREE.DirectGeometry.fromGeometry(): Undefined vertexUv2 ", c), this.uvs2.push(new s, new s, new s)); for (var x = 0; l > x; x++) { var S = a[x].vertices; e[x].data.push(S[C.a], S[C.b], S[C.c]) } for (x = 0; p > x; x++) { var w = d[x].vertexNormals[c]; h[x].data.push(w.a, w.b, w.c) } f && this.skinIndices.push(g[C.a], g[C.b], g[C.c]), m && this.skinWeights.push(u[C.a], u[C.b], u[C.c]) } return this.computeGroups(A), this.verticesNeedUpdate = A.verticesNeedUpdate, this.normalsNeedUpdate = A.normalsNeedUpdate, this.colorsNeedUpdate = A.colorsNeedUpdate, this.uvsNeedUpdate = A.uvsNeedUpdate, this.groupsNeedUpdate = A.groupsNeedUpdate, null !== A.boundingSphere && (this.boundingSphere = A.boundingSphere.clone()), null !== A.boundingBox && (this.boundingBox = A.boundingBox.clone()), this } }); var oe = 1, ne = new M, re = new H, ae = new y, se = new aA, le = new aA, ce = new y; function he() { Object.defineProperty(this, "id", { value: oe += 2 }), this.uuid = a.generateUUID(), this.name = "", this.type = "BufferGeometry", this.index = null, this.attributes = {}, this.morphAttributes = {}, this.morphTargetsRelative = !1, this.groups = [], this.boundingBox = null, this.boundingSphere = null, this.drawRange = { start: 0, count: 1 / 0 }, this.userData = {} } he.prototype = Object.assign(Object.create(i.prototype), { constructor: he, isBufferGeometry: !0, getIndex: function () { return this.index }, setIndex: function (A) { this.index = Array.isArray(A) ? new(ie(A) > 65535 ? $A : XA)(A, 1) : A }, getAttribute: function (A) { return this.attributes[A] }, setAttribute: function (A, e) { return this.attributes[A] = e, this }, deleteAttribute: function (A) { return delete this.attributes[A], this }, addGroup: function (A, e, t) { this.groups.push({ start: A, count: e, materialIndex: void 0 !== t ? t : 0 }) }, clearGroups: function () { this.groups = [] }, setDrawRange: function (A, e) { this.drawRange.start = A, this.drawRange.count = e }, applyMatrix4: function (A) { var e = this.attributes.position; void 0 !== e && (e.applyMatrix4(A), e.needsUpdate = !0); var t = this.attributes.normal; if (void 0 !== t) { var i = (new l).getNormalMatrix(A); t.applyNormalMatrix(i), t.needsUpdate = !0 } var o = this.attributes.tangent; return void 0 !== o && (o.transformDirection(A), o.needsUpdate = !0), null !== this.boundingBox && this.computeBoundingBox(), null !== this.boundingSphere && this.computeBoundingSphere(), this }, rotateX: function (A) { return ne.makeRotationX(A), this.applyMatrix4(ne), this }, rotateY: function (A) { return ne.makeRotationY(A), this.applyMatrix4(ne), this }, rotateZ: function (A) { return ne.makeRotationZ(A), this.applyMatrix4(ne), this }, translate: function (A, e, t) { return ne.makeTranslation(A, e, t), this.applyMatrix4(ne), this }, scale: function (A, e, t) { return ne.makeScale(A, e, t), this.applyMatrix4(ne), this }, lookAt: function (A) { return re.lookAt(A), re.updateMatrix(), this.applyMatrix4(re.matrix), this }, center: function () { return this.computeBoundingBox(), this.boundingBox.getCenter(ae).negate(), this.translate(ae.x, ae.y, ae.z), this }, setFromObject: function (A) { var e = A.geometry; if (A.isPoints || A.isLine) { var t = new Ae(3 * e.vertices.length, 3), i = new Ae(3 * e.colors.length, 3); if (this.setAttribute("position", t.copyVector3sArray(e.vertices)), this.setAttribute("color", i.copyColorsArray(e.colors)), e.lineDistances && e.lineDistances.length === e.vertices.length) { var o = new Ae(e.lineDistances.length, 1); this.setAttribute("lineDistance", o.copyArray(e.lineDistances)) } null !== e.boundingSphere && (this.boundingSphere = e.boundingSphere.clone()), null !== e.boundingBox && (this.boundingBox = e.boundingBox.clone()) } else A.isMesh && e && e.isGeometry && this.fromGeometry(e); return this }, setFromPoints: function (A) { for (var e = [], t = 0, i = A.length; i > t; t++) { var o = A[t]; e.push(o.x, o.y, o.z || 0) } return this.setAttribute("position", new Ae(e, 3)), this }, updateFromObject: function (A) { var e, t = A.geometry; if (A.isMesh) { var i = t.__directGeometry; if (!0 === t.elementsNeedUpdate && (i = void 0, t.elementsNeedUpdate = !1), void 0 === i) return this.fromGeometry(t); i.verticesNeedUpdate = t.verticesNeedUpdate, i.normalsNeedUpdate = t.normalsNeedUpdate, i.colorsNeedUpdate = t.colorsNeedUpdate, i.uvsNeedUpdate = t.uvsNeedUpdate, i.groupsNeedUpdate = t.groupsNeedUpdate, t.verticesNeedUpdate = !1, t.normalsNeedUpdate = !1, t.colorsNeedUpdate = !1, t.uvsNeedUpdate = !1, t.groupsNeedUpdate = !1, t = i } return !0 === t.verticesNeedUpdate && (void 0 !== (e = this.attributes.position) && (e.copyVector3sArray(t.vertices), e.needsUpdate = !0), t.verticesNeedUpdate = !1), !0 === t.normalsNeedUpdate && (void 0 !== (e = this.attributes.normal) && (e.copyVector3sArray(t.normals), e.needsUpdate = !0), t.normalsNeedUpdate = !1), !0 === t.colorsNeedUpdate && (void 0 !== (e = this.attributes.color) && (e.copyColorsArray(t.colors), e.needsUpdate = !0), t.colorsNeedUpdate = !1), t.uvsNeedUpdate && (void 0 !== (e = this.attributes.uv) && (e.copyVector2sArray(t.uvs), e.needsUpdate = !0), t.uvsNeedUpdate = !1), t.lineDistancesNeedUpdate && (void 0 !== (e = this.attributes.lineDistance) && (e.copyArray(t.lineDistances), e.needsUpdate = !0), t.lineDistancesNeedUpdate = !1), t.groupsNeedUpdate && (t.computeGroups(A.geometry), this.groups = t.groups, t.groupsNeedUpdate = !1), this }, fromGeometry: function (A) { return A.__directGeometry = (new te).fromGeometry(A), this.fromDirectGeometry(A.__directGeometry) }, fromDirectGeometry: function (A) { var e = new Float32Array(3 * A.vertices.length); if (this.setAttribute("position", new YA(e, 3).copyVector3sArray(A.vertices)), A.normals.length > 0) { var t = new Float32Array(3 * A.normals.length); this.setAttribute("normal", new YA(t, 3).copyVector3sArray(A.normals)) } if (A.colors.length > 0) { var i = new Float32Array(3 * A.colors.length); this.setAttribute("color", new YA(i, 3).copyColorsArray(A.colors)) } if (A.uvs.length > 0) { var o = new Float32Array(2 * A.uvs.length); this.setAttribute("uv", new YA(o, 2).copyVector2sArray(A.uvs)) } if (A.uvs2.length > 0) { var n = new Float32Array(2 * A.uvs2.length); this.setAttribute("uv2", new YA(n, 2).copyVector2sArray(A.uvs2)) } for (var r in this.groups = A.groups, A.morphTargets) { for (var a = [], s = A.morphTargets[r], l = 0, c = s.length; c > l; l++) { var h = s[l], d = new Ae(3 * h.data.length, 3); d.name = h.name, a.push(d.copyVector3sArray(h.data)) } this.morphAttributes[r] = a } if (A.skinIndices.length > 0) { var p = new Ae(4 * A.skinIndices.length, 4); this.setAttribute("skinIndex", p.copyVector4sArray(A.skinIndices)) } if (A.skinWeights.length > 0) { var g = new Ae(4 * A.skinWeights.length, 4); this.setAttribute("skinWeight", g.copyVector4sArray(A.skinWeights)) } return null !== A.boundingSphere && (this.boundingSphere = A.boundingSphere.clone()), null !== A.boundingBox && (this.boundingBox = A.boundingBox.clone()), this }, computeBoundingBox: function () { null === this.boundingBox && (this.boundingBox = new aA); var A = this.attributes.position, e = this.morphAttributes.position; if (void 0 !== A) { if (this.boundingBox.setFromBufferAttribute(A), e) for (var t = 0, i = e.length; i > t; t++) { se.setFromBufferAttribute(e[t]), this.morphTargetsRelative ? (ce.addVectors(this.boundingBox.min, se.min), this.boundingBox.expandByPoint(ce), ce.addVectors(this.boundingBox.max, se.max), this.boundingBox.expandByPoint(ce)) : (this.boundingBox.expandByPoint(se.min), this.boundingBox.expandByPoint(se.max)) } } else this.boundingBox.makeEmpty(); (isNaN(this.boundingBox.min.x) || isNaN(this.boundingBox.min.y) || isNaN(this.boundingBox.min.z)) && console.error('THREE.BufferGeometry.computeBoundingBox: Computed min/max have NaN values. The "position" attribute is likely to have NaN values.', this) }, computeBoundingSphere: function () { null === this.boundingSphere && (this.boundingSphere = new cA); var A = this.attributes.position, e = this.morphAttributes.position; if (A) { var t = this.boundingSphere.center; if (se.setFromBufferAttribute(A), e) for (var i = 0, o = e.length; o > i; i++) { le.setFromBufferAttribute(r = e[i]), this.morphTargetsRelative ? (ce.addVectors(se.min, le.min), se.expandByPoint(ce), ce.addVectors(se.max, le.max), se.expandByPoint(ce)) : (se.expandByPoint(le.min), se.expandByPoint(le.max)) } se.getCenter(t); var n = 0; for (i = 0, o = A.count; o > i; i++) ce.fromBufferAttribute(A, i), n = Math.max(n, t.distanceToSquared(ce)); if (e) for (i = 0, o = e.length; o > i; i++) for (var r, a = this.morphTargetsRelative, s = 0, l = (r = e[i]).count; l > s; s++) ce.fromBufferAttribute(r, s), a && (ae.fromBufferAttribute(A, s), ce.add(ae)), n = Math.max(n, t.distanceToSquared(ce)); this.boundingSphere.radius = Math.sqrt(n), isNaN(this.boundingSphere.radius) && console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.', this) } }, computeFaceNormals: function () {}, computeVertexNormals: function () { var A = this.index, e = this.attributes; if (e.position) { var t = e.position.array; if (void 0 === e.normal) this.setAttribute("normal", new YA(new Float32Array(t.length), 3)); else for (var i = e.normal.array, o = 0, n = i.length; n > o; o++) i[o] = 0; var r, a, s, l = e.normal.array, c = new y, h = new y, d = new y, p = new y, g = new y; if (A) { var u = A.array; for (o = 0, n = A.count; n > o; o += 3) a = 3 * u[o + 1], s = 3 * u[o + 2], c.fromArray(t, r = 3 * u[o + 0]), h.fromArray(t, a), d.fromArray(t, s), p.subVectors(d, h), g.subVectors(c, h), p.cross(g), l[r] += p.x, l[r + 1] += p.y, l[r + 2] += p.z, l[a] += p.x, l[a + 1] += p.y, l[a + 2] += p.z, l[s] += p.x, l[s + 1] += p.y, l[s + 2] += p.z } else for (o = 0, n = t.length; n > o; o += 9) c.fromArray(t, o), h.fromArray(t, o + 3), d.fromArray(t, o + 6), p.subVectors(d, h), g.subVectors(c, h), p.cross(g), l[o] = p.x, l[o + 1] = p.y, l[o + 2] = p.z, l[o + 3] = p.x, l[o + 4] = p.y, l[o + 5] = p.z, l[o + 6] = p.x, l[o + 7] = p.y, l[o + 8] = p.z; this.normalizeNormals(), e.normal.needsUpdate = !0 } }, merge: function (A, e) { if (A && A.isBufferGeometry) { void 0 === e && (e = 0, console.warn("THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset=0. Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge.")); var t = this.attributes; for (var i in t) if (void 0 !== A.attributes[i]) for (var o = t[i].array, n = A.attributes[i], r = n.array, a = n.itemSize * e, s = Math.min(r.length, o.length - a), l = 0, c = a; s > l; l++, c++) o[c] = r[l]; return this } console.error("THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.", A) }, normalizeNormals: function () { for (var A = this.attributes.normal, e = 0, t = A.count; t > e; e++) ce.x = A.getX(e), ce.y = A.getY(e), ce.z = A.getZ(e), ce.normalize(), A.setXYZ(e, ce.x, ce.y, ce.z) }, toNonIndexed: function () { function A(A, e) { for (var t = A.array, i = A.itemSize, o = new t.constructor(e.length * i), n = 0, r = 0, a = 0, s = e.length; s > a; a++) { n = e[a] * i; for (var l = 0; i > l; l++) o[r++] = t[n++] } return new YA(o, i) } if (null === this.index) return console.warn("THREE.BufferGeometry.toNonIndexed(): Geometry is already non-indexed."), this; var e = new he, t = this.index.array, i = this.attributes; for (var o in i) { var n = A(i[o], t); e.setAttribute(o, n) } var r = this.morphAttributes; for (o in r) { for (var a = [], s = r[o], l = 0, c = s.length; c > l; l++) { n = A(s[l], t); a.push(n) } e.morphAttributes[o] = a } e.morphTargetsRelative = this.morphTargetsRelative; for (var h = this.groups, d = (l = 0, h.length); d > l; l++) { var p = h[l]; e.addGroup(p.start, p.count, p.materialIndex) } return e }, toJSON: function () { var A = { metadata: { version: 4.5, type: "BufferGeometry", generator: "BufferGeometry.toJSON" } }; if (A.uuid = this.uuid, A.type = this.type, "" !== this.name && (A.name = this.name), Object.keys(this.userData).length > 0 && (A.userData = this.userData), void 0 !== this.parameters) { var e = this.parameters; for (var t in e) void 0 !== e[t] && (A[t] = e[t]); return A } A.data = { attributes: {} }; var i = this.index; null !== i && (A.data.index = { type: i.array.constructor.name, array: Array.prototype.slice.call(i.array) }); var o = this.attributes; for (var t in o) { var n = (d = o[t]).toJSON(); "" !== d.name && (n.name = d.name), A.data.attributes[t] = n } var r = {}, a = !1; for (var t in this.morphAttributes) { for (var s = this.morphAttributes[t], l = [], c = 0, h = s.length; h > c; c++) { var d; n = (d = s[c]).toJSON(); "" !== d.name && (n.name = d.name), l.push(n) } l.length > 0 && (r[t] = l, a = !0) } a && (A.data.morphAttributes = r, A.data.morphTargetsRelative = this.morphTargetsRelative); var p = this.groups; p.length > 0 && (A.data.groups = JSON.parse(JSON.stringify(p))); var g = this.boundingSphere; return null !== g && (A.data.boundingSphere = { center: g.center.toArray(), radius: g.radius }), A }, clone: function () { return (new he).copy(this) }, copy: function (A) { var e, t, i; this.index = null, this.attributes = {}, this.morphAttributes = {}, this.groups = [], this.boundingBox = null, this.boundingSphere = null, this.name = A.name; var o = A.index; null !== o && this.setIndex(o.clone()); var n = A.attributes; for (e in n) { this.setAttribute(e, n[e].clone()) } var r = A.morphAttributes; for (e in r) { var a = [], s = r[e]; for (t = 0, i = s.length; i > t; t++) a.push(s[t].clone()); this.morphAttributes[e] = a } this.morphTargetsRelative = A.morphTargetsRelative; var l = A.groups; for (t = 0, i = l.length; i > t; t++) { var c = l[t]; this.addGroup(c.start, c.count, c.materialIndex) } var h = A.boundingBox; null !== h && (this.boundingBox = h.clone()); var d = A.boundingSphere; return null !== d && (this.boundingSphere = d.clone()), this.drawRange.start = A.drawRange.start, this.drawRange.count = A.drawRange.count, this.userData = A.userData, this }, dispose: function () { this.dispatchEvent({ type: "dispose" }) } }); var de = new M, pe = new CA, ge = new cA, ue = new y, fe = new y, me = new y, Ce = new y, ye = new y, ve = new y, Ie = new y, Ee = new y, Be = new y, xe = new s, Se = new s, we = new s, Me = new y, be = new y; function Ue(A, e) { H.call(this), this.type = "Mesh", this.geometry = void 0 !== A ? A : new he, this.material = void 0 !== e ? e : new jA, this.updateMorphTargets() } function Fe(A, e, t, i, o, n, r, a) { if (null === (1 === e.side ? i.intersectTriangle(r, n, o, !0, a) : i.intersectTriangle(o, n, r, 2 !== e.side, a))) return null; be.copy(a), be.applyMatrix4(A.matrixWorld); var s = t.ray.origin.distanceTo(be); return t.near > s || s > t.far ? null : { distance: s, point: be.clone(), object: A } } function Ke(A, e, t, i, o, n, r, a, l, c, h, d) { ue.fromBufferAttribute(o, c), fe.fromBufferAttribute(o, h), me.fromBufferAttribute(o, d); var p = A.morphTargetInfluences; if (e.morphTargets && n && p) { Ie.set(0, 0, 0), Ee.set(0, 0, 0), Be.set(0, 0, 0); for (var g = 0, u = n.length; u > g; g++) { var f = p[g], m = n[g]; 0 !== f && (Ce.fromBufferAttribute(m, c), ye.fromBufferAttribute(m, h), ve.fromBufferAttribute(m, d), r ? (Ie.addScaledVector(Ce, f), Ee.addScaledVector(ye, f), Be.addScaledVector(ve, f)) : (Ie.addScaledVector(Ce.sub(ue), f), Ee.addScaledVector(ye.sub(fe), f), Be.addScaledVector(ve.sub(me), f))) } ue.add(Ie), fe.add(Ee), me.add(Be) } var C = Fe(A, e, t, i, ue, fe, me, Me); if (C) { a && (xe.fromBufferAttribute(a, c), Se.fromBufferAttribute(a, h), we.fromBufferAttribute(a, d), C.uv = RA.getUV(Me, ue, fe, me, xe, Se, we, new s)), l && (xe.fromBufferAttribute(l, c), Se.fromBufferAttribute(l, h), we.fromBufferAttribute(l, d), C.uv2 = RA.getUV(Me, ue, fe, me, xe, Se, we, new s)); var y = new GA(c, h, d); RA.getNormal(ue, fe, me, y.normal), C.face = y } return C } Ue.prototype = Object.assign(Object.create(H.prototype), { constructor: Ue, isMesh: !0, copy: function (A) { return H.prototype.copy.call(this, A), void 0 !== A.morphTargetInfluences && (this.morphTargetInfluences = A.morphTargetInfluences.slice()), void 0 !== A.morphTargetDictionary && (this.morphTargetDictionary = Object.assign({}, A.morphTargetDictionary)), this }, updateMorphTargets: function () { var A, e, t, i = this.geometry; if (i.isBufferGeometry) { var o = i.morphAttributes, n = Object.keys(o); if (n.length > 0) { var r = o[n[0]]; if (void 0 !== r) for (this.morphTargetInfluences = [], this.morphTargetDictionary = {}, A = 0, e = r.length; e > A; A++) t = r[A].name || String(A), this.morphTargetInfluences.push(0), this.morphTargetDictionary[t] = A } } else { var a = i.morphTargets; void 0 !== a && a.length > 0 && console.error("THREE.Mesh.updateMorphTargets() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.") } }, raycast: function (A, e) { var t, i = this.geometry, o = this.material, n = this.matrixWorld; if (void 0 !== o && (null === i.boundingSphere && i.computeBoundingSphere(), ge.copy(i.boundingSphere), ge.applyMatrix4(n), !1 !== A.ray.intersectsSphere(ge) && (de.getInverse(n), pe.copy(A.ray).applyMatrix4(de), null === i.boundingBox || !1 !== pe.intersectsBox(i.boundingBox)))) if (i.isBufferGeometry) { var r, a, l, c, h, d, p, g, u, f = i.index, m = i.attributes.position, C = i.morphAttributes.position, y = i.morphTargetsRelative, v = i.attributes.uv, I = i.attributes.uv2, E = i.groups, B = i.drawRange; if (null !== f) if (Array.isArray(o)) { for (c = 0, d = E.length; d > c; c++) if (u = o[(g = E[c]).materialIndex]) for (h = Math.max(g.start, B.start), p = Math.min(g.start + g.count, B.start + B.count); p > h; h += 3) r = f.getX(h), a = f.getX(h + 1), l = f.getX(h + 2), (t = Ke(this, u, A, pe, m, C, y, v, I, r, a, l)) && (t.faceIndex = Math.floor(h / 3), t.face.materialIndex = g.materialIndex, e.push(t)) } else for (c = Math.max(0, B.start), d = Math.min(f.count, B.start + B.count); d > c; c += 3) r = f.getX(c), a = f.getX(c + 1), l = f.getX(c + 2), (t = Ke(this, o, A, pe, m, C, y, v, I, r, a, l)) && (t.faceIndex = Math.floor(c / 3), e.push(t)); else if (void 0 !== m) if (Array.isArray(o)) for (c = 0, d = E.length; d > c; c++) for (u = o[(g = E[c]).materialIndex], h = Math.max(g.start, B.start), p = Math.min(g.start + g.count, B.start + B.count); p > h; h += 3) (t = Ke(this, u, A, pe, m, C, y, v, I, r = h, a = h + 1, l = h + 2)) && (t.faceIndex = Math.floor(h / 3), t.face.materialIndex = g.materialIndex, e.push(t)); else for (c = Math.max(0, B.start), d = Math.min(m.count, B.start + B.count); d > c; c += 3) (t = Ke(this, o, A, pe, m, C, y, v, I, r = c, a = c + 1, l = c + 2)) && (t.faceIndex = Math.floor(c / 3), e.push(t)) } else if (i.isGeometry) { var x, S, w, M, b = Array.isArray(o), U = i.vertices, F = i.faces, K = i.faceVertexUvs[0]; K.length > 0 && (M = K); for (var Q = 0, R = F.length; R > Q; Q++) { var T = F[Q], k = b ? o[T.materialIndex] : o; if (void 0 !== k && (t = Fe(this, k, A, pe, x = U[T.a], S = U[T.b], w = U[T.c], Me))) { if (M && M[Q]) { var D = M[Q]; xe.copy(D[0]), Se.copy(D[1]), we.copy(D[2]), t.uv = RA.getUV(Me, x, S, w, xe, Se, we, new s) } t.face = T, t.faceIndex = Q, e.push(t) } } } }, clone: function () { return new this.constructor(this.geometry, this.material).copy(this) } }); var Qe = 0, Re = new M, Te = new H, ke = new y; function De() { Object.defineProperty(this, "id", { value: Qe += 2 }), this.uuid = a.generateUUID(), this.name = "", this.type = "Geometry", this.vertices = [], this.colors = [], this.faces = [], this.faceVertexUvs = [ [] ], this.morphTargets = [], this.morphNormals = [], this.skinWeights = [], this.skinIndices = [], this.lineDistances = [], this.boundingBox = null, this.boundingSphere = null, this.elementsNeedUpdate = !1, this.verticesNeedUpdate = !1, this.uvsNeedUpdate = !1, this.normalsNeedUpdate = !1, this.colorsNeedUpdate = !1, this.lineDistancesNeedUpdate = !1, this.groupsNeedUpdate = !1 } De.prototype = Object.assign(Object.create(i.prototype), { constructor: De, isGeometry: !0, applyMatrix4: function (A) { for (var e = (new l).getNormalMatrix(A), t = 0, i = this.vertices.length; i > t; t++) { this.vertices[t].applyMatrix4(A) } for (t = 0, i = this.faces.length; i > t; t++) { var o = this.faces[t]; o.normal.applyMatrix3(e).normalize(); for (var n = 0, r = o.vertexNormals.length; r > n; n++) o.vertexNormals[n].applyMatrix3(e).normalize() } return null !== this.boundingBox && this.computeBoundingBox(), null !== this.boundingSphere && this.computeBoundingSphere(), this.verticesNeedUpdate = !0, this.normalsNeedUpdate = !0, this }, rotateX: function (A) { return Re.makeRotationX(A), this.applyMatrix4(Re), this }, rotateY: function (A) { return Re.makeRotationY(A), this.applyMatrix4(Re), this }, rotateZ: function (A) { return Re.makeRotationZ(A), this.applyMatrix4(Re), this }, translate: function (A, e, t) { return Re.makeTranslation(A, e, t), this.applyMatrix4(Re), this }, scale: function (A, e, t) { return Re.makeScale(A, e, t), this.applyMatrix4(Re), this }, lookAt: function (A) { return Te.lookAt(A), Te.updateMatrix(), this.applyMatrix4(Te.matrix), this }, fromBufferGeometry: function (A) { var e = this, t = null !== A.index ? A.index.array : void 0, i = A.attributes; if (void 0 === i.position) return console.error("THREE.Geometry.fromBufferGeometry(): Position attribute required for conversion."), this; var o = i.position.array, n = void 0 !== i.normal ? i.normal.array : void 0, r = void 0 !== i.color ? i.color.array : void 0, a = void 0 !== i.uv ? i.uv.array : void 0, l = void 0 !== i.uv2 ? i.uv2.array : void 0; void 0 !== l && (this.faceVertexUvs[1] = []); for (var c = 0; o.length > c; c += 3) e.vertices.push((new y).fromArray(o, c)), void 0 !== r && e.colors.push((new LA).fromArray(r, c)); function h(A, t, i, o) { var c = void 0 === r ? [] : [e.colors[A].clone(), e.colors[t].clone(), e.colors[i].clone()], h = new GA(A, t, i, void 0 === n ? [] : [(new y).fromArray(n, 3 * A), (new y).fromArray(n, 3 * t), (new y).fromArray(n, 3 * i)], c, o); e.faces.push(h), void 0 !== a && e.faceVertexUvs[0].push([(new s).fromArray(a, 2 * A), (new s).fromArray(a, 2 * t), (new s).fromArray(a, 2 * i)]), void 0 !== l && e.faceVertexUvs[1].push([(new s).fromArray(l, 2 * A), (new s).fromArray(l, 2 * t), (new s).fromArray(l, 2 * i)]) } var d = A.groups; if (d.length > 0) for (c = 0; d.length > c; c++) for (var p = d[c], g = p.start, u = g, f = g + p.count; f > u; u += 3) void 0 !== t ? h(t[u], t[u + 1], t[u + 2], p.materialIndex) : h(u, u + 1, u + 2, p.materialIndex); else if (void 0 !== t) for (c = 0; t.length > c; c += 3) h(t[c], t[c + 1], t[c + 2]); else for (c = 0; o.length / 3 > c; c += 3) h(c, c + 1, c + 2); return this.computeFaceNormals(), null !== A.boundingBox && (this.boundingBox = A.boundingBox.clone()), null !== A.boundingSphere && (this.boundingSphere = A.boundingSphere.clone()), this }, center: function () { return this.computeBoundingBox(), this.boundingBox.getCenter(ke).negate(), this.translate(ke.x, ke.y, ke.z), this }, normalize: function () { this.computeBoundingSphere(); var A = this.boundingSphere.center, e = this.boundingSphere.radius, t = 0 === e ? 1 : 1 / e, i = new M; return i.set(t, 0, 0, -t * A.x, 0, t, 0, -t * A.y, 0, 0, t, -t * A.z, 0, 0, 0, 1), this.applyMatrix4(i), this }, computeFaceNormals: function () { for (var A = new y, e = new y, t = 0, i = this.faces.length; i > t; t++) { var o = this.faces[t], n = this.vertices[o.a], r = this.vertices[o.b]; A.subVectors(this.vertices[o.c], r), e.subVectors(n, r), A.cross(e), A.normalize(), o.normal.copy(A) } }, computeVertexNormals: function (A) { var e, t, i, o, n, r; for (void 0 === A && (A = !0), r = new Array(this.vertices.length), e = 0, t = this.vertices.length; t > e; e++) r[e] = new y; if (A) { var a, s, l = new y, c = new y; for (i = 0, o = this.faces.length; o > i; i++) a = this.vertices[(n = this.faces[i]).a], l.subVectors(this.vertices[n.c], s = this.vertices[n.b]), c.subVectors(a, s), l.cross(c), r[n.a].add(l), r[n.b].add(l), r[n.c].add(l) } else for (this.computeFaceNormals(), i = 0, o = this.faces.length; o > i; i++) r[(n = this.faces[i]).a].add(n.normal), r[n.b].add(n.normal), r[n.c].add(n.normal); for (e = 0, t = this.vertices.length; t > e; e++) r[e].normalize(); for (i = 0, o = this.faces.length; o > i; i++) { var h = (n = this.faces[i]).vertexNormals; 3 === h.length ? (h[0].copy(r[n.a]), h[1].copy(r[n.b]), h[2].copy(r[n.c])) : (h[0] = r[n.a].clone(), h[1] = r[n.b].clone(), h[2] = r[n.c].clone()) } this.faces.length > 0 && (this.normalsNeedUpdate = !0) }, computeFlatVertexNormals: function () { var A, e, t; for (this.computeFaceNormals(), A = 0, e = this.faces.length; e > A; A++) { var i = (t = this.faces[A]).vertexNormals; 3 === i.length ? (i[0].copy(t.normal), i[1].copy(t.normal), i[2].copy(t.normal)) : (i[0] = t.normal.clone(), i[1] = t.normal.clone(), i[2] = t.normal.clone()) } this.faces.length > 0 && (this.normalsNeedUpdate = !0) }, computeMorphNormals: function () { var A, e, t, i, o; for (t = 0, i = this.faces.length; i > t; t++) for ((o = this.faces[t]).__originalFaceNormal ? o.__originalFaceNormal.copy(o.normal) : o.__originalFaceNormal = o.normal.clone(), o.__originalVertexNormals || (o.__originalVertexNormals = []), A = 0, e = o.vertexNormals.length; e > A; A++) o.__originalVertexNormals[A] ? o.__originalVertexNormals[A].copy(o.vertexNormals[A]) : o.__originalVertexNormals[A] = o.vertexNormals[A].clone(); var n = new De; for (n.faces = this.faces, A = 0, e = this.morphTargets.length; e > A; A++) { if (!this.morphNormals[A]) { this.morphNormals[A] = {}, this.morphNormals[A].faceNormals = [], this.morphNormals[A].vertexNormals = []; var r = this.morphNormals[A].faceNormals, a = this.morphNormals[A].vertexNormals; for (t = 0, i = this.faces.length; i > t; t++) s = new y, l = { a: new y, b: new y, c: new y }, r.push(s), a.push(l) } var s, l, c = this.morphNormals[A]; for (n.vertices = this.morphTargets[A].vertices, n.computeFaceNormals(), n.computeVertexNormals(), t = 0, i = this.faces.length; i > t; t++) l = c.vertexNormals[t], (s = c.faceNormals[t]).copy((o = this.faces[t]).normal), l.a.copy(o.vertexNormals[0]), l.b.copy(o.vertexNormals[1]), l.c.copy(o.vertexNormals[2]) } for (t = 0, i = this.faces.length; i > t; t++) (o = this.faces[t]).normal = o.__originalFaceNormal, o.vertexNormals = o.__originalVertexNormals }, computeBoundingBox: function () { null === this.boundingBox && (this.boundingBox = new aA), this.boundingBox.setFromPoints(this.vertices) }, computeBoundingSphere: function () { null === this.boundingSphere && (this.boundingSphere = new cA), this.boundingSphere.setFromPoints(this.vertices) }, merge: function (A, e, t) { if (A && A.isGeometry) { var i, o = this.vertices.length, n = this.vertices, r = A.vertices, a = this.faces, s = A.faces, c = this.colors, h = A.colors; void 0 === t && (t = 0), void 0 !== e && (i = (new l).getNormalMatrix(e)); for (var d = 0, p = r.length; p > d; d++) { var g = r[d].clone(); void 0 !== e && g.applyMatrix4(e), n.push(g) } for (d = 0, p = h.length; p > d; d++) c.push(h[d].clone()); for (d = 0, p = s.length; p > d; d++) { var u, f, m = s[d], C = m.vertexNormals, y = m.vertexColors; (u = new GA(m.a + o, m.b + o, m.c + o)).normal.copy(m.normal), void 0 !== i && u.normal.applyMatrix3(i).normalize(); for (var v = 0, I = C.length; I > v; v++) f = C[v].clone(), void 0 !== i && f.applyMatrix3(i).normalize(), u.vertexNormals.push(f); u.color.copy(m.color); for (v = 0, I = y.length; I > v; v++) u.vertexColors.push(y[v].clone()); u.materialIndex = m.materialIndex + t, a.push(u) } for (d = 0, p = A.faceVertexUvs.length; p > d; d++) { var E = A.faceVertexUvs[d]; void 0 === this.faceVertexUvs[d] && (this.faceVertexUvs[d] = []); for (v = 0, I = E.length; I > v; v++) { for (var B = E[v], x = [], S = 0, w = B.length; w > S; S++) x.push(B[S].clone()); this.faceVertexUvs[d].push(x) } } } else console.error("THREE.Geometry.merge(): geometry not an instance of THREE.Geometry.", A) }, mergeMesh: function (A) { A && A.isMesh ? (A.matrixAutoUpdate && A.updateMatrix(), this.merge(A.geometry, A.matrix)) : console.error("THREE.Geometry.mergeMesh(): mesh not an instance of THREE.Mesh.", A) }, mergeVertices: function () { var A, e, t, i, o, n, r, a, s = {}, l = [], c = [], h = Math.pow(10, 4); for (t = 0, i = this.vertices.length; i > t; t++) A = this.vertices[t], void 0 === s[e = Math.round(A.x * h) + "_" + Math.round(A.y * h) + "_" + Math.round(A.z * h)] ? (s[e] = t, l.push(this.vertices[t]), c[t] = l.length - 1) : c[t] = c[s[e]]; var d = []; for (t = 0, i = this.faces.length; i > t; t++) { (o = this.faces[t]).a = c[o.a], o.b = c[o.b], o.c = c[o.c], n = [o.a, o.b, o.c]; for (var p = 0; 3 > p; p++) if (n[p] === n[(p + 1) % 3]) { d.push(t); break } } for (t = d.length - 1; t >= 0; t--) { var g = d[t]; for (this.faces.splice(g, 1), r = 0, a = this.faceVertexUvs.length; a > r; r++) this.faceVertexUvs[r].splice(g, 1) } var u = this.vertices.length - l.length; return this.vertices = l, u }, setFromPoints: function (A) { this.vertices = []; for (var e = 0, t = A.length; t > e; e++) { var i = A[e]; this.vertices.push(new y(i.x, i.y, i.z || 0)) } return this }, sortFacesByMaterialIndex: function () { for (var A = this.faces, e = A.length, t = 0; e > t; t++) A[t]._id = t; A.sort((function (A, e) { return A.materialIndex - e.materialIndex })); var i, o, n = this.faceVertexUvs[0], r = this.faceVertexUvs[1]; n && n.length === e && (i = []), r && r.length === e && (o = []); for (t = 0; e > t; t++) { var a = A[t]._id; i && i.push(n[a]), o && o.push(r[a]) } i && (this.faceVertexUvs[0] = i), o && (this.faceVertexUvs[1] = o) }, toJSON: function () { var A = { metadata: { version: 4.5, type: "Geometry", generator: "Geometry.toJSON" } }; if (A.uuid = this.uuid, A.type = this.type, "" !== this.name && (A.name = this.name), void 0 !== this.parameters) { var e = this.parameters; for (var t in e) void 0 !== e[t] && (A[t] = e[t]); return A } for (var i = [], o = 0; this.vertices.length > o; o++) { var n = this.vertices[o]; i.push(n.x, n.y, n.z) } var r = [], a = [], s = {}, l = [], c = {}, h = [], d = {}; for (o = 0; this.faces.length > o; o++) { var p = this.faces[o], g = void 0 !== this.faceVertexUvs[0][o], u = p.normal.length() > 0, f = p.vertexNormals.length > 0, m = 1 !== p.color.r || 1 !== p.color.g || 1 !== p.color.b, C = p.vertexColors.length > 0, y = 0; if (y = B(y, 0, 0), y = B(y, 1, !0), y = B(y, 2, !1), y = B(y, 3, g), y = B(y, 4, u), y = B(y, 5, f), y = B(y, 6, m), y = B(y, 7, C), r.push(y), r.push(p.a, p.b, p.c), r.push(p.materialIndex), g) { var v = this.faceVertexUvs[0][o]; r.push(w(v[0]), w(v[1]), w(v[2])) } if (u && r.push(x(p.normal)), f) { var I = p.vertexNormals; r.push(x(I[0]), x(I[1]), x(I[2])) } if (m && r.push(S(p.color)), C) { var E = p.vertexColors; r.push(S(E[0]), S(E[1]), S(E[2])) } } function B(A, e, t) { return t ? A | 1 << e : A & ~(1 << e) } function x(A) { var e = A.x.toString() + A.y.toString() + A.z.toString(); return void 0 !== s[e] || (s[e] = a.length / 3, a.push(A.x, A.y, A.z)), s[e] } function S(A) { var e = A.r.toString() + A.g.toString() + A.b.toString(); return void 0 !== c[e] || (c[e] = l.length, l.push(A.getHex())), c[e] } function w(A) { var e = A.x.toString() + A.y.toString(); return void 0 !== d[e] || (d[e] = h.length / 2, h.push(A.x, A.y)), d[e] } return A.data = {}, A.data.vertices = i, A.data.normals = a, l.length > 0 && (A.data.colors = l), h.length > 0 && (A.data.uvs = [h]), A.data.faces = r, A }, clone: function () { return (new De).copy(this) }, copy: function (A) { var e, t, i, o, n, r; this.vertices = [], this.colors = [], this.faces = [], this.faceVertexUvs = [ [] ], this.morphTargets = [], this.morphNormals = [], this.skinWeights = [], this.skinIndices = [], this.lineDistances = [], this.boundingBox = null, this.boundingSphere = null, this.name = A.name; var a = A.vertices; for (e = 0, t = a.length; t > e; e++) this.vertices.push(a[e].clone()); var s = A.colors; for (e = 0, t = s.length; t > e; e++) this.colors.push(s[e].clone()); var l = A.faces; for (e = 0, t = l.length; t > e; e++) this.faces.push(l[e].clone()); for (e = 0, t = A.faceVertexUvs.length; t > e; e++) { var c = A.faceVertexUvs[e]; for (void 0 === this.faceVertexUvs[e] && (this.faceVertexUvs[e] = []), i = 0, o = c.length; o > i; i++) { var h = c[i], d = []; for (n = 0, r = h.length; r > n; n++) { d.push(h[n].clone()) } this.faceVertexUvs[e].push(d) } } var p = A.morphTargets; for (e = 0, t = p.length; t > e; e++) { var g = {}; if (g.name = p[e].name, void 0 !== p[e].vertices) for (g.vertices = [], i = 0, o = p[e].vertices.length; o > i; i++) g.vertices.push(p[e].vertices[i].clone()); if (void 0 !== p[e].normals) for (g.normals = [], i = 0, o = p[e].normals.length; o > i; i++) g.normals.push(p[e].normals[i].clone()); this.morphTargets.push(g) } var u = A.morphNormals; for (e = 0, t = u.length; t > e; e++) { var f = {}; if (void 0 !== u[e].vertexNormals) for (f.vertexNormals = [], i = 0, o = u[e].vertexNormals.length; o > i; i++) { var m = u[e].vertexNormals[i], C = {}; C.a = m.a.clone(), C.b = m.b.clone(), C.c = m.c.clone(), f.vertexNormals.push(C) } if (void 0 !== u[e].faceNormals) for (f.faceNormals = [], i = 0, o = u[e].faceNormals.length; o > i; i++) f.faceNormals.push(u[e].faceNormals[i].clone()); this.morphNormals.push(f) } var y = A.skinWeights; for (e = 0, t = y.length; t > e; e++) this.skinWeights.push(y[e].clone()); var v = A.skinIndices; for (e = 0, t = v.length; t > e; e++) this.skinIndices.push(v[e].clone()); var I = A.lineDistances; for (e = 0, t = I.length; t > e; e++) this.lineDistances.push(I[e]); var E = A.boundingBox; null !== E && (this.boundingBox = E.clone()); var B = A.boundingSphere; return null !== B && (this.boundingSphere = B.clone()), this.elementsNeedUpdate = A.elementsNeedUpdate, this.verticesNeedUpdate = A.verticesNeedUpdate, this.uvsNeedUpdate = A.uvsNeedUpdate, this.normalsNeedUpdate = A.normalsNeedUpdate, this.colorsNeedUpdate = A.colorsNeedUpdate, this.lineDistancesNeedUpdate = A.lineDistancesNeedUpdate, this.groupsNeedUpdate = A.groupsNeedUpdate, this }, dispose: function () { this.dispatchEvent({ type: "dispose" }) } }); class Le extends De { constructor(A, e, t, i, o, n) { super(), this.type = "BoxGeometry", this.parameters = { width: A, height: e, depth: t, widthSegments: i, heightSegments: o, depthSegments: n }, this.fromBufferGeometry(new Ne(A, e, t, i, o, n)), this.mergeVertices() } } class Ne extends he { constructor(A, e, t, i, o, n) { super(), this.type = "BoxBufferGeometry", this.parameters = { width: A, height: e, depth: t, widthSegments: i, heightSegments: o, depthSegments: n }; var r = this; A = A || 1, e = e || 1, t = t || 1, i = Math.floor(i) || 1, o = Math.floor(o) || 1, n = Math.floor(n) || 1; var a = [], s = [], l = [], c = [], h = 0, d = 0; function p(A, e, t, i, o, n, p, g, u, f, m) { var C, v, I = n / u, E = p / f, B = n / 2, x = p / 2, S = g / 2, w = u + 1, M = f + 1, b = 0, U = 0, F = new y; for (v = 0; M > v; v++) { var K = v * E - x; for (C = 0; w > C; C++) { F[A] = (C * I - B) * i, F[e] = K * o, F[t] = S, s.push(F.x, F.y, F.z), F[A] = 0, F[e] = 0, F[t] = g > 0 ? 1 : -1, l.push(F.x, F.y, F.z), c.push(C / u), c.push(1 - v / f), b += 1 } } for (v = 0; f > v; v++) for (C = 0; u > C; C++) { var Q = h + C + w * (v + 1), R = h + (C + 1) + w * (v + 1), T = h + (C + 1) + w * v; a.push(h + C + w * v, Q, T), a.push(Q, R, T), U += 6 } r.addGroup(d, U, m), d += U, h += b } p("z", "y", "x", -1, -1, t, e, A, n, o, 0), p("z", "y", "x", 1, -1, t, e, -A, n, o, 1), p("x", "z", "y", 1, 1, A, t, e, i, n, 2), p("x", "z", "y", 1, -1, A, t, -e, i, n, 3), p("x", "y", "z", 1, -1, A, e, t, i, o, 4), p("x", "y", "z", -1, -1, A, e, -t, i, o, 5), this.setIndex(a), this.setAttribute("position", new Ae(s, 3)), this.setAttribute("normal", new Ae(l, 3)), this.setAttribute("uv", new Ae(c, 2)) } } function Oe(A) { var e = {}; for (var t in A) for (var i in e[t] = {}, A[t]) { var o = A[t][i]; e[t][i] = o && (o.isColor || o.isMatrix3 || o.isMatrix4 || o.isVector2 || o.isVector3 || o.isVector4 || o.isTexture) ? o.clone() : Array.isArray(o) ? o.slice() : o } return e } function Ve(A) { for (var e = {}, t = 0; A.length > t; t++) { var i = Oe(A[t]); for (var o in i) e[o] = i[o] } return e } var Ge = { clone: Oe, merge: Ve }; function Pe(A) { qA.call(this), this.type = "ShaderMaterial", this.defines = {}, this.uniforms = {}, this.vertexShader = "void main() {\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n}", this.fragmentShader = "void main() {\n\tgl_FragColor = vec4( 1.0, 0.0, 0.0, 1.0 );\n}", this.linewidth = 1, this.wireframe = !1, this.wireframeLinewidth = 1, this.fog = !1, this.lights = !1, this.clipping = !1, this.skinning = !1, this.morphTargets = !1, this.morphNormals = !1, this.extensions = { derivatives: !1, fragDepth: !1, drawBuffers: !1, shaderTextureLOD: !1 }, this.defaultAttributeValues = { color: [1, 1, 1], uv: [0, 0], uv2: [0, 0] }, this.index0AttributeName = void 0, this.uniformsNeedUpdate = !1, void 0 !== A && (void 0 !== A.attributes && console.error("THREE.ShaderMaterial: attributes should now be defined in THREE.BufferGeometry instead."), this.setValues(A)) } function qe() { H.call(this), this.type = "Camera", this.matrixWorldInverse = new M, this.projectionMatrix = new M, this.projectionMatrixInverse = new M } function je(A, e, t, i) { qe.call(this), this.type = "PerspectiveCamera", this.fov = void 0 !== A ? A : 50, this.zoom = 1, this.near = void 0 !== t ? t : .1, this.far = void 0 !== i ? i : 2e3, this.focus = 10, this.aspect = void 0 !== e ? e : 1, this.view = null, this.filmGauge = 35, this.filmOffset = 0, this.updateProjectionMatrix() } (Pe.prototype = Object.create(qA.prototype)).constructor = Pe, Pe.prototype.isShaderMaterial = !0, Pe.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.fragmentShader = A.fragmentShader, this.vertexShader = A.vertexShader, this.uniforms = Oe(A.uniforms), this.defines = Object.assign({}, A.defines), this.wireframe = A.wireframe, this.wireframeLinewidth = A.wireframeLinewidth, this.lights = A.lights, this.clipping = A.clipping, this.skinning = A.skinning, this.morphTargets = A.morphTargets, this.morphNormals = A.morphNormals, this.extensions = A.extensions, this }, Pe.prototype.toJSON = function (A) { var e = qA.prototype.toJSON.call(this, A); for (var t in e.uniforms = {}, this.uniforms) { var i = this.uniforms[t].value; e.uniforms[t] = i && i.isTexture ? { type: "t", value: i.toJSON(A).uuid } : i && i.isColor ? { type: "c", value: i.getHex() } : i && i.isVector2 ? { type: "v2", value: i.toArray() } : i && i.isVector3 ? { type: "v3", value: i.toArray() } : i && i.isVector4 ? { type: "v4", value: i.toArray() } : i && i.isMatrix3 ? { type: "m3", value: i.toArray() } : i && i.isMatrix4 ? { type: "m4", value: i.toArray() } : { value: i } } Object.keys(this.defines).length > 0 && (e.defines = this.defines), e.vertexShader = this.vertexShader, e.fragmentShader = this.fragmentShader; var o = {}; for (var n in this.extensions) !0 === this.extensions[n] && (o[n] = !0); return Object.keys(o).length > 0 && (e.extensions = o), e }, qe.prototype = Object.assign(Object.create(H.prototype), { constructor: qe, isCamera: !0, copy: function (A, e) { return H.prototype.copy.call(this, A, e), this.matrixWorldInverse.copy(A.matrixWorldInverse), this.projectionMatrix.copy(A.projectionMatrix), this.projectionMatrixInverse.copy(A.projectionMatrixInverse), this }, getWorldDirection: function (A) { void 0 === A && (console.warn("THREE.Camera: .getWorldDirection() target is now required"), A = new y), this.updateMatrixWorld(!0); var e = this.matrixWorld.elements; return A.set(-e[8], -e[9], -e[10]).normalize() }, updateMatrixWorld: function (A) { H.prototype.updateMatrixWorld.call(this, A), this.matrixWorldInverse.getInverse(this.matrixWorld) }, updateWorldMatrix: function (A, e) { H.prototype.updateWorldMatrix.call(this, A, e), this.matrixWorldInverse.getInverse(this.matrixWorld) }, clone: function () { return (new this.constructor).copy(this) } }), je.prototype = Object.assign(Object.create(qe.prototype), { constructor: je, isPerspectiveCamera: !0, copy: function (A, e) { return qe.prototype.copy.call(this, A, e), this.fov = A.fov, this.zoom = A.zoom, this.near = A.near, this.far = A.far, this.focus = A.focus, this.aspect = A.aspect, this.view = null === A.view ? null : Object.assign({}, A.view), this.filmGauge = A.filmGauge, this.filmOffset = A.filmOffset, this }, setFocalLength: function (A) { var e = .5 * this.getFilmHeight() / A; this.fov = 2 * a.RAD2DEG * Math.atan(e), this.updateProjectionMatrix() }, getFocalLength: function () { var A = Math.tan(.5 * a.DEG2RAD * this.fov); return .5 * this.getFilmHeight() / A }, getEffectiveFOV: function () { return 2 * a.RAD2DEG * Math.atan(Math.tan(.5 * a.DEG2RAD * this.fov) / this.zoom) }, getFilmWidth: function () { return this.filmGauge * Math.min(this.aspect, 1) }, getFilmHeight: function () { return this.filmGauge / Math.max(this.aspect, 1) }, setViewOffset: function (A, e, t, i, o, n) { this.aspect = A / e, null === this.view && (this.view = { enabled: !0, fullWidth: 1, fullHeight: 1, offsetX: 0, offsetY: 0, width: 1, height: 1 }), this.view.enabled = !0, this.view.fullWidth = A, this.view.fullHeight = e, this.view.offsetX = t, this.view.offsetY = i, this.view.width = o, this.view.height = n, this.updateProjectionMatrix() }, clearViewOffset: function () { null !== this.view && (this.view.enabled = !1), this.updateProjectionMatrix() }, updateProjectionMatrix: function () { var A = this.near, e = A * Math.tan(.5 * a.DEG2RAD * this.fov) / this.zoom, t = 2 * e, i = this.aspect * t, o = -.5 * i, n = this.view; if (null !== this.view && this.view.enabled) { var r = n.fullWidth, s = n.fullHeight; o += n.offsetX * i / r, e -= n.offsetY * t / s, i *= n.width / r, t *= n.height / s } var l = this.filmOffset; 0 !== l && (o += A * l / this.getFilmWidth()), this.projectionMatrix.makePerspective(o, o + i, e, e - t, A, this.far), this.projectionMatrixInverse.getInverse(this.projectionMatrix) }, toJSON: function (A) { var e = H.prototype.toJSON.call(this, A); return e.object.fov = this.fov, e.object.zoom = this.zoom, e.object.near = this.near, e.object.far = this.far, e.object.focus = this.focus, e.object.aspect = this.aspect, null !== this.view && (e.object.view = Object.assign({}, this.view)), e.object.filmGauge = this.filmGauge, e.object.filmOffset = this.filmOffset, e } }); function He(A, e, t, i) { H.call(this), this.type = "CubeCamera"; var o = new je(90, 1, A, e); o.up.set(0, -1, 0), o.lookAt(new y(1, 0, 0)), this.add(o); var n = new je(90, 1, A, e); n.up.set(0, -1, 0), n.lookAt(new y(-1, 0, 0)), this.add(n); var r = new je(90, 1, A, e); r.up.set(0, 0, 1), r.lookAt(new y(0, 1, 0)), this.add(r); var a = new je(90, 1, A, e); a.up.set(0, 0, -1), a.lookAt(new y(0, -1, 0)), this.add(a); var s = new je(90, 1, A, e); s.up.set(0, -1, 0), s.lookAt(new y(0, 0, 1)), this.add(s); var l = new je(90, 1, A, e); l.up.set(0, -1, 0), l.lookAt(new y(0, 0, -1)), this.add(l), this.renderTarget = new Ye(t, i = i || { format: 1022, magFilter: 1006, minFilter: 1006 }), this.renderTarget.texture.name = "CubeCamera", this.update = function (A, e) { null === this.parent && this.updateMatrixWorld(); var t = A.getRenderTarget(), i = this.renderTarget, c = i.texture.generateMipmaps; i.texture.generateMipmaps = !1, A.setRenderTarget(i, 0), A.render(e, o), A.setRenderTarget(i, 1), A.render(e, n), A.setRenderTarget(i, 2), A.render(e, r), A.setRenderTarget(i, 3), A.render(e, a), A.setRenderTarget(i, 4), A.render(e, s), i.texture.generateMipmaps = c, A.setRenderTarget(i, 5), A.render(e, l), A.setRenderTarget(t) }, this.clear = function (A, e, t, i) { for (var o = A.getRenderTarget(), n = this.renderTarget, r = 0; 6 > r; r++) A.setRenderTarget(n, r), A.clear(e, t, i); A.setRenderTarget(o) } } function Ye(A, e, t) { Number.isInteger(e) && (console.warn("THREE.WebGLCubeRenderTarget: constructor signature is now WebGLCubeRenderTarget( size, options )"), e = t), g.call(this, A, A, e) } function We(A, e, t, i, o, n, r, a, s, l, c, h) { d.call(this, null, n, r, a, s, l, i, o, c, h), this.image = { data: A || null, width: e || 1, height: t || 1 }, this.magFilter = void 0 !== s ? s : 1003, this.minFilter = void 0 !== l ? l : 1003, this.generateMipmaps = !1, this.flipY = !1, this.unpackAlignment = 1, this.needsUpdate = !0 } (He.prototype = Object.create(H.prototype)).constructor = He, (Ye.prototype = Object.create(g.prototype)).constructor = Ye, Ye.prototype.isWebGLCubeRenderTarget = !0, Ye.prototype.fromEquirectangularTexture = function (A, e) { this.texture.type = e.type, this.texture.format = e.format, this.texture.encoding = e.encoding; var t = new Y, i = { uniforms: { tEquirect: { value: null } }, vertexShader: ["varying vec3 vWorldDirection;", "vec3 transformDirection( in vec3 dir, in mat4 matrix ) {", "\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );", "}", "void main() {", "\tvWorldDirection = transformDirection( position, modelMatrix );", "\t#include ", "\t#include ", "}"].join("\n"), fragmentShader: ["uniform sampler2D tEquirect;", "varying vec3 vWorldDirection;", "#define RECIPROCAL_PI 0.31830988618", "#define RECIPROCAL_PI2 0.15915494", "void main() {", "\tvec3 direction = normalize( vWorldDirection );", "\tvec2 sampleUV;", "\tsampleUV.y = asin( clamp( direction.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;", "\tsampleUV.x = atan( direction.z, direction.x ) * RECIPROCAL_PI2 + 0.5;", "\tgl_FragColor = texture2D( tEquirect, sampleUV );", "}"].join("\n") }, o = new Pe({ type: "CubemapFromEquirect", uniforms: Oe(i.uniforms), vertexShader: i.vertexShader, fragmentShader: i.fragmentShader, side: 1, blending: 0 }); o.uniforms.tEquirect.value = e; var n = new Ue(new Ne(5, 5, 5), o); t.add(n); var r = new He(1, 10, 1); return r.renderTarget = this, r.renderTarget.texture.name = "CubeCameraTexture", r.update(A, t), n.geometry.dispose(), n.material.dispose(), this }, (We.prototype = Object.create(d.prototype)).constructor = We, We.prototype.isDataTexture = !0; var Je = new cA, ze = new y; function Ze(A, e, t, i, o, n) { this.planes = [void 0 !== A ? A : new EA, void 0 !== e ? e : new EA, void 0 !== t ? t : new EA, void 0 !== i ? i : new EA, void 0 !== o ? o : new EA, void 0 !== n ? n : new EA] } Object.assign(Ze.prototype, { set: function (A, e, t, i, o, n) { var r = this.planes; return r[0].copy(A), r[1].copy(e), r[2].copy(t), r[3].copy(i), r[4].copy(o), r[5].copy(n), this }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { for (var e = this.planes, t = 0; 6 > t; t++) e[t].copy(A.planes[t]); return this }, setFromProjectionMatrix: function (A) { var e = this.planes, t = A.elements, i = t[0], o = t[1], n = t[2], r = t[3], a = t[4], s = t[5], l = t[6], c = t[7], h = t[8], d = t[9], p = t[10], g = t[11], u = t[12], f = t[13], m = t[14], C = t[15]; return e[0].setComponents(r - i, c - a, g - h, C - u).normalize(), e[1].setComponents(r + i, c + a, g + h, C + u).normalize(), e[2].setComponents(r + o, c + s, g + d, C + f).normalize(), e[3].setComponents(r - o, c - s, g - d, C - f).normalize(), e[4].setComponents(r - n, c - l, g - p, C - m).normalize(), e[5].setComponents(r + n, c + l, g + p, C + m).normalize(), this }, intersectsObject: function (A) { var e = A.geometry; return null === e.boundingSphere && e.computeBoundingSphere(), Je.copy(e.boundingSphere).applyMatrix4(A.matrixWorld), this.intersectsSphere(Je) }, intersectsSprite: function (A) { return Je.center.set(0, 0, 0), Je.radius = .7071067811865476, Je.applyMatrix4(A.matrixWorld), this.intersectsSphere(Je) }, intersectsSphere: function (A) { for (var e = this.planes, t = A.center, i = -A.radius, o = 0; 6 > o; o++) { if (i > e[o].distanceToPoint(t)) return !1 } return !0 }, intersectsBox: function (A) { for (var e = this.planes, t = 0; 6 > t; t++) { var i = e[t]; if (ze.x = i.normal.x > 0 ? A.max.x : A.min.x, ze.y = i.normal.y > 0 ? A.max.y : A.min.y, ze.z = i.normal.z > 0 ? A.max.z : A.min.z, 0 > i.distanceToPoint(ze)) return !1 } return !0 }, containsPoint: function (A) { for (var e = this.planes, t = 0; 6 > t; t++) if (0 > e[t].distanceToPoint(A)) return !1; return !0 } }); var Xe = { common: { diffuse: { value: new LA(15658734) }, opacity: { value: 1 }, map: { value: null }, uvTransform: { value: new l }, uv2Transform: { value: new l }, alphaMap: { value: null } }, specularmap: { specularMap: { value: null } }, envmap: { envMap: { value: null }, flipEnvMap: { value: -1 }, reflectivity: { value: 1 }, refractionRatio: { value: .98 }, maxMipLevel: { value: 0 } }, aomap: { aoMap: { value: null }, aoMapIntensity: { value: 1 } }, lightmap: { lightMap: { value: null }, lightMapIntensity: { value: 1 } }, emissivemap: { emissiveMap: { value: null } }, bumpmap: { bumpMap: { value: null }, bumpScale: { value: 1 } }, normalmap: { normalMap: { value: null }, normalScale: { value: new s(1, 1) } }, displacementmap: { displacementMap: { value: null }, displacementScale: { value: 1 }, displacementBias: { value: 0 } }, roughnessmap: { roughnessMap: { value: null } }, metalnessmap: { metalnessMap: { value: null } }, gradientmap: { gradientMap: { value: null } }, fog: { fogDensity: { value: 25e-5 }, fogNear: { value: 1 }, fogFar: { value: 2e3 }, fogColor: { value: new LA(16777215) } }, lights: { ambientLightColor: { value: [] }, lightProbe: { value: [] }, directionalLights: { value: [], properties: { direction: {}, color: {} } }, directionalLightShadows: { value: [], properties: { shadowBias: {}, shadowRadius: {}, shadowMapSize: {} } }, directionalShadowMap: { value: [] }, directionalShadowMatrix: { value: [] }, spotLights: { value: [], properties: { color: {}, position: {}, direction: {}, distance: {}, coneCos: {}, penumbraCos: {}, decay: {} } }, spotLightShadows: { value: [], properties: { shadowBias: {}, shadowRadius: {}, shadowMapSize: {} } }, spotShadowMap: { value: [] }, spotShadowMatrix: { value: [] }, pointLights: { value: [], properties: { color: {}, position: {}, decay: {}, distance: {} } }, pointLightShadows: { value: [], properties: { shadowBias: {}, shadowRadius: {}, shadowMapSize: {}, shadowCameraNear: {}, shadowCameraFar: {} } }, pointShadowMap: { value: [] }, pointShadowMatrix: { value: [] }, hemisphereLights: { value: [], properties: { direction: {}, skyColor: {}, groundColor: {} } }, rectAreaLights: { value: [], properties: { color: {}, position: {}, width: {}, height: {} } } }, points: { diffuse: { value: new LA(15658734) }, opacity: { value: 1 }, size: { value: 1 }, scale: { value: 1 }, map: { value: null }, alphaMap: { value: null }, uvTransform: { value: new l } }, sprite: { diffuse: { value: new LA(15658734) }, opacity: { value: 1 }, center: { value: new s(.5, .5) }, rotation: { value: 0 }, map: { value: null }, alphaMap: { value: null }, uvTransform: { value: new l } } }; function _e() { var A = null, e = !1, t = null; function i(o, n) { !1 !== e && (t(o, n), A.requestAnimationFrame(i)) } return { start: function () { !0 !== e && null !== t && (A.requestAnimationFrame(i), e = !0) }, stop: function () { e = !1 }, setAnimationLoop: function (A) { t = A }, setContext: function (e) { A = e } } } function $e(A, e) { var t = e.isWebGL2, i = new WeakMap; return { get: function (A) { return A.isInterleavedBufferAttribute && (A = A.data), i.get(A) }, remove: function (e) { e.isInterleavedBufferAttribute && (e = e.data); var t = i.get(e); t && (A.deleteBuffer(t.buffer), i.delete(e)) }, update: function (e, o) { e.isInterleavedBufferAttribute && (e = e.data); var n = i.get(e); void 0 === n ? i.set(e, function (e, t) { var i = e.array, o = e.usage, n = A.createBuffer(); A.bindBuffer(t, n), A.bufferData(t, i, o), e.onUploadCallback(); var r = 5126; return i instanceof Float32Array ? r = 5126 : i instanceof Float64Array ? console.warn("THREE.WebGLAttributes: Unsupported data buffer format: Float64Array.") : i instanceof Uint16Array ? r = 5123 : i instanceof Int16Array ? r = 5122 : i instanceof Uint32Array ? r = 5125 : i instanceof Int32Array ? r = 5124 : i instanceof Int8Array ? r = 5120 : i instanceof Uint8Array && (r = 5121), { buffer: n, type: r, bytesPerElement: i.BYTES_PER_ELEMENT, version: e.version } }(e, o)) : e.version > n.version && (! function (e, i, o) { var n = i.array, r = i.updateRange; A.bindBuffer(o, e), -1 === r.count ? A.bufferSubData(o, 0, n) : (t ? A.bufferSubData(o, r.offset * n.BYTES_PER_ELEMENT, n, r.offset, r.count) : A.bufferSubData(o, r.offset * n.BYTES_PER_ELEMENT, n.subarray(r.offset, r.offset + r.count)), r.count = -1) }(n.buffer, e, o), n.version = e.version) } } } function At(A, e, t, i) { De.call(this), this.type = "PlaneGeometry", this.parameters = { width: A, height: e, widthSegments: t, heightSegments: i }, this.fromBufferGeometry(new et(A, e, t, i)), this.mergeVertices() } function et(A, e, t, i) { he.call(this), this.type = "PlaneBufferGeometry", this.parameters = { width: A, height: e, widthSegments: t, heightSegments: i }; var o, n, r = (A = A || 1) / 2, a = (e = e || 1) / 2, s = Math.floor(t) || 1, l = Math.floor(i) || 1, c = s + 1, h = l + 1, d = A / s, p = e / l, g = [], u = [], f = [], m = []; for (n = 0; h > n; n++) { var C = n * p - a; for (o = 0; c > o; o++) { u.push(o * d - r, -C, 0), f.push(0, 0, 1), m.push(o / s), m.push(1 - n / l) } } for (n = 0; l > n; n++) for (o = 0; s > o; o++) { var y = o + c * (n + 1), v = o + 1 + c * (n + 1), I = o + 1 + c * n; g.push(o + c * n, y, I), g.push(y, v, I) } this.setIndex(g), this.setAttribute("position", new Ae(u, 3)), this.setAttribute("normal", new Ae(f, 3)), this.setAttribute("uv", new Ae(m, 2)) } (At.prototype = Object.create(De.prototype)).constructor = At, (et.prototype = Object.create(he.prototype)).constructor = et; var tt = { alphamap_fragment: "#ifdef USE_ALPHAMAP\n\tdiffuseColor.a *= texture2D( alphaMap, vUv ).g;\n#endif", alphamap_pars_fragment: "#ifdef USE_ALPHAMAP\n\tuniform sampler2D alphaMap;\n#endif", alphatest_fragment: "#ifdef ALPHATEST\n\tif ( diffuseColor.a < ALPHATEST ) discard;\n#endif", aomap_fragment: "#ifdef USE_AOMAP\n\tfloat ambientOcclusion = ( texture2D( aoMap, vUv2 ).r - 1.0 ) * aoMapIntensity + 1.0;\n\treflectedLight.indirectDiffuse *= ambientOcclusion;\n\t#if defined( USE_ENVMAP ) && defined( STANDARD )\n\t\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\n\t\treflectedLight.indirectSpecular *= computeSpecularOcclusion( dotNV, ambientOcclusion, material.specularRoughness );\n\t#endif\n#endif", aomap_pars_fragment: "#ifdef USE_AOMAP\n\tuniform sampler2D aoMap;\n\tuniform float aoMapIntensity;\n#endif", begin_vertex: "vec3 transformed = vec3( position );", beginnormal_vertex: "vec3 objectNormal = vec3( normal );\n#ifdef USE_TANGENT\n\tvec3 objectTangent = vec3( tangent.xyz );\n#endif", bsdfs: "vec2 integrateSpecularBRDF( const in float dotNV, const in float roughness ) {\n\tconst vec4 c0 = vec4( - 1, - 0.0275, - 0.572, 0.022 );\n\tconst vec4 c1 = vec4( 1, 0.0425, 1.04, - 0.04 );\n\tvec4 r = roughness * c0 + c1;\n\tfloat a004 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\n\treturn vec2( -1.04, 1.04 ) * a004 + r.zw;\n}\nfloat punctualLightIntensityToIrradianceFactor( const in float lightDistance, const in float cutoffDistance, const in float decayExponent ) {\n#if defined ( PHYSICALLY_CORRECT_LIGHTS )\n\tfloat distanceFalloff = 1.0 / max( pow( lightDistance, decayExponent ), 0.01 );\n\tif( cutoffDistance > 0.0 ) {\n\t\tdistanceFalloff *= pow2( saturate( 1.0 - pow4( lightDistance / cutoffDistance ) ) );\n\t}\n\treturn distanceFalloff;\n#else\n\tif( cutoffDistance > 0.0 && decayExponent > 0.0 ) {\n\t\treturn pow( saturate( -lightDistance / cutoffDistance + 1.0 ), decayExponent );\n\t}\n\treturn 1.0;\n#endif\n}\nvec3 BRDF_Diffuse_Lambert( const in vec3 diffuseColor ) {\n\treturn RECIPROCAL_PI * diffuseColor;\n}\nvec3 F_Schlick( const in vec3 specularColor, const in float dotLH ) {\n\tfloat fresnel = exp2( ( -5.55473 * dotLH - 6.98316 ) * dotLH );\n\treturn ( 1.0 - specularColor ) * fresnel + specularColor;\n}\nvec3 F_Schlick_RoughnessDependent( const in vec3 F0, const in float dotNV, const in float roughness ) {\n\tfloat fresnel = exp2( ( -5.55473 * dotNV - 6.98316 ) * dotNV );\n\tvec3 Fr = max( vec3( 1.0 - roughness ), F0 ) - F0;\n\treturn Fr * fresnel + F0;\n}\nfloat G_GGX_Smith( const in float alpha, const in float dotNL, const in float dotNV ) {\n\tfloat a2 = pow2( alpha );\n\tfloat gl = dotNL + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\n\tfloat gv = dotNV + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\n\treturn 1.0 / ( gl * gv );\n}\nfloat G_GGX_SmithCorrelated( const in float alpha, const in float dotNL, const in float dotNV ) {\n\tfloat a2 = pow2( alpha );\n\tfloat gv = dotNL * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\n\tfloat gl = dotNV * sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\n\treturn 0.5 / max( gv + gl, EPSILON );\n}\nfloat D_GGX( const in float alpha, const in float dotNH ) {\n\tfloat a2 = pow2( alpha );\n\tfloat denom = pow2( dotNH ) * ( a2 - 1.0 ) + 1.0;\n\treturn RECIPROCAL_PI * a2 / pow2( denom );\n}\nvec3 BRDF_Specular_GGX( const in IncidentLight incidentLight, const in vec3 viewDir, const in vec3 normal, const in vec3 specularColor, const in float roughness ) {\n\tfloat alpha = pow2( roughness );\n\tvec3 halfDir = normalize( incidentLight.direction + viewDir );\n\tfloat dotNL = saturate( dot( normal, incidentLight.direction ) );\n\tfloat dotNV = saturate( dot( normal, viewDir ) );\n\tfloat dotNH = saturate( dot( normal, halfDir ) );\n\tfloat dotLH = saturate( dot( incidentLight.direction, halfDir ) );\n\tvec3 F = F_Schlick( specularColor, dotLH );\n\tfloat G = G_GGX_SmithCorrelated( alpha, dotNL, dotNV );\n\tfloat D = D_GGX( alpha, dotNH );\n\treturn F * ( G * D );\n}\nvec2 LTC_Uv( const in vec3 N, const in vec3 V, const in float roughness ) {\n\tconst float LUT_SIZE = 64.0;\n\tconst float LUT_SCALE = ( LUT_SIZE - 1.0 ) / LUT_SIZE;\n\tconst float LUT_BIAS = 0.5 / LUT_SIZE;\n\tfloat dotNV = saturate( dot( N, V ) );\n\tvec2 uv = vec2( roughness, sqrt( 1.0 - dotNV ) );\n\tuv = uv * LUT_SCALE + LUT_BIAS;\n\treturn uv;\n}\nfloat LTC_ClippedSphereFormFactor( const in vec3 f ) {\n\tfloat l = length( f );\n\treturn max( ( l * l + f.z ) / ( l + 1.0 ), 0.0 );\n}\nvec3 LTC_EdgeVectorFormFactor( const in vec3 v1, const in vec3 v2 ) {\n\tfloat x = dot( v1, v2 );\n\tfloat y = abs( x );\n\tfloat a = 0.8543985 + ( 0.4965155 + 0.0145206 * y ) * y;\n\tfloat b = 3.4175940 + ( 4.1616724 + y ) * y;\n\tfloat v = a / b;\n\tfloat theta_sintheta = ( x > 0.0 ) ? v : 0.5 * inversesqrt( max( 1.0 - x * x, 1e-7 ) ) - v;\n\treturn cross( v1, v2 ) * theta_sintheta;\n}\nvec3 LTC_Evaluate( const in vec3 N, const in vec3 V, const in vec3 P, const in mat3 mInv, const in vec3 rectCoords[ 4 ] ) {\n\tvec3 v1 = rectCoords[ 1 ] - rectCoords[ 0 ];\n\tvec3 v2 = rectCoords[ 3 ] - rectCoords[ 0 ];\n\tvec3 lightNormal = cross( v1, v2 );\n\tif( dot( lightNormal, P - rectCoords[ 0 ] ) < 0.0 ) return vec3( 0.0 );\n\tvec3 T1, T2;\n\tT1 = normalize( V - N * dot( V, N ) );\n\tT2 = - cross( N, T1 );\n\tmat3 mat = mInv * transposeMat3( mat3( T1, T2, N ) );\n\tvec3 coords[ 4 ];\n\tcoords[ 0 ] = mat * ( rectCoords[ 0 ] - P );\n\tcoords[ 1 ] = mat * ( rectCoords[ 1 ] - P );\n\tcoords[ 2 ] = mat * ( rectCoords[ 2 ] - P );\n\tcoords[ 3 ] = mat * ( rectCoords[ 3 ] - P );\n\tcoords[ 0 ] = normalize( coords[ 0 ] );\n\tcoords[ 1 ] = normalize( coords[ 1 ] );\n\tcoords[ 2 ] = normalize( coords[ 2 ] );\n\tcoords[ 3 ] = normalize( coords[ 3 ] );\n\tvec3 vectorFormFactor = vec3( 0.0 );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 0 ], coords[ 1 ] );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 1 ], coords[ 2 ] );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 2 ], coords[ 3 ] );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 3 ], coords[ 0 ] );\n\tfloat result = LTC_ClippedSphereFormFactor( vectorFormFactor );\n\treturn vec3( result );\n}\nvec3 BRDF_Specular_GGX_Environment( const in vec3 viewDir, const in vec3 normal, const in vec3 specularColor, const in float roughness ) {\n\tfloat dotNV = saturate( dot( normal, viewDir ) );\n\tvec2 brdf = integrateSpecularBRDF( dotNV, roughness );\n\treturn specularColor * brdf.x + brdf.y;\n}\nvoid BRDF_Specular_Multiscattering_Environment( const in GeometricContext geometry, const in vec3 specularColor, const in float roughness, inout vec3 singleScatter, inout vec3 multiScatter ) {\n\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\n\tvec3 F = F_Schlick_RoughnessDependent( specularColor, dotNV, roughness );\n\tvec2 brdf = integrateSpecularBRDF( dotNV, roughness );\n\tvec3 FssEss = F * brdf.x + brdf.y;\n\tfloat Ess = brdf.x + brdf.y;\n\tfloat Ems = 1.0 - Ess;\n\tvec3 Favg = specularColor + ( 1.0 - specularColor ) * 0.047619;\tvec3 Fms = FssEss * Favg / ( 1.0 - Ems * Favg );\n\tsingleScatter += FssEss;\n\tmultiScatter += Fms * Ems;\n}\nfloat G_BlinnPhong_Implicit( ) {\n\treturn 0.25;\n}\nfloat D_BlinnPhong( const in float shininess, const in float dotNH ) {\n\treturn RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow( dotNH, shininess );\n}\nvec3 BRDF_Specular_BlinnPhong( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float shininess ) {\n\tvec3 halfDir = normalize( incidentLight.direction + geometry.viewDir );\n\tfloat dotNH = saturate( dot( geometry.normal, halfDir ) );\n\tfloat dotLH = saturate( dot( incidentLight.direction, halfDir ) );\n\tvec3 F = F_Schlick( specularColor, dotLH );\n\tfloat G = G_BlinnPhong_Implicit( );\n\tfloat D = D_BlinnPhong( shininess, dotNH );\n\treturn F * ( G * D );\n}\nfloat GGXRoughnessToBlinnExponent( const in float ggxRoughness ) {\n\treturn ( 2.0 / pow2( ggxRoughness + 0.0001 ) - 2.0 );\n}\nfloat BlinnExponentToGGXRoughness( const in float blinnExponent ) {\n\treturn sqrt( 2.0 / ( blinnExponent + 2.0 ) );\n}\n#if defined( USE_SHEEN )\nfloat D_Charlie(float roughness, float NoH) {\n\tfloat invAlpha = 1.0 / roughness;\n\tfloat cos2h = NoH * NoH;\n\tfloat sin2h = max(1.0 - cos2h, 0.0078125);\treturn (2.0 + invAlpha) * pow(sin2h, invAlpha * 0.5) / (2.0 * PI);\n}\nfloat V_Neubelt(float NoV, float NoL) {\n\treturn saturate(1.0 / (4.0 * (NoL + NoV - NoL * NoV)));\n}\nvec3 BRDF_Specular_Sheen( const in float roughness, const in vec3 L, const in GeometricContext geometry, vec3 specularColor ) {\n\tvec3 N = geometry.normal;\n\tvec3 V = geometry.viewDir;\n\tvec3 H = normalize( V + L );\n\tfloat dotNH = saturate( dot( N, H ) );\n\treturn specularColor * D_Charlie( roughness, dotNH ) * V_Neubelt( dot(N, V), dot(N, L) );\n}\n#endif", bumpmap_pars_fragment: "#ifdef USE_BUMPMAP\n\tuniform sampler2D bumpMap;\n\tuniform float bumpScale;\n\tvec2 dHdxy_fwd() {\n\t\tvec2 dSTdx = dFdx( vUv );\n\t\tvec2 dSTdy = dFdy( vUv );\n\t\tfloat Hll = bumpScale * texture2D( bumpMap, vUv ).x;\n\t\tfloat dBx = bumpScale * texture2D( bumpMap, vUv + dSTdx ).x - Hll;\n\t\tfloat dBy = bumpScale * texture2D( bumpMap, vUv + dSTdy ).x - Hll;\n\t\treturn vec2( dBx, dBy );\n\t}\n\tvec3 perturbNormalArb( vec3 surf_pos, vec3 surf_norm, vec2 dHdxy ) {\n\t\tvec3 vSigmaX = vec3( dFdx( surf_pos.x ), dFdx( surf_pos.y ), dFdx( surf_pos.z ) );\n\t\tvec3 vSigmaY = vec3( dFdy( surf_pos.x ), dFdy( surf_pos.y ), dFdy( surf_pos.z ) );\n\t\tvec3 vN = surf_norm;\n\t\tvec3 R1 = cross( vSigmaY, vN );\n\t\tvec3 R2 = cross( vN, vSigmaX );\n\t\tfloat fDet = dot( vSigmaX, R1 );\n\t\tfDet *= ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\tvec3 vGrad = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\n\t\treturn normalize( abs( fDet ) * surf_norm - vGrad );\n\t}\n#endif", clipping_planes_fragment: "#if NUM_CLIPPING_PLANES > 0\n\tvec4 plane;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < UNION_CLIPPING_PLANES; i ++ ) {\n\t\tplane = clippingPlanes[ i ];\n\t\tif ( dot( vClipPosition, plane.xyz ) > plane.w ) discard;\n\t}\n\t#pragma unroll_loop_end\n\t#if UNION_CLIPPING_PLANES < NUM_CLIPPING_PLANES\n\t\tbool clipped = true;\n\t\t#pragma unroll_loop_start\n\t\tfor ( int i = UNION_CLIPPING_PLANES; i < NUM_CLIPPING_PLANES; i ++ ) {\n\t\t\tplane = clippingPlanes[ i ];\n\t\t\tclipped = ( dot( vClipPosition, plane.xyz ) > plane.w ) && clipped;\n\t\t}\n\t\t#pragma unroll_loop_end\n\t\tif ( clipped ) discard;\n\t#endif\n#endif", clipping_planes_pars_fragment: "#if NUM_CLIPPING_PLANES > 0\n\tvarying vec3 vClipPosition;\n\tuniform vec4 clippingPlanes[ NUM_CLIPPING_PLANES ];\n#endif", clipping_planes_pars_vertex: "#if NUM_CLIPPING_PLANES > 0\n\tvarying vec3 vClipPosition;\n#endif", clipping_planes_vertex: "#if NUM_CLIPPING_PLANES > 0\n\tvClipPosition = - mvPosition.xyz;\n#endif", color_fragment: "#ifdef USE_COLOR\n\tdiffuseColor.rgb *= vColor;\n#endif", color_pars_fragment: "#ifdef USE_COLOR\n\tvarying vec3 vColor;\n#endif", color_pars_vertex: "#ifdef USE_COLOR\n\tvarying vec3 vColor;\n#endif", color_vertex: "#ifdef USE_COLOR\n\tvColor.xyz = color.xyz;\n#endif", common: "#define PI 3.14159265359\n#define PI2 6.28318530718\n#define PI_HALF 1.5707963267949\n#define RECIPROCAL_PI 0.31830988618\n#define RECIPROCAL_PI2 0.15915494\n#define LOG2 1.442695\n#define EPSILON 1e-6\n#ifndef saturate\n#define saturate(a) clamp( a, 0.0, 1.0 )\n#endif\n#define whiteComplement(a) ( 1.0 - saturate( a ) )\nfloat pow2( const in float x ) { return x*x; }\nfloat pow3( const in float x ) { return x*x*x; }\nfloat pow4( const in float x ) { float x2 = x*x; return x2*x2; }\nfloat average( const in vec3 color ) { return dot( color, vec3( 0.3333 ) ); }\nhighp float rand( const in vec2 uv ) {\n\tconst highp float a = 12.9898, b = 78.233, c = 43758.5453;\n\thighp float dt = dot( uv.xy, vec2( a,b ) ), sn = mod( dt, PI );\n\treturn fract(sin(sn) * c);\n}\n#ifdef HIGH_PRECISION\n\tfloat precisionSafeLength( vec3 v ) { return length( v ); }\n#else\n\tfloat max3( vec3 v ) { return max( max( v.x, v.y ), v.z ); }\n\tfloat precisionSafeLength( vec3 v ) {\n\t\tfloat maxComponent = max3( abs( v ) );\n\t\treturn length( v / maxComponent ) * maxComponent;\n\t}\n#endif\nstruct IncidentLight {\n\tvec3 color;\n\tvec3 direction;\n\tbool visible;\n};\nstruct ReflectedLight {\n\tvec3 directDiffuse;\n\tvec3 directSpecular;\n\tvec3 indirectDiffuse;\n\tvec3 indirectSpecular;\n};\nstruct GeometricContext {\n\tvec3 position;\n\tvec3 normal;\n\tvec3 viewDir;\n#ifdef CLEARCOAT\n\tvec3 clearcoatNormal;\n#endif\n};\nvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\n\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\n}\nvec3 inverseTransformDirection( in vec3 dir, in mat4 matrix ) {\n\treturn normalize( ( vec4( dir, 0.0 ) * matrix ).xyz );\n}\nvec3 projectOnPlane(in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\tfloat distance = dot( planeNormal, point - pointOnPlane );\n\treturn - distance * planeNormal + point;\n}\nfloat sideOfPlane( in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\treturn sign( dot( point - pointOnPlane, planeNormal ) );\n}\nvec3 linePlaneIntersect( in vec3 pointOnLine, in vec3 lineDirection, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\treturn lineDirection * ( dot( planeNormal, pointOnPlane - pointOnLine ) / dot( planeNormal, lineDirection ) ) + pointOnLine;\n}\nmat3 transposeMat3( const in mat3 m ) {\n\tmat3 tmp;\n\ttmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\n\ttmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\n\ttmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\n\treturn tmp;\n}\nfloat linearToRelativeLuminance( const in vec3 color ) {\n\tvec3 weights = vec3( 0.2126, 0.7152, 0.0722 );\n\treturn dot( weights, color.rgb );\n}\nbool isPerspectiveMatrix( mat4 m ) {\n return m[ 2 ][ 3 ] == - 1.0;\n}", cube_uv_reflection_fragment: "#ifdef ENVMAP_TYPE_CUBE_UV\n#define cubeUV_maxMipLevel 8.0\n#define cubeUV_minMipLevel 4.0\n#define cubeUV_maxTileSize 256.0\n#define cubeUV_minTileSize 16.0\nfloat getFace(vec3 direction) {\n vec3 absDirection = abs(direction);\n float face = -1.0;\n if (absDirection.x > absDirection.z) {\n if (absDirection.x > absDirection.y)\n face = direction.x > 0.0 ? 0.0 : 3.0;\n else\n face = direction.y > 0.0 ? 1.0 : 4.0;\n } else {\n if (absDirection.z > absDirection.y)\n face = direction.z > 0.0 ? 2.0 : 5.0;\n else\n face = direction.y > 0.0 ? 1.0 : 4.0;\n }\n return face;\n}\nvec2 getUV(vec3 direction, float face) {\n vec2 uv;\n if (face == 0.0) {\n uv = vec2(-direction.z, direction.y) / abs(direction.x);\n } else if (face == 1.0) {\n uv = vec2(direction.x, -direction.z) / abs(direction.y);\n } else if (face == 2.0) {\n uv = direction.xy / abs(direction.z);\n } else if (face == 3.0) {\n uv = vec2(direction.z, direction.y) / abs(direction.x);\n } else if (face == 4.0) {\n uv = direction.xz / abs(direction.y);\n } else {\n uv = vec2(-direction.x, direction.y) / abs(direction.z);\n }\n return 0.5 * (uv + 1.0);\n}\nvec3 bilinearCubeUV(sampler2D envMap, vec3 direction, float mipInt) {\n float face = getFace(direction);\n float filterInt = max(cubeUV_minMipLevel - mipInt, 0.0);\n mipInt = max(mipInt, cubeUV_minMipLevel);\n float faceSize = exp2(mipInt);\n float texelSize = 1.0 / (3.0 * cubeUV_maxTileSize);\n vec2 uv = getUV(direction, face) * (faceSize - 1.0);\n vec2 f = fract(uv);\n uv += 0.5 - f;\n if (face > 2.0) {\n uv.y += faceSize;\n face -= 3.0;\n }\n uv.x += face * faceSize;\n if(mipInt < cubeUV_maxMipLevel){\n uv.y += 2.0 * cubeUV_maxTileSize;\n }\n uv.y += filterInt * 2.0 * cubeUV_minTileSize;\n uv.x += 3.0 * max(0.0, cubeUV_maxTileSize - 2.0 * faceSize);\n uv *= texelSize;\n vec3 tl = envMapTexelToLinear(texture2D(envMap, uv)).rgb;\n uv.x += texelSize;\n vec3 tr = envMapTexelToLinear(texture2D(envMap, uv)).rgb;\n uv.y += texelSize;\n vec3 br = envMapTexelToLinear(texture2D(envMap, uv)).rgb;\n uv.x -= texelSize;\n vec3 bl = envMapTexelToLinear(texture2D(envMap, uv)).rgb;\n vec3 tm = mix(tl, tr, f.x);\n vec3 bm = mix(bl, br, f.x);\n return mix(tm, bm, f.y);\n}\n#define r0 1.0\n#define v0 0.339\n#define m0 -2.0\n#define r1 0.8\n#define v1 0.276\n#define m1 -1.0\n#define r4 0.4\n#define v4 0.046\n#define m4 2.0\n#define r5 0.305\n#define v5 0.016\n#define m5 3.0\n#define r6 0.21\n#define v6 0.0038\n#define m6 4.0\nfloat roughnessToMip(float roughness) {\n float mip = 0.0;\n if (roughness >= r1) {\n mip = (r0 - roughness) * (m1 - m0) / (r0 - r1) + m0;\n } else if (roughness >= r4) {\n mip = (r1 - roughness) * (m4 - m1) / (r1 - r4) + m1;\n } else if (roughness >= r5) {\n mip = (r4 - roughness) * (m5 - m4) / (r4 - r5) + m4;\n } else if (roughness >= r6) {\n mip = (r5 - roughness) * (m6 - m5) / (r5 - r6) + m5;\n } else {\n mip = -2.0 * log2(1.16 * roughness); }\n return mip;\n}\nvec4 textureCubeUV(sampler2D envMap, vec3 sampleDir, float roughness) {\n float mip = clamp(roughnessToMip(roughness), m0, cubeUV_maxMipLevel);\n float mipF = fract(mip);\n float mipInt = floor(mip);\n vec3 color0 = bilinearCubeUV(envMap, sampleDir, mipInt);\n if (mipF == 0.0) {\n return vec4(color0, 1.0);\n } else {\n vec3 color1 = bilinearCubeUV(envMap, sampleDir, mipInt + 1.0);\n return vec4(mix(color0, color1, mipF), 1.0);\n }\n}\n#endif", defaultnormal_vertex: "vec3 transformedNormal = objectNormal;\n#ifdef USE_INSTANCING\n\tmat3 m = mat3( instanceMatrix );\n\ttransformedNormal /= vec3( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) );\n\ttransformedNormal = m * transformedNormal;\n#endif\ntransformedNormal = normalMatrix * transformedNormal;\n#ifdef FLIP_SIDED\n\ttransformedNormal = - transformedNormal;\n#endif\n#ifdef USE_TANGENT\n\tvec3 transformedTangent = ( modelViewMatrix * vec4( objectTangent, 0.0 ) ).xyz;\n\t#ifdef FLIP_SIDED\n\t\ttransformedTangent = - transformedTangent;\n\t#endif\n#endif", displacementmap_pars_vertex: "#ifdef USE_DISPLACEMENTMAP\n\tuniform sampler2D displacementMap;\n\tuniform float displacementScale;\n\tuniform float displacementBias;\n#endif", displacementmap_vertex: "#ifdef USE_DISPLACEMENTMAP\n\ttransformed += normalize( objectNormal ) * ( texture2D( displacementMap, vUv ).x * displacementScale + displacementBias );\n#endif", emissivemap_fragment: "#ifdef USE_EMISSIVEMAP\n\tvec4 emissiveColor = texture2D( emissiveMap, vUv );\n\temissiveColor.rgb = emissiveMapTexelToLinear( emissiveColor ).rgb;\n\ttotalEmissiveRadiance *= emissiveColor.rgb;\n#endif", emissivemap_pars_fragment: "#ifdef USE_EMISSIVEMAP\n\tuniform sampler2D emissiveMap;\n#endif", encodings_fragment: "gl_FragColor = linearToOutputTexel( gl_FragColor );", encodings_pars_fragment: "\nvec4 LinearToLinear( in vec4 value ) {\n\treturn value;\n}\nvec4 GammaToLinear( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.rgb, vec3( gammaFactor ) ), value.a );\n}\nvec4 LinearToGamma( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.rgb, vec3( 1.0 / gammaFactor ) ), value.a );\n}\nvec4 sRGBToLinear( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), value.rgb * 0.0773993808, vec3( lessThanEqual( value.rgb, vec3( 0.04045 ) ) ) ), value.a );\n}\nvec4 LinearTosRGB( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a );\n}\nvec4 RGBEToLinear( in vec4 value ) {\n\treturn vec4( value.rgb * exp2( value.a * 255.0 - 128.0 ), 1.0 );\n}\nvec4 LinearToRGBE( in vec4 value ) {\n\tfloat maxComponent = max( max( value.r, value.g ), value.b );\n\tfloat fExp = clamp( ceil( log2( maxComponent ) ), -128.0, 127.0 );\n\treturn vec4( value.rgb / exp2( fExp ), ( fExp + 128.0 ) / 255.0 );\n}\nvec4 RGBMToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * value.a * maxRange, 1.0 );\n}\nvec4 LinearToRGBM( in vec4 value, in float maxRange ) {\n\tfloat maxRGB = max( value.r, max( value.g, value.b ) );\n\tfloat M = clamp( maxRGB / maxRange, 0.0, 1.0 );\n\tM = ceil( M * 255.0 ) / 255.0;\n\treturn vec4( value.rgb / ( M * maxRange ), M );\n}\nvec4 RGBDToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * ( ( maxRange / 255.0 ) / value.a ), 1.0 );\n}\nvec4 LinearToRGBD( in vec4 value, in float maxRange ) {\n\tfloat maxRGB = max( value.r, max( value.g, value.b ) );\n\tfloat D = max( maxRange / maxRGB, 1.0 );\n\tD = clamp( floor( D ) / 255.0, 0.0, 1.0 );\n\treturn vec4( value.rgb * ( D * ( 255.0 / maxRange ) ), D );\n}\nconst mat3 cLogLuvM = mat3( 0.2209, 0.3390, 0.4184, 0.1138, 0.6780, 0.7319, 0.0102, 0.1130, 0.2969 );\nvec4 LinearToLogLuv( in vec4 value ) {\n\tvec3 Xp_Y_XYZp = cLogLuvM * value.rgb;\n\tXp_Y_XYZp = max( Xp_Y_XYZp, vec3( 1e-6, 1e-6, 1e-6 ) );\n\tvec4 vResult;\n\tvResult.xy = Xp_Y_XYZp.xy / Xp_Y_XYZp.z;\n\tfloat Le = 2.0 * log2(Xp_Y_XYZp.y) + 127.0;\n\tvResult.w = fract( Le );\n\tvResult.z = ( Le - ( floor( vResult.w * 255.0 ) ) / 255.0 ) / 255.0;\n\treturn vResult;\n}\nconst mat3 cLogLuvInverseM = mat3( 6.0014, -2.7008, -1.7996, -1.3320, 3.1029, -5.7721, 0.3008, -1.0882, 5.6268 );\nvec4 LogLuvToLinear( in vec4 value ) {\n\tfloat Le = value.z * 255.0 + value.w;\n\tvec3 Xp_Y_XYZp;\n\tXp_Y_XYZp.y = exp2( ( Le - 127.0 ) / 2.0 );\n\tXp_Y_XYZp.z = Xp_Y_XYZp.y / value.y;\n\tXp_Y_XYZp.x = value.x * Xp_Y_XYZp.z;\n\tvec3 vRGB = cLogLuvInverseM * Xp_Y_XYZp.rgb;\n\treturn vec4( max( vRGB, 0.0 ), 1.0 );\n}", envmap_fragment: "#ifdef USE_ENVMAP\n\t#ifdef ENV_WORLDPOS\n\t\tvec3 cameraToFrag;\n\t\t\n\t\tif ( isOrthographic ) {\n\t\t\tcameraToFrag = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) );\n\t\t} else {\n\t\t\tcameraToFrag = normalize( vWorldPosition - cameraPosition );\n\t\t}\n\t\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvec3 reflectVec = reflect( cameraToFrag, worldNormal );\n\t\t#else\n\t\t\tvec3 reflectVec = refract( cameraToFrag, worldNormal, refractionRatio );\n\t\t#endif\n\t#else\n\t\tvec3 reflectVec = vReflect;\n\t#endif\n\t#ifdef ENVMAP_TYPE_CUBE\n\t\tvec4 envColor = textureCube( envMap, vec3( flipEnvMap * reflectVec.x, reflectVec.yz ) );\n\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\tvec4 envColor = textureCubeUV( envMap, reflectVec, 0.0 );\n\t#elif defined( ENVMAP_TYPE_EQUIREC )\n\t\tvec2 sampleUV;\n\t\treflectVec = normalize( reflectVec );\n\t\tsampleUV.y = asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\t\tsampleUV.x = atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;\n\t\tvec4 envColor = texture2D( envMap, sampleUV );\n\t#elif defined( ENVMAP_TYPE_SPHERE )\n\t\treflectVec = normalize( reflectVec );\n\t\tvec3 reflectView = normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0, 0.0, 1.0 ) );\n\t\tvec4 envColor = texture2D( envMap, reflectView.xy * 0.5 + 0.5 );\n\t#else\n\t\tvec4 envColor = vec4( 0.0 );\n\t#endif\n\t#ifndef ENVMAP_TYPE_CUBE_UV\n\t\tenvColor = envMapTexelToLinear( envColor );\n\t#endif\n\t#ifdef ENVMAP_BLENDING_MULTIPLY\n\t\toutgoingLight = mix( outgoingLight, outgoingLight * envColor.xyz, specularStrength * reflectivity );\n\t#elif defined( ENVMAP_BLENDING_MIX )\n\t\toutgoingLight = mix( outgoingLight, envColor.xyz, specularStrength * reflectivity );\n\t#elif defined( ENVMAP_BLENDING_ADD )\n\t\toutgoingLight += envColor.xyz * specularStrength * reflectivity;\n\t#endif\n#endif", envmap_common_pars_fragment: "#ifdef USE_ENVMAP\n\tuniform float envMapIntensity;\n\tuniform float flipEnvMap;\n\tuniform int maxMipLevel;\n\t#ifdef ENVMAP_TYPE_CUBE\n\t\tuniform samplerCube envMap;\n\t#else\n\t\tuniform sampler2D envMap;\n\t#endif\n\t\n#endif", envmap_pars_fragment: "#ifdef USE_ENVMAP\n\tuniform float reflectivity;\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\t#define ENV_WORLDPOS\n\t#endif\n\t#ifdef ENV_WORLDPOS\n\t\tvarying vec3 vWorldPosition;\n\t\tuniform float refractionRatio;\n\t#else\n\t\tvarying vec3 vReflect;\n\t#endif\n#endif", envmap_pars_vertex: "#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) ||defined( PHONG )\n\t\t#define ENV_WORLDPOS\n\t#endif\n\t#ifdef ENV_WORLDPOS\n\t\t\n\t\tvarying vec3 vWorldPosition;\n\t#else\n\t\tvarying vec3 vReflect;\n\t\tuniform float refractionRatio;\n\t#endif\n#endif", envmap_physical_pars_fragment: "#if defined( USE_ENVMAP )\n\t#ifdef ENVMAP_MODE_REFRACTION\n\t\tuniform float refractionRatio;\n\t#endif\n\tvec3 getLightProbeIndirectIrradiance( const in GeometricContext geometry, const in int maxMIPLevel ) {\n\t\tvec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix );\n\t\t#ifdef ENVMAP_TYPE_CUBE\n\t\t\tvec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor = textureCubeLodEXT( envMap, queryVec, float( maxMIPLevel ) );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor = textureCube( envMap, queryVec, float( maxMIPLevel ) );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec4 envMapColor = textureCubeUV( envMap, worldNormal, 1.0 );\n\t\t#else\n\t\t\tvec4 envMapColor = vec4( 0.0 );\n\t\t#endif\n\t\treturn PI * envMapColor.rgb * envMapIntensity;\n\t}\n\tfloat getSpecularMIPLevel( const in float roughness, const in int maxMIPLevel ) {\n\t\tfloat maxMIPLevelScalar = float( maxMIPLevel );\n\t\tfloat sigma = PI * roughness * roughness / ( 1.0 + roughness );\n\t\tfloat desiredMIPLevel = maxMIPLevelScalar + log2( sigma );\n\t\treturn clamp( desiredMIPLevel, 0.0, maxMIPLevelScalar );\n\t}\n\tvec3 getLightProbeIndirectRadiance( const in vec3 viewDir, const in vec3 normal, const in float roughness, const in int maxMIPLevel ) {\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t vec3 reflectVec = reflect( -viewDir, normal );\n\t\t reflectVec = normalize( mix( reflectVec, normal, roughness * roughness) );\n\t\t#else\n\t\t vec3 reflectVec = refract( -viewDir, normal, refractionRatio );\n\t\t#endif\n\t\treflectVec = inverseTransformDirection( reflectVec, viewMatrix );\n\t\tfloat specularMIPLevel = getSpecularMIPLevel( roughness, maxMIPLevel );\n\t\t#ifdef ENVMAP_TYPE_CUBE\n\t\t\tvec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor = textureCubeLodEXT( envMap, queryReflectVec, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor = textureCube( envMap, queryReflectVec, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec4 envMapColor = textureCubeUV( envMap, reflectVec, roughness );\n\t\t#elif defined( ENVMAP_TYPE_EQUIREC )\n\t\t\tvec2 sampleUV;\n\t\t\tsampleUV.y = asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\t\t\tsampleUV.x = atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor = texture2DLodEXT( envMap, sampleUV, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor = texture2D( envMap, sampleUV, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_SPHERE )\n\t\t\tvec3 reflectView = normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0,0.0,1.0 ) );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor = texture2DLodEXT( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor = texture2D( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\n\t\t#endif\n\t\treturn envMapColor.rgb * envMapIntensity;\n\t}\n#endif", envmap_vertex: "#ifdef USE_ENVMAP\n\t#ifdef ENV_WORLDPOS\n\t\tvWorldPosition = worldPosition.xyz;\n\t#else\n\t\tvec3 cameraToVertex;\n\t\tif ( isOrthographic ) { \n\t\t\tcameraToVertex = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) );\n\t\t} else {\n\t\t\tcameraToVertex = normalize( worldPosition.xyz - cameraPosition );\n\t\t}\n\t\tvec3 worldNormal = inverseTransformDirection( transformedNormal, viewMatrix );\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvReflect = reflect( cameraToVertex, worldNormal );\n\t\t#else\n\t\t\tvReflect = refract( cameraToVertex, worldNormal, refractionRatio );\n\t\t#endif\n\t#endif\n#endif", fog_vertex: "#ifdef USE_FOG\n\tfogDepth = -mvPosition.z;\n#endif", fog_pars_vertex: "#ifdef USE_FOG\n\tvarying float fogDepth;\n#endif", fog_fragment: "#ifdef USE_FOG\n\t#ifdef FOG_EXP2\n\t\tfloat fogFactor = 1.0 - exp( - fogDensity * fogDensity * fogDepth * fogDepth );\n\t#else\n\t\tfloat fogFactor = smoothstep( fogNear, fogFar, fogDepth );\n\t#endif\n\tgl_FragColor.rgb = mix( gl_FragColor.rgb, fogColor, fogFactor );\n#endif", fog_pars_fragment: "#ifdef USE_FOG\n\tuniform vec3 fogColor;\n\tvarying float fogDepth;\n\t#ifdef FOG_EXP2\n\t\tuniform float fogDensity;\n\t#else\n\t\tuniform float fogNear;\n\t\tuniform float fogFar;\n\t#endif\n#endif", gradientmap_pars_fragment: "#ifdef USE_GRADIENTMAP\n\tuniform sampler2D gradientMap;\n#endif\nvec3 getGradientIrradiance( vec3 normal, vec3 lightDirection ) {\n\tfloat dotNL = dot( normal, lightDirection );\n\tvec2 coord = vec2( dotNL * 0.5 + 0.5, 0.0 );\n\t#ifdef USE_GRADIENTMAP\n\t\treturn texture2D( gradientMap, coord ).rgb;\n\t#else\n\t\treturn ( coord.x < 0.7 ) ? vec3( 0.7 ) : vec3( 1.0 );\n\t#endif\n}", lightmap_fragment: "#ifdef USE_LIGHTMAP\n\tvec4 lightMapTexel= texture2D( lightMap, vUv2 );\n\treflectedLight.indirectDiffuse += PI * lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity;\n#endif", lightmap_pars_fragment: "#ifdef USE_LIGHTMAP\n\tuniform sampler2D lightMap;\n\tuniform float lightMapIntensity;\n#endif", lights_lambert_vertex: "vec3 diffuse = vec3( 1.0 );\nGeometricContext geometry;\ngeometry.position = mvPosition.xyz;\ngeometry.normal = normalize( transformedNormal );\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( -mvPosition.xyz );\nGeometricContext backGeometry;\nbackGeometry.position = geometry.position;\nbackGeometry.normal = -geometry.normal;\nbackGeometry.viewDir = geometry.viewDir;\nvLightFront = vec3( 0.0 );\nvIndirectFront = vec3( 0.0 );\n#ifdef DOUBLE_SIDED\n\tvLightBack = vec3( 0.0 );\n\tvIndirectBack = vec3( 0.0 );\n#endif\nIncidentLight directLight;\nfloat dotNL;\nvec3 directLightColor_Diffuse;\n#if NUM_POINT_LIGHTS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\t\tgetPointDirectLightIrradiance( pointLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = PI * directLight.color;\n\t\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack += saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if NUM_SPOT_LIGHTS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\t\tgetSpotDirectLightIrradiance( spotLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = PI * directLight.color;\n\t\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack += saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if NUM_DIR_LIGHTS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\t\tgetDirectionalDirectLightIrradiance( directionalLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = PI * directLight.color;\n\t\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack += saturate( -dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if NUM_HEMI_LIGHTS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\n\t\tvIndirectFront += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvIndirectBack += getHemisphereLightIrradiance( hemisphereLights[ i ], backGeometry );\n\t\t#endif\n\t}\n\t#pragma unroll_loop_end\n#endif", lights_pars_begin: "uniform bool receiveShadow;\nuniform vec3 ambientLightColor;\nuniform vec3 lightProbe[ 9 ];\nvec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) {\n\tfloat x = normal.x, y = normal.y, z = normal.z;\n\tvec3 result = shCoefficients[ 0 ] * 0.886227;\n\tresult += shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\n\tresult += shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\n\tresult += shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\n\tresult += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\n\tresult += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\n\tresult += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\n\tresult += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\n\tresult += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\n\treturn result;\n}\nvec3 getLightProbeIrradiance( const in vec3 lightProbe[ 9 ], const in GeometricContext geometry ) {\n\tvec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix );\n\tvec3 irradiance = shGetIrradianceAt( worldNormal, lightProbe );\n\treturn irradiance;\n}\nvec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {\n\tvec3 irradiance = ambientLightColor;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\treturn irradiance;\n}\n#if NUM_DIR_LIGHTS > 0\n\tstruct DirectionalLight {\n\t\tvec3 direction;\n\t\tvec3 color;\n\t};\n\tuniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ];\n\t#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n\t\tstruct DirectionalLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowRadius;\n\t\t\tvec2 shadowMapSize;\n\t\t};\n\t\tuniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ];\n\t#endif\n\tvoid getDirectionalDirectLightIrradiance( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tdirectLight.color = directionalLight.color;\n\t\tdirectLight.direction = directionalLight.direction;\n\t\tdirectLight.visible = true;\n\t}\n#endif\n#if NUM_POINT_LIGHTS > 0\n\tstruct PointLight {\n\t\tvec3 position;\n\t\tvec3 color;\n\t\tfloat distance;\n\t\tfloat decay;\n\t};\n\tuniform PointLight pointLights[ NUM_POINT_LIGHTS ];\n\t#if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0\n\t\tstruct PointLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowRadius;\n\t\t\tvec2 shadowMapSize;\n\t\t\tfloat shadowCameraNear;\n\t\t\tfloat shadowCameraFar;\n\t\t};\n\t\tuniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ];\n\t#endif\n\tvoid getPointDirectLightIrradiance( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tvec3 lVector = pointLight.position - geometry.position;\n\t\tdirectLight.direction = normalize( lVector );\n\t\tfloat lightDistance = length( lVector );\n\t\tdirectLight.color = pointLight.color;\n\t\tdirectLight.color *= punctualLightIntensityToIrradianceFactor( lightDistance, pointLight.distance, pointLight.decay );\n\t\tdirectLight.visible = ( directLight.color != vec3( 0.0 ) );\n\t}\n#endif\n#if NUM_SPOT_LIGHTS > 0\n\tstruct SpotLight {\n\t\tvec3 position;\n\t\tvec3 direction;\n\t\tvec3 color;\n\t\tfloat distance;\n\t\tfloat decay;\n\t\tfloat coneCos;\n\t\tfloat penumbraCos;\n\t};\n\tuniform SpotLight spotLights[ NUM_SPOT_LIGHTS ];\n\t#if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0\n\t\tstruct SpotLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowRadius;\n\t\t\tvec2 shadowMapSize;\n\t\t};\n\t\tuniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ];\n\t#endif\n\tvoid getSpotDirectLightIrradiance( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tvec3 lVector = spotLight.position - geometry.position;\n\t\tdirectLight.direction = normalize( lVector );\n\t\tfloat lightDistance = length( lVector );\n\t\tfloat angleCos = dot( directLight.direction, spotLight.direction );\n\t\tif ( angleCos > spotLight.coneCos ) {\n\t\t\tfloat spotEffect = smoothstep( spotLight.coneCos, spotLight.penumbraCos, angleCos );\n\t\t\tdirectLight.color = spotLight.color;\n\t\t\tdirectLight.color *= spotEffect * punctualLightIntensityToIrradianceFactor( lightDistance, spotLight.distance, spotLight.decay );\n\t\t\tdirectLight.visible = true;\n\t\t} else {\n\t\t\tdirectLight.color = vec3( 0.0 );\n\t\t\tdirectLight.visible = false;\n\t\t}\n\t}\n#endif\n#if NUM_RECT_AREA_LIGHTS > 0\n\tstruct RectAreaLight {\n\t\tvec3 color;\n\t\tvec3 position;\n\t\tvec3 halfWidth;\n\t\tvec3 halfHeight;\n\t};\n\tuniform sampler2D ltc_1;\tuniform sampler2D ltc_2;\n\tuniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ];\n#endif\n#if NUM_HEMI_LIGHTS > 0\n\tstruct HemisphereLight {\n\t\tvec3 direction;\n\t\tvec3 skyColor;\n\t\tvec3 groundColor;\n\t};\n\tuniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ];\n\tvec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in GeometricContext geometry ) {\n\t\tfloat dotNL = dot( geometry.normal, hemiLight.direction );\n\t\tfloat hemiDiffuseWeight = 0.5 * dotNL + 0.5;\n\t\tvec3 irradiance = mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tirradiance *= PI;\n\t\t#endif\n\t\treturn irradiance;\n\t}\n#endif", lights_toon_fragment: "ToonMaterial material;\nmaterial.diffuseColor = diffuseColor.rgb;\nmaterial.specularColor = specular;\nmaterial.specularShininess = shininess;\nmaterial.specularStrength = specularStrength;", lights_toon_pars_fragment: "varying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\nstruct ToonMaterial {\n\tvec3\tdiffuseColor;\n\tvec3\tspecularColor;\n\tfloat\tspecularShininess;\n\tfloat\tspecularStrength;\n};\nvoid RE_Direct_Toon( const in IncidentLight directLight, const in GeometricContext geometry, const in ToonMaterial material, inout ReflectedLight reflectedLight ) {\n\tvec3 irradiance = getGradientIrradiance( geometry.normal, directLight.direction ) * directLight.color;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\treflectedLight.directDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\treflectedLight.directSpecular += irradiance * BRDF_Specular_BlinnPhong( directLight, geometry, material.specularColor, material.specularShininess ) * material.specularStrength;\n}\nvoid RE_IndirectDiffuse_Toon( const in vec3 irradiance, const in GeometricContext geometry, const in ToonMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n}\n#define RE_Direct\t\t\t\tRE_Direct_Toon\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_Toon\n#define Material_LightProbeLOD( material )\t(0)", lights_phong_fragment: "BlinnPhongMaterial material;\nmaterial.diffuseColor = diffuseColor.rgb;\nmaterial.specularColor = specular;\nmaterial.specularShininess = shininess;\nmaterial.specularStrength = specularStrength;", lights_phong_pars_fragment: "varying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\nstruct BlinnPhongMaterial {\n\tvec3\tdiffuseColor;\n\tvec3\tspecularColor;\n\tfloat\tspecularShininess;\n\tfloat\tspecularStrength;\n};\nvoid RE_Direct_BlinnPhong( const in IncidentLight directLight, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\n\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\n\tvec3 irradiance = dotNL * directLight.color;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\treflectedLight.directDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\treflectedLight.directSpecular += irradiance * BRDF_Specular_BlinnPhong( directLight, geometry, material.specularColor, material.specularShininess ) * material.specularStrength;\n}\nvoid RE_IndirectDiffuse_BlinnPhong( const in vec3 irradiance, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n}\n#define RE_Direct\t\t\t\tRE_Direct_BlinnPhong\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_BlinnPhong\n#define Material_LightProbeLOD( material )\t(0)", lights_physical_fragment: "PhysicalMaterial material;\nmaterial.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor );\nvec3 dxy = max( abs( dFdx( geometryNormal ) ), abs( dFdy( geometryNormal ) ) );\nfloat geometryRoughness = max( max( dxy.x, dxy.y ), dxy.z );\nmaterial.specularRoughness = max( roughnessFactor, 0.0525 );material.specularRoughness += geometryRoughness;\nmaterial.specularRoughness = min( material.specularRoughness, 1.0 );\n#ifdef REFLECTIVITY\n\tmaterial.specularColor = mix( vec3( MAXIMUM_SPECULAR_COEFFICIENT * pow2( reflectivity ) ), diffuseColor.rgb, metalnessFactor );\n#else\n\tmaterial.specularColor = mix( vec3( DEFAULT_SPECULAR_COEFFICIENT ), diffuseColor.rgb, metalnessFactor );\n#endif\n#ifdef CLEARCOAT\n\tmaterial.clearcoat = clearcoat;\n\tmaterial.clearcoatRoughness = clearcoatRoughness;\n\t#ifdef USE_CLEARCOATMAP\n\t\tmaterial.clearcoat *= texture2D( clearcoatMap, vUv ).x;\n\t#endif\n\t#ifdef USE_CLEARCOAT_ROUGHNESSMAP\n\t\tmaterial.clearcoatRoughness *= texture2D( clearcoatRoughnessMap, vUv ).y;\n\t#endif\n\tmaterial.clearcoat = saturate( material.clearcoat );\tmaterial.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 );\n\tmaterial.clearcoatRoughness += geometryRoughness;\n\tmaterial.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 );\n#endif\n#ifdef USE_SHEEN\n\tmaterial.sheenColor = sheen;\n#endif", lights_physical_pars_fragment: "struct PhysicalMaterial {\n\tvec3\tdiffuseColor;\n\tfloat\tspecularRoughness;\n\tvec3\tspecularColor;\n#ifdef CLEARCOAT\n\tfloat clearcoat;\n\tfloat clearcoatRoughness;\n#endif\n#ifdef USE_SHEEN\n\tvec3 sheenColor;\n#endif\n};\n#define MAXIMUM_SPECULAR_COEFFICIENT 0.16\n#define DEFAULT_SPECULAR_COEFFICIENT 0.04\nfloat clearcoatDHRApprox( const in float roughness, const in float dotNL ) {\n\treturn DEFAULT_SPECULAR_COEFFICIENT + ( 1.0 - DEFAULT_SPECULAR_COEFFICIENT ) * ( pow( 1.0 - dotNL, 5.0 ) * pow( 1.0 - roughness, 2.0 ) );\n}\n#if NUM_RECT_AREA_LIGHTS > 0\n\tvoid RE_Direct_RectArea_Physical( const in RectAreaLight rectAreaLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\t\tvec3 normal = geometry.normal;\n\t\tvec3 viewDir = geometry.viewDir;\n\t\tvec3 position = geometry.position;\n\t\tvec3 lightPos = rectAreaLight.position;\n\t\tvec3 halfWidth = rectAreaLight.halfWidth;\n\t\tvec3 halfHeight = rectAreaLight.halfHeight;\n\t\tvec3 lightColor = rectAreaLight.color;\n\t\tfloat roughness = material.specularRoughness;\n\t\tvec3 rectCoords[ 4 ];\n\t\trectCoords[ 0 ] = lightPos + halfWidth - halfHeight;\t\trectCoords[ 1 ] = lightPos - halfWidth - halfHeight;\n\t\trectCoords[ 2 ] = lightPos - halfWidth + halfHeight;\n\t\trectCoords[ 3 ] = lightPos + halfWidth + halfHeight;\n\t\tvec2 uv = LTC_Uv( normal, viewDir, roughness );\n\t\tvec4 t1 = texture2D( ltc_1, uv );\n\t\tvec4 t2 = texture2D( ltc_2, uv );\n\t\tmat3 mInv = mat3(\n\t\t\tvec3( t1.x, 0, t1.y ),\n\t\t\tvec3( 0, 1, 0 ),\n\t\t\tvec3( t1.z, 0, t1.w )\n\t\t);\n\t\tvec3 fresnel = ( material.specularColor * t2.x + ( vec3( 1.0 ) - material.specularColor ) * t2.y );\n\t\treflectedLight.directSpecular += lightColor * fresnel * LTC_Evaluate( normal, viewDir, position, mInv, rectCoords );\n\t\treflectedLight.directDiffuse += lightColor * material.diffuseColor * LTC_Evaluate( normal, viewDir, position, mat3( 1.0 ), rectCoords );\n\t}\n#endif\nvoid RE_Direct_Physical( const in IncidentLight directLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\n\tvec3 irradiance = dotNL * directLight.color;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\t#ifdef CLEARCOAT\n\t\tfloat ccDotNL = saturate( dot( geometry.clearcoatNormal, directLight.direction ) );\n\t\tvec3 ccIrradiance = ccDotNL * directLight.color;\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tccIrradiance *= PI;\n\t\t#endif\n\t\tfloat clearcoatDHR = material.clearcoat * clearcoatDHRApprox( material.clearcoatRoughness, ccDotNL );\n\t\treflectedLight.directSpecular += ccIrradiance * material.clearcoat * BRDF_Specular_GGX( directLight, geometry.viewDir, geometry.clearcoatNormal, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearcoatRoughness );\n\t#else\n\t\tfloat clearcoatDHR = 0.0;\n\t#endif\n\t#ifdef USE_SHEEN\n\t\treflectedLight.directSpecular += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Specular_Sheen(\n\t\t\tmaterial.specularRoughness,\n\t\t\tdirectLight.direction,\n\t\t\tgeometry,\n\t\t\tmaterial.sheenColor\n\t\t);\n\t#else\n\t\treflectedLight.directSpecular += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Specular_GGX( directLight, geometry.viewDir, geometry.normal, material.specularColor, material.specularRoughness);\n\t#endif\n\treflectedLight.directDiffuse += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n}\nvoid RE_IndirectDiffuse_Physical( const in vec3 irradiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n}\nvoid RE_IndirectSpecular_Physical( const in vec3 radiance, const in vec3 irradiance, const in vec3 clearcoatRadiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight) {\n\t#ifdef CLEARCOAT\n\t\tfloat ccDotNV = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) );\n\t\treflectedLight.indirectSpecular += clearcoatRadiance * material.clearcoat * BRDF_Specular_GGX_Environment( geometry.viewDir, geometry.clearcoatNormal, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearcoatRoughness );\n\t\tfloat ccDotNL = ccDotNV;\n\t\tfloat clearcoatDHR = material.clearcoat * clearcoatDHRApprox( material.clearcoatRoughness, ccDotNL );\n\t#else\n\t\tfloat clearcoatDHR = 0.0;\n\t#endif\n\tfloat clearcoatInv = 1.0 - clearcoatDHR;\n\tvec3 singleScattering = vec3( 0.0 );\n\tvec3 multiScattering = vec3( 0.0 );\n\tvec3 cosineWeightedIrradiance = irradiance * RECIPROCAL_PI;\n\tBRDF_Specular_Multiscattering_Environment( geometry, material.specularColor, material.specularRoughness, singleScattering, multiScattering );\n\tvec3 diffuse = material.diffuseColor * ( 1.0 - ( singleScattering + multiScattering ) );\n\treflectedLight.indirectSpecular += clearcoatInv * radiance * singleScattering;\n\treflectedLight.indirectSpecular += multiScattering * cosineWeightedIrradiance;\n\treflectedLight.indirectDiffuse += diffuse * cosineWeightedIrradiance;\n}\n#define RE_Direct\t\t\t\tRE_Direct_Physical\n#define RE_Direct_RectArea\t\tRE_Direct_RectArea_Physical\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_Physical\n#define RE_IndirectSpecular\t\tRE_IndirectSpecular_Physical\nfloat computeSpecularOcclusion( const in float dotNV, const in float ambientOcclusion, const in float roughness ) {\n\treturn saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\n}", lights_fragment_begin: "\nGeometricContext geometry;\ngeometry.position = - vViewPosition;\ngeometry.normal = normal;\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition );\n#ifdef CLEARCOAT\n\tgeometry.clearcoatNormal = clearcoatNormal;\n#endif\nIncidentLight directLight;\n#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )\n\tPointLight pointLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0\n\tPointLightShadow pointLightShadow;\n\t#endif\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\t\tpointLight = pointLights[ i ];\n\t\tgetPointDirectLightIrradiance( pointLight, geometry, directLight );\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_POINT_LIGHT_SHADOWS )\n\t\tpointLightShadow = pointLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getPointShadow( pointShadowMap[ i ], pointLightShadow.shadowMapSize, pointLightShadow.shadowBias, pointLightShadow.shadowRadius, vPointShadowCoord[ i ], pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )\n\tSpotLight spotLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0\n\tSpotLightShadow spotLightShadow;\n\t#endif\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\t\tspotLight = spotLights[ i ];\n\t\tgetSpotDirectLightIrradiance( spotLight, geometry, directLight );\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_SPOT_LIGHT_SHADOWS )\n\t\tspotLightShadow = spotLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( spotShadowMap[ i ], spotLightShadow.shadowMapSize, spotLightShadow.shadowBias, spotLightShadow.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )\n\tDirectionalLight directionalLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n\tDirectionalLightShadow directionalLightShadow;\n\t#endif\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\t\tdirectionalLight = directionalLights[ i ];\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\n\t\tdirectionalLightShadow = directionalLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )\n\tRectAreaLight rectAreaLight;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {\n\t\trectAreaLight = rectAreaLights[ i ];\n\t\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if defined( RE_IndirectDiffuse )\n\tvec3 iblIrradiance = vec3( 0.0 );\n\tvec3 irradiance = getAmbientLightIrradiance( ambientLightColor );\n\tirradiance += getLightProbeIrradiance( lightProbe, geometry );\n\t#if ( NUM_HEMI_LIGHTS > 0 )\n\t\t#pragma unroll_loop_start\n\t\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\n\t\t\tirradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\t\t}\n\t\t#pragma unroll_loop_end\n\t#endif\n#endif\n#if defined( RE_IndirectSpecular )\n\tvec3 radiance = vec3( 0.0 );\n\tvec3 clearcoatRadiance = vec3( 0.0 );\n#endif", lights_fragment_maps: "#if defined( RE_IndirectDiffuse )\n\t#ifdef USE_LIGHTMAP\n\t\tvec4 lightMapTexel= texture2D( lightMap, vUv2 );\n\t\tvec3 lightMapIrradiance = lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity;\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tlightMapIrradiance *= PI;\n\t\t#endif\n\t\tirradiance += lightMapIrradiance;\n\t#endif\n\t#if defined( USE_ENVMAP ) && defined( STANDARD ) && defined( ENVMAP_TYPE_CUBE_UV )\n\t\tiblIrradiance += getLightProbeIndirectIrradiance( geometry, maxMipLevel );\n\t#endif\n#endif\n#if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )\n\tradiance += getLightProbeIndirectRadiance( geometry.viewDir, geometry.normal, material.specularRoughness, maxMipLevel );\n\t#ifdef CLEARCOAT\n\t\tclearcoatRadiance += getLightProbeIndirectRadiance( geometry.viewDir, geometry.clearcoatNormal, material.clearcoatRoughness, maxMipLevel );\n\t#endif\n#endif", lights_fragment_end: "#if defined( RE_IndirectDiffuse )\n\tRE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );\n#endif\n#if defined( RE_IndirectSpecular )\n\tRE_IndirectSpecular( radiance, iblIrradiance, clearcoatRadiance, geometry, material, reflectedLight );\n#endif", logdepthbuf_fragment: "#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\n\tgl_FragDepthEXT = vIsPerspective == 0.0 ? gl_FragCoord.z : log2( vFragDepth ) * logDepthBufFC * 0.5;\n#endif", logdepthbuf_pars_fragment: "#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\n\tuniform float logDepthBufFC;\n\tvarying float vFragDepth;\n\tvarying float vIsPerspective;\n#endif", logdepthbuf_pars_vertex: "#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvarying float vFragDepth;\n\t\tvarying float vIsPerspective;\n\t#else\n\t\tuniform float logDepthBufFC;\n\t#endif\n#endif", logdepthbuf_vertex: "#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvFragDepth = 1.0 + gl_Position.w;\n\t\tvIsPerspective = float( isPerspectiveMatrix( projectionMatrix ) );\n\t#else\n\t\tif ( isPerspectiveMatrix( projectionMatrix ) ) {\n\t\t\tgl_Position.z = log2( max( EPSILON, gl_Position.w + 1.0 ) ) * logDepthBufFC - 1.0;\n\t\t\tgl_Position.z *= gl_Position.w;\n\t\t}\n\t#endif\n#endif", map_fragment: "#ifdef USE_MAP\n\tvec4 texelColor = texture2D( map, vUv );\n\ttexelColor = mapTexelToLinear( texelColor );\n\tdiffuseColor *= texelColor;\n#endif", map_pars_fragment: "#ifdef USE_MAP\n\tuniform sampler2D map;\n#endif", map_particle_fragment: "#if defined( USE_MAP ) || defined( USE_ALPHAMAP )\n\tvec2 uv = ( uvTransform * vec3( gl_PointCoord.x, 1.0 - gl_PointCoord.y, 1 ) ).xy;\n#endif\n#ifdef USE_MAP\n\tvec4 mapTexel = texture2D( map, uv );\n\tdiffuseColor *= mapTexelToLinear( mapTexel );\n#endif\n#ifdef USE_ALPHAMAP\n\tdiffuseColor.a *= texture2D( alphaMap, uv ).g;\n#endif", map_particle_pars_fragment: "#if defined( USE_MAP ) || defined( USE_ALPHAMAP )\n\tuniform mat3 uvTransform;\n#endif\n#ifdef USE_MAP\n\tuniform sampler2D map;\n#endif\n#ifdef USE_ALPHAMAP\n\tuniform sampler2D alphaMap;\n#endif", metalnessmap_fragment: "float metalnessFactor = metalness;\n#ifdef USE_METALNESSMAP\n\tvec4 texelMetalness = texture2D( metalnessMap, vUv );\n\tmetalnessFactor *= texelMetalness.b;\n#endif", metalnessmap_pars_fragment: "#ifdef USE_METALNESSMAP\n\tuniform sampler2D metalnessMap;\n#endif", morphnormal_vertex: "#ifdef USE_MORPHNORMALS\n\tobjectNormal *= morphTargetBaseInfluence;\n\tobjectNormal += morphNormal0 * morphTargetInfluences[ 0 ];\n\tobjectNormal += morphNormal1 * morphTargetInfluences[ 1 ];\n\tobjectNormal += morphNormal2 * morphTargetInfluences[ 2 ];\n\tobjectNormal += morphNormal3 * morphTargetInfluences[ 3 ];\n#endif", morphtarget_pars_vertex: "#ifdef USE_MORPHTARGETS\n\tuniform float morphTargetBaseInfluence;\n\t#ifndef USE_MORPHNORMALS\n\tuniform float morphTargetInfluences[ 8 ];\n\t#else\n\tuniform float morphTargetInfluences[ 4 ];\n\t#endif\n#endif", morphtarget_vertex: "#ifdef USE_MORPHTARGETS\n\ttransformed *= morphTargetBaseInfluence;\n\ttransformed += morphTarget0 * morphTargetInfluences[ 0 ];\n\ttransformed += morphTarget1 * morphTargetInfluences[ 1 ];\n\ttransformed += morphTarget2 * morphTargetInfluences[ 2 ];\n\ttransformed += morphTarget3 * morphTargetInfluences[ 3 ];\n\t#ifndef USE_MORPHNORMALS\n\ttransformed += morphTarget4 * morphTargetInfluences[ 4 ];\n\ttransformed += morphTarget5 * morphTargetInfluences[ 5 ];\n\ttransformed += morphTarget6 * morphTargetInfluences[ 6 ];\n\ttransformed += morphTarget7 * morphTargetInfluences[ 7 ];\n\t#endif\n#endif", normal_fragment_begin: "#ifdef FLAT_SHADED\n\tvec3 fdx = vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) );\n\tvec3 fdy = vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) );\n\tvec3 normal = normalize( cross( fdx, fdy ) );\n#else\n\tvec3 normal = normalize( vNormal );\n\t#ifdef DOUBLE_SIDED\n\t\tnormal = normal * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t#endif\n\t#ifdef USE_TANGENT\n\t\tvec3 tangent = normalize( vTangent );\n\t\tvec3 bitangent = normalize( vBitangent );\n\t\t#ifdef DOUBLE_SIDED\n\t\t\ttangent = tangent * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\t\tbitangent = bitangent * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\t#endif\n\t\t#if defined( TANGENTSPACE_NORMALMAP ) || defined( USE_CLEARCOAT_NORMALMAP )\n\t\t\tmat3 vTBN = mat3( tangent, bitangent, normal );\n\t\t#endif\n\t#endif\n#endif\nvec3 geometryNormal = normal;", normal_fragment_maps: "#ifdef OBJECTSPACE_NORMALMAP\n\tnormal = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\t#ifdef FLIP_SIDED\n\t\tnormal = - normal;\n\t#endif\n\t#ifdef DOUBLE_SIDED\n\t\tnormal = normal * ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t#endif\n\tnormal = normalize( normalMatrix * normal );\n#elif defined( TANGENTSPACE_NORMALMAP )\n\tvec3 mapN = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\tmapN.xy *= normalScale;\n\t#ifdef USE_TANGENT\n\t\tnormal = normalize( vTBN * mapN );\n\t#else\n\t\tnormal = perturbNormal2Arb( -vViewPosition, normal, mapN );\n\t#endif\n#elif defined( USE_BUMPMAP )\n\tnormal = perturbNormalArb( -vViewPosition, normal, dHdxy_fwd() );\n#endif", normalmap_pars_fragment: "#ifdef USE_NORMALMAP\n\tuniform sampler2D normalMap;\n\tuniform vec2 normalScale;\n#endif\n#ifdef OBJECTSPACE_NORMALMAP\n\tuniform mat3 normalMatrix;\n#endif\n#if ! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALMAP ) || defined ( USE_CLEARCOAT_NORMALMAP ) )\n\tvec3 perturbNormal2Arb( vec3 eye_pos, vec3 surf_norm, vec3 mapN ) {\n\t\tvec3 q0 = vec3( dFdx( eye_pos.x ), dFdx( eye_pos.y ), dFdx( eye_pos.z ) );\n\t\tvec3 q1 = vec3( dFdy( eye_pos.x ), dFdy( eye_pos.y ), dFdy( eye_pos.z ) );\n\t\tvec2 st0 = dFdx( vUv.st );\n\t\tvec2 st1 = dFdy( vUv.st );\n\t\tfloat scale = sign( st1.t * st0.s - st0.t * st1.s );\n\t\tvec3 S = normalize( ( q0 * st1.t - q1 * st0.t ) * scale );\n\t\tvec3 T = normalize( ( - q0 * st1.s + q1 * st0.s ) * scale );\n\t\tvec3 N = normalize( surf_norm );\n\t\tmat3 tsn = mat3( S, T, N );\n\t\tmapN.xy *= ( float( gl_FrontFacing ) * 2.0 - 1.0 );\n\t\treturn normalize( tsn * mapN );\n\t}\n#endif", clearcoat_normal_fragment_begin: "#ifdef CLEARCOAT\n\tvec3 clearcoatNormal = geometryNormal;\n#endif", clearcoat_normal_fragment_maps: "#ifdef USE_CLEARCOAT_NORMALMAP\n\tvec3 clearcoatMapN = texture2D( clearcoatNormalMap, vUv ).xyz * 2.0 - 1.0;\n\tclearcoatMapN.xy *= clearcoatNormalScale;\n\t#ifdef USE_TANGENT\n\t\tclearcoatNormal = normalize( vTBN * clearcoatMapN );\n\t#else\n\t\tclearcoatNormal = perturbNormal2Arb( - vViewPosition, clearcoatNormal, clearcoatMapN );\n\t#endif\n#endif", clearcoat_pars_fragment: "#ifdef USE_CLEARCOATMAP\n\tuniform sampler2D clearcoatMap;\n#endif\n#ifdef USE_CLEARCOAT_ROUGHNESSMAP\n\tuniform sampler2D clearcoatRoughnessMap;\n#endif\n#ifdef USE_CLEARCOAT_NORMALMAP\n\tuniform sampler2D clearcoatNormalMap;\n\tuniform vec2 clearcoatNormalScale;\n#endif", packing: "vec3 packNormalToRGB( const in vec3 normal ) {\n\treturn normalize( normal ) * 0.5 + 0.5;\n}\nvec3 unpackRGBToNormal( const in vec3 rgb ) {\n\treturn 2.0 * rgb.xyz - 1.0;\n}\nconst float PackUpscale = 256. / 255.;const float UnpackDownscale = 255. / 256.;\nconst vec3 PackFactors = vec3( 256. * 256. * 256., 256. * 256., 256. );\nconst vec4 UnpackFactors = UnpackDownscale / vec4( PackFactors, 1. );\nconst float ShiftRight8 = 1. / 256.;\nvec4 packDepthToRGBA( const in float v ) {\n\tvec4 r = vec4( fract( v * PackFactors ), v );\n\tr.yzw -= r.xyz * ShiftRight8;\treturn r * PackUpscale;\n}\nfloat unpackRGBAToDepth( const in vec4 v ) {\n\treturn dot( v, UnpackFactors );\n}\nvec4 pack2HalfToRGBA( vec2 v ) {\n\tvec4 r = vec4( v.x, fract( v.x * 255.0 ), v.y, fract( v.y * 255.0 ));\n\treturn vec4( r.x - r.y / 255.0, r.y, r.z - r.w / 255.0, r.w);\n}\nvec2 unpackRGBATo2Half( vec4 v ) {\n\treturn vec2( v.x + ( v.y / 255.0 ), v.z + ( v.w / 255.0 ) );\n}\nfloat viewZToOrthographicDepth( const in float viewZ, const in float near, const in float far ) {\n\treturn ( viewZ + near ) / ( near - far );\n}\nfloat orthographicDepthToViewZ( const in float linearClipZ, const in float near, const in float far ) {\n\treturn linearClipZ * ( near - far ) - near;\n}\nfloat viewZToPerspectiveDepth( const in float viewZ, const in float near, const in float far ) {\n\treturn (( near + viewZ ) * far ) / (( far - near ) * viewZ );\n}\nfloat perspectiveDepthToViewZ( const in float invClipZ, const in float near, const in float far ) {\n\treturn ( near * far ) / ( ( far - near ) * invClipZ - far );\n}", premultiplied_alpha_fragment: "#ifdef PREMULTIPLIED_ALPHA\n\tgl_FragColor.rgb *= gl_FragColor.a;\n#endif", project_vertex: "vec4 mvPosition = vec4( transformed, 1.0 );\n#ifdef USE_INSTANCING\n\tmvPosition = instanceMatrix * mvPosition;\n#endif\nmvPosition = modelViewMatrix * mvPosition;\ngl_Position = projectionMatrix * mvPosition;", dithering_fragment: "#ifdef DITHERING\n\tgl_FragColor.rgb = dithering( gl_FragColor.rgb );\n#endif", dithering_pars_fragment: "#ifdef DITHERING\n\tvec3 dithering( vec3 color ) {\n\t\tfloat grid_position = rand( gl_FragCoord.xy );\n\t\tvec3 dither_shift_RGB = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\n\t\tdither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\n\t\treturn color + dither_shift_RGB;\n\t}\n#endif", roughnessmap_fragment: "float roughnessFactor = roughness;\n#ifdef USE_ROUGHNESSMAP\n\tvec4 texelRoughness = texture2D( roughnessMap, vUv );\n\troughnessFactor *= texelRoughness.g;\n#endif", roughnessmap_pars_fragment: "#ifdef USE_ROUGHNESSMAP\n\tuniform sampler2D roughnessMap;\n#endif", shadowmap_pars_fragment: "#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHT_SHADOWS > 0\n\t\tuniform sampler2D directionalShadowMap[ NUM_DIR_LIGHT_SHADOWS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ];\n\t#endif\n\t#if NUM_SPOT_LIGHT_SHADOWS > 0\n\t\tuniform sampler2D spotShadowMap[ NUM_SPOT_LIGHT_SHADOWS ];\n\t\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ];\n\t#endif\n\t#if NUM_POINT_LIGHT_SHADOWS > 0\n\t\tuniform sampler2D pointShadowMap[ NUM_POINT_LIGHT_SHADOWS ];\n\t\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ];\n\t#endif\n\tfloat texture2DCompare( sampler2D depths, vec2 uv, float compare ) {\n\t\treturn step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) );\n\t}\n\tvec2 texture2DDistribution( sampler2D shadow, vec2 uv ) {\n\t\treturn unpackRGBATo2Half( texture2D( shadow, uv ) );\n\t}\n\tfloat VSMShadow (sampler2D shadow, vec2 uv, float compare ){\n\t\tfloat occlusion = 1.0;\n\t\tvec2 distribution = texture2DDistribution( shadow, uv );\n\t\tfloat hard_shadow = step( compare , distribution.x );\n\t\tif (hard_shadow != 1.0 ) {\n\t\t\tfloat distance = compare - distribution.x ;\n\t\t\tfloat variance = max( 0.00000, distribution.y * distribution.y );\n\t\t\tfloat softness_probability = variance / (variance + distance * distance );\t\t\tsoftness_probability = clamp( ( softness_probability - 0.3 ) / ( 0.95 - 0.3 ), 0.0, 1.0 );\t\t\tocclusion = clamp( max( hard_shadow, softness_probability ), 0.0, 1.0 );\n\t\t}\n\t\treturn occlusion;\n\t}\n\tfloat getShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord ) {\n\t\tfloat shadow = 1.0;\n\t\tshadowCoord.xyz /= shadowCoord.w;\n\t\tshadowCoord.z += shadowBias;\n\t\tbvec4 inFrustumVec = bvec4 ( shadowCoord.x >= 0.0, shadowCoord.x <= 1.0, shadowCoord.y >= 0.0, shadowCoord.y <= 1.0 );\n\t\tbool inFrustum = all( inFrustumVec );\n\t\tbvec2 frustumTestVec = bvec2( inFrustum, shadowCoord.z <= 1.0 );\n\t\tbool frustumTest = all( frustumTestVec );\n\t\tif ( frustumTest ) {\n\t\t#if defined( SHADOWMAP_TYPE_PCF )\n\t\t\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\n\t\t\tfloat dx0 = - texelSize.x * shadowRadius;\n\t\t\tfloat dy0 = - texelSize.y * shadowRadius;\n\t\t\tfloat dx1 = + texelSize.x * shadowRadius;\n\t\t\tfloat dy1 = + texelSize.y * shadowRadius;\n\t\t\tfloat dx2 = dx0 / 2.0;\n\t\t\tfloat dy2 = dy0 / 2.0;\n\t\t\tfloat dx3 = dx1 / 2.0;\n\t\t\tfloat dy3 = dy1 / 2.0;\n\t\t\tshadow = (\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy2 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy2 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy2 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy3 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy3 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy3 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\n\t\t\t) * ( 1.0 / 17.0 );\n\t\t#elif defined( SHADOWMAP_TYPE_PCF_SOFT )\n\t\t\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\n\t\t\tfloat dx = texelSize.x;\n\t\t\tfloat dy = texelSize.y;\n\t\t\tvec2 uv = shadowCoord.xy;\n\t\t\tvec2 f = fract( uv * shadowMapSize + 0.5 );\n\t\t\tuv -= f * texelSize;\n\t\t\tshadow = (\n\t\t\t\ttexture2DCompare( shadowMap, uv, shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, uv + vec2( dx, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, uv + vec2( 0.0, dy ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, uv + texelSize, shadowCoord.z ) +\n\t\t\t\tmix( texture2DCompare( shadowMap, uv + vec2( -dx, 0.0 ), shadowCoord.z ), \n\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 0.0 ), shadowCoord.z ),\n\t\t\t\t\t f.x ) +\n\t\t\t\tmix( texture2DCompare( shadowMap, uv + vec2( -dx, dy ), shadowCoord.z ), \n\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, dy ), shadowCoord.z ),\n\t\t\t\t\t f.x ) +\n\t\t\t\tmix( texture2DCompare( shadowMap, uv + vec2( 0.0, -dy ), shadowCoord.z ), \n\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( 0.0, 2.0 * dy ), shadowCoord.z ),\n\t\t\t\t\t f.y ) +\n\t\t\t\tmix( texture2DCompare( shadowMap, uv + vec2( dx, -dy ), shadowCoord.z ), \n\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( dx, 2.0 * dy ), shadowCoord.z ),\n\t\t\t\t\t f.y ) +\n\t\t\t\tmix( mix( texture2DCompare( shadowMap, uv + vec2( -dx, -dy ), shadowCoord.z ), \n\t\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, -dy ), shadowCoord.z ),\n\t\t\t\t\t\t f.x ),\n\t\t\t\t\t mix( texture2DCompare( shadowMap, uv + vec2( -dx, 2.0 * dy ), shadowCoord.z ), \n\t\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 2.0 * dy ), shadowCoord.z ),\n\t\t\t\t\t\t f.x ),\n\t\t\t\t\t f.y )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#elif defined( SHADOWMAP_TYPE_VSM )\n\t\t\tshadow = VSMShadow( shadowMap, shadowCoord.xy, shadowCoord.z );\n\t\t#else\n\t\t\tshadow = texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z );\n\t\t#endif\n\t\t}\n\t\treturn shadow;\n\t}\n\tvec2 cubeToUV( vec3 v, float texelSizeY ) {\n\t\tvec3 absV = abs( v );\n\t\tfloat scaleToCube = 1.0 / max( absV.x, max( absV.y, absV.z ) );\n\t\tabsV *= scaleToCube;\n\t\tv *= scaleToCube * ( 1.0 - 2.0 * texelSizeY );\n\t\tvec2 planar = v.xy;\n\t\tfloat almostATexel = 1.5 * texelSizeY;\n\t\tfloat almostOne = 1.0 - almostATexel;\n\t\tif ( absV.z >= almostOne ) {\n\t\t\tif ( v.z > 0.0 )\n\t\t\t\tplanar.x = 4.0 - v.x;\n\t\t} else if ( absV.x >= almostOne ) {\n\t\t\tfloat signX = sign( v.x );\n\t\t\tplanar.x = v.z * signX + 2.0 * signX;\n\t\t} else if ( absV.y >= almostOne ) {\n\t\t\tfloat signY = sign( v.y );\n\t\t\tplanar.x = v.x + 2.0 * signY + 2.0;\n\t\t\tplanar.y = v.z * signY - 2.0;\n\t\t}\n\t\treturn vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 );\n\t}\n\tfloat getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) {\n\t\tvec2 texelSize = vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) );\n\t\tvec3 lightToPosition = shadowCoord.xyz;\n\t\tfloat dp = ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear );\t\tdp += shadowBias;\n\t\tvec3 bd3D = normalize( lightToPosition );\n\t\t#if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT ) || defined( SHADOWMAP_TYPE_VSM )\n\t\t\tvec2 offset = vec2( - 1, 1 ) * shadowRadius * texelSize.y;\n\t\t\treturn (\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#else\n\t\t\treturn texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp );\n\t\t#endif\n\t}\n#endif", shadowmap_pars_vertex: "#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHT_SHADOWS > 0\n\t\tuniform mat4 directionalShadowMatrix[ NUM_DIR_LIGHT_SHADOWS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ];\n\t#endif\n\t#if NUM_SPOT_LIGHT_SHADOWS > 0\n\t\tuniform mat4 spotShadowMatrix[ NUM_SPOT_LIGHT_SHADOWS ];\n\t\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ];\n\t#endif\n\t#if NUM_POINT_LIGHT_SHADOWS > 0\n\t\tuniform mat4 pointShadowMatrix[ NUM_POINT_LIGHT_SHADOWS ];\n\t\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ];\n\t#endif\n#endif", shadowmap_vertex: "#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHT_SHADOWS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_DIR_LIGHT_SHADOWS; i ++ ) {\n\t\tvDirectionalShadowCoord[ i ] = directionalShadowMatrix[ i ] * worldPosition;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n\t#if NUM_SPOT_LIGHT_SHADOWS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_SPOT_LIGHT_SHADOWS; i ++ ) {\n\t\tvSpotShadowCoord[ i ] = spotShadowMatrix[ i ] * worldPosition;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n\t#if NUM_POINT_LIGHT_SHADOWS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_POINT_LIGHT_SHADOWS; i ++ ) {\n\t\tvPointShadowCoord[ i ] = pointShadowMatrix[ i ] * worldPosition;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n#endif", shadowmask_pars_fragment: "float getShadowMask() {\n\tfloat shadow = 1.0;\n\t#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHT_SHADOWS > 0\n\tDirectionalLightShadow directionalLight;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_DIR_LIGHT_SHADOWS; i ++ ) {\n\t\tdirectionalLight = directionalLightShadows[ i ];\n\t\tshadow *= receiveShadow ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n\t#if NUM_SPOT_LIGHT_SHADOWS > 0\n\tSpotLightShadow spotLight;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_SPOT_LIGHT_SHADOWS; i ++ ) {\n\t\tspotLight = spotLightShadows[ i ];\n\t\tshadow *= receiveShadow ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n\t#if NUM_POINT_LIGHT_SHADOWS > 0\n\tPointLightShadow pointLight;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_POINT_LIGHT_SHADOWS; i ++ ) {\n\t\tpointLight = pointLightShadows[ i ];\n\t\tshadow *= receiveShadow ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n\t#endif\n\treturn shadow;\n}", skinbase_vertex: "#ifdef USE_SKINNING\n\tmat4 boneMatX = getBoneMatrix( skinIndex.x );\n\tmat4 boneMatY = getBoneMatrix( skinIndex.y );\n\tmat4 boneMatZ = getBoneMatrix( skinIndex.z );\n\tmat4 boneMatW = getBoneMatrix( skinIndex.w );\n#endif", skinning_pars_vertex: "#ifdef USE_SKINNING\n\tuniform mat4 bindMatrix;\n\tuniform mat4 bindMatrixInverse;\n\t#ifdef BONE_TEXTURE\n\t\tuniform highp sampler2D boneTexture;\n\t\tuniform int boneTextureSize;\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tfloat j = i * 4.0;\n\t\t\tfloat x = mod( j, float( boneTextureSize ) );\n\t\t\tfloat y = floor( j / float( boneTextureSize ) );\n\t\t\tfloat dx = 1.0 / float( boneTextureSize );\n\t\t\tfloat dy = 1.0 / float( boneTextureSize );\n\t\t\ty = dy * ( y + 0.5 );\n\t\t\tvec4 v1 = texture2D( boneTexture, vec2( dx * ( x + 0.5 ), y ) );\n\t\t\tvec4 v2 = texture2D( boneTexture, vec2( dx * ( x + 1.5 ), y ) );\n\t\t\tvec4 v3 = texture2D( boneTexture, vec2( dx * ( x + 2.5 ), y ) );\n\t\t\tvec4 v4 = texture2D( boneTexture, vec2( dx * ( x + 3.5 ), y ) );\n\t\t\tmat4 bone = mat4( v1, v2, v3, v4 );\n\t\t\treturn bone;\n\t\t}\n\t#else\n\t\tuniform mat4 boneMatrices[ MAX_BONES ];\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tmat4 bone = boneMatrices[ int(i) ];\n\t\t\treturn bone;\n\t\t}\n\t#endif\n#endif", skinning_vertex: "#ifdef USE_SKINNING\n\tvec4 skinVertex = bindMatrix * vec4( transformed, 1.0 );\n\tvec4 skinned = vec4( 0.0 );\n\tskinned += boneMatX * skinVertex * skinWeight.x;\n\tskinned += boneMatY * skinVertex * skinWeight.y;\n\tskinned += boneMatZ * skinVertex * skinWeight.z;\n\tskinned += boneMatW * skinVertex * skinWeight.w;\n\ttransformed = ( bindMatrixInverse * skinned ).xyz;\n#endif", skinnormal_vertex: "#ifdef USE_SKINNING\n\tmat4 skinMatrix = mat4( 0.0 );\n\tskinMatrix += skinWeight.x * boneMatX;\n\tskinMatrix += skinWeight.y * boneMatY;\n\tskinMatrix += skinWeight.z * boneMatZ;\n\tskinMatrix += skinWeight.w * boneMatW;\n\tskinMatrix = bindMatrixInverse * skinMatrix * bindMatrix;\n\tobjectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz;\n\t#ifdef USE_TANGENT\n\t\tobjectTangent = vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz;\n\t#endif\n#endif", specularmap_fragment: "float specularStrength;\n#ifdef USE_SPECULARMAP\n\tvec4 texelSpecular = texture2D( specularMap, vUv );\n\tspecularStrength = texelSpecular.r;\n#else\n\tspecularStrength = 1.0;\n#endif", specularmap_pars_fragment: "#ifdef USE_SPECULARMAP\n\tuniform sampler2D specularMap;\n#endif", tonemapping_fragment: "#if defined( TONE_MAPPING )\n\tgl_FragColor.rgb = toneMapping( gl_FragColor.rgb );\n#endif", tonemapping_pars_fragment: "#ifndef saturate\n#define saturate(a) clamp( a, 0.0, 1.0 )\n#endif\nuniform float toneMappingExposure;\nuniform float toneMappingWhitePoint;\nvec3 LinearToneMapping( vec3 color ) {\n\treturn toneMappingExposure * color;\n}\nvec3 ReinhardToneMapping( vec3 color ) {\n\tcolor *= toneMappingExposure;\n\treturn saturate( color / ( vec3( 1.0 ) + color ) );\n}\n#define Uncharted2Helper( x ) max( ( ( x * ( 0.15 * x + 0.10 * 0.50 ) + 0.20 * 0.02 ) / ( x * ( 0.15 * x + 0.50 ) + 0.20 * 0.30 ) ) - 0.02 / 0.30, vec3( 0.0 ) )\nvec3 Uncharted2ToneMapping( vec3 color ) {\n\tcolor *= toneMappingExposure;\n\treturn saturate( Uncharted2Helper( color ) / Uncharted2Helper( vec3( toneMappingWhitePoint ) ) );\n}\nvec3 OptimizedCineonToneMapping( vec3 color ) {\n\tcolor *= toneMappingExposure;\n\tcolor = max( vec3( 0.0 ), color - 0.004 );\n\treturn pow( ( color * ( 6.2 * color + 0.5 ) ) / ( color * ( 6.2 * color + 1.7 ) + 0.06 ), vec3( 2.2 ) );\n}\nvec3 ACESFilmicToneMapping( vec3 color ) {\n\tcolor *= toneMappingExposure;\n\treturn saturate( ( color * ( 2.51 * color + 0.03 ) ) / ( color * ( 2.43 * color + 0.59 ) + 0.14 ) );\n}", uv_pars_fragment: "#if ( defined( USE_UV ) && ! defined( UVS_VERTEX_ONLY ) )\n\tvarying vec2 vUv;\n#endif", uv_pars_vertex: "#ifdef USE_UV\n\t#ifdef UVS_VERTEX_ONLY\n\t\tvec2 vUv;\n\t#else\n\t\tvarying vec2 vUv;\n\t#endif\n\tuniform mat3 uvTransform;\n#endif", uv_vertex: "#ifdef USE_UV\n\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\n#endif", uv2_pars_fragment: "#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvarying vec2 vUv2;\n#endif", uv2_pars_vertex: "#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tattribute vec2 uv2;\n\tvarying vec2 vUv2;\n\tuniform mat3 uv2Transform;\n#endif", uv2_vertex: "#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvUv2 = ( uv2Transform * vec3( uv2, 1 ) ).xy;\n#endif", worldpos_vertex: "#if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP )\n\tvec4 worldPosition = vec4( transformed, 1.0 );\n\t#ifdef USE_INSTANCING\n\t\tworldPosition = instanceMatrix * worldPosition;\n\t#endif\n\tworldPosition = modelMatrix * worldPosition;\n#endif", background_frag: "uniform sampler2D t2D;\nvarying vec2 vUv;\nvoid main() {\n\tvec4 texColor = texture2D( t2D, vUv );\n\tgl_FragColor = mapTexelToLinear( texColor );\n\t#include \n\t#include \n}", background_vert: "varying vec2 vUv;\nuniform mat3 uvTransform;\nvoid main() {\n\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\n\tgl_Position = vec4( position.xy, 1.0, 1.0 );\n}", cube_frag: "#include \nuniform float opacity;\nvarying vec3 vWorldDirection;\n#include \nvoid main() {\n\tvec3 vReflect = vWorldDirection;\n\t#include \n\tgl_FragColor = envColor;\n\tgl_FragColor.a *= opacity;\n\t#include \n\t#include \n}", cube_vert: "varying vec3 vWorldDirection;\n#include \nvoid main() {\n\tvWorldDirection = transformDirection( position, modelMatrix );\n\t#include \n\t#include \n\tgl_Position.z = gl_Position.w;\n}", depth_frag: "#if DEPTH_PACKING == 3200\n\tuniform float opacity;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvarying vec2 vHighPrecisionZW;\nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( 1.0 );\n\t#if DEPTH_PACKING == 3200\n\t\tdiffuseColor.a = opacity;\n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\tfloat fragCoordZ = 0.5 * vHighPrecisionZW[0] / vHighPrecisionZW[1] + 0.5;\n\t#if DEPTH_PACKING == 3200\n\t\tgl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );\n\t#elif DEPTH_PACKING == 3201\n\t\tgl_FragColor = packDepthToRGBA( fragCoordZ );\n\t#endif\n}", depth_vert: "#include \n#include \n#include \n#include \n#include \n#include \n#include \nvarying vec2 vHighPrecisionZW;\nvoid main() {\n\t#include \n\t#include \n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include \n\t\t#include \n\t\t#include \n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvHighPrecisionZW = gl_Position.zw;\n}", distanceRGBA_frag: "#define DISTANCE\nuniform vec3 referencePosition;\nuniform float nearDistance;\nuniform float farDistance;\nvarying vec3 vWorldPosition;\n#include \n#include \n#include \n#include \n#include \n#include \nvoid main () {\n\t#include \n\tvec4 diffuseColor = vec4( 1.0 );\n\t#include \n\t#include \n\t#include \n\tfloat dist = length( vWorldPosition - referencePosition );\n\tdist = ( dist - nearDistance ) / ( farDistance - nearDistance );\n\tdist = saturate( dist );\n\tgl_FragColor = packDepthToRGBA( dist );\n}", distanceRGBA_vert: "#define DISTANCE\nvarying vec3 vWorldPosition;\n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include \n\t\t#include \n\t\t#include \n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvWorldPosition = worldPosition.xyz;\n}", equirect_frag: "uniform sampler2D tEquirect;\nvarying vec3 vWorldDirection;\n#include \nvoid main() {\n\tvec3 direction = normalize( vWorldDirection );\n\tvec2 sampleUV;\n\tsampleUV.y = asin( clamp( direction.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\tsampleUV.x = atan( direction.z, direction.x ) * RECIPROCAL_PI2 + 0.5;\n\tvec4 texColor = texture2D( tEquirect, sampleUV );\n\tgl_FragColor = mapTexelToLinear( texColor );\n\t#include \n\t#include \n}", equirect_vert: "varying vec3 vWorldDirection;\n#include \nvoid main() {\n\tvWorldDirection = transformDirection( position, modelMatrix );\n\t#include \n\t#include \n}", linedashed_frag: "uniform vec3 diffuse;\nuniform float opacity;\nuniform float dashSize;\nuniform float totalSize;\nvarying float vLineDistance;\n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tif ( mod( vLineDistance, totalSize ) > dashSize ) {\n\t\tdiscard;\n\t}\n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include \n\t#include \n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include \n\t#include \n\t#include \n\t#include \n}", linedashed_vert: "uniform float scale;\nattribute float lineDistance;\nvarying float vLineDistance;\n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\tvLineDistance = scale * lineDistance;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}", meshbasic_frag: "uniform vec3 diffuse;\nuniform float opacity;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\t#ifdef USE_LIGHTMAP\n\t\n\t\tvec4 lightMapTexel= texture2D( lightMap, vUv2 );\n\t\treflectedLight.indirectDiffuse += lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity;\n\t#else\n\t\treflectedLight.indirectDiffuse += vec3( 1.0 );\n\t#endif\n\t#include \n\treflectedLight.indirectDiffuse *= diffuseColor.rgb;\n\tvec3 outgoingLight = reflectedLight.indirectDiffuse;\n\t#include \n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include \n\t#include \n\t#include \n\t#include \n}", meshbasic_vert: "#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#ifdef USE_ENVMAP\n\t#include \n\t#include \n\t#include \n\t#include \n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}", meshlambert_frag: "uniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float opacity;\nvarying vec3 vLightFront;\nvarying vec3 vIndirectFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n\tvarying vec3 vIndirectBack;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\treflectedLight.indirectDiffuse = getAmbientLightIrradiance( ambientLightColor );\n\t#ifdef DOUBLE_SIDED\n\t\treflectedLight.indirectDiffuse += ( gl_FrontFacing ) ? vIndirectFront : vIndirectBack;\n\t#else\n\t\treflectedLight.indirectDiffuse += vIndirectFront;\n\t#endif\n\t#include \n\treflectedLight.indirectDiffuse *= BRDF_Diffuse_Lambert( diffuseColor.rgb );\n\t#ifdef DOUBLE_SIDED\n\t\treflectedLight.directDiffuse = ( gl_FrontFacing ) ? vLightFront : vLightBack;\n\t#else\n\t\treflectedLight.directDiffuse = vLightFront;\n\t#endif\n\treflectedLight.directDiffuse *= BRDF_Diffuse_Lambert( diffuseColor.rgb ) * getShadowMask();\n\t#include \n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\n\t#include \n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}", meshlambert_vert: "#define LAMBERT\nvarying vec3 vLightFront;\nvarying vec3 vIndirectFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n\tvarying vec3 vIndirectBack;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}", meshmatcap_frag: "#define MATCAP\nuniform vec3 diffuse;\nuniform float opacity;\nuniform sampler2D matcap;\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvec3 viewDir = normalize( vViewPosition );\n\tvec3 x = normalize( vec3( viewDir.z, 0.0, - viewDir.x ) );\n\tvec3 y = cross( viewDir, x );\n\tvec2 uv = vec2( dot( x, normal ), dot( y, normal ) ) * 0.495 + 0.5;\n\t#ifdef USE_MATCAP\n\t\tvec4 matcapColor = texture2D( matcap, uv );\n\t\tmatcapColor = matcapTexelToLinear( matcapColor );\n\t#else\n\t\tvec4 matcapColor = vec4( 1.0 );\n\t#endif\n\tvec3 outgoingLight = diffuseColor.rgb * matcapColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include \n\t#include \n\t#include \n\t#include \n}", meshmatcap_vert: "#define MATCAP\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#ifndef FLAT_SHADED\n\t\tvNormal = normalize( transformedNormal );\n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvViewPosition = - mvPosition.xyz;\n}", meshtoon_frag: "#define TOON\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform vec3 specular;\nuniform float shininess;\nuniform float opacity;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}", meshtoon_vert: "#define TOON\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvViewPosition = - mvPosition.xyz;\n\t#include \n\t#include \n\t#include \n}", meshphong_frag: "#define PHONG\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform vec3 specular;\nuniform float shininess;\nuniform float opacity;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\t#include \n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}", meshphong_vert: "#define PHONG\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvViewPosition = - mvPosition.xyz;\n\t#include \n\t#include \n\t#include \n\t#include \n}", meshphysical_frag: "#define STANDARD\n#ifdef PHYSICAL\n\t#define REFLECTIVITY\n\t#define CLEARCOAT\n\t#define TRANSPARENCY\n#endif\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float roughness;\nuniform float metalness;\nuniform float opacity;\n#ifdef TRANSPARENCY\n\tuniform float transparency;\n#endif\n#ifdef REFLECTIVITY\n\tuniform float reflectivity;\n#endif\n#ifdef CLEARCOAT\n\tuniform float clearcoat;\n\tuniform float clearcoatRoughness;\n#endif\n#ifdef USE_SHEEN\n\tuniform vec3 sheen;\n#endif\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\t#ifdef TRANSPARENCY\n\t\tdiffuseColor.a *= saturate( 1. - transparency + linearToRelativeLuminance( reflectedLight.directSpecular + reflectedLight.indirectSpecular ) );\n\t#endif\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}", meshphysical_vert: "#define STANDARD\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n\t#ifdef USE_TANGENT\n\t\tvTangent = normalize( transformedTangent );\n\t\tvBitangent = normalize( cross( vNormal, vTangent ) * tangent.w );\n\t#endif\n#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvViewPosition = - mvPosition.xyz;\n\t#include \n\t#include \n\t#include \n}", normal_frag: "#define NORMAL\nuniform float opacity;\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\n\tvarying vec3 vViewPosition;\n#endif\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\tgl_FragColor = vec4( packNormalToRGB( normal ), opacity );\n}", normal_vert: "#define NORMAL\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\n\tvarying vec3 vViewPosition;\n#endif\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n\t#ifdef USE_TANGENT\n\t\tvTangent = normalize( transformedTangent );\n\t\tvBitangent = normalize( cross( vNormal, vTangent ) * tangent.w );\n\t#endif\n#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\n\tvViewPosition = - mvPosition.xyz;\n#endif\n}", points_frag: "uniform vec3 diffuse;\nuniform float opacity;\n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include \n\t#include \n\t#include \n\t#include \n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include \n\t#include \n\t#include \n\t#include \n}", points_vert: "uniform float size;\nuniform float scale;\n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\tgl_PointSize = size;\n\t#ifdef USE_SIZEATTENUATION\n\t\tbool isPerspective = isPerspectiveMatrix( projectionMatrix );\n\t\tif ( isPerspective ) gl_PointSize *= ( scale / - mvPosition.z );\n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n}", shadow_frag: "uniform vec3 color;\nuniform float opacity;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\tgl_FragColor = vec4( color, opacity * ( 1.0 - getShadowMask() ) );\n\t#include \n\t#include \n\t#include \n}", shadow_vert: "#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}", sprite_frag: "uniform vec3 diffuse;\nuniform float opacity;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include \n\t#include \n\t#include \n\t#include \n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include \n\t#include \n\t#include \n}", sprite_vert: "uniform float rotation;\nuniform vec2 center;\n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 mvPosition = modelViewMatrix * vec4( 0.0, 0.0, 0.0, 1.0 );\n\tvec2 scale;\n\tscale.x = length( vec3( modelMatrix[ 0 ].x, modelMatrix[ 0 ].y, modelMatrix[ 0 ].z ) );\n\tscale.y = length( vec3( modelMatrix[ 1 ].x, modelMatrix[ 1 ].y, modelMatrix[ 1 ].z ) );\n\t#ifndef USE_SIZEATTENUATION\n\t\tbool isPerspective = isPerspectiveMatrix( projectionMatrix );\n\t\tif ( isPerspective ) scale *= - mvPosition.z;\n\t#endif\n\tvec2 alignedPosition = ( position.xy - ( center - vec2( 0.5 ) ) ) * scale;\n\tvec2 rotatedPosition;\n\trotatedPosition.x = cos( rotation ) * alignedPosition.x - sin( rotation ) * alignedPosition.y;\n\trotatedPosition.y = sin( rotation ) * alignedPosition.x + cos( rotation ) * alignedPosition.y;\n\tmvPosition.xy += rotatedPosition;\n\tgl_Position = projectionMatrix * mvPosition;\n\t#include \n\t#include \n\t#include \n}" }, it = { basic: { uniforms: Ve([Xe.common, Xe.specularmap, Xe.envmap, Xe.aomap, Xe.lightmap, Xe.fog]), vertexShader: tt.meshbasic_vert, fragmentShader: tt.meshbasic_frag }, lambert: { uniforms: Ve([Xe.common, Xe.specularmap, Xe.envmap, Xe.aomap, Xe.lightmap, Xe.emissivemap, Xe.fog, Xe.lights, { emissive: { value: new LA(0) } }]), vertexShader: tt.meshlambert_vert, fragmentShader: tt.meshlambert_frag }, phong: { uniforms: Ve([Xe.common, Xe.specularmap, Xe.envmap, Xe.aomap, Xe.lightmap, Xe.emissivemap, Xe.bumpmap, Xe.normalmap, Xe.displacementmap, Xe.fog, Xe.lights, { emissive: { value: new LA(0) }, specular: { value: new LA(1118481) }, shininess: { value: 30 } }]), vertexShader: tt.meshphong_vert, fragmentShader: tt.meshphong_frag }, standard: { uniforms: Ve([Xe.common, Xe.envmap, Xe.aomap, Xe.lightmap, Xe.emissivemap, Xe.bumpmap, Xe.normalmap, Xe.displacementmap, Xe.roughnessmap, Xe.metalnessmap, Xe.fog, Xe.lights, { emissive: { value: new LA(0) }, roughness: { value: .5 }, metalness: { value: .5 }, envMapIntensity: { value: 1 } }]), vertexShader: tt.meshphysical_vert, fragmentShader: tt.meshphysical_frag }, toon: { uniforms: Ve([Xe.common, Xe.specularmap, Xe.aomap, Xe.lightmap, Xe.emissivemap, Xe.bumpmap, Xe.normalmap, Xe.displacementmap, Xe.gradientmap, Xe.fog, Xe.lights, { emissive: { value: new LA(0) }, specular: { value: new LA(1118481) }, shininess: { value: 30 } }]), vertexShader: tt.meshtoon_vert, fragmentShader: tt.meshtoon_frag }, matcap: { uniforms: Ve([Xe.common, Xe.bumpmap, Xe.normalmap, Xe.displacementmap, Xe.fog, { matcap: { value: null } }]), vertexShader: tt.meshmatcap_vert, fragmentShader: tt.meshmatcap_frag }, points: { uniforms: Ve([Xe.points, Xe.fog]), vertexShader: tt.points_vert, fragmentShader: tt.points_frag }, dashed: { uniforms: Ve([Xe.common, Xe.fog, { scale: { value: 1 }, dashSize: { value: 1 }, totalSize: { value: 2 } }]), vertexShader: tt.linedashed_vert, fragmentShader: tt.linedashed_frag }, depth: { uniforms: Ve([Xe.common, Xe.displacementmap]), vertexShader: tt.depth_vert, fragmentShader: tt.depth_frag }, normal: { uniforms: Ve([Xe.common, Xe.bumpmap, Xe.normalmap, Xe.displacementmap, { opacity: { value: 1 } }]), vertexShader: tt.normal_vert, fragmentShader: tt.normal_frag }, sprite: { uniforms: Ve([Xe.sprite, Xe.fog]), vertexShader: tt.sprite_vert, fragmentShader: tt.sprite_frag }, background: { uniforms: { uvTransform: { value: new l }, t2D: { value: null } }, vertexShader: tt.background_vert, fragmentShader: tt.background_frag }, cube: { uniforms: Ve([Xe.envmap, { opacity: { value: 1 } }]), vertexShader: tt.cube_vert, fragmentShader: tt.cube_frag }, equirect: { uniforms: { tEquirect: { value: null } }, vertexShader: tt.equirect_vert, fragmentShader: tt.equirect_frag }, distanceRGBA: { uniforms: Ve([Xe.common, Xe.displacementmap, { referencePosition: { value: new y }, nearDistance: { value: 1 }, farDistance: { value: 1e3 } }]), vertexShader: tt.distanceRGBA_vert, fragmentShader: tt.distanceRGBA_frag }, shadow: { uniforms: Ve([Xe.lights, Xe.fog, { color: { value: new LA(0) }, opacity: { value: 1 } }]), vertexShader: tt.shadow_vert, fragmentShader: tt.shadow_frag } }; function ot(A, e, t, i) { var o, n, r = new LA(0), a = 0, s = null, l = 0, c = null; function h(A, t) { e.buffers.color.setClear(A.r, A.g, A.b, t, i) } return { getClearColor: function () { return r }, setClearColor: function (A, e) { r.set(A), h(r, a = void 0 !== e ? e : 1) }, getClearAlpha: function () { return a }, setClearAlpha: function (A) { h(r, a = A) }, render: function (e, i, d, p) { var g = i.background, u = A.xr, f = u.getSession && u.getSession(); if (f && "additive" === f.environmentBlendMode && (g = null), null === g ? h(r, a) : g && g.isColor && (h(g, 1), p = !0), (A.autoClear || p) && A.clear(A.autoClearColor, A.autoClearDepth, A.autoClearStencil), g && (g.isCubeTexture || g.isWebGLCubeRenderTarget || 306 === g.mapping)) { void 0 === n && ((n = new Ue(new Ne(1, 1, 1), new Pe({ type: "BackgroundCubeMaterial", uniforms: Oe(it.cube.uniforms), vertexShader: it.cube.vertexShader, fragmentShader: it.cube.fragmentShader, side: 1, depthTest: !1, depthWrite: !1, fog: !1 }))).geometry.deleteAttribute("normal"), n.geometry.deleteAttribute("uv"), n.onBeforeRender = function (A, e, t) { this.matrixWorld.copyPosition(t.matrixWorld) }, Object.defineProperty(n.material, "envMap", { get: function () { return this.uniforms.envMap.value } }), t.update(n)); var m = g.isWebGLCubeRenderTarget ? g.texture : g; n.material.uniforms.envMap.value = m, n.material.uniforms.flipEnvMap.value = m.isCubeTexture ? -1 : 1, s === g && l === m.version && c === A.toneMapping || (n.material.needsUpdate = !0, s = g, l = m.version, c = A.toneMapping), e.unshift(n, n.geometry, n.material, 0, 0, null) } else g && g.isTexture && (void 0 === o && ((o = new Ue(new et(2, 2), new Pe({ type: "BackgroundMaterial", uniforms: Oe(it.background.uniforms), vertexShader: it.background.vertexShader, fragmentShader: it.background.fragmentShader, side: 0, depthTest: !1, depthWrite: !1, fog: !1 }))).geometry.deleteAttribute("normal"), Object.defineProperty(o.material, "map", { get: function () { return this.uniforms.t2D.value } }), t.update(o)), o.material.uniforms.t2D.value = g, !0 === g.matrixAutoUpdate && g.updateMatrix(), o.material.uniforms.uvTransform.value.copy(g.matrix), s === g && l === g.version && c === A.toneMapping || (o.material.needsUpdate = !0, s = g, l = g.version, c = A.toneMapping), e.unshift(o, o.geometry, o.material, 0, 0, null)) } } } function nt(A, e, t, i) { var o, n = i.isWebGL2; this.setMode = function (A) { o = A }, this.render = function (e, i) { A.drawArrays(o, e, i), t.update(i, o) }, this.renderInstances = function (i, r, a, s) { if (0 !== s) { var l, c; if (n) l = A, c = "drawArraysInstanced"; else if (c = "drawArraysInstancedANGLE", null === (l = e.get("ANGLE_instanced_arrays"))) return void console.error("THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays."); l[c](o, r, a, s), t.update(a, o, s) } } } function rt(A, e, t) { var i; function o(e) { if ("highp" === e) { if (A.getShaderPrecisionFormat(35633, 36338).precision > 0 && A.getShaderPrecisionFormat(35632, 36338).precision > 0) return "highp"; e = "mediump" } return "mediump" === e && A.getShaderPrecisionFormat(35633, 36337).precision > 0 && A.getShaderPrecisionFormat(35632, 36337).precision > 0 ? "mediump" : "lowp" } var n = "undefined" != typeof WebGL2RenderingContext && A instanceof WebGL2RenderingContext || "undefined" != typeof WebGL2ComputeRenderingContext && A instanceof WebGL2ComputeRenderingContext, r = void 0 !== t.precision ? t.precision : "highp", a = o(r); a !== r && (console.warn("THREE.WebGLRenderer:", r, "not supported, using", a, "instead."), r = a); var s = !0 === t.logarithmicDepthBuffer, l = A.getParameter(34930), c = A.getParameter(35660), h = A.getParameter(3379), d = A.getParameter(34076), p = A.getParameter(34921), g = A.getParameter(36347), u = A.getParameter(36348), f = A.getParameter(36349), m = c > 0, C = n || !!e.get("OES_texture_float"); return { isWebGL2: n, getMaxAnisotropy: function () { if (void 0 !== i) return i; var t = e.get("EXT_texture_filter_anisotropic"); return i = null !== t ? A.getParameter(t.MAX_TEXTURE_MAX_ANISOTROPY_EXT) : 0 }, getMaxPrecision: o, precision: r, logarithmicDepthBuffer: s, maxTextures: l, maxVertexTextures: c, maxTextureSize: h, maxCubemapSize: d, maxAttributes: p, maxVertexUniforms: g, maxVaryings: u, maxFragmentUniforms: f, vertexTextures: m, floatFragmentTextures: C, floatVertexTextures: m && C, maxSamples: n ? A.getParameter(36183) : 0 } } function at() { var A = this, e = null, t = 0, i = !1, o = !1, n = new EA, r = new l, a = { value: null, needsUpdate: !1 }; function s() { a.value !== e && (a.value = e, a.needsUpdate = t > 0), A.numPlanes = t, A.numIntersection = 0 } function c(e, t, i, o) { var s = null !== e ? e.length : 0, l = null; if (0 !== s) { if (l = a.value, !0 !== o || null === l) { var c = i + 4 * s, h = t.matrixWorldInverse; r.getNormalMatrix(h), (null === l || c > l.length) && (l = new Float32Array(c)); for (var d = 0, p = i; d !== s; ++d, p += 4) n.copy(e[d]).applyMatrix4(h, r), n.normal.toArray(l, p), l[p + 3] = n.constant } a.value = l, a.needsUpdate = !0 } return A.numPlanes = s, A.numIntersection = 0, l } this.uniform = a, this.numPlanes = 0, this.numIntersection = 0, this.init = function (A, o, n) { var r = 0 !== A.length || o || 0 !== t || i; return i = o, e = c(A, n, 0), t = A.length, r }, this.beginShadows = function () { o = !0, c(null) }, this.endShadows = function () { o = !1, s() }, this.setState = function (A, n, r, l, h, d) { if (!i || null === A || 0 === A.length || o && !r) o ? c(null) : s(); else { var p = o ? 0 : t, g = 4 * p, u = h.clippingState || null; a.value = u, u = c(A, l, g, d); for (var f = 0; f !== g; ++f) u[f] = e[f]; h.clippingState = u, this.numIntersection = n ? this.numPlanes : 0, this.numPlanes += p } } } function st(A) { var e = {}; return { get: function (t) { if (void 0 !== e[t]) return e[t]; var i; switch (t) { case "WEBGL_depth_texture": i = A.getExtension("WEBGL_depth_texture") || A.getExtension("MOZ_WEBGL_depth_texture") || A.getExtension("WEBKIT_WEBGL_depth_texture"); break; case "EXT_texture_filter_anisotropic": i = A.getExtension("EXT_texture_filter_anisotropic") || A.getExtension("MOZ_EXT_texture_filter_anisotropic") || A.getExtension("WEBKIT_EXT_texture_filter_anisotropic"); break; case "WEBGL_compressed_texture_s3tc": i = A.getExtension("WEBGL_compressed_texture_s3tc") || A.getExtension("MOZ_WEBGL_compressed_texture_s3tc") || A.getExtension("WEBKIT_WEBGL_compressed_texture_s3tc"); break; case "WEBGL_compressed_texture_pvrtc": i = A.getExtension("WEBGL_compressed_texture_pvrtc") || A.getExtension("WEBKIT_WEBGL_compressed_texture_pvrtc"); break; default: i = A.getExtension(t) } return null === i && console.warn("THREE.WebGLRenderer: " + t + " extension not supported."), e[t] = i, i } } } function lt(A, e, t) { var i = new WeakMap, o = new WeakMap; function n(A) { var r = A.target, a = i.get(r); for (var s in null !== a.index && e.remove(a.index), a.attributes) e.remove(a.attributes[s]); r.removeEventListener("dispose", n), i.delete(r); var l = o.get(a); l && (e.remove(l), o.delete(a)), t.memory.geometries-- } function r(A) { var t = [], i = A.index, n = A.attributes.position, r = 0; if (null !== i) { r = i.version; for (var a = 0, s = (l = i.array).length; s > a; a += 3) { t.push(c = l[a + 0], h = l[a + 1], h, d = l[a + 2], d, c) } } else { var l; r = n.version; for (a = 0, s = (l = n.array).length / 3 - 1; s > a; a += 3) { var c, h, d; t.push(c = a + 0, h = a + 1, h, d = a + 2, d, c) } } var p = new(ie(t) > 65535 ? $A : XA)(t, 1); p.version = r, e.update(p, 34963); var g = o.get(A); g && e.remove(g), o.set(A, p) } return { get: function (A, e) { var o = i.get(e); return o || (e.addEventListener("dispose", n), e.isBufferGeometry ? o = e : e.isGeometry && (void 0 === e._bufferGeometry && (e._bufferGeometry = (new he).setFromObject(A)), o = e._bufferGeometry), i.set(e, o), t.memory.geometries++, o) }, update: function (A) { var t = A.index, i = A.attributes; for (var o in null !== t && e.update(t, 34963), i) e.update(i[o], 34962); var n = A.morphAttributes; for (var o in n) for (var r = n[o], a = 0, s = r.length; s > a; a++) e.update(r[a], 34962) }, getWireframeAttribute: function (A) { var e = o.get(A); if (e) { var t = A.index; null !== t && t.version > e.version && r(A) } else r(A); return o.get(A) } } } function ct(A, e, t, i) { var o, n, r, a = i.isWebGL2; this.setMode = function (A) { o = A }, this.setIndex = function (A) { n = A.type, r = A.bytesPerElement }, this.render = function (e, i) { A.drawElements(o, i, n, e * r), t.update(i, o) }, this.renderInstances = function (i, s, l, c) { if (0 !== c) { var h, d; if (a) h = A, d = "drawElementsInstanced"; else if (d = "drawElementsInstancedANGLE", null === (h = e.get("ANGLE_instanced_arrays"))) return void console.error("THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays."); h[d](o, l, n, s * r, c), t.update(l, o, c) } } } function ht(A) { var e = { frame: 0, calls: 0, triangles: 0, points: 0, lines: 0 }; return { memory: { geometries: 0, textures: 0 }, render: e, programs: null, autoReset: !0, reset: function () { e.frame++, e.calls = 0, e.triangles = 0, e.points = 0, e.lines = 0 }, update: function (A, t, i) { switch (i = i || 1, e.calls++, t) { case 4: e.triangles += i * (A / 3); break; case 1: e.lines += i * (A / 2); break; case 3: e.lines += i * (A - 1); break; case 2: e.lines += i * A; break; case 0: e.points += i * A; break; default: console.error("THREE.WebGLInfo: Unknown draw mode:", t) } } } } function dt(A, e) { return Math.abs(e[1]) - Math.abs(A[1]) } function pt(A) { var e = {}, t = new Float32Array(8); return { update: function (i, o, n, r) { var a = i.morphTargetInfluences, s = void 0 === a ? 0 : a.length, l = e[o.id]; if (void 0 === l) { l = []; for (var c = 0; s > c; c++) l[c] = [c, 0]; e[o.id] = l } var h = n.morphTargets && o.morphAttributes.position, d = n.morphNormals && o.morphAttributes.normal; for (c = 0; s > c; c++) { 0 !== (g = l[c])[1] && (h && o.deleteAttribute("morphTarget" + c), d && o.deleteAttribute("morphNormal" + c)) } for (c = 0; s > c; c++) { (g = l[c])[0] = c, g[1] = a[c] } l.sort(dt); var p = 0; for (c = 0; 8 > c; c++) { var g; if (g = l[c]) { var u = g[0], f = g[1]; if (f) { h && o.setAttribute("morphTarget" + c, h[u]), d && o.setAttribute("morphNormal" + c, d[u]), t[c] = f, p += f; continue } } t[c] = 0 } var m = o.morphTargetsRelative ? 1 : 1 - p; r.getUniforms().setValue(A, "morphTargetBaseInfluence", m), r.getUniforms().setValue(A, "morphTargetInfluences", t) } } } function gt(A, e, t, i) { var o = new WeakMap; return { update: function (A) { var n = i.render.frame, r = A.geometry, a = e.get(A, r); return o.get(a) !== n && (r.isGeometry && a.updateFromObject(A), e.update(a), o.set(a, n)), A.isInstancedMesh && t.update(A.instanceMatrix, 34962), a }, dispose: function () { o = new WeakMap } } } function ut(A, e, t, i, o, n, r, a, s, l) { d.call(this, A = void 0 !== A ? A : [], e = void 0 !== e ? e : 301, t, i, o, n, r = void 0 !== r ? r : 1022, a, s, l), this.flipY = !1 } function ft(A, e, t, i) { d.call(this, null), this.image = { data: A || null, width: e || 1, height: t || 1, depth: i || 1 }, this.magFilter = 1003, this.minFilter = 1003, this.wrapR = 1001, this.generateMipmaps = !1, this.flipY = !1, this.needsUpdate = !0 } function mt(A, e, t, i) { d.call(this, null), this.image = { data: A || null, width: e || 1, height: t || 1, depth: i || 1 }, this.magFilter = 1003, this.minFilter = 1003, this.wrapR = 1001, this.generateMipmaps = !1, this.flipY = !1, this.needsUpdate = !0 } it.physical = { uniforms: Ve([it.standard.uniforms, { clearcoat: { value: 0 }, clearcoatMap: { value: null }, clearcoatRoughness: { value: 0 }, clearcoatRoughnessMap: { value: null }, clearcoatNormalScale: { value: new s(1, 1) }, clearcoatNormalMap: { value: null }, sheen: { value: new LA(0) }, transparency: { value: 0 } }]), vertexShader: tt.meshphysical_vert, fragmentShader: tt.meshphysical_frag }, (ut.prototype = Object.create(d.prototype)).constructor = ut, ut.prototype.isCubeTexture = !0, Object.defineProperty(ut.prototype, "images", { get: function () { return this.image }, set: function (A) { this.image = A } }), (ft.prototype = Object.create(d.prototype)).constructor = ft, ft.prototype.isDataTexture2DArray = !0, (mt.prototype = Object.create(d.prototype)).constructor = mt, mt.prototype.isDataTexture3D = !0; var Ct = new d, yt = new ft, vt = new mt, It = new ut, Et = [], Bt = [], xt = new Float32Array(16), St = new Float32Array(9), wt = new Float32Array(4); function Mt(A, e, t) { var i = A[0]; if (0 >= i || i > 0) return A; var o = e * t, n = Et[o]; if (void 0 === n && (n = new Float32Array(o), Et[o] = n), 0 !== e) { i.toArray(n, 0); for (var r = 1, a = 0; r !== e; ++r) A[r].toArray(n, a += t) } return n } function bt(A, e) { if (A.length !== e.length) return !1; for (var t = 0, i = A.length; i > t; t++) if (A[t] !== e[t]) return !1; return !0 } function Ut(A, e) { for (var t = 0, i = e.length; i > t; t++) A[t] = e[t] } function Ft(A, e) { var t = Bt[e]; void 0 === t && (t = new Int32Array(e), Bt[e] = t); for (var i = 0; i !== e; ++i) t[i] = A.allocateTextureUnit(); return t } function Kt(A, e) { var t = this.cache; t[0] !== e && (A.uniform1f(this.addr, e), t[0] = e) } function Qt(A, e) { var t = this.cache; if (void 0 !== e.x) t[0] === e.x && t[1] === e.y || (A.uniform2f(this.addr, e.x, e.y), t[0] = e.x, t[1] = e.y); else { if (bt(t, e)) return; A.uniform2fv(this.addr, e), Ut(t, e) } } function Rt(A, e) { var t = this.cache; if (void 0 !== e.x) t[0] === e.x && t[1] === e.y && t[2] === e.z || (A.uniform3f(this.addr, e.x, e.y, e.z), t[0] = e.x, t[1] = e.y, t[2] = e.z); else if (void 0 !== e.r) t[0] === e.r && t[1] === e.g && t[2] === e.b || (A.uniform3f(this.addr, e.r, e.g, e.b), t[0] = e.r, t[1] = e.g, t[2] = e.b); else { if (bt(t, e)) return; A.uniform3fv(this.addr, e), Ut(t, e) } } function Tt(A, e) { var t = this.cache; if (void 0 !== e.x) t[0] === e.x && t[1] === e.y && t[2] === e.z && t[3] === e.w || (A.uniform4f(this.addr, e.x, e.y, e.z, e.w), t[0] = e.x, t[1] = e.y, t[2] = e.z, t[3] = e.w); else { if (bt(t, e)) return; A.uniform4fv(this.addr, e), Ut(t, e) } } function kt(A, e) { var t = this.cache, i = e.elements; if (void 0 === i) { if (bt(t, e)) return; A.uniformMatrix2fv(this.addr, !1, e), Ut(t, e) } else { if (bt(t, i)) return; wt.set(i), A.uniformMatrix2fv(this.addr, !1, wt), Ut(t, i) } } function Dt(A, e) { var t = this.cache, i = e.elements; if (void 0 === i) { if (bt(t, e)) return; A.uniformMatrix3fv(this.addr, !1, e), Ut(t, e) } else { if (bt(t, i)) return; St.set(i), A.uniformMatrix3fv(this.addr, !1, St), Ut(t, i) } } function Lt(A, e) { var t = this.cache, i = e.elements; if (void 0 === i) { if (bt(t, e)) return; A.uniformMatrix4fv(this.addr, !1, e), Ut(t, e) } else { if (bt(t, i)) return; xt.set(i), A.uniformMatrix4fv(this.addr, !1, xt), Ut(t, i) } } function Nt(A, e, t) { var i = this.cache, o = t.allocateTextureUnit(); i[0] !== o && (A.uniform1i(this.addr, o), i[0] = o), t.safeSetTexture2D(e || Ct, o) } function Ot(A, e, t) { var i = this.cache, o = t.allocateTextureUnit(); i[0] !== o && (A.uniform1i(this.addr, o), i[0] = o), t.setTexture2DArray(e || yt, o) } function Vt(A, e, t) { var i = this.cache, o = t.allocateTextureUnit(); i[0] !== o && (A.uniform1i(this.addr, o), i[0] = o), t.setTexture3D(e || vt, o) } function Gt(A, e, t) { var i = this.cache, o = t.allocateTextureUnit(); i[0] !== o && (A.uniform1i(this.addr, o), i[0] = o), t.safeSetTextureCube(e || It, o) } function Pt(A, e) { var t = this.cache; t[0] !== e && (A.uniform1i(this.addr, e), t[0] = e) } function qt(A, e) { var t = this.cache; bt(t, e) || (A.uniform2iv(this.addr, e), Ut(t, e)) } function jt(A, e) { var t = this.cache; bt(t, e) || (A.uniform3iv(this.addr, e), Ut(t, e)) } function Ht(A, e) { var t = this.cache; bt(t, e) || (A.uniform4iv(this.addr, e), Ut(t, e)) } function Yt(A, e) { var t = this.cache; t[0] !== e && (A.uniform1ui(this.addr, e), t[0] = e) } function Wt(A, e) { A.uniform1fv(this.addr, e) } function Jt(A, e) { A.uniform1iv(this.addr, e) } function zt(A, e) { A.uniform2iv(this.addr, e) } function Zt(A, e) { A.uniform3iv(this.addr, e) } function Xt(A, e) { A.uniform4iv(this.addr, e) } function _t(A, e) { var t = Mt(e, this.size, 2); A.uniform2fv(this.addr, t) } function $t(A, e) { var t = Mt(e, this.size, 3); A.uniform3fv(this.addr, t) } function Ai(A, e) { var t = Mt(e, this.size, 4); A.uniform4fv(this.addr, t) } function ei(A, e) { var t = Mt(e, this.size, 4); A.uniformMatrix2fv(this.addr, !1, t) } function ti(A, e) { var t = Mt(e, this.size, 9); A.uniformMatrix3fv(this.addr, !1, t) } function ii(A, e) { var t = Mt(e, this.size, 16); A.uniformMatrix4fv(this.addr, !1, t) } function oi(A, e, t) { var i = e.length, o = Ft(t, i); A.uniform1iv(this.addr, o); for (var n = 0; n !== i; ++n) t.safeSetTexture2D(e[n] || Ct, o[n]) } function ni(A, e, t) { var i = e.length, o = Ft(t, i); A.uniform1iv(this.addr, o); for (var n = 0; n !== i; ++n) t.safeSetTextureCube(e[n] || It, o[n]) } function ri(A, e, t) { this.id = A, this.addr = t, this.cache = [], this.setValue = function (A) { switch (A) { case 5126: return Kt; case 35664: return Qt; case 35665: return Rt; case 35666: return Tt; case 35674: return kt; case 35675: return Dt; case 35676: return Lt; case 5124: case 35670: return Pt; case 35667: case 35671: return qt; case 35668: case 35672: return jt; case 35669: case 35673: return Ht; case 5125: return Yt; case 35678: case 36198: case 36298: case 36306: case 35682: return Nt; case 35679: case 36299: case 36307: return Vt; case 35680: case 36300: case 36308: case 36293: return Gt; case 36289: case 36303: case 36311: case 36292: return Ot } }(e.type) } function ai(A, e, t) { this.id = A, this.addr = t, this.cache = [], this.size = e.size, this.setValue = function (A) { switch (A) { case 5126: return Wt; case 35664: return _t; case 35665: return $t; case 35666: return Ai; case 35674: return ei; case 35675: return ti; case 35676: return ii; case 5124: case 35670: return Jt; case 35667: case 35671: return zt; case 35668: case 35672: return Zt; case 35669: case 35673: return Xt; case 35678: case 36198: case 36298: case 36306: case 35682: return oi; case 35680: case 36300: case 36308: case 36293: return ni } }(e.type) } function si(A) { this.id = A, this.seq = [], this.map = {} } ai.prototype.updateCache = function (A) { var e = this.cache; A instanceof Float32Array && e.length !== A.length && (this.cache = new Float32Array(A.length)), Ut(e, A) }, si.prototype.setValue = function (A, e, t) { for (var i = this.seq, o = 0, n = i.length; o !== n; ++o) { var r = i[o]; r.setValue(A, e[r.id], t) } }; var li = /([\w\d_]+)(\])?(\[|\.)?/g; function ci(A, e) { A.seq.push(e), A.map[e.id] = e } function hi(A, e, t) { var i = A.name, o = i.length; for (li.lastIndex = 0;;) { var n = li.exec(i), r = n[1], a = n[3]; if ("]" === n[2] && (r |= 0), void 0 === a || "[" === a && li.lastIndex + 2 === o) { ci(t, void 0 === a ? new ri(r, A, e) : new ai(r, A, e)); break } var s = t.map[r]; void 0 === s && ci(t, s = new si(r)), t = s } } function di(A, e) { this.seq = [], this.map = {}; for (var t = A.getProgramParameter(e, 35718), i = 0; t > i; ++i) { var o = A.getActiveUniform(e, i); hi(o, A.getUniformLocation(e, o.name), this) } } function pi(A, e, t) { var i = A.createShader(e); return A.shaderSource(i, t), A.compileShader(i), i } di.prototype.setValue = function (A, e, t, i) { var o = this.map[e]; void 0 !== o && o.setValue(A, t, i) }, di.prototype.setOptional = function (A, e, t) { var i = e[t]; void 0 !== i && this.setValue(A, t, i) }, di.upload = function (A, e, t, i) { for (var o = 0, n = e.length; o !== n; ++o) { var r = e[o], a = t[r.id]; !1 !== a.needsUpdate && r.setValue(A, a.value, i) } }, di.seqWithValue = function (A, e) { for (var t = [], i = 0, o = A.length; i !== o; ++i) { var n = A[i]; n.id in e && t.push(n) } return t }; var gi = 0; function ui(A) { switch (A) { case 3e3: return ["Linear", "( value )"]; case 3001: return ["sRGB", "( value )"]; case 3002: return ["RGBE", "( value )"]; case 3004: return ["RGBM", "( value, 7.0 )"]; case 3005: return ["RGBM", "( value, 16.0 )"]; case 3006: return ["RGBD", "( value, 256.0 )"]; case 3007: return ["Gamma", "( value, float( GAMMA_FACTOR ) )"]; case 3003: return ["LogLuv", "( value )"]; default: throw new Error("unsupported encoding: " + A) } } function fi(A, e, t) { var i = A.getShaderParameter(e, 35713), o = A.getShaderInfoLog(e).trim(); return i && "" === o ? "" : "THREE.WebGLShader: gl.getShaderInfoLog() " + t + "\n" + o + function (A) { for (var e = A.split("\n"), t = 0; e.length > t; t++) e[t] = t + 1 + ": " + e[t]; return e.join("\n") }(A.getShaderSource(e)) } function mi(A, e) { var t = ui(e); return "vec4 " + A + "( vec4 value ) { return " + t[0] + "ToLinear" + t[1] + "; }" } function Ci(A, e) { var t; switch (e) { case 1: t = "Linear"; break; case 2: t = "Reinhard"; break; case 3: t = "Uncharted2"; break; case 4: t = "OptimizedCineon"; break; case 5: t = "ACESFilmic"; break; default: throw new Error("unsupported toneMapping: " + e) } return "vec3 " + A + "( vec3 color ) { return " + t + "ToneMapping( color ); }" } function yi(A) { return "" !== A } function vi(A, e) { return A.replace(/NUM_DIR_LIGHTS/g, e.numDirLights).replace(/NUM_SPOT_LIGHTS/g, e.numSpotLights).replace(/NUM_RECT_AREA_LIGHTS/g, e.numRectAreaLights).replace(/NUM_POINT_LIGHTS/g, e.numPointLights).replace(/NUM_HEMI_LIGHTS/g, e.numHemiLights).replace(/NUM_DIR_LIGHT_SHADOWS/g, e.numDirLightShadows).replace(/NUM_SPOT_LIGHT_SHADOWS/g, e.numSpotLightShadows).replace(/NUM_POINT_LIGHT_SHADOWS/g, e.numPointLightShadows) } function Ii(A, e) { return A.replace(/NUM_CLIPPING_PLANES/g, e.numClippingPlanes).replace(/UNION_CLIPPING_PLANES/g, e.numClippingPlanes - e.numClipIntersection) } var Ei = /^[ \t]*#include +<([\w\d./]+)>/gm; function Bi(A) { return A.replace(Ei, xi) } function xi(A, e) { var t = tt[e]; if (void 0 === t) throw new Error("Can not resolve #include <" + e + ">"); return Bi(t) } var Si = /#pragma unroll_loop[\s]+?for \( int i \= (\d+)\; i < (\d+)\; i \+\+ \) \{([\s\S]+?)(?=\})\}/g, wi = /#pragma unroll_loop_start[\s]+?for \( int i \= (\d+)\; i < (\d+)\; i \+\+ \) \{([\s\S]+?)(?=\})\}[\s]+?#pragma unroll_loop_end/g; function Mi(A) { return A.replace(wi, Ui).replace(Si, bi) } function bi(A, e, t, i) { return console.warn("WebGLProgram: #pragma unroll_loop shader syntax is deprecated. Please use #pragma unroll_loop_start syntax instead."), Ui(A, e, t, i) } function Ui(A, e, t, i) { for (var o = "", n = parseInt(e); n < parseInt(t); n++) o += i.replace(/\[ i \]/g, "[ " + n + " ]").replace(/UNROLLED_LOOP_INDEX/g, n); return o } function Fi(A) { var e = "precision " + A.precision + " float;\nprecision " + A.precision + " int;"; return "highp" === A.precision ? e += "\n#define HIGH_PRECISION" : "mediump" === A.precision ? e += "\n#define MEDIUM_PRECISION" : "lowp" === A.precision && (e += "\n#define LOW_PRECISION"), e } function Ki(A, e, t) { var i, o, n, r, a, s = A.getContext(), l = t.defines, c = t.vertexShader, h = t.fragmentShader, d = function (A) { var e = "SHADOWMAP_TYPE_BASIC"; return 1 === A.shadowMapType ? e = "SHADOWMAP_TYPE_PCF" : 2 === A.shadowMapType ? e = "SHADOWMAP_TYPE_PCF_SOFT" : 3 === A.shadowMapType && (e = "SHADOWMAP_TYPE_VSM"), e }(t), p = function (A) { var e = "ENVMAP_TYPE_CUBE"; if (A.envMap) switch (A.envMapMode) { case 301: case 302: e = "ENVMAP_TYPE_CUBE"; break; case 306: case 307: e = "ENVMAP_TYPE_CUBE_UV"; break; case 303: case 304: e = "ENVMAP_TYPE_EQUIREC"; break; case 305: e = "ENVMAP_TYPE_SPHERE" } return e }(t), g = function (A) { var e = "ENVMAP_MODE_REFLECTION"; if (A.envMap) switch (A.envMapMode) { case 302: case 304: e = "ENVMAP_MODE_REFRACTION" } return e }(t), u = function (A) { var e = "ENVMAP_BLENDING_NONE"; if (A.envMap) switch (A.combine) { case 0: e = "ENVMAP_BLENDING_MULTIPLY"; break; case 1: e = "ENVMAP_BLENDING_MIX"; break; case 2: e = "ENVMAP_BLENDING_ADD" } return e }(t), f = A.gammaFactor > 0 ? A.gammaFactor : 1, m = t.isWebGL2 ? "" : function (A) { return [A.extensionDerivatives || A.envMapCubeUV || A.bumpMap || A.tangentSpaceNormalMap || A.clearcoatNormalMap || A.flatShading || "physical" === A.shaderID ? "#extension GL_OES_standard_derivatives : enable" : "", (A.extensionFragDepth || A.logarithmicDepthBuffer) && A.rendererExtensionFragDepth ? "#extension GL_EXT_frag_depth : enable" : "", A.extensionDrawBuffers && A.rendererExtensionDrawBuffers ? "#extension GL_EXT_draw_buffers : require" : "", (A.extensionShaderTextureLOD || A.envMap) && A.rendererExtensionShaderTextureLod ? "#extension GL_EXT_shader_texture_lod : enable" : ""].filter(yi).join("\n") }(t), C = function (A) { var e = []; for (var t in A) { var i = A[t]; !1 !== i && e.push("#define " + t + " " + i) } return e.join("\n") }(l), y = s.createProgram(); if (t.isRawShaderMaterial ? ((i = [C].filter(yi).join("\n")).length > 0 && (i += "\n"), (o = [m, C].filter(yi).join("\n")).length > 0 && (o += "\n")) : (i = [Fi(t), "#define SHADER_NAME " + t.shaderName, C, t.instancing ? "#define USE_INSTANCING" : "", t.supportsVertexTextures ? "#define VERTEX_TEXTURES" : "", "#define GAMMA_FACTOR " + f, "#define MAX_BONES " + t.maxBones, t.useFog && t.fog ? "#define USE_FOG" : "", t.useFog && t.fogExp2 ? "#define FOG_EXP2" : "", t.map ? "#define USE_MAP" : "", t.envMap ? "#define USE_ENVMAP" : "", t.envMap ? "#define " + g : "", t.lightMap ? "#define USE_LIGHTMAP" : "", t.aoMap ? "#define USE_AOMAP" : "", t.emissiveMap ? "#define USE_EMISSIVEMAP" : "", t.bumpMap ? "#define USE_BUMPMAP" : "", t.normalMap ? "#define USE_NORMALMAP" : "", t.normalMap && t.objectSpaceNormalMap ? "#define OBJECTSPACE_NORMALMAP" : "", t.normalMap && t.tangentSpaceNormalMap ? "#define TANGENTSPACE_NORMALMAP" : "", t.clearcoatMap ? "#define USE_CLEARCOATMAP" : "", t.clearcoatRoughnessMap ? "#define USE_CLEARCOAT_ROUGHNESSMAP" : "", t.clearcoatNormalMap ? "#define USE_CLEARCOAT_NORMALMAP" : "", t.displacementMap && t.supportsVertexTextures ? "#define USE_DISPLACEMENTMAP" : "", t.specularMap ? "#define USE_SPECULARMAP" : "", t.roughnessMap ? "#define USE_ROUGHNESSMAP" : "", t.metalnessMap ? "#define USE_METALNESSMAP" : "", t.alphaMap ? "#define USE_ALPHAMAP" : "", t.vertexTangents ? "#define USE_TANGENT" : "", t.vertexColors ? "#define USE_COLOR" : "", t.vertexUvs ? "#define USE_UV" : "", t.uvsVertexOnly ? "#define UVS_VERTEX_ONLY" : "", t.flatShading ? "#define FLAT_SHADED" : "", t.skinning ? "#define USE_SKINNING" : "", t.useVertexTexture ? "#define BONE_TEXTURE" : "", t.morphTargets ? "#define USE_MORPHTARGETS" : "", t.morphNormals && !1 === t.flatShading ? "#define USE_MORPHNORMALS" : "", t.doubleSided ? "#define DOUBLE_SIDED" : "", t.flipSided ? "#define FLIP_SIDED" : "", t.shadowMapEnabled ? "#define USE_SHADOWMAP" : "", t.shadowMapEnabled ? "#define " + d : "", t.sizeAttenuation ? "#define USE_SIZEATTENUATION" : "", t.logarithmicDepthBuffer ? "#define USE_LOGDEPTHBUF" : "", t.logarithmicDepthBuffer && t.rendererExtensionFragDepth ? "#define USE_LOGDEPTHBUF_EXT" : "", "uniform mat4 modelMatrix;", "uniform mat4 modelViewMatrix;", "uniform mat4 projectionMatrix;", "uniform mat4 viewMatrix;", "uniform mat3 normalMatrix;", "uniform vec3 cameraPosition;", "uniform bool isOrthographic;", "#ifdef USE_INSTANCING", " attribute mat4 instanceMatrix;", "#endif", "attribute vec3 position;", "attribute vec3 normal;", "attribute vec2 uv;", "#ifdef USE_TANGENT", "\tattribute vec4 tangent;", "#endif", "#ifdef USE_COLOR", "\tattribute vec3 color;", "#endif", "#ifdef USE_MORPHTARGETS", "\tattribute vec3 morphTarget0;", "\tattribute vec3 morphTarget1;", "\tattribute vec3 morphTarget2;", "\tattribute vec3 morphTarget3;", "\t#ifdef USE_MORPHNORMALS", "\t\tattribute vec3 morphNormal0;", "\t\tattribute vec3 morphNormal1;", "\t\tattribute vec3 morphNormal2;", "\t\tattribute vec3 morphNormal3;", "\t#else", "\t\tattribute vec3 morphTarget4;", "\t\tattribute vec3 morphTarget5;", "\t\tattribute vec3 morphTarget6;", "\t\tattribute vec3 morphTarget7;", "\t#endif", "#endif", "#ifdef USE_SKINNING", "\tattribute vec4 skinIndex;", "\tattribute vec4 skinWeight;", "#endif", "\n"].filter(yi).join("\n"), o = [m, Fi(t), "#define SHADER_NAME " + t.shaderName, C, t.alphaTest ? "#define ALPHATEST " + t.alphaTest + (t.alphaTest % 1 ? "" : ".0") : "", "#define GAMMA_FACTOR " + f, t.useFog && t.fog ? "#define USE_FOG" : "", t.useFog && t.fogExp2 ? "#define FOG_EXP2" : "", t.map ? "#define USE_MAP" : "", t.matcap ? "#define USE_MATCAP" : "", t.envMap ? "#define USE_ENVMAP" : "", t.envMap ? "#define " + p : "", t.envMap ? "#define " + g : "", t.envMap ? "#define " + u : "", t.lightMap ? "#define USE_LIGHTMAP" : "", t.aoMap ? "#define USE_AOMAP" : "", t.emissiveMap ? "#define USE_EMISSIVEMAP" : "", t.bumpMap ? "#define USE_BUMPMAP" : "", t.normalMap ? "#define USE_NORMALMAP" : "", t.normalMap && t.objectSpaceNormalMap ? "#define OBJECTSPACE_NORMALMAP" : "", t.normalMap && t.tangentSpaceNormalMap ? "#define TANGENTSPACE_NORMALMAP" : "", t.clearcoatMap ? "#define USE_CLEARCOATMAP" : "", t.clearcoatRoughnessMap ? "#define USE_CLEARCOAT_ROUGHNESSMAP" : "", t.clearcoatNormalMap ? "#define USE_CLEARCOAT_NORMALMAP" : "", t.specularMap ? "#define USE_SPECULARMAP" : "", t.roughnessMap ? "#define USE_ROUGHNESSMAP" : "", t.metalnessMap ? "#define USE_METALNESSMAP" : "", t.alphaMap ? "#define USE_ALPHAMAP" : "", t.sheen ? "#define USE_SHEEN" : "", t.vertexTangents ? "#define USE_TANGENT" : "", t.vertexColors ? "#define USE_COLOR" : "", t.vertexUvs ? "#define USE_UV" : "", t.uvsVertexOnly ? "#define UVS_VERTEX_ONLY" : "", t.gradientMap ? "#define USE_GRADIENTMAP" : "", t.flatShading ? "#define FLAT_SHADED" : "", t.doubleSided ? "#define DOUBLE_SIDED" : "", t.flipSided ? "#define FLIP_SIDED" : "", t.shadowMapEnabled ? "#define USE_SHADOWMAP" : "", t.shadowMapEnabled ? "#define " + d : "", t.premultipliedAlpha ? "#define PREMULTIPLIED_ALPHA" : "", t.physicallyCorrectLights ? "#define PHYSICALLY_CORRECT_LIGHTS" : "", t.logarithmicDepthBuffer ? "#define USE_LOGDEPTHBUF" : "", t.logarithmicDepthBuffer && t.rendererExtensionFragDepth ? "#define USE_LOGDEPTHBUF_EXT" : "", (t.extensionShaderTextureLOD || t.envMap) && t.rendererExtensionShaderTextureLod ? "#define TEXTURE_LOD_EXT" : "", "uniform mat4 viewMatrix;", "uniform vec3 cameraPosition;", "uniform bool isOrthographic;", 0 !== t.toneMapping ? "#define TONE_MAPPING" : "", 0 !== t.toneMapping ? tt.tonemapping_pars_fragment : "", 0 !== t.toneMapping ? Ci("toneMapping", t.toneMapping) : "", t.dithering ? "#define DITHERING" : "", t.outputEncoding || t.mapEncoding || t.matcapEncoding || t.envMapEncoding || t.emissiveMapEncoding || t.lightMapEncoding ? tt.encodings_pars_fragment : "", t.mapEncoding ? mi("mapTexelToLinear", t.mapEncoding) : "", t.matcapEncoding ? mi("matcapTexelToLinear", t.matcapEncoding) : "", t.envMapEncoding ? mi("envMapTexelToLinear", t.envMapEncoding) : "", t.emissiveMapEncoding ? mi("emissiveMapTexelToLinear", t.emissiveMapEncoding) : "", t.lightMapEncoding ? mi("lightMapTexelToLinear", t.lightMapEncoding) : "", t.outputEncoding ? (n = "linearToOutputTexel", r = t.outputEncoding, a = ui(r), "vec4 " + n + "( vec4 value ) { return LinearTo" + a[0] + a[1] + "; }") : "", t.depthPacking ? "#define DEPTH_PACKING " + t.depthPacking : "", "\n"].filter(yi).join("\n")), c = Ii(c = vi(c = Bi(c), t), t), h = Ii(h = vi(h = Bi(h), t), t), c = Mi(c), h = Mi(h), t.isWebGL2 && !t.isRawShaderMaterial) { var v = !1, I = /^\s*#version\s+300\s+es\s*\n/; t.isShaderMaterial && null !== c.match(I) && null !== h.match(I) && (v = !0, c = c.replace(I, ""), h = h.replace(I, "")), i = ["#version 300 es\n", "#define attribute in", "#define varying out", "#define texture2D texture"].join("\n") + "\n" + i, o = ["#version 300 es\n", "#define varying in", v ? "" : "out highp vec4 pc_fragColor;", v ? "" : "#define gl_FragColor pc_fragColor", "#define gl_FragDepthEXT gl_FragDepth", "#define texture2D texture", "#define textureCube texture", "#define texture2DProj textureProj", "#define texture2DLodEXT textureLod", "#define texture2DProjLodEXT textureProjLod", "#define textureCubeLodEXT textureLod", "#define texture2DGradEXT textureGrad", "#define texture2DProjGradEXT textureProjGrad", "#define textureCubeGradEXT textureGrad"].join("\n") + "\n" + o } var E, B, x = o + h, S = pi(s, 35633, i + c), w = pi(s, 35632, x); if (s.attachShader(y, S), s.attachShader(y, w), void 0 !== t.index0AttributeName ? s.bindAttribLocation(y, 0, t.index0AttributeName) : !0 === t.morphTargets && s.bindAttribLocation(y, 0, "position"), s.linkProgram(y), A.debug.checkShaderErrors) { var M = s.getProgramInfoLog(y).trim(), b = s.getShaderInfoLog(S).trim(), U = s.getShaderInfoLog(w).trim(), F = !0, K = !0; if (!1 === s.getProgramParameter(y, 35714)) { F = !1; var Q = fi(s, S, "vertex"), R = fi(s, w, "fragment"); console.error("THREE.WebGLProgram: shader error: ", s.getError(), "35715", s.getProgramParameter(y, 35715), "gl.getProgramInfoLog", M, Q, R) } else "" !== M ? console.warn("THREE.WebGLProgram: gl.getProgramInfoLog()", M) : "" !== b && "" !== U || (K = !1); K && (this.diagnostics = { runnable: F, programLog: M, vertexShader: { log: b, prefix: i }, fragmentShader: { log: U, prefix: o } }) } return s.detachShader(y, S), s.detachShader(y, w), s.deleteShader(S), s.deleteShader(w), this.getUniforms = function () { return void 0 === E && (E = new di(s, y)), E }, this.getAttributes = function () { return void 0 === B && (B = function (A, e) { for (var t = {}, i = A.getProgramParameter(e, 35721), o = 0; i > o; o++) { var n = A.getActiveAttrib(e, o).name; t[n] = A.getAttribLocation(e, n) } return t }(s, y)), B }, this.destroy = function () { s.deleteProgram(y), this.program = void 0 }, this.name = t.shaderName, this.id = gi++, this.cacheKey = e, this.usedTimes = 1, this.program = y, this.vertexShader = S, this.fragmentShader = w, this } function Qi(A, e, t) { var i = [], o = t.isWebGL2, n = t.logarithmicDepthBuffer, r = t.floatVertexTextures, a = t.precision, s = t.maxVertexUniforms, l = t.vertexTextures, c = { MeshDepthMaterial: "depth", MeshDistanceMaterial: "distanceRGBA", MeshNormalMaterial: "normal", MeshBasicMaterial: "basic", MeshLambertMaterial: "lambert", MeshPhongMaterial: "phong", MeshToonMaterial: "toon", MeshStandardMaterial: "physical", MeshPhysicalMaterial: "physical", MeshMatcapMaterial: "matcap", LineBasicMaterial: "basic", LineDashedMaterial: "dashed", PointsMaterial: "points", ShadowMaterial: "shadow", SpriteMaterial: "sprite" }, h = ["precision", "isWebGL2", "supportsVertexTextures", "outputEncoding", "instancing", "map", "mapEncoding", "matcap", "matcapEncoding", "envMap", "envMapMode", "envMapEncoding", "envMapCubeUV", "lightMap", "lightMapEncoding", "aoMap", "emissiveMap", "emissiveMapEncoding", "bumpMap", "normalMap", "objectSpaceNormalMap", "tangentSpaceNormalMap", "clearcoatMap", "clearcoatRoughnessMap", "clearcoatNormalMap", "displacementMap", "specularMap", "roughnessMap", "metalnessMap", "gradientMap", "alphaMap", "combine", "vertexColors", "vertexTangents", "vertexUvs", "uvsVertexOnly", "fog", "useFog", "fogExp2", "flatShading", "sizeAttenuation", "logarithmicDepthBuffer", "skinning", "maxBones", "useVertexTexture", "morphTargets", "morphNormals", "maxMorphTargets", "maxMorphNormals", "premultipliedAlpha", "numDirLights", "numPointLights", "numSpotLights", "numHemiLights", "numRectAreaLights", "numDirLightShadows", "numPointLightShadows", "numSpotLightShadows", "shadowMapEnabled", "shadowMapType", "toneMapping", "physicallyCorrectLights", "alphaTest", "doubleSided", "flipSided", "numClippingPlanes", "numClipIntersection", "depthPacking", "dithering", "sheen"]; function d(A) { var e; return A ? A.isTexture ? e = A.encoding : A.isWebGLRenderTarget && (console.warn("THREE.WebGLPrograms.getTextureEncodingFromMap: don't use render targets as textures. Use their .texture property instead."), e = A.texture.encoding) : e = 3e3, e } this.getParameters = function (i, h, p, g, u, f, m) { var C = g.fog, y = i.envMap || (i.isMeshStandardMaterial ? g.environment : null), v = c[i.type], I = m.isSkinnedMesh ? function (A) { var e = A.skeleton.bones; if (r) return 1024; var t = Math.floor((s - 20) / 4), i = Math.min(t, e.length); return e.length > i ? (console.warn("THREE.WebGLRenderer: Skeleton has " + e.length + " bones. This GPU supports " + i + "."), 0) : i }(m) : 0; null !== i.precision && (a = t.getMaxPrecision(i.precision)) !== i.precision && console.warn("THREE.WebGLProgram.getParameters:", i.precision, "not supported, using", a, "instead."); var E = function (A, e) { var t; if (e) { var i = it[e]; t = { name: A.type, uniforms: Ge.clone(i.uniforms), vertexShader: i.vertexShader, fragmentShader: i.fragmentShader } } else t = { name: A.type, uniforms: A.uniforms, vertexShader: A.vertexShader, fragmentShader: A.fragmentShader }; return t }(i, v); i.onBeforeCompile(E, A); var B = A.getRenderTarget(); return { isWebGL2: o, shaderID: v, shaderName: E.name, uniforms: E.uniforms, vertexShader: E.vertexShader, fragmentShader: E.fragmentShader, defines: i.defines, isRawShaderMaterial: i.isRawShaderMaterial, isShaderMaterial: i.isShaderMaterial, precision: a, instancing: !0 === m.isInstancedMesh, supportsVertexTextures: l, outputEncoding: null !== B ? d(B.texture) : A.outputEncoding, map: !!i.map, mapEncoding: d(i.map), matcap: !!i.matcap, matcapEncoding: d(i.matcap), envMap: !!y, envMapMode: y && y.mapping, envMapEncoding: d(y), envMapCubeUV: !!y && (306 === y.mapping || 307 === y.mapping), lightMap: !!i.lightMap, lightMapEncoding: d(i.lightMap), aoMap: !!i.aoMap, emissiveMap: !!i.emissiveMap, emissiveMapEncoding: d(i.emissiveMap), bumpMap: !!i.bumpMap, normalMap: !!i.normalMap, objectSpaceNormalMap: 1 === i.normalMapType, tangentSpaceNormalMap: 0 === i.normalMapType, clearcoatMap: !!i.clearcoatMap, clearcoatRoughnessMap: !!i.clearcoatRoughnessMap, clearcoatNormalMap: !!i.clearcoatNormalMap, displacementMap: !!i.displacementMap, roughnessMap: !!i.roughnessMap, metalnessMap: !!i.metalnessMap, specularMap: !!i.specularMap, alphaMap: !!i.alphaMap, gradientMap: !!i.gradientMap, sheen: !!i.sheen, combine: i.combine, vertexTangents: i.normalMap && i.vertexTangents, vertexColors: i.vertexColors, vertexUvs: !!(i.map || i.bumpMap || i.normalMap || i.specularMap || i.alphaMap || i.emissiveMap || i.roughnessMap || i.metalnessMap || i.clearcoatMap || i.clearcoatRoughnessMap || i.clearcoatNormalMap || i.displacementMap), uvsVertexOnly: !(i.map || i.bumpMap || i.normalMap || i.specularMap || i.alphaMap || i.emissiveMap || i.roughnessMap || i.metalnessMap || i.clearcoatNormalMap || !i.displacementMap), fog: !!C, useFog: i.fog, fogExp2: C && C.isFogExp2, flatShading: i.flatShading, sizeAttenuation: i.sizeAttenuation, logarithmicDepthBuffer: n, skinning: i.skinning && I > 0, maxBones: I, useVertexTexture: r, morphTargets: i.morphTargets, morphNormals: i.morphNormals, maxMorphTargets: A.maxMorphTargets, maxMorphNormals: A.maxMorphNormals, numDirLights: h.directional.length, numPointLights: h.point.length, numSpotLights: h.spot.length, numRectAreaLights: h.rectArea.length, numHemiLights: h.hemi.length, numDirLightShadows: h.directionalShadowMap.length, numPointLightShadows: h.pointShadowMap.length, numSpotLightShadows: h.spotShadowMap.length, numClippingPlanes: u, numClipIntersection: f, dithering: i.dithering, shadowMapEnabled: A.shadowMap.enabled && p.length > 0, shadowMapType: A.shadowMap.type, toneMapping: i.toneMapped ? A.toneMapping : 0, physicallyCorrectLights: A.physicallyCorrectLights, premultipliedAlpha: i.premultipliedAlpha, alphaTest: i.alphaTest, doubleSided: 2 === i.side, flipSided: 1 === i.side, depthPacking: void 0 !== i.depthPacking && i.depthPacking, index0AttributeName: i.index0AttributeName, extensionDerivatives: i.extensions && i.extensions.derivatives, extensionFragDepth: i.extensions && i.extensions.fragDepth, extensionDrawBuffers: i.extensions && i.extensions.drawBuffers, extensionShaderTextureLOD: i.extensions && i.extensions.shaderTextureLOD, rendererExtensionFragDepth: o || null !== e.get("EXT_frag_depth"), rendererExtensionDrawBuffers: o || null !== e.get("WEBGL_draw_buffers"), rendererExtensionShaderTextureLod: o || null !== e.get("EXT_shader_texture_lod"), onBeforeCompile: i.onBeforeCompile } }, this.getProgramCacheKey = function (e) { var t = []; if (e.shaderID ? t.push(e.shaderID) : (t.push(e.fragmentShader), t.push(e.vertexShader)), void 0 !== e.defines) for (var i in e.defines) t.push(i), t.push(e.defines[i]); if (void 0 === e.isRawShaderMaterial) { for (var o = 0; h.length > o; o++) t.push(e[h[o]]); t.push(A.outputEncoding), t.push(A.gammaFactor) } return t.push(e.onBeforeCompile.toString()), t.join() }, this.acquireProgram = function (e, t) { for (var o, n = 0, r = i.length; r > n; n++) { var a = i[n]; if (a.cacheKey === t) { ++(o = a).usedTimes; break } } return void 0 === o && (o = new Ki(A, t, e), i.push(o)), o }, this.releaseProgram = function (A) { if (0 == --A.usedTimes) { var e = i.indexOf(A); i[e] = i[i.length - 1], i.pop(), A.destroy() } }, this.programs = i } function Ri() { var A = new WeakMap; return { get: function (e) { var t = A.get(e); return void 0 === t && A.set(e, t = {}), t }, remove: function (e) { A.delete(e) }, update: function (e, t, i) { A.get(e)[t] = i }, dispose: function () { A = new WeakMap } } } function Ti(A, e) { return A.groupOrder !== e.groupOrder ? A.groupOrder - e.groupOrder : A.renderOrder !== e.renderOrder ? A.renderOrder - e.renderOrder : A.program !== e.program ? A.program.id - e.program.id : A.material.id !== e.material.id ? A.material.id - e.material.id : A.z !== e.z ? A.z - e.z : A.id - e.id } function ki(A, e) { return A.groupOrder !== e.groupOrder ? A.groupOrder - e.groupOrder : A.renderOrder !== e.renderOrder ? A.renderOrder - e.renderOrder : A.z !== e.z ? e.z - A.z : A.id - e.id } function Di() { var A = [], e = 0, t = [], i = [], o = { id: -1 }; function n(t, i, n, r, a, s) { var l = A[e]; return void 0 === l ? A[e] = l = { id: t.id, object: t, geometry: i, material: n, program: n.program || o, groupOrder: r, renderOrder: t.renderOrder, z: a, group: s } : (l.id = t.id, l.object = t, l.geometry = i, l.material = n, l.program = n.program || o, l.groupOrder = r, l.renderOrder = t.renderOrder, l.z = a, l.group = s), e++, l } return { opaque: t, transparent: i, init: function () { e = 0, t.length = 0, i.length = 0 }, push: function (A, e, o, r, a, s) { var l = n(A, e, o, r, a, s); (!0 === o.transparent ? i : t).push(l) }, unshift: function (A, e, o, r, a, s) { var l = n(A, e, o, r, a, s); (!0 === o.transparent ? i : t).unshift(l) }, finish: function () { for (var t = e, i = A.length; i > t; t++) { var o = A[t]; if (null === o.id) break; o.id = null, o.object = null, o.geometry = null, o.material = null, o.program = null, o.group = null } }, sort: function (A, e) { t.length > 1 && t.sort(A || Ti), i.length > 1 && i.sort(e || ki) } } } function Li() { var A = new WeakMap; function e(t) { var i = t.target; i.removeEventListener("dispose", e), A.delete(i) } return { get: function (t, i) { var o, n = A.get(t); return void 0 === n ? (o = new Di, A.set(t, new WeakMap), A.get(t).set(i, o), t.addEventListener("dispose", e)) : void 0 === (o = n.get(i)) && (o = new Di, n.set(i, o)), o }, dispose: function () { A = new WeakMap } } } function Ni() { var A = {}; return { get: function (e) { if (void 0 !== A[e.id]) return A[e.id]; var t; switch (e.type) { case "DirectionalLight": t = { direction: new y, color: new LA }; break; case "SpotLight": t = { position: new y, direction: new y, color: new LA, distance: 0, coneCos: 0, penumbraCos: 0, decay: 0 }; break; case "PointLight": t = { position: new y, color: new LA, distance: 0, decay: 0 }; break; case "HemisphereLight": t = { direction: new y, skyColor: new LA, groundColor: new LA }; break; case "RectAreaLight": t = { color: new LA, position: new y, halfWidth: new y, halfHeight: new y } } return A[e.id] = t, t } } } var Oi = 0; function Vi(A, e) { return (e.castShadow ? 1 : 0) - (A.castShadow ? 1 : 0) } function Gi() { for (var A, e = new Ni, t = (A = {}, { get: function (e) { if (void 0 !== A[e.id]) return A[e.id]; var t; switch (e.type) { case "DirectionalLight": case "SpotLight": t = { shadowBias: 0, shadowRadius: 1, shadowMapSize: new s }; break; case "PointLight": t = { shadowBias: 0, shadowRadius: 1, shadowMapSize: new s, shadowCameraNear: 1, shadowCameraFar: 1e3 } } return A[e.id] = t, t } }), i = { version: 0, hash: { directionalLength: -1, pointLength: -1, spotLength: -1, rectAreaLength: -1, hemiLength: -1, numDirectionalShadows: -1, numPointShadows: -1, numSpotShadows: -1 }, ambient: [0, 0, 0], probe: [], directional: [], directionalShadow: [], directionalShadowMap: [], directionalShadowMatrix: [], spot: [], spotShadow: [], spotShadowMap: [], spotShadowMatrix: [], rectArea: [], point: [], pointShadow: [], pointShadowMap: [], pointShadowMatrix: [], hemi: [] }, o = 0; 9 > o; o++) i.probe.push(new y); var n = new y, r = new M, a = new M; return { setup: function (A, o, s) { for (var l = 0, c = 0, h = 0, d = 0; 9 > d; d++) i.probe[d].set(0, 0, 0); var p = 0, g = 0, u = 0, f = 0, m = 0, C = 0, y = 0, v = 0, I = s.matrixWorldInverse; A.sort(Vi), d = 0; for (var E = A.length; E > d; d++) { var B = A[d], x = B.color, S = B.intensity, w = B.distance, M = B.shadow && B.shadow.map ? B.shadow.map.texture : null; if (B.isAmbientLight) l += x.r * S, c += x.g * S, h += x.b * S; else if (B.isLightProbe) for (var b = 0; 9 > b; b++) i.probe[b].addScaledVector(B.sh.coefficients[b], S); else if (B.isDirectionalLight) { if ((K = e.get(B)).color.copy(B.color).multiplyScalar(B.intensity), K.direction.setFromMatrixPosition(B.matrixWorld), n.setFromMatrixPosition(B.target.matrixWorld), K.direction.sub(n), K.direction.transformDirection(I), B.castShadow) { var U = B.shadow; (F = t.get(B)).shadowBias = U.bias, F.shadowRadius = U.radius, F.shadowMapSize = U.mapSize, i.directionalShadow[p] = F, i.directionalShadowMap[p] = M, i.directionalShadowMatrix[p] = B.shadow.matrix, C++ } i.directional[p] = K, p++ } else if (B.isSpotLight) { if ((K = e.get(B)).position.setFromMatrixPosition(B.matrixWorld), K.position.applyMatrix4(I), K.color.copy(x).multiplyScalar(S), K.distance = w, K.direction.setFromMatrixPosition(B.matrixWorld), n.setFromMatrixPosition(B.target.matrixWorld), K.direction.sub(n), K.direction.transformDirection(I), K.coneCos = Math.cos(B.angle), K.penumbraCos = Math.cos(B.angle * (1 - B.penumbra)), K.decay = B.decay, B.castShadow) { U = B.shadow; (F = t.get(B)).shadowBias = U.bias, F.shadowRadius = U.radius, F.shadowMapSize = U.mapSize, i.spotShadow[u] = F, i.spotShadowMap[u] = M, i.spotShadowMatrix[u] = B.shadow.matrix, v++ } i.spot[u] = K, u++ } else if (B.isRectAreaLight) { (K = e.get(B)).color.copy(x).multiplyScalar(S), K.position.setFromMatrixPosition(B.matrixWorld), K.position.applyMatrix4(I), a.identity(), r.copy(B.matrixWorld), r.premultiply(I), a.extractRotation(r), K.halfWidth.set(.5 * B.width, 0, 0), K.halfHeight.set(0, .5 * B.height, 0), K.halfWidth.applyMatrix4(a), K.halfHeight.applyMatrix4(a), i.rectArea[f] = K, f++ } else if (B.isPointLight) { if ((K = e.get(B)).position.setFromMatrixPosition(B.matrixWorld), K.position.applyMatrix4(I), K.color.copy(B.color).multiplyScalar(B.intensity), K.distance = B.distance, K.decay = B.decay, B.castShadow) { var F; U = B.shadow; (F = t.get(B)).shadowBias = U.bias, F.shadowRadius = U.radius, F.shadowMapSize = U.mapSize, F.shadowCameraNear = U.camera.near, F.shadowCameraFar = U.camera.far, i.pointShadow[g] = F, i.pointShadowMap[g] = M, i.pointShadowMatrix[g] = B.shadow.matrix, y++ } i.point[g] = K, g++ } else if (B.isHemisphereLight) { var K; (K = e.get(B)).direction.setFromMatrixPosition(B.matrixWorld), K.direction.transformDirection(I), K.direction.normalize(), K.skyColor.copy(B.color).multiplyScalar(S), K.groundColor.copy(B.groundColor).multiplyScalar(S), i.hemi[m] = K, m++ } } i.ambient[0] = l, i.ambient[1] = c, i.ambient[2] = h; var Q = i.hash; Q.directionalLength === p && Q.pointLength === g && Q.spotLength === u && Q.rectAreaLength === f && Q.hemiLength === m && Q.numDirectionalShadows === C && Q.numPointShadows === y && Q.numSpotShadows === v || (i.directional.length = p, i.spot.length = u, i.rectArea.length = f, i.point.length = g, i.hemi.length = m, i.directionalShadow.length = C, i.directionalShadowMap.length = C, i.pointShadow.length = y, i.pointShadowMap.length = y, i.spotShadow.length = v, i.spotShadowMap.length = v, i.directionalShadowMatrix.length = C, i.pointShadowMatrix.length = y, i.spotShadowMatrix.length = v, Q.directionalLength = p, Q.pointLength = g, Q.spotLength = u, Q.rectAreaLength = f, Q.hemiLength = m, Q.numDirectionalShadows = C, Q.numPointShadows = y, Q.numSpotShadows = v, i.version = Oi++) }, state: i } } function Pi() { var A = new Gi, e = [], t = []; return { init: function () { e.length = 0, t.length = 0 }, state: { lightsArray: e, shadowsArray: t, lights: A }, setupLights: function (i) { A.setup(e, t, i) }, pushLight: function (A) { e.push(A) }, pushShadow: function (A) { t.push(A) } } } function qi() { var A = new WeakMap; function e(t) { var i = t.target; i.removeEventListener("dispose", e), A.delete(i) } return { get: function (t, i) { var o; return !1 === A.has(t) ? (o = new Pi, A.set(t, new WeakMap), A.get(t).set(i, o), t.addEventListener("dispose", e)) : !1 === A.get(t).has(i) ? (o = new Pi, A.get(t).set(i, o)) : o = A.get(t).get(i), o }, dispose: function () { A = new WeakMap } } } function ji(A) { qA.call(this), this.type = "MeshDepthMaterial", this.depthPacking = 3200, this.skinning = !1, this.morphTargets = !1, this.map = null, this.alphaMap = null, this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.wireframe = !1, this.wireframeLinewidth = 1, this.fog = !1, this.setValues(A) } function Hi(A) { qA.call(this), this.type = "MeshDistanceMaterial", this.referencePosition = new y, this.nearDistance = 1, this.farDistance = 1e3, this.skinning = !1, this.morphTargets = !1, this.map = null, this.alphaMap = null, this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.fog = !1, this.setValues(A) } (ji.prototype = Object.create(qA.prototype)).constructor = ji, ji.prototype.isMeshDepthMaterial = !0, ji.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.depthPacking = A.depthPacking, this.skinning = A.skinning, this.morphTargets = A.morphTargets, this.map = A.map, this.alphaMap = A.alphaMap, this.displacementMap = A.displacementMap, this.displacementScale = A.displacementScale, this.displacementBias = A.displacementBias, this.wireframe = A.wireframe, this.wireframeLinewidth = A.wireframeLinewidth, this }, (Hi.prototype = Object.create(qA.prototype)).constructor = Hi, Hi.prototype.isMeshDistanceMaterial = !0, Hi.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.referencePosition.copy(A.referencePosition), this.nearDistance = A.nearDistance, this.farDistance = A.farDistance, this.skinning = A.skinning, this.morphTargets = A.morphTargets, this.map = A.map, this.alphaMap = A.alphaMap, this.displacementMap = A.displacementMap, this.displacementScale = A.displacementScale, this.displacementBias = A.displacementBias, this }; function Yi(A, e, t) { var i = new Ze, o = new s, n = new s, r = new p, a = [], l = [], c = {}, h = { 0: 1, 1: 0, 2: 2 }, d = new Pe({ defines: { SAMPLE_RATE: 2 / 8, HALF_SAMPLE_RATE: 1 / 8 }, uniforms: { shadow_pass: { value: null }, resolution: { value: new s }, radius: { value: 4 } }, vertexShader: "void main() {\n\tgl_Position = vec4( position, 1.0 );\n}", fragmentShader: "uniform sampler2D shadow_pass;\nuniform vec2 resolution;\nuniform float radius;\n#include \nvoid main() {\n float mean = 0.0;\n float squared_mean = 0.0;\n\tfloat depth = unpackRGBAToDepth( texture2D( shadow_pass, ( gl_FragCoord.xy ) / resolution ) );\n for ( float i = -1.0; i < 1.0 ; i += SAMPLE_RATE) {\n #ifdef HORIZONAL_PASS\n vec2 distribution = unpackRGBATo2Half( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( i, 0.0 ) * radius ) / resolution ) );\n mean += distribution.x;\n squared_mean += distribution.y * distribution.y + distribution.x * distribution.x;\n #else\n float depth = unpackRGBAToDepth( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( 0.0, i ) * radius ) / resolution ) );\n mean += depth;\n squared_mean += depth * depth;\n #endif\n }\n mean = mean * HALF_SAMPLE_RATE;\n squared_mean = squared_mean * HALF_SAMPLE_RATE;\n float std_dev = sqrt( squared_mean - mean * mean );\n gl_FragColor = pack2HalfToRGBA( vec2( mean, std_dev ) );\n}" }), u = d.clone(); u.defines.HORIZONAL_PASS = 1; var f = new he; f.setAttribute("position", new YA(new Float32Array([-1, -1, .5, 3, -1, .5, -1, 3, .5]), 3)); var m = new Ue(f, d), C = this; function y(t, i) { var o = e.update(m); d.uniforms.shadow_pass.value = t.map.texture, d.uniforms.resolution.value = t.mapSize, d.uniforms.radius.value = t.radius, A.setRenderTarget(t.mapPass), A.clear(), A.renderBufferDirect(i, null, o, d, m, null), u.uniforms.shadow_pass.value = t.mapPass.texture, u.uniforms.resolution.value = t.mapSize, u.uniforms.radius.value = t.radius, A.setRenderTarget(t.map), A.clear(), A.renderBufferDirect(i, null, o, u, m, null) } function v(A, e, t) { var i = A << 0 | e << 1 | t << 2, o = a[i]; return void 0 === o && (o = new ji({ depthPacking: 3201, morphTargets: A, skinning: e }), a[i] = o), o } function I(A, e, t) { var i = A << 0 | e << 1 | t << 2, o = l[i]; return void 0 === o && (o = new Hi({ morphTargets: A, skinning: e }), l[i] = o), o } function E(e, t, i, o, n, r) { var a = e.geometry, s = null, l = v, d = e.customDepthMaterial; if (!0 === i.isPointLight && (l = I, d = e.customDistanceMaterial), void 0 === d) { var p = !1; !0 === t.morphTargets && (!0 === a.isBufferGeometry ? p = a.morphAttributes && a.morphAttributes.position && a.morphAttributes.position.length > 0 : !0 === a.isGeometry && (p = a.morphTargets && a.morphTargets.length > 0)); var g = !1; !0 === e.isSkinnedMesh && (!0 === t.skinning ? g = !0 : console.warn("THREE.WebGLShadowMap: THREE.SkinnedMesh with material.skinning set to false:", e)), s = l(p, g, !0 === e.isInstancedMesh) } else s = d; if (A.localClippingEnabled && !0 === t.clipShadows && 0 !== t.clippingPlanes.length) { var u = s.uuid, f = t.uuid, m = c[u]; void 0 === m && (c[u] = m = {}); var C = m[f]; void 0 === C && (C = s.clone(), m[f] = C), s = C } return s.visible = t.visible, s.wireframe = t.wireframe, s.side = 3 === r ? null !== t.shadowSide ? t.shadowSide : t.side : null !== t.shadowSide ? t.shadowSide : h[t.side], s.clipShadows = t.clipShadows, s.clippingPlanes = t.clippingPlanes, s.clipIntersection = t.clipIntersection, s.wireframeLinewidth = t.wireframeLinewidth, s.linewidth = t.linewidth, !0 === i.isPointLight && !0 === s.isMeshDistanceMaterial && (s.referencePosition.setFromMatrixPosition(i.matrixWorld), s.nearDistance = o, s.farDistance = n), s } function B(t, o, n, r, a) { if (!1 !== t.visible) { if (t.layers.test(o.layers) && (t.isMesh || t.isLine || t.isPoints) && (t.castShadow || t.receiveShadow && 3 === a) && (!t.frustumCulled || i.intersectsObject(t))) { t.modelViewMatrix.multiplyMatrices(n.matrixWorldInverse, t.matrixWorld); var s = e.update(t), l = t.material; if (Array.isArray(l)) for (var c = s.groups, h = 0, d = c.length; d > h; h++) { var p = c[h], g = l[p.materialIndex]; if (g && g.visible && g.opacity > .9) { var u = E(t, g, r, n.near, n.far, a); A.renderBufferDirect(n, null, s, u, t, p) } } else if (l.visible && l.opacity > .9) { u = E(t, l, r, n.near, n.far, a); A.renderBufferDirect(n, null, s, u, t, null) } } for (var f = t.children, m = 0, C = f.length; C > m; m++) B(f[m], o, n, r, a) } } this.enabled = !1, this.autoUpdate = !0, this.needsUpdate = !1, this.type = 1, this.render = function (e, a, s) { if (!1 !== C.enabled && (!1 !== C.autoUpdate || !1 !== C.needsUpdate) && 0 !== e.length) { var l = A.getRenderTarget(), c = A.getActiveCubeFace(), h = A.getActiveMipmapLevel(), d = A.state; d.setBlending(0), d.buffers.color.setClear(1, 1, 1, 1), d.buffers.depth.setTest(!0), d.setScissorTest(!1); for (var p = 0, u = e.length; u > p; p++) { var f = e[p], m = f.shadow; if (void 0 !== m) { o.copy(m.mapSize); var v, I = m.getFrameExtents(); if (o.multiply(I), n.copy(m.mapSize), (o.x > t || o.y > t) && (console.warn("THREE.WebGLShadowMap:", f, "has shadow exceeding max texture size, reducing"), o.x > t && (n.x = Math.floor(t / I.x), o.x = n.x * I.x, m.mapSize.x = n.x), o.y > t && (n.y = Math.floor(t / I.y), o.y = n.y * I.y, m.mapSize.y = n.y)), null === m.map && !m.isPointLightShadow && 3 === this.type) m.map = new g(o.x, o.y, v = { minFilter: 1006, magFilter: 1006, format: 1023 }), m.map.texture.name = f.name + ".shadowMap", m.mapPass = new g(o.x, o.y, v), m.camera.updateProjectionMatrix(); if (null === m.map) m.map = new g(o.x, o.y, v = { minFilter: 1003, magFilter: 1003, format: 1023 }), m.map.texture.name = f.name + ".shadowMap", m.camera.updateProjectionMatrix(); A.setRenderTarget(m.map), A.clear(); for (var E = m.getViewportCount(), x = 0; E > x; x++) { var S = m.getViewport(x); r.set(n.x * S.x, n.y * S.y, n.x * S.z, n.y * S.w), d.viewport(r), m.updateMatrices(f, x), i = m.getFrustum(), B(a, s, m.camera, f, this.type) } m.isPointLightShadow || 3 !== this.type || y(m, s) } else console.warn("THREE.WebGLShadowMap:", f, "has no shadow.") } C.needsUpdate = !1, A.setRenderTarget(l, c, h) } } } function Wi(A, e, t) { var i = t.isWebGL2; var o = new function () { var e = !1, t = new p, i = null, o = new p(0, 0, 0, 0); return { setMask: function (t) { i === t || e || (A.colorMask(t, t, t, t), i = t) }, setLocked: function (A) { e = A }, setClear: function (e, i, n, r, a) { !0 === a && (e *= r, i *= r, n *= r), t.set(e, i, n, r), !1 === o.equals(t) && (A.clearColor(e, i, n, r), o.copy(t)) }, reset: function () { e = !1, i = null, o.set(-1, 0, 0, 0) } } }, n = new function () { var e = !1, t = null, i = null, o = null; return { setTest: function (A) { A ? O(2929) : V(2929) }, setMask: function (i) { t === i || e || (A.depthMask(i), t = i) }, setFunc: function (e) { if (i !== e) { if (e) switch (e) { case 0: A.depthFunc(512); break; case 1: A.depthFunc(519); break; case 2: A.depthFunc(513); break; case 3: A.depthFunc(515); break; case 4: A.depthFunc(514); break; case 5: A.depthFunc(518); break; case 6: A.depthFunc(516); break; case 7: A.depthFunc(517); break; default: A.depthFunc(515) } else A.depthFunc(515); i = e } }, setLocked: function (A) { e = A }, setClear: function (e) { o !== e && (A.clearDepth(e), o = e) }, reset: function () { e = !1, t = null, i = null, o = null } } }, r = new function () { var e = !1, t = null, i = null, o = null, n = null, r = null, a = null, s = null, l = null; return { setTest: function (A) { e || (A ? O(2960) : V(2960)) }, setMask: function (i) { t === i || e || (A.stencilMask(i), t = i) }, setFunc: function (e, t, r) { i === e && o === t && n === r || (A.stencilFunc(e, t, r), i = e, o = t, n = r) }, setOp: function (e, t, i) { r === e && a === t && s === i || (A.stencilOp(e, t, i), r = e, a = t, s = i) }, setLocked: function (A) { e = A }, setClear: function (e) { l !== e && (A.clearStencil(e), l = e) }, reset: function () { e = !1, t = null, i = null, o = null, n = null, r = null, a = null, s = null, l = null } } }, a = A.getParameter(34921), s = new Uint8Array(a), l = new Uint8Array(a), c = new Uint8Array(a), h = {}, d = null, g = null, u = null, f = null, m = null, C = null, y = null, v = null, I = null, E = !1, B = null, x = null, S = null, w = null, M = null, b = A.getParameter(35661), U = !1, F = 0, K = A.getParameter(7938); - 1 !== K.indexOf("WebGL") ? (F = parseFloat(/^WebGL\ ([0-9])/.exec(K)[1]), U = F >= 1) : -1 !== K.indexOf("OpenGL ES") && (F = parseFloat(/^OpenGL\ ES\ ([0-9])/.exec(K)[1]), U = F >= 2); var Q = null, R = {}, T = new p, k = new p; function D(e, t, i) { var o = new Uint8Array(4), n = A.createTexture(); A.bindTexture(e, n), A.texParameteri(e, 10241, 9728), A.texParameteri(e, 10240, 9728); for (var r = 0; i > r; r++) A.texImage2D(t + r, 0, 6408, 1, 1, 0, 6408, 5121, o); return n } var L = {}; function N(t, o) { (s[t] = 1, 0 === l[t] && (A.enableVertexAttribArray(t), l[t] = 1), c[t] !== o) && ((i ? A : e.get("ANGLE_instanced_arrays"))[i ? "vertexAttribDivisor" : "vertexAttribDivisorANGLE"](t, o), c[t] = o) } function O(e) { !0 !== h[e] && (A.enable(e), h[e] = !0) } function V(e) { !1 !== h[e] && (A.disable(e), h[e] = !1) } L[3553] = D(3553, 3553, 1), L[34067] = D(34067, 34069, 6), o.setClear(0, 0, 0, 1), n.setClear(1), r.setClear(0), O(2929), n.setFunc(3), H(!1), Y(1), O(2884), j(0); var G = { 100: 32774, 101: 32778, 102: 32779 }; if (i) G[103] = 32775, G[104] = 32776; else { var P = e.get("EXT_blend_minmax"); null !== P && (G[103] = P.MIN_EXT, G[104] = P.MAX_EXT) } var q = { 200: 0, 201: 1, 202: 768, 204: 770, 210: 776, 208: 774, 206: 772, 203: 769, 205: 771, 209: 775, 207: 773 }; function j(e, t, i, o, n, r, a, s) { if (0 !== e) { if (g || (O(3042), g = !0), 5 === e) n = n || t, r = r || i, a = a || o, t === f && n === y || (A.blendEquationSeparate(G[t], G[n]), f = t, y = n), i === m && o === C && r === v && a === I || (A.blendFuncSeparate(q[i], q[o], q[r], q[a]), m = i, C = o, v = r, I = a), u = e, E = null; else if (e !== u || s !== E) { if (100 === f && 100 === y || (A.blendEquation(32774), f = 100, y = 100), s) switch (e) { case 1: A.blendFuncSeparate(1, 771, 1, 771); break; case 2: A.blendFunc(1, 1); break; case 3: A.blendFuncSeparate(0, 0, 769, 771); break; case 4: A.blendFuncSeparate(0, 768, 0, 770); break; default: console.error("THREE.WebGLState: Invalid blending: ", e) } else switch (e) { case 1: A.blendFuncSeparate(770, 771, 1, 771); break; case 2: A.blendFunc(770, 1); break; case 3: A.blendFunc(0, 769); break; case 4: A.blendFunc(0, 768); break; default: console.error("THREE.WebGLState: Invalid blending: ", e) } m = null, C = null, v = null, I = null, u = e, E = s } } else g && (V(3042), g = !1) } function H(e) { B !== e && (A.frontFace(e ? 2304 : 2305), B = e) } function Y(e) { 0 !== e ? (O(2884), e !== x && A.cullFace(1 === e ? 1029 : 2 === e ? 1028 : 1032)) : V(2884), x = e } function W(e, t, i) { e ? (O(32823), w === t && M === i || (A.polygonOffset(t, i), w = t, M = i)) : V(32823) } function J(e) { void 0 === e && (e = 33984 + b - 1), Q !== e && (A.activeTexture(e), Q = e) } return { buffers: { color: o, depth: n, stencil: r }, initAttributes: function () { for (var A = 0, e = s.length; e > A; A++) s[A] = 0 }, enableAttribute: function (A) { N(A, 0) }, enableAttributeAndDivisor: N, disableUnusedAttributes: function () { for (var e = 0, t = l.length; e !== t; ++e) l[e] !== s[e] && (A.disableVertexAttribArray(e), l[e] = 0) }, enable: O, disable: V, useProgram: function (e) { return d !== e && (A.useProgram(e), d = e, !0) }, setBlending: j, setMaterial: function (A, e) { 2 === A.side ? V(2884) : O(2884); var t = 1 === A.side; e && (t = !t), H(t), 1 === A.blending && !1 === A.transparent ? j(0) : j(A.blending, A.blendEquation, A.blendSrc, A.blendDst, A.blendEquationAlpha, A.blendSrcAlpha, A.blendDstAlpha, A.premultipliedAlpha), n.setFunc(A.depthFunc), n.setTest(A.depthTest), n.setMask(A.depthWrite), o.setMask(A.colorWrite); var i = A.stencilWrite; r.setTest(i), i && (r.setMask(A.stencilWriteMask), r.setFunc(A.stencilFunc, A.stencilRef, A.stencilFuncMask), r.setOp(A.stencilFail, A.stencilZFail, A.stencilZPass)), W(A.polygonOffset, A.polygonOffsetFactor, A.polygonOffsetUnits) }, setFlipSided: H, setCullFace: Y, setLineWidth: function (e) { e !== S && (U && A.lineWidth(e), S = e) }, setPolygonOffset: W, setScissorTest: function (A) { A ? O(3089) : V(3089) }, activeTexture: J, bindTexture: function (e, t) { null === Q && J(); var i = R[Q]; void 0 === i && (R[Q] = i = { type: void 0, texture: void 0 }), i.type === e && i.texture === t || (A.bindTexture(e, t || L[e]), i.type = e, i.texture = t) }, unbindTexture: function () { var e = R[Q]; void 0 !== e && void 0 !== e.type && (A.bindTexture(e.type, null), e.type = void 0, e.texture = void 0) }, compressedTexImage2D: function () { try { A.compressedTexImage2D.apply(A, arguments) } catch (A) { console.error("THREE.WebGLState:", A) } }, texImage2D: function () { try { A.texImage2D.apply(A, arguments) } catch (A) { console.error("THREE.WebGLState:", A) } }, texImage3D: function () { try { A.texImage3D.apply(A, arguments) } catch (A) { console.error("THREE.WebGLState:", A) } }, scissor: function (e) { !1 === T.equals(e) && (A.scissor(e.x, e.y, e.z, e.w), T.copy(e)) }, viewport: function (e) { !1 === k.equals(e) && (A.viewport(e.x, e.y, e.z, e.w), k.copy(e)) }, reset: function () { for (var e = 0; l.length > e; e++) 1 === l[e] && (A.disableVertexAttribArray(e), l[e] = 0); h = {}, Q = null, R = {}, d = null, u = null, B = null, x = null, o.reset(), n.reset(), r.reset() } } } function Ji(A, e, t, i, o, n, r) { var s, l = o.isWebGL2, c = o.maxTextures, h = o.maxCubemapSize, d = o.maxTextureSize, p = o.maxSamples, g = new WeakMap, u = !1; try { u = "undefined" != typeof OffscreenCanvas && null !== new OffscreenCanvas(1, 1).getContext("2d") } catch (A) {} function f(A, e) { return u ? new OffscreenCanvas(A, e) : document.createElementNS("http://www.w3.org/1999/xhtml", "canvas") } function m(A, e, t, i) { var o = 1; if ((A.width > i || A.height > i) && (o = i / Math.max(A.width, A.height)), 1 > o || !0 === e) { if ("undefined" != typeof HTMLImageElement && A instanceof HTMLImageElement || "undefined" != typeof HTMLCanvasElement && A instanceof HTMLCanvasElement || "undefined" != typeof ImageBitmap && A instanceof ImageBitmap) { var n = e ? a.floorPowerOfTwo : Math.floor, r = n(o * A.width), l = n(o * A.height); void 0 === s && (s = f(r, l)); var c = t ? f(r, l) : s; return c.width = r, c.height = l, c.getContext("2d").drawImage(A, 0, 0, r, l), console.warn("THREE.WebGLRenderer: Texture has been resized from (" + A.width + "x" + A.height + ") to (" + r + "x" + l + ")."), c } return "data" in A && console.warn("THREE.WebGLRenderer: Image in DataTexture is too big (" + A.width + "x" + A.height + ")."), A } return A } function C(A) { return a.isPowerOfTwo(A.width) && a.isPowerOfTwo(A.height) } function y(A, e) { return A.generateMipmaps && e && 1003 !== A.minFilter && 1006 !== A.minFilter } function v(e, t, o, n) { A.generateMipmap(e), i.get(t).__maxMipLevel = Math.log(Math.max(o, n)) * Math.LOG2E } function I(t, i, o) { if (!1 === l) return i; if (null !== t) { if (void 0 !== A[t]) return A[t]; console.warn("THREE.WebGLRenderer: Attempt to use non-existing WebGL internal format '" + t + "'") } var n = i; return 6403 === i && (5126 === o && (n = 33326), 5131 === o && (n = 33325), 5121 === o && (n = 33321)), 6407 === i && (5126 === o && (n = 34837), 5131 === o && (n = 34843), 5121 === o && (n = 32849)), 6408 === i && (5126 === o && (n = 34836), 5131 === o && (n = 34842), 5121 === o && (n = 32856)), 33325 !== n && 33326 !== n && 34842 !== n && 34836 !== n || e.get("EXT_color_buffer_float"), n } function E(A) { return 1003 === A || 1004 === A || 1005 === A ? 9728 : 9729 } function B(e) { var t = e.target; t.removeEventListener("dispose", B), function (e) { var t = i.get(e); if (void 0 === t.__webglInit) return; A.deleteTexture(t.__webglTexture), i.remove(e) }(t), t.isVideoTexture && g.delete(t), r.memory.textures-- } function x(e) { var t = e.target; t.removeEventListener("dispose", x), function (e) { var t = i.get(e), o = i.get(e.texture); if (!e) return; void 0 !== o.__webglTexture && A.deleteTexture(o.__webglTexture); e.depthTexture && e.depthTexture.dispose(); if (e.isWebGLCubeRenderTarget) for (var n = 0; 6 > n; n++) A.deleteFramebuffer(t.__webglFramebuffer[n]), t.__webglDepthbuffer && A.deleteRenderbuffer(t.__webglDepthbuffer[n]); else A.deleteFramebuffer(t.__webglFramebuffer), t.__webglDepthbuffer && A.deleteRenderbuffer(t.__webglDepthbuffer), t.__webglMultisampledFramebuffer && A.deleteFramebuffer(t.__webglMultisampledFramebuffer), t.__webglColorRenderbuffer && A.deleteRenderbuffer(t.__webglColorRenderbuffer), t.__webglDepthRenderbuffer && A.deleteRenderbuffer(t.__webglDepthRenderbuffer); i.remove(e.texture), i.remove(e) }(t), r.memory.textures-- } var S = 0; function w(A, e) { var o = i.get(A); if (A.isVideoTexture && function (A) { var e = r.render.frame; g.get(A) !== e && (g.set(A, e), A.update()) }(A), A.version > 0 && o.__version !== A.version) { var n = A.image; if (void 0 === n) console.warn("THREE.WebGLRenderer: Texture marked for update but image is undefined"); else { if (!1 !== n.complete) return void R(o, A, e); console.warn("THREE.WebGLRenderer: Texture marked for update but image is incomplete") } } t.activeTexture(33984 + e), t.bindTexture(3553, o.__webglTexture) } function M(e, o) { if (6 === e.image.length) { var r = i.get(e); if (e.version > 0 && r.__version !== e.version) { Q(r, e), t.activeTexture(33984 + o), t.bindTexture(34067, r.__webglTexture), A.pixelStorei(37440, e.flipY); for (var a = e && (e.isCompressedTexture || e.image[0].isCompressedTexture), s = e.image[0] && e.image[0].isDataTexture, c = [], d = 0; 6 > d; d++) c[d] = a || s ? s ? e.image[d].image : e.image[d] : m(e.image[d], !1, !0, h); var p, g = c[0], u = C(g) || l, f = n.convert(e.format), E = n.convert(e.type), B = I(e.internalFormat, f, E); if (K(34067, e, u), a) { for (d = 0; 6 > d; d++) { p = c[d].mipmaps; for (var x = 0; p.length > x; x++) { var S = p[x]; 1023 !== e.format && 1022 !== e.format ? null !== f ? t.compressedTexImage2D(34069 + d, x, B, S.width, S.height, 0, S.data) : console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()") : t.texImage2D(34069 + d, x, B, S.width, S.height, 0, f, E, S.data) } } r.__maxMipLevel = p.length - 1 } else { p = e.mipmaps; for (d = 0; 6 > d; d++) if (s) { t.texImage2D(34069 + d, 0, B, c[d].width, c[d].height, 0, f, E, c[d].data); for (x = 0; p.length > x; x++) { var w = (S = p[x]).image[d].image; t.texImage2D(34069 + d, x + 1, B, w.width, w.height, 0, f, E, w.data) } } else { t.texImage2D(34069 + d, 0, B, f, E, c[d]); for (x = 0; p.length > x; x++) { t.texImage2D(34069 + d, x + 1, B, f, E, (S = p[x]).image[d]) } } r.__maxMipLevel = p.length } y(e, u) && v(34067, e, g.width, g.height), r.__version = e.version, e.onUpdate && e.onUpdate(e) } else t.activeTexture(33984 + o), t.bindTexture(34067, r.__webglTexture) } } function b(A, e) { t.activeTexture(33984 + e), t.bindTexture(34067, i.get(A).__webglTexture) } var U = { 1e3: 10497, 1001: 33071, 1002: 33648 }, F = { 1003: 9728, 1004: 9984, 1005: 9986, 1006: 9729, 1007: 9985, 1008: 9987 }; function K(t, n, r) { r ? (A.texParameteri(t, 10242, U[n.wrapS]), A.texParameteri(t, 10243, U[n.wrapT]), 32879 !== t && 35866 !== t || A.texParameteri(t, 32882, U[n.wrapR]), A.texParameteri(t, 10240, F[n.magFilter]), A.texParameteri(t, 10241, F[n.minFilter])) : (A.texParameteri(t, 10242, 33071), A.texParameteri(t, 10243, 33071), 32879 !== t && 35866 !== t || A.texParameteri(t, 32882, 33071), 1001 === n.wrapS && 1001 === n.wrapT || console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping."), A.texParameteri(t, 10240, E(n.magFilter)), A.texParameteri(t, 10241, E(n.minFilter)), 1003 !== n.minFilter && 1006 !== n.minFilter && console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter.")); var a = e.get("EXT_texture_filter_anisotropic"); if (a) { if (1015 === n.type && null === e.get("OES_texture_float_linear")) return; if (1016 === n.type && null === (l || e.get("OES_texture_half_float_linear"))) return; (n.anisotropy > 1 || i.get(n).__currentAnisotropy) && (A.texParameterf(t, a.TEXTURE_MAX_ANISOTROPY_EXT, Math.min(n.anisotropy, o.getMaxAnisotropy())), i.get(n).__currentAnisotropy = n.anisotropy) } } function Q(e, t) { void 0 === e.__webglInit && (e.__webglInit = !0, t.addEventListener("dispose", B), e.__webglTexture = A.createTexture(), r.memory.textures++) } function R(e, i, o) { var r = 3553; i.isDataTexture2DArray && (r = 35866), i.isDataTexture3D && (r = 32879), Q(e, i), t.activeTexture(33984 + o), t.bindTexture(r, e.__webglTexture), A.pixelStorei(37440, i.flipY), A.pixelStorei(37441, i.premultiplyAlpha), A.pixelStorei(3317, i.unpackAlignment); var a = function (A) { return !l && (1001 !== A.wrapS || 1001 !== A.wrapT || 1003 !== A.minFilter && 1006 !== A.minFilter) }(i) && !1 === C(i.image), s = m(i.image, a, !1, d), c = C(s) || l, h = n.convert(i.format), p = n.convert(i.type), g = I(i.internalFormat, h, p); K(r, i, c); var u, f = i.mipmaps; if (i.isDepthTexture) g = 6402, l ? g = 1015 === i.type ? 36012 : 1014 === i.type ? 33190 : 1020 === i.type ? 35056 : 33189 : 1015 === i.type && console.error("WebGLRenderer: Floating point depth texture requires WebGL2."), 1026 === i.format && 6402 === g && 1012 !== i.type && 1014 !== i.type && (console.warn("THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture."), i.type = 1012, p = n.convert(i.type)), 1027 === i.format && 6402 === g && (g = 34041, 1020 !== i.type && (console.warn("THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture."), i.type = 1020, p = n.convert(i.type))), t.texImage2D(3553, 0, g, s.width, s.height, 0, h, p, null); else if (i.isDataTexture) if (f.length > 0 && c) { for (var E = 0, B = f.length; B > E; E++) t.texImage2D(3553, E, g, (u = f[E]).width, u.height, 0, h, p, u.data); i.generateMipmaps = !1, e.__maxMipLevel = f.length - 1 } else t.texImage2D(3553, 0, g, s.width, s.height, 0, h, p, s.data), e.__maxMipLevel = 0; else if (i.isCompressedTexture) { for (E = 0, B = f.length; B > E; E++) u = f[E], 1023 !== i.format && 1022 !== i.format ? null !== h ? t.compressedTexImage2D(3553, E, g, u.width, u.height, 0, u.data) : console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()") : t.texImage2D(3553, E, g, u.width, u.height, 0, h, p, u.data); e.__maxMipLevel = f.length - 1 } else if (i.isDataTexture2DArray) t.texImage3D(35866, 0, g, s.width, s.height, s.depth, 0, h, p, s.data), e.__maxMipLevel = 0; else if (i.isDataTexture3D) t.texImage3D(32879, 0, g, s.width, s.height, s.depth, 0, h, p, s.data), e.__maxMipLevel = 0; else if (f.length > 0 && c) { for (E = 0, B = f.length; B > E; E++) t.texImage2D(3553, E, g, h, p, u = f[E]); i.generateMipmaps = !1, e.__maxMipLevel = f.length - 1 } else t.texImage2D(3553, 0, g, h, p, s), e.__maxMipLevel = 0; y(i, c) && v(r, i, s.width, s.height), e.__version = i.version, i.onUpdate && i.onUpdate(i) } function T(e, o, r, a) { var s = n.convert(o.texture.format), l = n.convert(o.texture.type), c = I(o.texture.internalFormat, s, l); t.texImage2D(a, 0, c, o.width, o.height, 0, s, l, null), A.bindFramebuffer(36160, e), A.framebufferTexture2D(36160, r, a, i.get(o.texture).__webglTexture, 0), A.bindFramebuffer(36160, null) } function k(e, t, i) { if (A.bindRenderbuffer(36161, e), t.depthBuffer && !t.stencilBuffer) { var o = 33189; if (i) { var r = t.depthTexture; r && r.isDepthTexture && (1015 === r.type ? o = 36012 : 1014 === r.type && (o = 33190)); var a = L(t); A.renderbufferStorageMultisample(36161, a, o, t.width, t.height) } else A.renderbufferStorage(36161, o, t.width, t.height); A.framebufferRenderbuffer(36160, 36096, 36161, e) } else if (t.depthBuffer && t.stencilBuffer) { if (i) { a = L(t); A.renderbufferStorageMultisample(36161, a, 35056, t.width, t.height) } else A.renderbufferStorage(36161, 34041, t.width, t.height); A.framebufferRenderbuffer(36160, 33306, 36161, e) } else { var s = n.convert(t.texture.format), l = n.convert(t.texture.type); o = I(t.texture.internalFormat, s, l); if (i) { a = L(t); A.renderbufferStorageMultisample(36161, a, o, t.width, t.height) } else A.renderbufferStorage(36161, o, t.width, t.height) } A.bindRenderbuffer(36161, null) } function D(e) { var t = i.get(e), o = !0 === e.isWebGLCubeRenderTarget; if (e.depthTexture) { if (o) throw new Error("target.depthTexture not supported in Cube render targets"); ! function (e, t) { if (t && t.isWebGLCubeRenderTarget) throw new Error("Depth Texture with cube render targets is not supported"); if (A.bindFramebuffer(36160, e), !t.depthTexture || !t.depthTexture.isDepthTexture) throw new Error("renderTarget.depthTexture must be an instance of THREE.DepthTexture"); i.get(t.depthTexture).__webglTexture && t.depthTexture.image.width === t.width && t.depthTexture.image.height === t.height || (t.depthTexture.image.width = t.width, t.depthTexture.image.height = t.height, t.depthTexture.needsUpdate = !0), w(t.depthTexture, 0); var o = i.get(t.depthTexture).__webglTexture; if (1026 === t.depthTexture.format) A.framebufferTexture2D(36160, 36096, 3553, o, 0); else { if (1027 !== t.depthTexture.format) throw new Error("Unknown depthTexture format"); A.framebufferTexture2D(36160, 33306, 3553, o, 0) } }(t.__webglFramebuffer, e) } else if (o) { t.__webglDepthbuffer = []; for (var n = 0; 6 > n; n++) A.bindFramebuffer(36160, t.__webglFramebuffer[n]), t.__webglDepthbuffer[n] = A.createRenderbuffer(), k(t.__webglDepthbuffer[n], e, !1) } else A.bindFramebuffer(36160, t.__webglFramebuffer), t.__webglDepthbuffer = A.createRenderbuffer(), k(t.__webglDepthbuffer, e, !1); A.bindFramebuffer(36160, null) } function L(A) { return l && A.isWebGLMultisampleRenderTarget ? Math.min(p, A.samples) : 0 } var N = !1, O = !1; this.allocateTextureUnit = function () { var A = S; return c > A || console.warn("THREE.WebGLTextures: Trying to use " + A + " texture units while this GPU supports only " + c), S += 1, A }, this.resetTextureUnits = function () { S = 0 }, this.setTexture2D = w, this.setTexture2DArray = function (A, e) { var o = i.get(A); A.version > 0 && o.__version !== A.version ? R(o, A, e) : (t.activeTexture(33984 + e), t.bindTexture(35866, o.__webglTexture)) }, this.setTexture3D = function (A, e) { var o = i.get(A); A.version > 0 && o.__version !== A.version ? R(o, A, e) : (t.activeTexture(33984 + e), t.bindTexture(32879, o.__webglTexture)) }, this.setTextureCube = M, this.setTextureCubeDynamic = b, this.setupRenderTarget = function (e) { var o = i.get(e), a = i.get(e.texture); e.addEventListener("dispose", x), a.__webglTexture = A.createTexture(), r.memory.textures++; var s = !0 === e.isWebGLCubeRenderTarget, c = !0 === e.isWebGLMultisampleRenderTarget, h = C(e) || l; if (!l || 1022 !== e.texture.format || 1015 !== e.texture.type && 1016 !== e.texture.type || (e.texture.format = 1023, console.warn("THREE.WebGLRenderer: Rendering to textures with RGB format is not supported. Using RGBA format instead.")), s) { o.__webglFramebuffer = []; for (var d = 0; 6 > d; d++) o.__webglFramebuffer[d] = A.createFramebuffer() } else if (o.__webglFramebuffer = A.createFramebuffer(), c) if (l) { o.__webglMultisampledFramebuffer = A.createFramebuffer(), o.__webglColorRenderbuffer = A.createRenderbuffer(), A.bindRenderbuffer(36161, o.__webglColorRenderbuffer); var p = n.convert(e.texture.format), g = n.convert(e.texture.type), u = I(e.texture.internalFormat, p, g), f = L(e); A.renderbufferStorageMultisample(36161, f, u, e.width, e.height), A.bindFramebuffer(36160, o.__webglMultisampledFramebuffer), A.framebufferRenderbuffer(36160, 36064, 36161, o.__webglColorRenderbuffer), A.bindRenderbuffer(36161, null), e.depthBuffer && (o.__webglDepthRenderbuffer = A.createRenderbuffer(), k(o.__webglDepthRenderbuffer, e, !0)), A.bindFramebuffer(36160, null) } else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2."); if (s) { t.bindTexture(34067, a.__webglTexture), K(34067, e.texture, h); for (d = 0; 6 > d; d++) T(o.__webglFramebuffer[d], e, 36064, 34069 + d); y(e.texture, h) && v(34067, e.texture, e.width, e.height), t.bindTexture(34067, null) } else t.bindTexture(3553, a.__webglTexture), K(3553, e.texture, h), T(o.__webglFramebuffer, e, 36064, 3553), y(e.texture, h) && v(3553, e.texture, e.width, e.height), t.bindTexture(3553, null); e.depthBuffer && D(e) }, this.updateRenderTargetMipmap = function (A) { var e = A.texture; if (y(e, C(A) || l)) { var o = A.isWebGLCubeRenderTarget ? 34067 : 3553, n = i.get(e).__webglTexture; t.bindTexture(o, n), v(o, e, A.width, A.height), t.bindTexture(o, null) } }, this.updateMultisampleRenderTarget = function (e) { if (e.isWebGLMultisampleRenderTarget) if (l) { var t = i.get(e); A.bindFramebuffer(36008, t.__webglMultisampledFramebuffer), A.bindFramebuffer(36009, t.__webglFramebuffer); var o = e.width, n = e.height, r = 16384; e.depthBuffer && (r |= 256), e.stencilBuffer && (r |= 1024), A.blitFramebuffer(0, 0, o, n, 0, 0, o, n, r, 9728), A.bindFramebuffer(36160, t.__webglMultisampledFramebuffer) } else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.") }, this.safeSetTexture2D = function (A, e) { A && A.isWebGLRenderTarget && (!1 === N && (console.warn("THREE.WebGLTextures.safeSetTexture2D: don't use render targets as textures. Use their .texture property instead."), N = !0), A = A.texture), w(A, e) }, this.safeSetTextureCube = function (A, e) { A && A.isWebGLCubeRenderTarget && (!1 === O && (console.warn("THREE.WebGLTextures.safeSetTextureCube: don't use cube render targets as textures. Use their .texture property instead."), O = !0), A = A.texture), A && A.isCubeTexture || Array.isArray(A.image) && 6 === A.image.length ? M(A, e) : b(A, e) } } function zi(A, e, t) { var i = t.isWebGL2; return { convert: function (A) { var t; if (1009 === A) return 5121; if (1017 === A) return 32819; if (1018 === A) return 32820; if (1019 === A) return 33635; if (1010 === A) return 5120; if (1011 === A) return 5122; if (1012 === A) return 5123; if (1013 === A) return 5124; if (1014 === A) return 5125; if (1015 === A) return 5126; if (1016 === A) return i ? 5131 : null !== (t = e.get("OES_texture_half_float")) ? t.HALF_FLOAT_OES : null; if (1021 === A) return 6406; if (1022 === A) return 6407; if (1023 === A) return 6408; if (1024 === A) return 6409; if (1025 === A) return 6410; if (1026 === A) return 6402; if (1027 === A) return 34041; if (1028 === A) return 6403; if (1029 === A) return 36244; if (1030 === A) return 33319; if (1031 === A) return 33320; if (1032 === A) return 36248; if (1033 === A) return 36249; if (33776 === A || 33777 === A || 33778 === A || 33779 === A) { if (null === (t = e.get("WEBGL_compressed_texture_s3tc"))) return null; if (33776 === A) return t.COMPRESSED_RGB_S3TC_DXT1_EXT; if (33777 === A) return t.COMPRESSED_RGBA_S3TC_DXT1_EXT; if (33778 === A) return t.COMPRESSED_RGBA_S3TC_DXT3_EXT; if (33779 === A) return t.COMPRESSED_RGBA_S3TC_DXT5_EXT } if (35840 === A || 35841 === A || 35842 === A || 35843 === A) { if (null === (t = e.get("WEBGL_compressed_texture_pvrtc"))) return null; if (35840 === A) return t.COMPRESSED_RGB_PVRTC_4BPPV1_IMG; if (35841 === A) return t.COMPRESSED_RGB_PVRTC_2BPPV1_IMG; if (35842 === A) return t.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG; if (35843 === A) return t.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG } if (36196 === A) return null !== (t = e.get("WEBGL_compressed_texture_etc1")) ? t.COMPRESSED_RGB_ETC1_WEBGL : null; if ((37492 === A || 37496 === A) && null !== (t = e.get("WEBGL_compressed_texture_etc"))) { if (37492 === A) return t.COMPRESSED_RGB8_ETC2; if (37496 === A) return t.COMPRESSED_RGBA8_ETC2_EAC } return 37808 === A || 37809 === A || 37810 === A || 37811 === A || 37812 === A || 37813 === A || 37814 === A || 37815 === A || 37816 === A || 37817 === A || 37818 === A || 37819 === A || 37820 === A || 37821 === A || 37840 === A || 37841 === A || 37842 === A || 37843 === A || 37844 === A || 37845 === A || 37846 === A || 37847 === A || 37848 === A || 37849 === A || 37850 === A || 37851 === A || 37852 === A || 37853 === A ? null !== (t = e.get("WEBGL_compressed_texture_astc")) ? A : null : 36492 === A ? null !== (t = e.get("EXT_texture_compression_bptc")) ? A : null : 1020 === A ? i ? 34042 : null !== (t = e.get("WEBGL_depth_texture")) ? t.UNSIGNED_INT_24_8_WEBGL : null : void 0 } } } function Zi(A) { je.call(this), this.cameras = A || [] } function Xi() { H.call(this), this.type = "Group" } function _i(A, e) { var t = this, i = null, o = 1, n = null, r = "local-floor", a = null, s = [], l = new Map, c = new je; c.layers.enable(1), c.viewport = new p; var h = new je; h.layers.enable(2), h.viewport = new p; var d = new Zi([c, h]); d.layers.enable(1), d.layers.enable(2); var g = null, u = null; function f(A) { var e = l.get(A.inputSource); e && (e.targetRay && e.targetRay.dispatchEvent({ type: A.type }), e.grip && e.grip.dispatchEvent({ type: A.type })) } function m() { l.forEach((function (A, e) { A.targetRay && (A.targetRay.dispatchEvent({ type: "disconnected", data: e }), A.targetRay.visible = !1), A.grip && (A.grip.dispatchEvent({ type: "disconnected", data: e }), A.grip.visible = !1) })), l.clear(), A.setFramebuffer(null), A.setRenderTarget(A.getRenderTarget()), S.stop(), t.isPresenting = !1, t.dispatchEvent({ type: "sessionend" }) } function C(A) { n = A, S.setContext(i), S.start(), t.isPresenting = !0, t.dispatchEvent({ type: "sessionstart" }) } function v(A) { for (var e = i.inputSources, t = 0; s.length > t; t++) l.set(e[t], s[t]); for (t = 0; A.removed.length > t; t++) { (n = l.get(o = A.removed[t])) && (n.targetRay && n.targetRay.dispatchEvent({ type: "disconnected", data: o }), n.grip && n.grip.dispatchEvent({ type: "disconnected", data: o }), l.delete(o)) } for (t = 0; A.added.length > t; t++) { var o, n; (n = l.get(o = A.added[t])) && (n.targetRay && n.targetRay.dispatchEvent({ type: "connected", data: o }), n.grip && n.grip.dispatchEvent({ type: "connected", data: o })) } } this.enabled = !1, this.isPresenting = !1, this.getController = function (A) { var e = s[A]; return void 0 === e && (s[A] = e = {}), void 0 === e.targetRay && (e.targetRay = new Xi, e.targetRay.matrixAutoUpdate = !1, e.targetRay.visible = !1), e.targetRay }, this.getControllerGrip = function (A) { var e = s[A]; return void 0 === e && (s[A] = e = {}), void 0 === e.grip && (e.grip = new Xi, e.grip.matrixAutoUpdate = !1, e.grip.visible = !1), e.grip }, this.setFramebufferScaleFactor = function (A) { o = A, 1 == t.isPresenting && console.warn("WebXRManager: Cannot change framebuffer scale while presenting VR content") }, this.setReferenceSpaceType = function (A) { r = A }, this.getReferenceSpace = function () { return n }, this.getSession = function () { return i }, this.setSession = function (A) { if (null !== (i = A)) { i.addEventListener("select", f), i.addEventListener("selectstart", f), i.addEventListener("selectend", f), i.addEventListener("squeeze", f), i.addEventListener("squeezestart", f), i.addEventListener("squeezeend", f), i.addEventListener("end", m); var t = e.getContextAttributes(), n = new XRWebGLLayer(i, e, { antialias: t.antialias, alpha: t.alpha, depth: t.depth, stencil: t.stencil, framebufferScaleFactor: o }); i.updateRenderState({ baseLayer: n }), i.requestReferenceSpace(r).then(C), i.addEventListener("inputsourceschange", v) } }; var I = new y, E = new y; function B(A, e) { null === e ? A.matrixWorld.copy(A.matrix) : A.matrixWorld.multiplyMatrices(e.matrixWorld, A.matrix), A.matrixWorldInverse.getInverse(A.matrixWorld) } this.getCamera = function (A) { d.near = h.near = c.near = A.near, d.far = h.far = c.far = A.far, g === d.near && u === d.far || (i.updateRenderState({ depthNear: d.near, depthFar: d.far }), g = d.near, u = d.far); var e = A.parent, t = d.cameras; B(d, e); for (var o = 0; t.length > o; o++) B(t[o], e); A.matrixWorld.copy(d.matrixWorld); for (var n = A.children, r = (o = 0, n.length); r > o; o++) n[o].updateMatrixWorld(!0); return function (A, e, t) { I.setFromMatrixPosition(e.matrixWorld), E.setFromMatrixPosition(t.matrixWorld); var i = I.distanceTo(E), o = e.projectionMatrix.elements, n = t.projectionMatrix.elements, r = o[14] / (o[10] - 1), a = o[14] / (o[10] + 1), s = (o[9] + 1) / o[5], l = (o[9] - 1) / o[5], c = (o[8] - 1) / o[0], h = (n[8] + 1) / n[0], d = r * c, p = r * h, g = i / (-c + h), u = g * -c; e.matrixWorld.decompose(A.position, A.quaternion, A.scale), A.translateX(u), A.translateZ(g), A.matrixWorld.compose(A.position, A.quaternion, A.scale), A.matrixWorldInverse.getInverse(A.matrixWorld); var f = r + g, m = a + g; A.projectionMatrix.makePerspective(d - u, p + (i - u), s * a / m * f, l * a / m * f, f, m) }(d, c, h), d }; var x = null; var S = new _e; S.setAnimationLoop((function (e, t) { if (null !== (a = t.getViewerPose(n))) { var o = a.views, r = i.renderState.baseLayer; A.setFramebuffer(r.framebuffer); for (var l = 0; o.length > l; l++) { var c = o[l], h = r.getViewport(c), p = d.cameras[l]; p.matrix.fromArray(c.transform.matrix), p.projectionMatrix.fromArray(c.projectionMatrix), p.viewport.set(h.x, h.y, h.width, h.height), 0 === l && d.matrix.copy(p.matrix) } } var g = i.inputSources; for (l = 0; s.length > l; l++) { var u = s[l], f = g[l], m = null, C = null; f && (u.targetRay && null !== (m = t.getPose(f.targetRaySpace, n)) && (u.targetRay.matrix.fromArray(m.transform.matrix), u.targetRay.matrix.decompose(u.targetRay.position, u.targetRay.rotation, u.targetRay.scale)), u.grip && f.gripSpace && null !== (C = t.getPose(f.gripSpace, n)) && (u.grip.matrix.fromArray(C.transform.matrix), u.grip.matrix.decompose(u.grip.position, u.grip.rotation, u.grip.scale))), u.targetRay && (u.targetRay.visible = null !== m), u.grip && (u.grip.visible = null !== C) } x && x(e, t) })), this.setAnimationLoop = function (A) { x = A }, this.dispose = function () {} } function $i(A) { var e = void 0 !== (A = A || {}).canvas ? A.canvas : document.createElementNS("http://www.w3.org/1999/xhtml", "canvas"), t = void 0 !== A.context ? A.context : null, i = void 0 !== A.alpha && A.alpha, o = void 0 === A.depth || A.depth, n = void 0 === A.stencil || A.stencil, r = void 0 !== A.antialias && A.antialias, l = void 0 === A.premultipliedAlpha || A.premultipliedAlpha, c = void 0 !== A.preserveDrawingBuffer && A.preserveDrawingBuffer, h = void 0 !== A.powerPreference ? A.powerPreference : "default", d = void 0 !== A.failIfMajorPerformanceCaveat && A.failIfMajorPerformanceCaveat, g = null, u = null; this.domElement = e, this.debug = { checkShaderErrors: !0 }, this.autoClear = !0, this.autoClearColor = !0, this.autoClearDepth = !0, this.autoClearStencil = !0, this.sortObjects = !0, this.clippingPlanes = [], this.localClippingEnabled = !1, this.gammaFactor = 2, this.outputEncoding = 3e3, this.physicallyCorrectLights = !1, this.toneMapping = 1, this.toneMappingExposure = 1, this.toneMappingWhitePoint = 1, this.maxMorphTargets = 8, this.maxMorphNormals = 4; var f, m, C, v, I, E, B, x, S, w, b, U, F, K, Q, R, T, k, D = this, L = !1, N = null, O = 0, V = 0, G = null, P = null, q = -1, j = { geometry: null, program: null, wireframe: !1 }, H = null, W = null, J = new p, z = new p, Z = null, X = e.width, _ = e.height, $ = 1, AA = null, eA = null, tA = new p(0, 0, X, _), iA = new p(0, 0, X, _), oA = !1, nA = new Ze, rA = new at, aA = !1, sA = !1, lA = new M, cA = new y; function hA() { return null === G ? $ : 1 } try { var dA = { alpha: i, depth: o, stencil: n, antialias: r, premultipliedAlpha: l, preserveDrawingBuffer: c, powerPreference: h, failIfMajorPerformanceCaveat: d, xrCompatible: !0 }; if (e.addEventListener("webglcontextlost", fA, !1), e.addEventListener("webglcontextrestored", mA, !1), null === (f = t || e.getContext("webgl", dA) || e.getContext("experimental-webgl", dA))) throw null !== e.getContext("webgl") ? new Error("Error creating WebGL context with your selected attributes.") : new Error("Error creating WebGL context."); void 0 === f.getShaderPrecisionFormat && (f.getShaderPrecisionFormat = function () { return { rangeMin: 1, rangeMax: 1, precision: 1 } }) } catch (A) { throw console.error("THREE.WebGLRenderer: " + A.message), A } function pA() { m = new st(f), !1 === (C = new rt(f, m, A)).isWebGL2 && (m.get("WEBGL_depth_texture"), m.get("OES_texture_float"), m.get("OES_texture_half_float"), m.get("OES_texture_half_float_linear"), m.get("OES_standard_derivatives"), m.get("OES_element_index_uint"), m.get("ANGLE_instanced_arrays")), m.get("OES_texture_float_linear"), k = new zi(f, m, C), (v = new Wi(f, m, C)).scissor(z.copy(iA).multiplyScalar($).floor()), v.viewport(J.copy(tA).multiplyScalar($).floor()), I = new ht(f), E = new Ri, B = new Ji(f, m, v, E, C, k, I), x = new $e(f, C), S = new lt(f, x, I), w = new gt(f, S, x, I), Q = new pt(f), b = new Qi(D, m, C), U = new Li, F = new qi, K = new ot(D, v, w, l), R = new nt(f, m, I, C), T = new ct(f, m, I, C), I.programs = b.programs, D.capabilities = C, D.extensions = m, D.properties = E, D.renderLists = U, D.state = v, D.info = I } pA(); var gA = new _i(D, f); this.xr = gA; var uA = new Yi(D, w, C.maxTextureSize); function fA(A) { A.preventDefault(), console.log("THREE.WebGLRenderer: Context Lost."), L = !0 } function mA() { console.log("THREE.WebGLRenderer: Context Restored."), L = !1, pA() } function CA(A) { var e = A.target; e.removeEventListener("dispose", CA), function (A) { yA(A), E.remove(A) }(e) } function yA(A) { var e = E.get(A).program; A.program = void 0, void 0 !== e && b.releaseProgram(e) } this.shadowMap = uA, this.getContext = function () { return f }, this.getContextAttributes = function () { return f.getContextAttributes() }, this.forceContextLoss = function () { var A = m.get("WEBGL_lose_context"); A && A.loseContext() }, this.forceContextRestore = function () { var A = m.get("WEBGL_lose_context"); A && A.restoreContext() }, this.getPixelRatio = function () { return $ }, this.setPixelRatio = function (A) { void 0 !== A && ($ = A, this.setSize(X, _, !1)) }, this.getSize = function (A) { return void 0 === A && (console.warn("WebGLRenderer: .getsize() now requires a Vector2 as an argument"), A = new s), A.set(X, _) }, this.setSize = function (A, t, i) { gA.isPresenting ? console.warn("THREE.WebGLRenderer: Can't change size while VR device is presenting.") : (X = A, _ = t, e.width = Math.floor(A * $), e.height = Math.floor(t * $), !1 !== i && (e.style.width = A + "px", e.style.height = t + "px"), this.setViewport(0, 0, A, t)) }, this.getDrawingBufferSize = function (A) { return void 0 === A && (console.warn("WebGLRenderer: .getdrawingBufferSize() now requires a Vector2 as an argument"), A = new s), A.set(X * $, _ * $).floor() }, this.setDrawingBufferSize = function (A, t, i) { X = A, _ = t, $ = i, e.width = Math.floor(A * i), e.height = Math.floor(t * i), this.setViewport(0, 0, A, t) }, this.getCurrentViewport = function (A) { return void 0 === A && (console.warn("WebGLRenderer: .getCurrentViewport() now requires a Vector4 as an argument"), A = new p), A.copy(J) }, this.getViewport = function (A) { return A.copy(tA) }, this.setViewport = function (A, e, t, i) { A.isVector4 ? tA.set(A.x, A.y, A.z, A.w) : tA.set(A, e, t, i), v.viewport(J.copy(tA).multiplyScalar($).floor()) }, this.getScissor = function (A) { return A.copy(iA) }, this.setScissor = function (A, e, t, i) { A.isVector4 ? iA.set(A.x, A.y, A.z, A.w) : iA.set(A, e, t, i), v.scissor(z.copy(iA).multiplyScalar($).floor()) }, this.getScissorTest = function () { return oA }, this.setScissorTest = function (A) { v.setScissorTest(oA = A) }, this.setOpaqueSort = function (A) { AA = A }, this.setTransparentSort = function (A) { eA = A }, this.getClearColor = function () { return K.getClearColor() }, this.setClearColor = function () { K.setClearColor.apply(K, arguments) }, this.getClearAlpha = function () { return K.getClearAlpha() }, this.setClearAlpha = function () { K.setClearAlpha.apply(K, arguments) }, this.clear = function (A, e, t) { var i = 0; (void 0 === A || A) && (i |= 16384), (void 0 === e || e) && (i |= 256), (void 0 === t || t) && (i |= 1024), f.clear(i) }, this.clearColor = function () { this.clear(!0, !1, !1) }, this.clearDepth = function () { this.clear(!1, !0, !1) }, this.clearStencil = function () { this.clear(!1, !1, !0) }, this.dispose = function () { e.removeEventListener("webglcontextlost", fA, !1), e.removeEventListener("webglcontextrestored", mA, !1), U.dispose(), F.dispose(), E.dispose(), w.dispose(), gA.dispose(), EA.stop(), this.forceContextLoss() }, this.renderBufferImmediate = function (A, e) { v.initAttributes(); var t = E.get(A); A.hasPositions && !t.position && (t.position = f.createBuffer()), A.hasNormals && !t.normal && (t.normal = f.createBuffer()), A.hasUvs && !t.uv && (t.uv = f.createBuffer()), A.hasColors && !t.color && (t.color = f.createBuffer()); var i = e.getAttributes(); A.hasPositions && (f.bindBuffer(34962, t.position), f.bufferData(34962, A.positionArray, 35048), v.enableAttribute(i.position), f.vertexAttribPointer(i.position, 3, 5126, !1, 0, 0)), A.hasNormals && (f.bindBuffer(34962, t.normal), f.bufferData(34962, A.normalArray, 35048), v.enableAttribute(i.normal), f.vertexAttribPointer(i.normal, 3, 5126, !1, 0, 0)), A.hasUvs && (f.bindBuffer(34962, t.uv), f.bufferData(34962, A.uvArray, 35048), v.enableAttribute(i.uv), f.vertexAttribPointer(i.uv, 2, 5126, !1, 0, 0)), A.hasColors && (f.bindBuffer(34962, t.color), f.bufferData(34962, A.colorArray, 35048), v.enableAttribute(i.color), f.vertexAttribPointer(i.color, 3, 5126, !1, 0, 0)), v.disableUnusedAttributes(), f.drawArrays(4, 0, A.count), A.count = 0 }; var vA = new Y; this.renderBufferDirect = function (A, e, t, i, o, n) { null === e && (e = vA); var r = o.isMesh && 0 > o.matrixWorld.determinant(), a = MA(A, e, i, o); v.setMaterial(i, r); var s = !1; j.geometry === t.id && j.program === a.id && j.wireframe === (!0 === i.wireframe) || (j.geometry = t.id, j.program = a.id, j.wireframe = !0 === i.wireframe, s = !0), (i.morphTargets || i.morphNormals) && (Q.update(o, t, i, a), s = !0); var l = t.index, c = t.attributes.position; if (null === l) { if (void 0 === c || 0 === c.count) return } else if (0 === l.count) return; var h, d = 1; !0 === i.wireframe && (l = S.getWireframeAttribute(t), d = 2); var p = R; null !== l && (h = x.get(l), (p = T).setIndex(h)), s && (! function (A, e, t, i) { if (!1 === C.isWebGL2 && (A.isInstancedMesh || e.isInstancedBufferGeometry) && null === m.get("ANGLE_instanced_arrays")) return; v.initAttributes(); var o = e.attributes, n = i.getAttributes(), r = t.defaultAttributeValues; for (var a in n) { var s = n[a]; if (s >= 0) { var l = o[a]; if (void 0 !== l) { var c = l.normalized, h = l.itemSize; if (void 0 === (E = x.get(l))) continue; var d = E.buffer, p = E.type, g = E.bytesPerElement; if (l.isInterleavedBufferAttribute) { var u = l.data, y = u.stride, I = l.offset; u && u.isInstancedInterleavedBuffer ? (v.enableAttributeAndDivisor(s, u.meshPerAttribute), void 0 === e.maxInstancedCount && (e.maxInstancedCount = u.meshPerAttribute * u.count)) : v.enableAttribute(s), f.bindBuffer(34962, d), f.vertexAttribPointer(s, h, p, c, y * g, I * g) } else l.isInstancedBufferAttribute ? (v.enableAttributeAndDivisor(s, l.meshPerAttribute), void 0 === e.maxInstancedCount && (e.maxInstancedCount = l.meshPerAttribute * l.count)) : v.enableAttribute(s), f.bindBuffer(34962, d), f.vertexAttribPointer(s, h, p, c, 0, 0) } else if ("instanceMatrix" === a) { var E; if (void 0 === (E = x.get(A.instanceMatrix))) continue; d = E.buffer, p = E.type; v.enableAttributeAndDivisor(s + 0, 1), v.enableAttributeAndDivisor(s + 1, 1), v.enableAttributeAndDivisor(s + 2, 1), v.enableAttributeAndDivisor(s + 3, 1), f.bindBuffer(34962, d), f.vertexAttribPointer(s + 0, 4, p, !1, 64, 0), f.vertexAttribPointer(s + 1, 4, p, !1, 64, 16), f.vertexAttribPointer(s + 2, 4, p, !1, 64, 32), f.vertexAttribPointer(s + 3, 4, p, !1, 64, 48) } else if (void 0 !== r) { var B = r[a]; if (void 0 !== B) switch (B.length) { case 2: f.vertexAttrib2fv(s, B); break; case 3: f.vertexAttrib3fv(s, B); break; case 4: f.vertexAttrib4fv(s, B); break; default: f.vertexAttrib1fv(s, B) } } } } v.disableUnusedAttributes() }(o, t, i, a), null !== l && f.bindBuffer(34963, h.buffer)); var g = null !== l ? l.count : c.count, u = t.drawRange.start * d, y = t.drawRange.count * d, I = null !== n ? n.start * d : 0, E = null !== n ? n.count * d : 1 / 0, B = Math.max(u, I), w = Math.min(g, u + y, I + E) - 1, M = Math.max(0, w - B + 1); if (0 !== M) { if (o.isMesh) !0 === i.wireframe ? (v.setLineWidth(i.wireframeLinewidth * hA()), p.setMode(1)) : p.setMode(4); else if (o.isLine) { var b = i.linewidth; void 0 === b && (b = 1), v.setLineWidth(b * hA()), p.setMode(o.isLineSegments ? 1 : o.isLineLoop ? 2 : 3) } else o.isPoints ? p.setMode(0) : o.isSprite && p.setMode(4); o.isInstancedMesh ? p.renderInstances(t, B, M, o.count) : t.isInstancedBufferGeometry ? p.renderInstances(t, B, M, t.maxInstancedCount) : p.render(B, M) } }, this.compile = function (A, e) { (u = F.get(A, e)).init(), A.traverse((function (A) { A.isLight && (u.pushLight(A), A.castShadow && u.pushShadow(A)) })), u.setupLights(e); var t = {}; A.traverse((function (e) { if (e.material) if (Array.isArray(e.material)) for (var i = 0; e.material.length > i; i++) e.material[i].uuid in t == !1 && (wA(e.material[i], A, e), t[e.material[i].uuid] = !0); else e.material.uuid in t == !1 && (wA(e.material, A, e), t[e.material.uuid] = !0) })) }; var IA = null; var EA = new _e; function BA(A, e, t, i) { if (!1 !== A.visible) { if (A.layers.test(e.layers)) if (A.isGroup) t = A.renderOrder; else if (A.isLOD) !0 === A.autoUpdate && A.update(e); else if (A.isLight) u.pushLight(A), A.castShadow && u.pushShadow(A); else if (A.isSprite) { if (!A.frustumCulled || nA.intersectsSprite(A)) { i && cA.setFromMatrixPosition(A.matrixWorld).applyMatrix4(lA); var o = w.update(A); (n = A.material).visible && g.push(A, o, n, t, cA.z, null) } } else if (A.isImmediateRenderObject) i && cA.setFromMatrixPosition(A.matrixWorld).applyMatrix4(lA), g.push(A, null, A.material, t, cA.z, null); else if ((A.isMesh || A.isLine || A.isPoints) && (A.isSkinnedMesh && A.skeleton.frame !== I.render.frame && (A.skeleton.update(), A.skeleton.frame = I.render.frame), !A.frustumCulled || nA.intersectsObject(A))) { i && cA.setFromMatrixPosition(A.matrixWorld).applyMatrix4(lA); o = w.update(A); var n = A.material; if (Array.isArray(n)) for (var r = o.groups, a = 0, s = r.length; s > a; a++) { var l = r[a], c = n[l.materialIndex]; c && c.visible && g.push(A, o, c, t, cA.z, l) } else n.visible && g.push(A, o, n, t, cA.z, null) } var h = A.children; for (a = 0, s = h.length; s > a; a++) BA(h[a], e, t, i) } } function xA(A, e, t, i) { for (var o = 0, n = A.length; n > o; o++) { var r = A[o], a = r.object, s = r.geometry, l = void 0 === i ? r.material : i, c = r.group; if (t.isArrayCamera) { W = t; for (var h = t.cameras, d = 0, p = h.length; p > d; d++) { var g = h[d]; a.layers.test(g.layers) && (v.viewport(J.copy(g.viewport)), u.setupLights(g), SA(a, e, g, s, l, c)) } } else W = null, SA(a, e, t, s, l, c) } } function SA(A, e, t, i, o, n) { if (A.onBeforeRender(D, e, t, i, o, n), u = F.get(e, W || t), A.modelViewMatrix.multiplyMatrices(t.matrixWorldInverse, A.matrixWorld), A.normalMatrix.getNormalMatrix(A.modelViewMatrix), A.isImmediateRenderObject) { var r = MA(t, e, o, A); v.setMaterial(o), j.geometry = null, j.program = null, j.wireframe = !1, function (A, e) { A.render((function (A) { D.renderBufferImmediate(A, e) })) }(A, r) } else D.renderBufferDirect(t, e, i, o, A, n); A.onAfterRender(D, e, t, i, o, n), u = F.get(e, W || t) } function wA(A, e, t) { var i = E.get(A), o = u.state.lights, n = o.state.version, r = b.getParameters(A, o.state, u.state.shadowsArray, e, rA.numPlanes, rA.numIntersection, t), a = b.getProgramCacheKey(r), s = i.program, l = !0; if (void 0 === s) A.addEventListener("dispose", CA); else if (s.cacheKey !== a) yA(A); else if (i.lightsStateVersion !== n) i.lightsStateVersion = n, l = !1; else { if (void 0 !== r.shaderID) return; l = !1 } l && (s = b.acquireProgram(r, a), i.program = s, i.uniforms = r.uniforms, i.environment = A.isMeshStandardMaterial ? e.environment : null, i.outputEncoding = D.outputEncoding, A.program = s); var c = s.getAttributes(); if (A.morphTargets) { A.numSupportedMorphTargets = 0; for (var h = 0; D.maxMorphTargets > h; h++) 0 > c["morphTarget" + h] || A.numSupportedMorphTargets++ } if (A.morphNormals) { A.numSupportedMorphNormals = 0; for (h = 0; D.maxMorphNormals > h; h++) 0 > c["morphNormal" + h] || A.numSupportedMorphNormals++ } var d = i.uniforms; (A.isShaderMaterial || A.isRawShaderMaterial) && !0 !== A.clipping || (i.numClippingPlanes = rA.numPlanes, i.numIntersection = rA.numIntersection, d.clippingPlanes = rA.uniform), i.fog = e.fog, i.needsLights = function (A) { return A.isMeshLambertMaterial || A.isMeshToonMaterial || A.isMeshPhongMaterial || A.isMeshStandardMaterial || A.isShadowMaterial || A.isShaderMaterial && !0 === A.lights }(A), i.lightsStateVersion = n, i.needsLights && (d.ambientLightColor.value = o.state.ambient, d.lightProbe.value = o.state.probe, d.directionalLights.value = o.state.directional, d.directionalLightShadows.value = o.state.directionalShadow, d.spotLights.value = o.state.spot, d.spotLightShadows.value = o.state.spotShadow, d.rectAreaLights.value = o.state.rectArea, d.pointLights.value = o.state.point, d.pointLightShadows.value = o.state.pointShadow, d.hemisphereLights.value = o.state.hemi, d.directionalShadowMap.value = o.state.directionalShadowMap, d.directionalShadowMatrix.value = o.state.directionalShadowMatrix, d.spotShadowMap.value = o.state.spotShadowMap, d.spotShadowMatrix.value = o.state.spotShadowMatrix, d.pointShadowMap.value = o.state.pointShadowMap, d.pointShadowMatrix.value = o.state.pointShadowMatrix); var p = i.program.getUniforms(), g = di.seqWithValue(p.seq, d); i.uniformsList = g } function MA(A, e, t, i) { B.resetTextureUnits(); var o = e.fog, n = t.isMeshStandardMaterial ? e.environment : null, r = E.get(t), s = u.state.lights; aA && ((sA || A !== H) && rA.setState(t.clippingPlanes, t.clipIntersection, t.clipShadows, A, r, A === H && t.id === q)); t.version === r.__version ? void 0 === r.program || t.fog && r.fog !== o || r.environment !== n || r.needsLights && r.lightsStateVersion !== s.state.version ? wA(t, e, i) : void 0 === r.numClippingPlanes || r.numClippingPlanes === rA.numPlanes && r.numIntersection === rA.numIntersection ? r.outputEncoding !== D.outputEncoding && wA(t, e, i) : wA(t, e, i) : (wA(t, e, i), r.__version = t.version); var l, c, h = !1, d = !1, p = !1, g = r.program, m = g.getUniforms(), y = r.uniforms; if (v.useProgram(g.program) && (h = !0, d = !0, p = !0), t.id !== q && (q = t.id, d = !0), h || H !== A) { if (m.setValue(f, "projectionMatrix", A.projectionMatrix), C.logarithmicDepthBuffer && m.setValue(f, "logDepthBufFC", 2 / (Math.log(A.far + 1) / Math.LN2)), H !== A && (H = A, d = !0, p = !0), t.isShaderMaterial || t.isMeshPhongMaterial || t.isMeshToonMaterial || t.isMeshStandardMaterial || t.envMap) { var I = m.map.cameraPosition; void 0 !== I && I.setValue(f, cA.setFromMatrixPosition(A.matrixWorld)) } (t.isMeshPhongMaterial || t.isMeshToonMaterial || t.isMeshLambertMaterial || t.isMeshBasicMaterial || t.isMeshStandardMaterial || t.isShaderMaterial) && m.setValue(f, "isOrthographic", !0 === A.isOrthographicCamera), (t.isMeshPhongMaterial || t.isMeshToonMaterial || t.isMeshLambertMaterial || t.isMeshBasicMaterial || t.isMeshStandardMaterial || t.isShaderMaterial || t.skinning) && m.setValue(f, "viewMatrix", A.matrixWorldInverse) } if (t.skinning) { m.setOptional(f, i, "bindMatrix"), m.setOptional(f, i, "bindMatrixInverse"); var x = i.skeleton; if (x) if (C.floatVertexTextures) { if (void 0 === x.boneTexture) { var S = Math.sqrt(4 * x.bones.length); S = a.ceilPowerOfTwo(S), S = Math.max(S, 4); var w = new Float32Array(S * S * 4); w.set(x.boneMatrices); var M = new We(w, S, S, 1023, 1015); x.boneMatrices = w, x.boneTexture = M, x.boneTextureSize = S } m.setValue(f, "boneTexture", x.boneTexture, B), m.setValue(f, "boneTextureSize", x.boneTextureSize) } else m.setOptional(f, x, "boneMatrices") } return (d || r.receiveShadow !== i.receiveShadow) && (r.receiveShadow = i.receiveShadow, m.setValue(f, "receiveShadow", i.receiveShadow)), d && (m.setValue(f, "toneMappingExposure", D.toneMappingExposure), m.setValue(f, "toneMappingWhitePoint", D.toneMappingWhitePoint), r.needsLights && ((l = y).ambientLightColor.needsUpdate = c = p, l.lightProbe.needsUpdate = c, l.directionalLights.needsUpdate = c, l.directionalLightShadows.needsUpdate = c, l.pointLights.needsUpdate = c, l.pointLightShadows.needsUpdate = c, l.spotLights.needsUpdate = c, l.spotLightShadows.needsUpdate = c, l.rectAreaLights.needsUpdate = c, l.hemisphereLights.needsUpdate = c), o && t.fog && function (A, e) { A.fogColor.value.copy(e.color), e.isFog ? (A.fogNear.value = e.near, A.fogFar.value = e.far) : e.isFogExp2 && (A.fogDensity.value = e.density) }(y, o), t.isMeshBasicMaterial ? bA(y, t) : t.isMeshLambertMaterial ? (bA(y, t), function (A, e) { e.emissiveMap && (A.emissiveMap.value = e.emissiveMap) }(y, t)) : t.isMeshToonMaterial ? (bA(y, t), function (A, e) { A.specular.value.copy(e.specular), A.shininess.value = Math.max(e.shininess, 1e-4), e.gradientMap && (A.gradientMap.value = e.gradientMap); e.emissiveMap && (A.emissiveMap.value = e.emissiveMap); e.bumpMap && (A.bumpMap.value = e.bumpMap, A.bumpScale.value = e.bumpScale, 1 === e.side && (A.bumpScale.value *= -1)); e.normalMap && (A.normalMap.value = e.normalMap, A.normalScale.value.copy(e.normalScale), 1 === e.side && A.normalScale.value.negate()); e.displacementMap && (A.displacementMap.value = e.displacementMap, A.displacementScale.value = e.displacementScale, A.displacementBias.value = e.displacementBias) }(y, t)) : t.isMeshPhongMaterial ? (bA(y, t), function (A, e) { A.specular.value.copy(e.specular), A.shininess.value = Math.max(e.shininess, 1e-4), e.emissiveMap && (A.emissiveMap.value = e.emissiveMap); e.bumpMap && (A.bumpMap.value = e.bumpMap, A.bumpScale.value = e.bumpScale, 1 === e.side && (A.bumpScale.value *= -1)); e.normalMap && (A.normalMap.value = e.normalMap, A.normalScale.value.copy(e.normalScale), 1 === e.side && A.normalScale.value.negate()); e.displacementMap && (A.displacementMap.value = e.displacementMap, A.displacementScale.value = e.displacementScale, A.displacementBias.value = e.displacementBias) }(y, t)) : t.isMeshStandardMaterial ? (bA(y, t, n), t.isMeshPhysicalMaterial ? function (A, e, t) { UA(A, e, t), A.reflectivity.value = e.reflectivity, A.clearcoat.value = e.clearcoat, A.clearcoatRoughness.value = e.clearcoatRoughness, e.sheen && A.sheen.value.copy(e.sheen); e.clearcoatMap && (A.clearcoatMap.value = e.clearcoatMap); e.clearcoatRoughnessMap && (A.clearcoatRoughnessMap.value = e.clearcoatRoughnessMap); e.clearcoatNormalMap && (A.clearcoatNormalScale.value.copy(e.clearcoatNormalScale), A.clearcoatNormalMap.value = e.clearcoatNormalMap, 1 === e.side && A.clearcoatNormalScale.value.negate()); A.transparency.value = e.transparency }(y, t, n) : UA(y, t, n)) : t.isMeshMatcapMaterial ? (bA(y, t), function (A, e) { e.matcap && (A.matcap.value = e.matcap); e.bumpMap && (A.bumpMap.value = e.bumpMap, A.bumpScale.value = e.bumpScale, 1 === e.side && (A.bumpScale.value *= -1)); e.normalMap && (A.normalMap.value = e.normalMap, A.normalScale.value.copy(e.normalScale), 1 === e.side && A.normalScale.value.negate()); e.displacementMap && (A.displacementMap.value = e.displacementMap, A.displacementScale.value = e.displacementScale, A.displacementBias.value = e.displacementBias) }(y, t)) : t.isMeshDepthMaterial ? (bA(y, t), function (A, e) { e.displacementMap && (A.displacementMap.value = e.displacementMap, A.displacementScale.value = e.displacementScale, A.displacementBias.value = e.displacementBias) }(y, t)) : t.isMeshDistanceMaterial ? (bA(y, t), function (A, e) { e.displacementMap && (A.displacementMap.value = e.displacementMap, A.displacementScale.value = e.displacementScale, A.displacementBias.value = e.displacementBias); A.referencePosition.value.copy(e.referencePosition), A.nearDistance.value = e.nearDistance, A.farDistance.value = e.farDistance }(y, t)) : t.isMeshNormalMaterial ? (bA(y, t), function (A, e) { e.bumpMap && (A.bumpMap.value = e.bumpMap, A.bumpScale.value = e.bumpScale, 1 === e.side && (A.bumpScale.value *= -1)); e.normalMap && (A.normalMap.value = e.normalMap, A.normalScale.value.copy(e.normalScale), 1 === e.side && A.normalScale.value.negate()); e.displacementMap && (A.displacementMap.value = e.displacementMap, A.displacementScale.value = e.displacementScale, A.displacementBias.value = e.displacementBias) }(y, t)) : t.isLineBasicMaterial ? (function (A, e) { A.diffuse.value.copy(e.color), A.opacity.value = e.opacity }(y, t), t.isLineDashedMaterial && function (A, e) { A.dashSize.value = e.dashSize, A.totalSize.value = e.dashSize + e.gapSize, A.scale.value = e.scale }(y, t)) : t.isPointsMaterial ? function (A, e) { A.diffuse.value.copy(e.color), A.opacity.value = e.opacity, A.size.value = e.size * $, A.scale.value = .5 * _, e.map && (A.map.value = e.map); e.alphaMap && (A.alphaMap.value = e.alphaMap); var t; e.map ? t = e.map : e.alphaMap && (t = e.alphaMap); void 0 !== t && (!0 === t.matrixAutoUpdate && t.updateMatrix(), A.uvTransform.value.copy(t.matrix)) }(y, t) : t.isSpriteMaterial ? function (A, e) { A.diffuse.value.copy(e.color), A.opacity.value = e.opacity, A.rotation.value = e.rotation, e.map && (A.map.value = e.map); e.alphaMap && (A.alphaMap.value = e.alphaMap); var t; e.map ? t = e.map : e.alphaMap && (t = e.alphaMap); void 0 !== t && (!0 === t.matrixAutoUpdate && t.updateMatrix(), A.uvTransform.value.copy(t.matrix)) }(y, t) : t.isShadowMaterial && (y.color.value.copy(t.color), y.opacity.value = t.opacity), void 0 !== y.ltc_1 && (y.ltc_1.value = Xe.LTC_1), void 0 !== y.ltc_2 && (y.ltc_2.value = Xe.LTC_2), di.upload(f, r.uniformsList, y, B), t.isShaderMaterial && (t.uniformsNeedUpdate = !1)), t.isShaderMaterial && !0 === t.uniformsNeedUpdate && (di.upload(f, r.uniformsList, y, B), t.uniformsNeedUpdate = !1), t.isSpriteMaterial && m.setValue(f, "center", i.center), m.setValue(f, "modelViewMatrix", i.modelViewMatrix), m.setValue(f, "normalMatrix", i.normalMatrix), m.setValue(f, "modelMatrix", i.matrixWorld), g } function bA(A, e, t) { A.opacity.value = e.opacity, e.color && A.diffuse.value.copy(e.color), e.emissive && A.emissive.value.copy(e.emissive).multiplyScalar(e.emissiveIntensity), e.map && (A.map.value = e.map), e.alphaMap && (A.alphaMap.value = e.alphaMap), e.specularMap && (A.specularMap.value = e.specularMap); var i, o, n = e.envMap || t; n && (A.envMap.value = n, A.flipEnvMap.value = n.isCubeTexture ? -1 : 1, A.reflectivity.value = e.reflectivity, A.refractionRatio.value = e.refractionRatio, A.maxMipLevel.value = E.get(n).__maxMipLevel), e.lightMap && (A.lightMap.value = e.lightMap, A.lightMapIntensity.value = e.lightMapIntensity), e.aoMap && (A.aoMap.value = e.aoMap, A.aoMapIntensity.value = e.aoMapIntensity), e.map ? i = e.map : e.specularMap ? i = e.specularMap : e.displacementMap ? i = e.displacementMap : e.normalMap ? i = e.normalMap : e.bumpMap ? i = e.bumpMap : e.roughnessMap ? i = e.roughnessMap : e.metalnessMap ? i = e.metalnessMap : e.alphaMap ? i = e.alphaMap : e.emissiveMap && (i = e.emissiveMap), void 0 !== i && (i.isWebGLRenderTarget && (i = i.texture), !0 === i.matrixAutoUpdate && i.updateMatrix(), A.uvTransform.value.copy(i.matrix)), e.aoMap ? o = e.aoMap : e.lightMap && (o = e.lightMap), void 0 !== o && (o.isWebGLRenderTarget && (o = o.texture), !0 === o.matrixAutoUpdate && o.updateMatrix(), A.uv2Transform.value.copy(o.matrix)) } function UA(A, e, t) { A.roughness.value = e.roughness, A.metalness.value = e.metalness, e.roughnessMap && (A.roughnessMap.value = e.roughnessMap), e.metalnessMap && (A.metalnessMap.value = e.metalnessMap), e.emissiveMap && (A.emissiveMap.value = e.emissiveMap), e.bumpMap && (A.bumpMap.value = e.bumpMap, A.bumpScale.value = e.bumpScale, 1 === e.side && (A.bumpScale.value *= -1)), e.normalMap && (A.normalMap.value = e.normalMap, A.normalScale.value.copy(e.normalScale), 1 === e.side && A.normalScale.value.negate()), e.displacementMap && (A.displacementMap.value = e.displacementMap, A.displacementScale.value = e.displacementScale, A.displacementBias.value = e.displacementBias), (e.envMap || t) && (A.envMapIntensity.value = e.envMapIntensity) } EA.setAnimationLoop((function (A) { gA.isPresenting || IA && IA(A) })), "undefined" != typeof window && EA.setContext(window), this.setAnimationLoop = function (A) { IA = A, gA.setAnimationLoop(A), EA.start() }, this.render = function (A, e) { var t, i; if (void 0 !== arguments[2] && (console.warn("THREE.WebGLRenderer.render(): the renderTarget argument has been removed. Use .setRenderTarget() instead."), t = arguments[2]), void 0 !== arguments[3] && (console.warn("THREE.WebGLRenderer.render(): the forceClear argument has been removed. Use .clear() instead."), i = arguments[3]), e && e.isCamera) { if (!L) { j.geometry = null, j.program = null, j.wireframe = !1, q = -1, H = null, !0 === A.autoUpdate && A.updateMatrixWorld(), null === e.parent && e.updateMatrixWorld(), gA.enabled && gA.isPresenting && (e = gA.getCamera(e)), (u = F.get(A, e)).init(), A.onBeforeRender(D, A, e, t || G), lA.multiplyMatrices(e.projectionMatrix, e.matrixWorldInverse), nA.setFromProjectionMatrix(lA), aA = rA.init(this.clippingPlanes, sA = this.localClippingEnabled, e), (g = U.get(A, e)).init(), BA(A, e, 0, D.sortObjects), g.finish(), !0 === D.sortObjects && g.sort(AA, eA), aA && rA.beginShadows(); var o = u.state.shadowsArray; uA.render(o, A, e), u.setupLights(e), aA && rA.endShadows(), this.info.autoReset && this.info.reset(), void 0 !== t && this.setRenderTarget(t), K.render(g, A, e, i); var n = g.opaque, r = g.transparent; if (A.overrideMaterial) { var a = A.overrideMaterial; n.length && xA(n, A, e, a), r.length && xA(r, A, e, a) } else n.length && xA(n, A, e), r.length && xA(r, A, e); A.onAfterRender(D, A, e), null !== G && (B.updateRenderTargetMipmap(G), B.updateMultisampleRenderTarget(G)), v.buffers.depth.setTest(!0), v.buffers.depth.setMask(!0), v.buffers.color.setMask(!0), v.setPolygonOffset(!1), g = null, u = null } } else console.error("THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.") }, this.setFramebuffer = function (A) { N !== A && null === G && f.bindFramebuffer(36160, A), N = A }, this.getActiveCubeFace = function () { return O }, this.getActiveMipmapLevel = function () { return V }, this.getRenderTarget = function () { return G }, this.setRenderTarget = function (A, e, t) { G = A, O = e, V = t, A && void 0 === E.get(A).__webglFramebuffer && B.setupRenderTarget(A); var i = N, o = !1; if (A) { var n = E.get(A).__webglFramebuffer; A.isWebGLCubeRenderTarget ? (i = n[e || 0], o = !0) : i = A.isWebGLMultisampleRenderTarget ? E.get(A).__webglMultisampledFramebuffer : n, J.copy(A.viewport), z.copy(A.scissor), Z = A.scissorTest } else J.copy(tA).multiplyScalar($).floor(), z.copy(iA).multiplyScalar($).floor(), Z = oA; if (P !== i && (f.bindFramebuffer(36160, i), P = i), v.viewport(J), v.scissor(z), v.setScissorTest(Z), o) { var r = E.get(A.texture); f.framebufferTexture2D(36160, 36064, 34069 + (e || 0), r.__webglTexture, t || 0) } }, this.readRenderTargetPixels = function (A, e, t, i, o, n, r) { if (A && A.isWebGLRenderTarget) { var a = E.get(A).__webglFramebuffer; if (A.isWebGLCubeRenderTarget && void 0 !== r && (a = a[r]), a) { var s = !1; a !== P && (f.bindFramebuffer(36160, a), s = !0); try { var l = A.texture, c = l.format, h = l.type; if (1023 !== c && k.convert(c) !== f.getParameter(35739)) return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format."); if (!(1009 === h || k.convert(h) === f.getParameter(35738) || 1015 === h && (C.isWebGL2 || m.get("OES_texture_float") || m.get("WEBGL_color_buffer_float")) || 1016 === h && m.get(C.isWebGL2 ? "EXT_color_buffer_float" : "EXT_color_buffer_half_float"))) return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type."); 36053 === f.checkFramebufferStatus(36160) ? 0 > e || e > A.width - i || 0 > t || t > A.height - o || f.readPixels(e, t, i, o, k.convert(c), k.convert(h), n) : console.error("THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete.") } finally { s && f.bindFramebuffer(36160, P) } } } else console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.") }, this.copyFramebufferToTexture = function (A, e, t) { void 0 === t && (t = 0); var i = Math.pow(2, -t), o = Math.floor(e.image.width * i), n = Math.floor(e.image.height * i), r = k.convert(e.format); B.setTexture2D(e, 0), f.copyTexImage2D(3553, t, r, A.x, A.y, o, n, 0), v.unbindTexture() }, this.copyTextureToTexture = function (A, e, t, i) { var o = e.image.width, n = e.image.height, r = k.convert(t.format), a = k.convert(t.type); B.setTexture2D(t, 0), e.isDataTexture ? f.texSubImage2D(3553, i || 0, A.x, A.y, o, n, r, a, e.image.data) : f.texSubImage2D(3553, i || 0, A.x, A.y, r, a, e.image), v.unbindTexture() }, this.initTexture = function (A) { B.setTexture2D(A, 0), v.unbindTexture() }, "undefined" != typeof __THREE_DEVTOOLS__ && __THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe", { detail: this })) } function Ao(A, e) { this.name = "", this.color = new LA(A), this.density = void 0 !== e ? e : 25e-5 } function eo(A, e, t) { this.name = "", this.color = new LA(A), this.near = void 0 !== e ? e : 1, this.far = void 0 !== t ? t : 1e3 } function to(A, e) { this.array = A, this.stride = e, this.count = void 0 !== A ? A.length / e : 0, this.usage = 35044, this.updateRange = { offset: 0, count: -1 }, this.version = 0 } Zi.prototype = Object.assign(Object.create(je.prototype), { constructor: Zi, isArrayCamera: !0 }), Xi.prototype = Object.assign(Object.create(H.prototype), { constructor: Xi, isGroup: !0 }), Object.assign(_i.prototype, i.prototype), Object.assign(Ao.prototype, { isFogExp2: !0, clone: function () { return new Ao(this.color, this.density) }, toJSON: function () { return { type: "FogExp2", color: this.color.getHex(), density: this.density } } }), Object.assign(eo.prototype, { isFog: !0, clone: function () { return new eo(this.color, this.near, this.far) }, toJSON: function () { return { type: "Fog", color: this.color.getHex(), near: this.near, far: this.far } } }), Object.defineProperty(to.prototype, "needsUpdate", { set: function (A) { !0 === A && this.version++ } }), Object.assign(to.prototype, { isInterleavedBuffer: !0, onUploadCallback: function () {}, setUsage: function (A) { return this.usage = A, this }, copy: function (A) { return this.array = new A.array.constructor(A.array), this.count = A.count, this.stride = A.stride, this.usage = A.usage, this }, copyAt: function (A, e, t) { A *= this.stride, t *= e.stride; for (var i = 0, o = this.stride; o > i; i++) this.array[A + i] = e.array[t + i]; return this }, set: function (A, e) { return void 0 === e && (e = 0), this.array.set(A, e), this }, clone: function () { return (new this.constructor).copy(this) }, onUpload: function (A) { return this.onUploadCallback = A, this } }); var io, oo = new y; function no(A, e, t, i) { this.data = A, this.itemSize = e, this.offset = t, this.normalized = !0 === i } function ro(A) { qA.call(this), this.type = "SpriteMaterial", this.color = new LA(16777215), this.map = null, this.alphaMap = null, this.rotation = 0, this.sizeAttenuation = !0, this.transparent = !0, this.setValues(A) } Object.defineProperties(no.prototype, { count: { get: function () { return this.data.count } }, array: { get: function () { return this.data.array } } }), Object.assign(no.prototype, { isInterleavedBufferAttribute: !0, applyMatrix4: function (A) { for (var e = 0, t = this.data.count; t > e; e++) oo.x = this.getX(e), oo.y = this.getY(e), oo.z = this.getZ(e), oo.applyMatrix4(A), this.setXYZ(e, oo.x, oo.y, oo.z); return this }, setX: function (A, e) { return this.data.array[A * this.data.stride + this.offset] = e, this }, setY: function (A, e) { return this.data.array[A * this.data.stride + this.offset + 1] = e, this }, setZ: function (A, e) { return this.data.array[A * this.data.stride + this.offset + 2] = e, this }, setW: function (A, e) { return this.data.array[A * this.data.stride + this.offset + 3] = e, this }, getX: function (A) { return this.data.array[A * this.data.stride + this.offset] }, getY: function (A) { return this.data.array[A * this.data.stride + this.offset + 1] }, getZ: function (A) { return this.data.array[A * this.data.stride + this.offset + 2] }, getW: function (A) { return this.data.array[A * this.data.stride + this.offset + 3] }, setXY: function (A, e, t) { return this.data.array[(A = A * this.data.stride + this.offset) + 0] = e, this.data.array[A + 1] = t, this }, setXYZ: function (A, e, t, i) { return this.data.array[(A = A * this.data.stride + this.offset) + 0] = e, this.data.array[A + 1] = t, this.data.array[A + 2] = i, this }, setXYZW: function (A, e, t, i, o) { return this.data.array[(A = A * this.data.stride + this.offset) + 0] = e, this.data.array[A + 1] = t, this.data.array[A + 2] = i, this.data.array[A + 3] = o, this } }), (ro.prototype = Object.create(qA.prototype)).constructor = ro, ro.prototype.isSpriteMaterial = !0, ro.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.color.copy(A.color), this.map = A.map, this.alphaMap = A.alphaMap, this.rotation = A.rotation, this.sizeAttenuation = A.sizeAttenuation, this }; var ao = new y, so = new y, lo = new y, co = new s, ho = new s, po = new M, go = new y, uo = new y, fo = new y, mo = new s, Co = new s, yo = new s; function vo(A) { if (H.call(this), this.type = "Sprite", void 0 === io) { io = new he; var e = new to(new Float32Array([-.5, -.5, 0, 0, 0, .5, -.5, 0, 1, 0, .5, .5, 0, 1, 1, -.5, .5, 0, 0, 1]), 5); io.setIndex([0, 1, 2, 0, 2, 3]), io.setAttribute("position", new no(e, 3, 0, !1)), io.setAttribute("uv", new no(e, 2, 3, !1)) } this.geometry = io, this.material = void 0 !== A ? A : new ro, this.center = new s(.5, .5) } function Io(A, e, t, i, o, n) { co.subVectors(A, t).addScalar(.5).multiply(i), void 0 !== o ? (ho.x = n * co.x - o * co.y, ho.y = o * co.x + n * co.y) : ho.copy(co), A.copy(e), A.x += ho.x, A.y += ho.y, A.applyMatrix4(po) } vo.prototype = Object.assign(Object.create(H.prototype), { constructor: vo, isSprite: !0, raycast: function (A, e) { null === A.camera && console.error('THREE.Sprite: "Raycaster.camera" needs to be set in order to raycast against sprites.'), so.setFromMatrixScale(this.matrixWorld), po.copy(A.camera.matrixWorld), this.modelViewMatrix.multiplyMatrices(A.camera.matrixWorldInverse, this.matrixWorld), lo.setFromMatrixPosition(this.modelViewMatrix), A.camera.isPerspectiveCamera && !1 === this.material.sizeAttenuation && so.multiplyScalar(-lo.z); var t, i, o = this.material.rotation; 0 !== o && (i = Math.cos(o), t = Math.sin(o)); var n = this.center; Io(go.set(-.5, -.5, 0), lo, n, so, t, i), Io(uo.set(.5, -.5, 0), lo, n, so, t, i), Io(fo.set(.5, .5, 0), lo, n, so, t, i), mo.set(0, 0), Co.set(1, 0), yo.set(1, 1); var r = A.ray.intersectTriangle(go, uo, fo, !1, ao); if (null !== r || (Io(uo.set(-.5, .5, 0), lo, n, so, t, i), Co.set(0, 1), null !== (r = A.ray.intersectTriangle(go, fo, uo, !1, ao)))) { var a = A.ray.origin.distanceTo(ao); A.near > a || a > A.far || e.push({ distance: a, point: ao.clone(), uv: RA.getUV(ao, go, uo, fo, mo, Co, yo, new s), face: null, object: this }) } }, clone: function () { return new this.constructor(this.material).copy(this) }, copy: function (A) { return H.prototype.copy.call(this, A), void 0 !== A.center && this.center.copy(A.center), this } }); var Eo = new y, Bo = new y; function xo() { H.call(this), this._currentLevel = 0, this.type = "LOD", Object.defineProperties(this, { levels: { enumerable: !0, value: [] } }), this.autoUpdate = !0 } function So(A, e) { A && A.isGeometry && console.error("THREE.SkinnedMesh no longer supports THREE.Geometry. Use THREE.BufferGeometry instead."), Ue.call(this, A, e), this.type = "SkinnedMesh", this.bindMode = "attached", this.bindMatrix = new M, this.bindMatrixInverse = new M } xo.prototype = Object.assign(Object.create(H.prototype), { constructor: xo, isLOD: !0, copy: function (A) { H.prototype.copy.call(this, A, !1); for (var e = A.levels, t = 0, i = e.length; i > t; t++) { var o = e[t]; this.addLevel(o.object.clone(), o.distance) } return this.autoUpdate = A.autoUpdate, this }, addLevel: function (A, e) { void 0 === e && (e = 0), e = Math.abs(e); for (var t = this.levels, i = 0; t.length > i && t[i].distance <= e; i++) ; return t.splice(i, 0, { distance: e, object: A }), this.add(A), this }, getCurrentLevel: function () { return this._currentLevel }, getObjectForDistance: function (A) { var e = this.levels; if (e.length > 0) { for (var t = 1, i = e.length; i > t && e[t].distance <= A; t++) ; return e[t - 1].object } return null }, raycast: function (A, e) { if (this.levels.length > 0) { Eo.setFromMatrixPosition(this.matrixWorld); var t = A.ray.origin.distanceTo(Eo); this.getObjectForDistance(t).raycast(A, e) } }, update: function (A) { var e = this.levels; if (e.length > 1) { Eo.setFromMatrixPosition(A.matrixWorld), Bo.setFromMatrixPosition(this.matrixWorld); var t = Eo.distanceTo(Bo) / A.zoom; e[0].object.visible = !0; for (var i = 1, o = e.length; o > i && e[i].distance <= t; i++) e[i - 1].object.visible = !1, e[i].object.visible = !0; for (this._currentLevel = i - 1; o > i; i++) e[i].object.visible = !1 } }, toJSON: function (A) { var e = H.prototype.toJSON.call(this, A); !1 === this.autoUpdate && (e.object.autoUpdate = !1), e.object.levels = []; for (var t = this.levels, i = 0, o = t.length; o > i; i++) { var n = t[i]; e.object.levels.push({ object: n.object.uuid, distance: n.distance }) } return e } }), So.prototype = Object.assign(Object.create(Ue.prototype), { constructor: So, isSkinnedMesh: !0, bind: function (A, e) { this.skeleton = A, void 0 === e && (this.updateMatrixWorld(!0), this.skeleton.calculateInverses(), e = this.matrixWorld), this.bindMatrix.copy(e), this.bindMatrixInverse.getInverse(e) }, pose: function () { this.skeleton.pose() }, normalizeSkinWeights: function () { for (var A = new p, e = this.geometry.attributes.skinWeight, t = 0, i = e.count; i > t; t++) { A.x = e.getX(t), A.y = e.getY(t), A.z = e.getZ(t), A.w = e.getW(t); var o = 1 / A.manhattanLength(); o !== 1 / 0 ? A.multiplyScalar(o) : A.set(1, 0, 0, 0), e.setXYZW(t, A.x, A.y, A.z, A.w) } }, updateMatrixWorld: function (A) { Ue.prototype.updateMatrixWorld.call(this, A), "attached" === this.bindMode ? this.bindMatrixInverse.getInverse(this.matrixWorld) : "detached" === this.bindMode ? this.bindMatrixInverse.getInverse(this.bindMatrix) : console.warn("THREE.SkinnedMesh: Unrecognized bindMode: " + this.bindMode) }, clone: function () { return new this.constructor(this.geometry, this.material).copy(this) } }); var wo = new M, Mo = new M; function bo(A, e) { if (this.bones = (A = A || []).slice(0), this.boneMatrices = new Float32Array(16 * this.bones.length), this.frame = -1, void 0 === e) this.calculateInverses(); else if (this.bones.length === e.length) this.boneInverses = e.slice(0); else { console.warn("THREE.Skeleton boneInverses is the wrong length."), this.boneInverses = []; for (var t = 0, i = this.bones.length; i > t; t++) this.boneInverses.push(new M) } } function Uo() { H.call(this), this.type = "Bone" } Object.assign(bo.prototype, { calculateInverses: function () { this.boneInverses = []; for (var A = 0, e = this.bones.length; e > A; A++) { var t = new M; this.bones[A] && t.getInverse(this.bones[A].matrixWorld), this.boneInverses.push(t) } }, pose: function () { var A, e, t; for (e = 0, t = this.bones.length; t > e; e++) (A = this.bones[e]) && A.matrixWorld.getInverse(this.boneInverses[e]); for (e = 0, t = this.bones.length; t > e; e++) (A = this.bones[e]) && (A.parent && A.parent.isBone ? (A.matrix.getInverse(A.parent.matrixWorld), A.matrix.multiply(A.matrixWorld)) : A.matrix.copy(A.matrixWorld), A.matrix.decompose(A.position, A.quaternion, A.scale)) }, update: function () { for (var A = this.bones, e = this.boneInverses, t = this.boneMatrices, i = this.boneTexture, o = 0, n = A.length; n > o; o++) { wo.multiplyMatrices(A[o] ? A[o].matrixWorld : Mo, e[o]), wo.toArray(t, 16 * o) } void 0 !== i && (i.needsUpdate = !0) }, clone: function () { return new bo(this.bones, this.boneInverses) }, getBoneByName: function (A) { for (var e = 0, t = this.bones.length; t > e; e++) { var i = this.bones[e]; if (i.name === A) return i } }, dispose: function () { this.boneTexture && (this.boneTexture.dispose(), this.boneTexture = void 0) } }), Uo.prototype = Object.assign(Object.create(H.prototype), { constructor: Uo, isBone: !0 }); var Fo = new M, Ko = new M, Qo = [], Ro = new Ue; function To(A, e, t) { Ue.call(this, A, e), this.instanceMatrix = new YA(new Float32Array(16 * t), 16), this.count = t, this.frustumCulled = !1 } function ko(A) { qA.call(this), this.type = "LineBasicMaterial", this.color = new LA(16777215), this.linewidth = 1, this.linecap = "round", this.linejoin = "round", this.setValues(A) } To.prototype = Object.assign(Object.create(Ue.prototype), { constructor: To, isInstancedMesh: !0, getMatrixAt: function (A, e) { e.fromArray(this.instanceMatrix.array, 16 * A) }, raycast: function (A, e) { var t = this.matrixWorld, i = this.count; if (Ro.geometry = this.geometry, Ro.material = this.material, void 0 !== Ro.material) for (var o = 0; i > o; o++) this.getMatrixAt(o, Fo), Ko.multiplyMatrices(t, Fo), Ro.matrixWorld = Ko, Ro.raycast(A, Qo), Qo.length > 0 && (Qo[0].instanceId = o, Qo[0].object = this, e.push(Qo[0]), Qo.length = 0) }, setMatrixAt: function (A, e) { e.toArray(this.instanceMatrix.array, 16 * A) }, updateMorphTargets: function () {} }), (ko.prototype = Object.create(qA.prototype)).constructor = ko, ko.prototype.isLineBasicMaterial = !0, ko.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.color.copy(A.color), this.linewidth = A.linewidth, this.linecap = A.linecap, this.linejoin = A.linejoin, this }; var Do = new y, Lo = new y, No = new M, Oo = new CA, Vo = new cA; function Go(A, e, t) { 1 === t && console.error("THREE.Line: parameter THREE.LinePieces no longer supported. Use THREE.LineSegments instead."), H.call(this), this.type = "Line", this.geometry = void 0 !== A ? A : new he, this.material = void 0 !== e ? e : new ko } Go.prototype = Object.assign(Object.create(H.prototype), { constructor: Go, isLine: !0, computeLineDistances: function () { var A = this.geometry; if (A.isBufferGeometry) if (null === A.index) { for (var e = A.attributes.position, t = [0], i = 1, o = e.count; o > i; i++) Do.fromBufferAttribute(e, i - 1), Lo.fromBufferAttribute(e, i), t[i] = t[i - 1], t[i] += Do.distanceTo(Lo); A.setAttribute("lineDistance", new Ae(t, 1)) } else console.warn("THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry."); else if (A.isGeometry) { var n = A.vertices; (t = A.lineDistances)[0] = 0; for (i = 1, o = n.length; o > i; i++) t[i] = t[i - 1], t[i] += n[i - 1].distanceTo(n[i]) } return this }, raycast: function (A, e) { var t = this.geometry, i = this.matrixWorld, o = A.params.Line.threshold; if (null === t.boundingSphere && t.computeBoundingSphere(), Vo.copy(t.boundingSphere), Vo.applyMatrix4(i), Vo.radius += o, !1 !== A.ray.intersectsSphere(Vo)) { No.getInverse(i), Oo.copy(A.ray).applyMatrix4(No); var n = o / ((this.scale.x + this.scale.y + this.scale.z) / 3), r = n * n, a = new y, s = new y, l = new y, c = new y, h = this && this.isLineSegments ? 2 : 1; if (t.isBufferGeometry) { var d = t.index, p = t.attributes.position.array; if (null !== d) for (var g = d.array, u = 0, f = g.length - 1; f > u; u += h) { var m = g[u + 1]; if (a.fromArray(p, 3 * g[u]), s.fromArray(p, 3 * m), r >= Oo.distanceSqToSegment(a, s, c, l)) { c.applyMatrix4(this.matrixWorld); var C = A.ray.origin.distanceTo(c); A.near > C || C > A.far || e.push({ distance: C, point: l.clone().applyMatrix4(this.matrixWorld), index: u, face: null, faceIndex: null, object: this }) } } else for (u = 0, f = p.length / 3 - 1; f > u; u += h) { if (a.fromArray(p, 3 * u), s.fromArray(p, 3 * u + 3), r >= Oo.distanceSqToSegment(a, s, c, l)) { c.applyMatrix4(this.matrixWorld); C = A.ray.origin.distanceTo(c); A.near > C || C > A.far || e.push({ distance: C, point: l.clone().applyMatrix4(this.matrixWorld), index: u, face: null, faceIndex: null, object: this }) } } } else if (t.isGeometry) { var v = t.vertices, I = v.length; for (u = 0; I - 1 > u; u += h) { if (r >= Oo.distanceSqToSegment(v[u], v[u + 1], c, l)) { c.applyMatrix4(this.matrixWorld); C = A.ray.origin.distanceTo(c); A.near > C || C > A.far || e.push({ distance: C, point: l.clone().applyMatrix4(this.matrixWorld), index: u, face: null, faceIndex: null, object: this }) } } } } }, clone: function () { return new this.constructor(this.geometry, this.material).copy(this) } }); var Po = new y, qo = new y; function jo(A, e) { Go.call(this, A, e), this.type = "LineSegments" } function Ho(A, e) { Go.call(this, A, e), this.type = "LineLoop" } function Yo(A) { qA.call(this), this.type = "PointsMaterial", this.color = new LA(16777215), this.map = null, this.alphaMap = null, this.size = 1, this.sizeAttenuation = !0, this.morphTargets = !1, this.setValues(A) } jo.prototype = Object.assign(Object.create(Go.prototype), { constructor: jo, isLineSegments: !0, computeLineDistances: function () { var A = this.geometry; if (A.isBufferGeometry) if (null === A.index) { for (var e = A.attributes.position, t = [], i = 0, o = e.count; o > i; i += 2) Po.fromBufferAttribute(e, i), qo.fromBufferAttribute(e, i + 1), t[i] = 0 === i ? 0 : t[i - 1], t[i + 1] = t[i] + Po.distanceTo(qo); A.setAttribute("lineDistance", new Ae(t, 1)) } else console.warn("THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry."); else if (A.isGeometry) { var n = A.vertices; for (t = A.lineDistances, i = 0, o = n.length; o > i; i += 2) Po.copy(n[i]), qo.copy(n[i + 1]), t[i] = 0 === i ? 0 : t[i - 1], t[i + 1] = t[i] + Po.distanceTo(qo) } return this } }), Ho.prototype = Object.assign(Object.create(Go.prototype), { constructor: Ho, isLineLoop: !0 }), (Yo.prototype = Object.create(qA.prototype)).constructor = Yo, Yo.prototype.isPointsMaterial = !0, Yo.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.color.copy(A.color), this.map = A.map, this.alphaMap = A.alphaMap, this.size = A.size, this.sizeAttenuation = A.sizeAttenuation, this.morphTargets = A.morphTargets, this }; var Wo = new M, Jo = new CA, zo = new cA, Zo = new y; function Xo(A, e) { H.call(this), this.type = "Points", this.geometry = void 0 !== A ? A : new he, this.material = void 0 !== e ? e : new Yo, this.updateMorphTargets() } function _o(A, e, t, i, o, n, r) { var a = Jo.distanceSqToPoint(A); if (t > a) { var s = new y; Jo.closestPointToPoint(A, s), s.applyMatrix4(i); var l = o.ray.origin.distanceTo(s); if (o.near > l || l > o.far) return; n.push({ distance: l, distanceToRay: Math.sqrt(a), point: s, index: e, face: null, object: r }) } } function $o(A, e, t, i, o, n, r, a, s) { d.call(this, A, e, t, i, o, n, r, a, s), this.format = void 0 !== r ? r : 1022, this.minFilter = void 0 !== n ? n : 1006, this.magFilter = void 0 !== o ? o : 1006, this.generateMipmaps = !1 } function An(A, e, t, i, o, n, r, a, s, l, c, h) { d.call(this, null, n, r, a, s, l, i, o, c, h), this.image = { width: e, height: t }, this.mipmaps = A, this.flipY = !1, this.generateMipmaps = !1 } function en(A, e, t, i, o, n, r, a, s) { d.call(this, A, e, t, i, o, n, r, a, s), this.needsUpdate = !0 } function tn(A, e, t, i, o, n, r, a, s, l) { if (1026 !== (l = void 0 !== l ? l : 1026) && 1027 !== l) throw new Error("DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat"); void 0 === t && 1026 === l && (t = 1012), void 0 === t && 1027 === l && (t = 1020), d.call(this, null, i, o, n, r, a, l, t, s), this.image = { width: A, height: e }, this.magFilter = void 0 !== r ? r : 1003, this.minFilter = void 0 !== a ? a : 1003, this.flipY = !1, this.generateMipmaps = !1 } function on(A) { he.call(this), this.type = "WireframeGeometry"; var e, t, i, o, n, r, a, s, l, c, h = [], d = [0, 0], p = {}, g = ["a", "b", "c"]; if (A && A.isGeometry) { var u = A.faces; for (e = 0, i = u.length; i > e; e++) { var f = u[e]; for (t = 0; 3 > t; t++) a = f[g[t]], s = f[g[(t + 1) % 3]], d[0] = Math.min(a, s), d[1] = Math.max(a, s), void 0 === p[l = d[0] + "," + d[1]] && (p[l] = { index1: d[0], index2: d[1] }) } for (l in p) h.push((c = A.vertices[(r = p[l]).index1]).x, c.y, c.z), h.push((c = A.vertices[r.index2]).x, c.y, c.z) } else if (A && A.isBufferGeometry) { var m, C, v, I, E; if (c = new y, null !== A.index) { for (m = A.attributes.position, C = A.index, 0 === (v = A.groups).length && (v = [{ start: 0, count: C.count, materialIndex: 0 }]), o = 0, n = v.length; n > o; ++o) for (e = E = (I = v[o]).start, i = E + I.count; i > e; e += 3) for (t = 0; 3 > t; t++) a = C.getX(e + t), s = C.getX(e + (t + 1) % 3), d[0] = Math.min(a, s), d[1] = Math.max(a, s), void 0 === p[l = d[0] + "," + d[1]] && (p[l] = { index1: d[0], index2: d[1] }); for (l in p) c.fromBufferAttribute(m, (r = p[l]).index1), h.push(c.x, c.y, c.z), c.fromBufferAttribute(m, r.index2), h.push(c.x, c.y, c.z) } else for (e = 0, i = (m = A.attributes.position).count / 3; i > e; e++) for (t = 0; 3 > t; t++) c.fromBufferAttribute(m, 3 * e + t), h.push(c.x, c.y, c.z), c.fromBufferAttribute(m, 3 * e + (t + 1) % 3), h.push(c.x, c.y, c.z) } this.setAttribute("position", new Ae(h, 3)) } function nn(A, e, t) { De.call(this), this.type = "ParametricGeometry", this.parameters = { func: A, slices: e, stacks: t }, this.fromBufferGeometry(new rn(A, e, t)), this.mergeVertices() } function rn(A, e, t) { he.call(this), this.type = "ParametricBufferGeometry", this.parameters = { func: A, slices: e, stacks: t }; var i, o, n = [], r = [], a = [], s = [], l = 1e-5, c = new y, h = new y, d = new y, p = new y, g = new y; 3 > A.length && console.error("THREE.ParametricGeometry: Function must now modify a Vector3 as third parameter."); var u = e + 1; for (i = 0; t >= i; i++) { var f = i / t; for (o = 0; e >= o; o++) { var m = o / e; A(m, f, h), r.push(h.x, h.y, h.z), 0 > m - l ? (A(m + l, f, d), p.subVectors(d, h)) : (A(m - l, f, d), p.subVectors(h, d)), 0 > f - l ? (A(m, f + l, d), g.subVectors(d, h)) : (A(m, f - l, d), g.subVectors(h, d)), c.crossVectors(p, g).normalize(), a.push(c.x, c.y, c.z), s.push(m, f) } } for (i = 0; t > i; i++) for (o = 0; e > o; o++) { var C = i * u + o + 1, v = (i + 1) * u + o + 1, I = (i + 1) * u + o; n.push(i * u + o, C, I), n.push(C, v, I) } this.setIndex(n), this.setAttribute("position", new Ae(r, 3)), this.setAttribute("normal", new Ae(a, 3)), this.setAttribute("uv", new Ae(s, 2)) } function an(A, e, t, i) { De.call(this), this.type = "PolyhedronGeometry", this.parameters = { vertices: A, indices: e, radius: t, detail: i }, this.fromBufferGeometry(new sn(A, e, t, i)), this.mergeVertices() } function sn(A, e, t, i) { he.call(this), this.type = "PolyhedronBufferGeometry", this.parameters = { vertices: A, indices: e, radius: t, detail: i }, t = t || 1; var o = [], n = []; function r(A, e, t, i) { var o, n, r = Math.pow(2, i), s = []; for (o = 0; r >= o; o++) { s[o] = []; var l = A.clone().lerp(t, o / r), c = e.clone().lerp(t, o / r), h = r - o; for (n = 0; h >= n; n++) s[o][n] = 0 === n && o === r ? l : l.clone().lerp(c, n / h) } for (o = 0; r > o; o++) for (n = 0; 2 * (r - o) - 1 > n; n++) { var d = Math.floor(n / 2); n % 2 == 0 ? (a(s[o][d + 1]), a(s[o + 1][d]), a(s[o][d])) : (a(s[o][d + 1]), a(s[o + 1][d + 1]), a(s[o + 1][d])) } } function a(A) { o.push(A.x, A.y, A.z) } function l(e, t) { var i = 3 * e; t.x = A[i + 0], t.y = A[i + 1], t.z = A[i + 2] } function c(A, e, t, i) { 0 > i && 1 === A.x && (n[e] = A.x - 1), 0 === t.x && 0 === t.z && (n[e] = i / 2 / Math.PI + .5) } function h(A) { return Math.atan2(A.z, -A.x) }! function (A) { for (var t = new y, i = new y, o = new y, n = 0; e.length > n; n += 3) l(e[n + 0], t), l(e[n + 1], i), l(e[n + 2], o), r(t, i, o, A) }(i = i || 0), function (A) { for (var e = new y, t = 0; o.length > t; t += 3) e.x = o[t + 0], e.y = o[t + 1], e.z = o[t + 2], e.normalize().multiplyScalar(A), o[t + 0] = e.x, o[t + 1] = e.y, o[t + 2] = e.z }(t), function () { for (var A = new y, e = 0; o.length > e; e += 3) { A.x = o[e + 0], A.y = o[e + 1], A.z = o[e + 2]; var t = h(A) / 2 / Math.PI + .5, i = (r = A, Math.atan2(-r.y, Math.sqrt(r.x * r.x + r.z * r.z)) / Math.PI + .5); n.push(t, 1 - i) } var r; (function () { for (var A = new y, e = new y, t = new y, i = new y, r = new s, a = new s, l = new s, d = 0, p = 0; o.length > d; d += 9, p += 6) { A.set(o[d + 0], o[d + 1], o[d + 2]), e.set(o[d + 3], o[d + 4], o[d + 5]), t.set(o[d + 6], o[d + 7], o[d + 8]), r.set(n[p + 0], n[p + 1]), a.set(n[p + 2], n[p + 3]), l.set(n[p + 4], n[p + 5]), i.copy(A).add(e).add(t).divideScalar(3); var g = h(i); c(r, p + 0, A, g), c(a, p + 2, e, g), c(l, p + 4, t, g) } })(), function () { for (var A = 0; n.length > A; A += 6) { var e = n[A + 0], t = n[A + 2], i = n[A + 4], o = Math.max(e, t, i), r = Math.min(e, t, i); o > .9 && .1 > r && (.2 > e && (n[A + 0] += 1), .2 > t && (n[A + 2] += 1), .2 > i && (n[A + 4] += 1)) } }() }(), this.setAttribute("position", new Ae(o, 3)), this.setAttribute("normal", new Ae(o.slice(), 3)), this.setAttribute("uv", new Ae(n, 2)), 0 === i ? this.computeVertexNormals() : this.normalizeNormals() } function ln(A, e) { De.call(this), this.type = "TetrahedronGeometry", this.parameters = { radius: A, detail: e }, this.fromBufferGeometry(new cn(A, e)), this.mergeVertices() } function cn(A, e) { sn.call(this, [1, 1, 1, -1, -1, 1, -1, 1, -1, 1, -1, -1], [2, 1, 0, 0, 3, 2, 1, 3, 0, 2, 3, 1], A, e), this.type = "TetrahedronBufferGeometry", this.parameters = { radius: A, detail: e } } function hn(A, e) { De.call(this), this.type = "OctahedronGeometry", this.parameters = { radius: A, detail: e }, this.fromBufferGeometry(new dn(A, e)), this.mergeVertices() } function dn(A, e) { sn.call(this, [1, 0, 0, -1, 0, 0, 0, 1, 0, 0, -1, 0, 0, 0, 1, 0, 0, -1], [0, 2, 4, 0, 4, 3, 0, 3, 5, 0, 5, 2, 1, 2, 5, 1, 5, 3, 1, 3, 4, 1, 4, 2], A, e), this.type = "OctahedronBufferGeometry", this.parameters = { radius: A, detail: e } } function pn(A, e) { De.call(this), this.type = "IcosahedronGeometry", this.parameters = { radius: A, detail: e }, this.fromBufferGeometry(new gn(A, e)), this.mergeVertices() } function gn(A, e) { var t = (1 + Math.sqrt(5)) / 2; sn.call(this, [-1, t, 0, 1, t, 0, -1, -t, 0, 1, -t, 0, 0, -1, t, 0, 1, t, 0, -1, -t, 0, 1, -t, t, 0, -1, t, 0, 1, -t, 0, -1, -t, 0, 1], [0, 11, 5, 0, 5, 1, 0, 1, 7, 0, 7, 10, 0, 10, 11, 1, 5, 9, 5, 11, 4, 11, 10, 2, 10, 7, 6, 7, 1, 8, 3, 9, 4, 3, 4, 2, 3, 2, 6, 3, 6, 8, 3, 8, 9, 4, 9, 5, 2, 4, 11, 6, 2, 10, 8, 6, 7, 9, 8, 1], A, e), this.type = "IcosahedronBufferGeometry", this.parameters = { radius: A, detail: e } } function un(A, e) { De.call(this), this.type = "DodecahedronGeometry", this.parameters = { radius: A, detail: e }, this.fromBufferGeometry(new fn(A, e)), this.mergeVertices() } function fn(A, e) { var t = (1 + Math.sqrt(5)) / 2, i = 1 / t; sn.call(this, [-1, -1, -1, -1, -1, 1, -1, 1, -1, -1, 1, 1, 1, -1, -1, 1, -1, 1, 1, 1, -1, 1, 1, 1, 0, -i, -t, 0, -i, t, 0, i, -t, 0, i, t, -i, -t, 0, -i, t, 0, i, -t, 0, i, t, 0, -t, 0, -i, t, 0, -i, -t, 0, i, t, 0, i], [3, 11, 7, 3, 7, 15, 3, 15, 13, 7, 19, 17, 7, 17, 6, 7, 6, 15, 17, 4, 8, 17, 8, 10, 17, 10, 6, 8, 0, 16, 8, 16, 2, 8, 2, 10, 0, 12, 1, 0, 1, 18, 0, 18, 16, 6, 10, 2, 6, 2, 13, 6, 13, 15, 2, 16, 18, 2, 18, 3, 2, 3, 13, 18, 1, 9, 18, 9, 11, 18, 11, 3, 4, 14, 12, 4, 12, 0, 4, 0, 8, 11, 9, 5, 11, 5, 19, 11, 19, 7, 19, 5, 14, 19, 14, 4, 19, 4, 17, 1, 12, 14, 1, 14, 5, 1, 5, 9], A, e), this.type = "DodecahedronBufferGeometry", this.parameters = { radius: A, detail: e } } function mn(A, e, t, i, o, n) { De.call(this), this.type = "TubeGeometry", this.parameters = { path: A, tubularSegments: e, radius: t, radialSegments: i, closed: o }, void 0 !== n && console.warn("THREE.TubeGeometry: taper has been removed."); var r = new Cn(A, e, t, i, o); this.tangents = r.tangents, this.normals = r.normals, this.binormals = r.binormals, this.fromBufferGeometry(r), this.mergeVertices() } function Cn(A, e, t, i, o) { he.call(this), this.type = "TubeBufferGeometry", this.parameters = { path: A, tubularSegments: e, radius: t, radialSegments: i, closed: o }, t = t || 1, i = i || 8; var n = A.computeFrenetFrames(e = e || 64, o = o || !1); this.tangents = n.tangents, this.normals = n.normals, this.binormals = n.binormals; var r, a, l = new y, c = new y, h = new s, d = new y, p = [], g = [], u = [], f = []; function m(o) { d = A.getPointAt(o / e, d); var r = n.normals[o], s = n.binormals[o]; for (a = 0; i >= a; a++) { var h = a / i * Math.PI * 2, u = Math.sin(h), f = -Math.cos(h); c.x = f * r.x + u * s.x, c.y = f * r.y + u * s.y, c.z = f * r.z + u * s.z, c.normalize(), g.push(c.x, c.y, c.z), l.x = d.x + t * c.x, l.y = d.y + t * c.y, l.z = d.z + t * c.z, p.push(l.x, l.y, l.z) } }! function () { for (r = 0; e > r; r++) m(r); m(!1 === o ? e : 0), function () { for (r = 0; e >= r; r++) for (a = 0; i >= a; a++) h.x = r / e, h.y = a / i, u.push(h.x, h.y) }(), function () { for (a = 1; e >= a; a++) for (r = 1; i >= r; r++) { var A = (i + 1) * a + (r - 1), t = (i + 1) * a + r, o = (i + 1) * (a - 1) + r; f.push((i + 1) * (a - 1) + (r - 1), A, o), f.push(A, t, o) } }() }(), this.setIndex(f), this.setAttribute("position", new Ae(p, 3)), this.setAttribute("normal", new Ae(g, 3)), this.setAttribute("uv", new Ae(u, 2)) } function yn(A, e, t, i, o, n, r) { De.call(this), this.type = "TorusKnotGeometry", this.parameters = { radius: A, tube: e, tubularSegments: t, radialSegments: i, p: o, q: n }, void 0 !== r && console.warn("THREE.TorusKnotGeometry: heightScale has been deprecated. Use .scale( x, y, z ) instead."), this.fromBufferGeometry(new vn(A, e, t, i, o, n)), this.mergeVertices() } function vn(A, e, t, i, o, n) { he.call(this), this.type = "TorusKnotBufferGeometry", this.parameters = { radius: A, tube: e, tubularSegments: t, radialSegments: i, p: o, q: n }, A = A || 1, e = e || .4, t = Math.floor(t) || 64, i = Math.floor(i) || 8, o = o || 2, n = n || 3; var r, a, s = [], l = [], c = [], h = [], d = new y, p = new y, g = new y, u = new y, f = new y, m = new y, C = new y; for (r = 0; t >= r; ++r) { var v = r / t * o * Math.PI * 2; for (M(v, o, n, A, g), M(v + .01, o, n, A, u), m.subVectors(u, g), C.addVectors(u, g), f.crossVectors(m, C), C.crossVectors(f, m), f.normalize(), C.normalize(), a = 0; i >= a; ++a) { var I = a / i * Math.PI * 2, E = -e * Math.cos(I), B = e * Math.sin(I); d.x = g.x + (E * C.x + B * f.x), d.y = g.y + (E * C.y + B * f.y), d.z = g.z + (E * C.z + B * f.z), l.push(d.x, d.y, d.z), p.subVectors(d, g).normalize(), c.push(p.x, p.y, p.z), h.push(r / t), h.push(a / i) } } for (a = 1; t >= a; a++) for (r = 1; i >= r; r++) { var x = (i + 1) * a + (r - 1), S = (i + 1) * a + r, w = (i + 1) * (a - 1) + r; s.push((i + 1) * (a - 1) + (r - 1), x, w), s.push(x, S, w) } function M(A, e, t, i, o) { var n = Math.cos(A), r = Math.sin(A), a = t / e * A, s = Math.cos(a); o.x = i * (2 + s) * .5 * n, o.y = i * (2 + s) * r * .5, o.z = i * Math.sin(a) * .5 } this.setIndex(s), this.setAttribute("position", new Ae(l, 3)), this.setAttribute("normal", new Ae(c, 3)), this.setAttribute("uv", new Ae(h, 2)) } function In(A, e, t, i, o) { De.call(this), this.type = "TorusGeometry", this.parameters = { radius: A, tube: e, radialSegments: t, tubularSegments: i, arc: o }, this.fromBufferGeometry(new En(A, e, t, i, o)), this.mergeVertices() } function En(A, e, t, i, o) { he.call(this), this.type = "TorusBufferGeometry", this.parameters = { radius: A, tube: e, radialSegments: t, tubularSegments: i, arc: o }, A = A || 1, e = e || .4, t = Math.floor(t) || 8, i = Math.floor(i) || 6, o = o || 2 * Math.PI; var n, r, a = [], s = [], l = [], c = [], h = new y, d = new y, p = new y; for (n = 0; t >= n; n++) for (r = 0; i >= r; r++) { var g = r / i * o, u = n / t * Math.PI * 2; d.x = (A + e * Math.cos(u)) * Math.cos(g), d.y = (A + e * Math.cos(u)) * Math.sin(g), d.z = e * Math.sin(u), s.push(d.x, d.y, d.z), h.x = A * Math.cos(g), h.y = A * Math.sin(g), p.subVectors(d, h).normalize(), l.push(p.x, p.y, p.z), c.push(r / i), c.push(n / t) } for (n = 1; t >= n; n++) for (r = 1; i >= r; r++) { var f = (i + 1) * (n - 1) + r - 1, m = (i + 1) * (n - 1) + r, C = (i + 1) * n + r; a.push((i + 1) * n + r - 1, f, C), a.push(f, m, C) } this.setIndex(a), this.setAttribute("position", new Ae(s, 3)), this.setAttribute("normal", new Ae(l, 3)), this.setAttribute("uv", new Ae(c, 2)) } Xo.prototype = Object.assign(Object.create(H.prototype), { constructor: Xo, isPoints: !0, raycast: function (A, e) { var t = this.geometry, i = this.matrixWorld, o = A.params.Points.threshold; if (null === t.boundingSphere && t.computeBoundingSphere(), zo.copy(t.boundingSphere), zo.applyMatrix4(i), zo.radius += o, !1 !== A.ray.intersectsSphere(zo)) { Wo.getInverse(i), Jo.copy(A.ray).applyMatrix4(Wo); var n = o / ((this.scale.x + this.scale.y + this.scale.z) / 3), r = n * n; if (t.isBufferGeometry) { var a = t.index, s = t.attributes.position.array; if (null !== a) for (var l = a.array, c = 0, h = l.length; h > c; c++) { var d = l[c]; Zo.fromArray(s, 3 * d), _o(Zo, d, r, i, A, e, this) } else { c = 0; for (var p = s.length / 3; p > c; c++) Zo.fromArray(s, 3 * c), _o(Zo, c, r, i, A, e, this) } } else { var g = t.vertices; for (c = 0, p = g.length; p > c; c++) _o(g[c], c, r, i, A, e, this) } } }, updateMorphTargets: function () { var A, e, t, i = this.geometry; if (i.isBufferGeometry) { var o = i.morphAttributes, n = Object.keys(o); if (n.length > 0) { var r = o[n[0]]; if (void 0 !== r) for (this.morphTargetInfluences = [], this.morphTargetDictionary = {}, A = 0, e = r.length; e > A; A++) t = r[A].name || String(A), this.morphTargetInfluences.push(0), this.morphTargetDictionary[t] = A } } else { var a = i.morphTargets; void 0 !== a && a.length > 0 && console.error("THREE.Points.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead.") } }, clone: function () { return new this.constructor(this.geometry, this.material).copy(this) } }), $o.prototype = Object.assign(Object.create(d.prototype), { constructor: $o, isVideoTexture: !0, update: function () { var A = this.image; A.HAVE_CURRENT_DATA > A.readyState || (this.needsUpdate = !0) } }), (An.prototype = Object.create(d.prototype)).constructor = An, An.prototype.isCompressedTexture = !0, (en.prototype = Object.create(d.prototype)).constructor = en, en.prototype.isCanvasTexture = !0, (tn.prototype = Object.create(d.prototype)).constructor = tn, tn.prototype.isDepthTexture = !0, (on.prototype = Object.create(he.prototype)).constructor = on, (nn.prototype = Object.create(De.prototype)).constructor = nn, (rn.prototype = Object.create(he.prototype)).constructor = rn, (an.prototype = Object.create(De.prototype)).constructor = an, (sn.prototype = Object.create(he.prototype)).constructor = sn, (ln.prototype = Object.create(De.prototype)).constructor = ln, (cn.prototype = Object.create(sn.prototype)).constructor = cn, (hn.prototype = Object.create(De.prototype)).constructor = hn, (dn.prototype = Object.create(sn.prototype)).constructor = dn, (pn.prototype = Object.create(De.prototype)).constructor = pn, (gn.prototype = Object.create(sn.prototype)).constructor = gn, (un.prototype = Object.create(De.prototype)).constructor = un, (fn.prototype = Object.create(sn.prototype)).constructor = fn, (mn.prototype = Object.create(De.prototype)).constructor = mn, (Cn.prototype = Object.create(he.prototype)).constructor = Cn, Cn.prototype.toJSON = function () { var A = he.prototype.toJSON.call(this); return A.path = this.parameters.path.toJSON(), A }, (yn.prototype = Object.create(De.prototype)).constructor = yn, (vn.prototype = Object.create(he.prototype)).constructor = vn, (In.prototype = Object.create(De.prototype)).constructor = In, (En.prototype = Object.create(he.prototype)).constructor = En; var Bn = function (A, e, t) { t = t || 2; var i, o, n, r, a, s, l, c = e && e.length, h = c ? e[0] * t : A.length, d = xn(A, 0, h, t, !0), p = []; if (!d || d.next === d.prev) return p; if (c && (d = function (A, e, t, i) { var o, n, r, a = []; for (o = 0, n = e.length; n > o; o++) (r = xn(A, e[o] * i, n - 1 > o ? e[o + 1] * i : A.length, i, !1)) === r.next && (r.steiner = !0), a.push(Tn(r)); for (a.sort(Kn), o = 0; a.length > o; o++) Qn(a[o], t), t = Sn(t, t.next); return t }(A, e, d, t)), A.length > 80 * t) { i = n = A[0], o = r = A[1]; for (var g = t; h > g; g += t) i > (a = A[g]) && (i = a), o > (s = A[g + 1]) && (o = s), a > n && (n = a), s > r && (r = s); l = 0 !== (l = Math.max(n - i, r - o)) ? 1 / l : 0 } return wn(d, p, t, i, o, l), p }; function xn(A, e, t, i, o) { var n, r; if (o === function (A, e, t, i) { for (var o = 0, n = e, r = t - i; t > n; n += i) o += (A[r] - A[n]) * (A[n + 1] + A[r + 1]), r = n; return o }(A, e, t, i) > 0) for (n = e; t > n; n += i) r = Pn(n, A[n], A[n + 1], r); else for (n = t - i; n >= e; n -= i) r = Pn(n, A[n], A[n + 1], r); return r && Nn(r, r.next) && (qn(r), r = r.next), r } function Sn(A, e) { if (!A) return A; e || (e = A); var t, i = A; do { if (t = !1, i.steiner || !Nn(i, i.next) && 0 !== Ln(i.prev, i, i.next)) i = i.next; else { if (qn(i), (i = e = i.prev) === i.next) break; t = !0 } } while (t || i !== e); return e } function wn(A, e, t, i, o, n, r) { if (A) { !r && n && function (A, e, t, i) { var o = A; do { null === o.z && (o.z = Rn(o.x, o.y, e, t, i)), o.prevZ = o.prev, o.nextZ = o.next, o = o.next } while (o !== A); o.prevZ.nextZ = null, o.prevZ = null, function (A) { var e, t, i, o, n, r, a, s, l = 1; do { for (t = A, A = null, n = null, r = 0; t;) { for (r++, i = t, a = 0, e = 0; l > e && (a++, i = i.nextZ); e++) ; for (s = l; a > 0 || s > 0 && i;) 0 === a || 0 !== s && i && t.z > i.z ? (o = i, i = i.nextZ, s--) : (o = t, t = t.nextZ, a--), n ? n.nextZ = o : A = o, o.prevZ = n, n = o; t = i } n.nextZ = null, l *= 2 } while (r > 1) }(o) }(A, i, o, n); for (var a, s, l = A; A.prev !== A.next;) if (a = A.prev, s = A.next, n ? bn(A, i, o, n) : Mn(A)) e.push(a.i / t), e.push(A.i / t), e.push(s.i / t), qn(A), A = s.next, l = s.next; else if ((A = s) === l) { r ? 1 === r ? wn(A = Un(A, e, t), e, t, i, o, n, 2) : 2 === r && Fn(A, e, t, i, o, n) : wn(Sn(A), e, t, i, o, n, 1); break } } } function Mn(A) { var e = A.prev, t = A, i = A.next; if (Ln(e, t, i) >= 0) return !1; for (var o = A.next.next; o !== A.prev;) { if (kn(e.x, e.y, t.x, t.y, i.x, i.y, o.x, o.y) && Ln(o.prev, o, o.next) >= 0) return !1; o = o.next } return !0 } function bn(A, e, t, i) { var o = A.prev, n = A, r = A.next; if (Ln(o, n, r) >= 0) return !1; for (var a = o.x > n.x ? o.x > r.x ? o.x : r.x : n.x > r.x ? n.x : r.x, s = o.y > n.y ? o.y > r.y ? o.y : r.y : n.y > r.y ? n.y : r.y, l = Rn(n.x > o.x ? r.x > o.x ? o.x : r.x : r.x > n.x ? n.x : r.x, n.y > o.y ? r.y > o.y ? o.y : r.y : r.y > n.y ? n.y : r.y, e, t, i), c = Rn(a, s, e, t, i), h = A.prevZ, d = A.nextZ; h && h.z >= l && d && c >= d.z;) { if (h !== A.prev && h !== A.next && kn(o.x, o.y, n.x, n.y, r.x, r.y, h.x, h.y) && Ln(h.prev, h, h.next) >= 0) return !1; if (h = h.prevZ, d !== A.prev && d !== A.next && kn(o.x, o.y, n.x, n.y, r.x, r.y, d.x, d.y) && Ln(d.prev, d, d.next) >= 0) return !1; d = d.nextZ } for (; h && h.z >= l;) { if (h !== A.prev && h !== A.next && kn(o.x, o.y, n.x, n.y, r.x, r.y, h.x, h.y) && Ln(h.prev, h, h.next) >= 0) return !1; h = h.prevZ } for (; d && c >= d.z;) { if (d !== A.prev && d !== A.next && kn(o.x, o.y, n.x, n.y, r.x, r.y, d.x, d.y) && Ln(d.prev, d, d.next) >= 0) return !1; d = d.nextZ } return !0 } function Un(A, e, t) { var i = A; do { var o = i.prev, n = i.next.next; !Nn(o, n) && On(o, i, i.next, n) && Vn(o, n) && Vn(n, o) && (e.push(o.i / t), e.push(i.i / t), e.push(n.i / t), qn(i), qn(i.next), i = A = n), i = i.next } while (i !== A); return i } function Fn(A, e, t, i, o, n) { var r = A; do { for (var a = r.next.next; a !== r.prev;) { if (r.i !== a.i && Dn(r, a)) { var s = Gn(r, a); return r = Sn(r, r.next), s = Sn(s, s.next), wn(r, e, t, i, o, n), void wn(s, e, t, i, o, n) } a = a.next } r = r.next } while (r !== A) } function Kn(A, e) { return A.x - e.x } function Qn(A, e) { if (e = function (A, e) { var t, i = e, o = A.x, n = A.y, r = -1 / 0; do { if (i.y >= n && n >= i.next.y && i.next.y !== i.y) { var a = i.x + (n - i.y) * (i.next.x - i.x) / (i.next.y - i.y); if (o >= a && a > r) { if (r = a, a === o) { if (n === i.y) return i; if (n === i.next.y) return i.next } t = i.next.x > i.x ? i : i.next } } i = i.next } while (i !== e); if (!t) return null; if (o === r) return t.prev; var s, l = t, c = t.x, h = t.y, d = 1 / 0; i = t.next; for (; i !== l;) i.x > o || c > i.x || o === i.x || !kn(h > n ? o : r, n, c, h, h > n ? r : o, n, i.x, i.y) || (s = Math.abs(n - i.y) / (o - i.x), (d > s || s === d && i.x > t.x) && Vn(i, A) && (t = i, d = s)), i = i.next; return t }(A, e)) { var t = Gn(e, A); Sn(t, t.next) } } function Rn(A, e, t, i, o) { return (A = 1431655765 & ((A = 858993459 & ((A = 252645135 & ((A = 16711935 & ((A = 32767 * (A - t) * o) | A << 8)) | A << 4)) | A << 2)) | A << 1)) | (e = 1431655765 & ((e = 858993459 & ((e = 252645135 & ((e = 16711935 & ((e = 32767 * (e - i) * o) | e << 8)) | e << 4)) | e << 2)) | e << 1)) << 1 } function Tn(A) { var e = A, t = A; do { (t.x > e.x || e.x === t.x && t.y > e.y) && (t = e), e = e.next } while (e !== A); return t } function kn(A, e, t, i, o, n, r, a) { return (o - r) * (e - a) - (A - r) * (n - a) >= 0 && (A - r) * (i - a) - (t - r) * (e - a) >= 0 && (t - r) * (n - a) - (o - r) * (i - a) >= 0 } function Dn(A, e) { return A.next.i !== e.i && A.prev.i !== e.i && ! function (A, e) { var t = A; do { if (t.i !== A.i && t.next.i !== A.i && t.i !== e.i && t.next.i !== e.i && On(t, t.next, A, e)) return !0; t = t.next } while (t !== A); return !1 }(A, e) && Vn(A, e) && Vn(e, A) && function (A, e) { var t = A, i = !1, o = (A.x + e.x) / 2, n = (A.y + e.y) / 2; do { t.y > n != t.next.y > n && t.next.y !== t.y && (t.next.x - t.x) * (n - t.y) / (t.next.y - t.y) + t.x > o && (i = !i), t = t.next } while (t !== A); return i }(A, e) } function Ln(A, e, t) { return (e.y - A.y) * (t.x - e.x) - (e.x - A.x) * (t.y - e.y) } function Nn(A, e) { return A.x === e.x && A.y === e.y } function On(A, e, t, i) { return !!(Nn(A, t) && Nn(e, i) || Nn(A, i) && Nn(t, e)) || Ln(A, e, t) > 0 != Ln(A, e, i) > 0 && Ln(t, i, A) > 0 != Ln(t, i, e) > 0 } function Vn(A, e) { return 0 > Ln(A.prev, A, A.next) ? Ln(A, e, A.next) >= 0 && Ln(A, A.prev, e) >= 0 : 0 > Ln(A, e, A.prev) || 0 > Ln(A, A.next, e) } function Gn(A, e) { var t = new jn(A.i, A.x, A.y), i = new jn(e.i, e.x, e.y), o = A.next, n = e.prev; return A.next = e, e.prev = A, t.next = o, o.prev = t, i.next = t, t.prev = i, n.next = i, i.prev = n, i } function Pn(A, e, t, i) { var o = new jn(A, e, t); return i ? (o.next = i.next, o.prev = i, i.next.prev = o, i.next = o) : (o.prev = o, o.next = o), o } function qn(A) { A.next.prev = A.prev, A.prev.next = A.next, A.prevZ && (A.prevZ.nextZ = A.nextZ), A.nextZ && (A.nextZ.prevZ = A.prevZ) } function jn(A, e, t) { this.i = A, this.x = e, this.y = t, this.prev = null, this.next = null, this.z = null, this.prevZ = null, this.nextZ = null, this.steiner = !1 } var Hn = { area: function (A) { for (var e = A.length, t = 0, i = e - 1, o = 0; e > o; i = o++) t += A[i].x * A[o].y - A[o].x * A[i].y; return .5 * t }, isClockWise: function (A) { return 0 > Hn.area(A) }, triangulateShape: function (A, e) { var t = [], i = [], o = []; Yn(A), Wn(t, A); var n = A.length; e.forEach(Yn); for (var r = 0; e.length > r; r++) i.push(n), n += e[r].length, Wn(t, e[r]); var a = Bn(t, i); for (r = 0; a.length > r; r += 3) o.push(a.slice(r, r + 3)); return o } }; function Yn(A) { var e = A.length; e > 2 && A[e - 1].equals(A[0]) && A.pop() } function Wn(A, e) { for (var t = 0; e.length > t; t++) A.push(e[t].x), A.push(e[t].y) } function Jn(A, e) { De.call(this), this.type = "ExtrudeGeometry", this.parameters = { shapes: A, options: e }, this.fromBufferGeometry(new zn(A, e)), this.mergeVertices() } function zn(A, e) { he.call(this), this.type = "ExtrudeBufferGeometry", this.parameters = { shapes: A, options: e }, A = Array.isArray(A) ? A : [A]; for (var t = this, i = [], o = [], n = 0, r = A.length; r > n; n++) { a(A[n]) } function a(A) { var n = [], r = void 0 !== e.curveSegments ? e.curveSegments : 12, a = void 0 !== e.steps ? e.steps : 1, l = void 0 !== e.depth ? e.depth : 100, c = void 0 === e.bevelEnabled || e.bevelEnabled, h = void 0 !== e.bevelThickness ? e.bevelThickness : 6, d = void 0 !== e.bevelSize ? e.bevelSize : h - 2, p = void 0 !== e.bevelOffset ? e.bevelOffset : 0, g = void 0 !== e.bevelSegments ? e.bevelSegments : 3, u = e.extrudePath, f = void 0 !== e.UVGenerator ? e.UVGenerator : Zn; void 0 !== e.amount && (console.warn("THREE.ExtrudeBufferGeometry: amount has been renamed to depth."), l = e.amount); var m, C, v, I, E, B, x, S, w = !1; u && (m = u.getSpacedPoints(a), w = !0, c = !1, C = u.computeFrenetFrames(a, !1), v = new y, I = new y, E = new y), c || (g = 0, h = 0, d = 0, p = 0); var M = A.extractPoints(r), b = M.shape, U = M.holes; if (!Hn.isClockWise(b)) for (b = b.reverse(), x = 0, S = U.length; S > x; x++) Hn.isClockWise(B = U[x]) && (U[x] = B.reverse()); var F = Hn.triangulateShape(b, U), K = b; for (x = 0, S = U.length; S > x; x++) b = b.concat(B = U[x]); function Q(A, e, t) { return e || console.error("THREE.ExtrudeGeometry: vec does not exist"), e.clone().multiplyScalar(t).add(A) } var R, T, k, D, L, N, O = b.length, V = F.length; function G(A, e, t) { var i, o, n, r = A.x - e.x, a = A.y - e.y, l = t.x - A.x, c = t.y - A.y, h = r * r + a * a; if (Math.abs(r * c - a * l) > Number.EPSILON) { var d = Math.sqrt(h), p = Math.sqrt(l * l + c * c), g = e.x - a / d, u = e.y + r / d, f = ((t.x - c / p - g) * c - (t.y + l / p - u) * l) / (r * c - a * l), m = (i = g + r * f - A.x) * i + (o = u + a * f - A.y) * o; if (2 >= m) return new s(i, o); n = Math.sqrt(m / 2) } else { var C = !1; r > Number.EPSILON ? l > Number.EPSILON && (C = !0) : -Number.EPSILON > r ? -Number.EPSILON > l && (C = !0) : Math.sign(a) === Math.sign(c) && (C = !0), C ? (i = -a, o = r, n = Math.sqrt(h)) : (i = r, o = a, n = Math.sqrt(h / 2)) } return new s(i / n, o / n) } for (var P = [], q = 0, j = K.length, H = j - 1, Y = q + 1; j > q; q++, H++, Y++) H === j && (H = 0), Y === j && (Y = 0), P[q] = G(K[q], K[H], K[Y]); var W, J, z = [], Z = P.concat(); for (x = 0, S = U.length; S > x; x++) { for (W = [], H = (j = (B = U[x]).length) - 1, Y = (q = 0) + 1; j > q; q++, H++, Y++) H === j && (H = 0), Y === j && (Y = 0), W[q] = G(B[q], B[H], B[Y]); z.push(W), Z = Z.concat(W) } for (R = 0; g > R; R++) { for (k = R / g, D = h * Math.cos(k * Math.PI / 2), T = d * Math.sin(k * Math.PI / 2) + p, q = 0, j = K.length; j > q; q++) _((L = Q(K[q], P[q], T)).x, L.y, -D); for (x = 0, S = U.length; S > x; x++) for (W = z[x], q = 0, j = (B = U[x]).length; j > q; q++) _((L = Q(B[q], W[q], T)).x, L.y, -D) } for (T = d + p, q = 0; O > q; q++) L = c ? Q(b[q], Z[q], T) : b[q], w ? (I.copy(C.normals[0]).multiplyScalar(L.x), v.copy(C.binormals[0]).multiplyScalar(L.y), E.copy(m[0]).add(I).add(v), _(E.x, E.y, E.z)) : _(L.x, L.y, 0); for (J = 1; a >= J; J++) for (q = 0; O > q; q++) L = c ? Q(b[q], Z[q], T) : b[q], w ? (I.copy(C.normals[J]).multiplyScalar(L.x), v.copy(C.binormals[J]).multiplyScalar(L.y), E.copy(m[J]).add(I).add(v), _(E.x, E.y, E.z)) : _(L.x, L.y, l / a * J); for (R = g - 1; R >= 0; R--) { for (k = R / g, D = h * Math.cos(k * Math.PI / 2), T = d * Math.sin(k * Math.PI / 2) + p, q = 0, j = K.length; j > q; q++) _((L = Q(K[q], P[q], T)).x, L.y, l + D); for (x = 0, S = U.length; S > x; x++) for (W = z[x], q = 0, j = (B = U[x]).length; j > q; q++) L = Q(B[q], W[q], T), w ? _(L.x, L.y + m[a - 1].y, m[a - 1].x + D) : _(L.x, L.y, l + D) } function X(A, e) { var t, i; for (q = A.length; --q >= 0;) { t = q, 0 > (i = q - 1) && (i = A.length - 1); var o = 0, n = a + 2 * g; for (o = 0; n > o; o++) { var r = O * o, s = O * (o + 1); AA(e + t + r, e + i + r, e + i + s, e + t + s) } } } function _(A, e, t) { n.push(A), n.push(e), n.push(t) } function $(A, e, o) { eA(A), eA(e), eA(o); var n = i.length / 3, r = f.generateTopUV(t, i, n - 3, n - 2, n - 1); tA(r[0]), tA(r[1]), tA(r[2]) } function AA(A, e, o, n) { eA(A), eA(e), eA(n), eA(e), eA(o), eA(n); var r = i.length / 3, a = f.generateSideWallUV(t, i, r - 6, r - 3, r - 2, r - 1); tA(a[0]), tA(a[1]), tA(a[3]), tA(a[1]), tA(a[2]), tA(a[3]) } function eA(A) { i.push(n[3 * A + 0]), i.push(n[3 * A + 1]), i.push(n[3 * A + 2]) } function tA(A) { o.push(A.x), o.push(A.y) }! function () { var A = i.length / 3; if (c) { var e = 0, o = O * e; for (q = 0; V > q; q++) $((N = F[q])[2] + o, N[1] + o, N[0] + o); for (o = O * (e = a + 2 * g), q = 0; V > q; q++) $((N = F[q])[0] + o, N[1] + o, N[2] + o) } else { for (q = 0; V > q; q++) $((N = F[q])[2], N[1], N[0]); for (q = 0; V > q; q++) $((N = F[q])[0] + O * a, N[1] + O * a, N[2] + O * a) } t.addGroup(A, i.length / 3 - A, 0) }(), function () { var A = i.length / 3, e = 0; for (X(K, e), e += K.length, x = 0, S = U.length; S > x; x++) X(B = U[x], e), e += B.length; t.addGroup(A, i.length / 3 - A, 1) }() } this.setAttribute("position", new Ae(i, 3)), this.setAttribute("uv", new Ae(o, 2)), this.computeVertexNormals() } (Jn.prototype = Object.create(De.prototype)).constructor = Jn, Jn.prototype.toJSON = function () { var A = De.prototype.toJSON.call(this); return Xn(this.parameters.shapes, this.parameters.options, A) }, (zn.prototype = Object.create(he.prototype)).constructor = zn, zn.prototype.toJSON = function () { var A = he.prototype.toJSON.call(this); return Xn(this.parameters.shapes, this.parameters.options, A) }; var Zn = { generateTopUV: function (A, e, t, i, o) { var n = e[3 * i], r = e[3 * i + 1], a = e[3 * o], l = e[3 * o + 1]; return [new s(e[3 * t], e[3 * t + 1]), new s(n, r), new s(a, l)] }, generateSideWallUV: function (A, e, t, i, o, n) { var r = e[3 * t], a = e[3 * t + 1], l = e[3 * t + 2], c = e[3 * i], h = e[3 * i + 1], d = e[3 * i + 2], p = e[3 * o], g = e[3 * o + 1], u = e[3 * o + 2], f = e[3 * n], m = e[3 * n + 1], C = e[3 * n + 2]; return .01 > Math.abs(a - h) ? [new s(r, 1 - l), new s(c, 1 - d), new s(p, 1 - u), new s(f, 1 - C)] : [new s(a, 1 - l), new s(h, 1 - d), new s(g, 1 - u), new s(m, 1 - C)] } }; function Xn(A, e, t) { if (t.shapes = [], Array.isArray(A)) for (var i = 0, o = A.length; o > i; i++) { t.shapes.push(A[i].uuid) } else t.shapes.push(A.uuid); return void 0 !== e.extrudePath && (t.options.extrudePath = e.extrudePath.toJSON()), t } function _n(A, e) { De.call(this), this.type = "TextGeometry", this.parameters = { text: A, parameters: e }, this.fromBufferGeometry(new $n(A, e)), this.mergeVertices() } function $n(A, e) { var t = (e = e || {}).font; if (!t || !t.isFont) return console.error("THREE.TextGeometry: font parameter is not an instance of THREE.Font."), new De; var i = t.generateShapes(A, e.size); e.depth = void 0 !== e.height ? e.height : 50, void 0 === e.bevelThickness && (e.bevelThickness = 10), void 0 === e.bevelSize && (e.bevelSize = 8), void 0 === e.bevelEnabled && (e.bevelEnabled = !1), zn.call(this, i, e), this.type = "TextBufferGeometry" } function Ar(A, e, t, i, o, n, r) { De.call(this), this.type = "SphereGeometry", this.parameters = { radius: A, widthSegments: e, heightSegments: t, phiStart: i, phiLength: o, thetaStart: n, thetaLength: r }, this.fromBufferGeometry(new er(A, e, t, i, o, n, r)), this.mergeVertices() } function er(A, e, t, i, o, n, r) { he.call(this), this.type = "SphereBufferGeometry", this.parameters = { radius: A, widthSegments: e, heightSegments: t, phiStart: i, phiLength: o, thetaStart: n, thetaLength: r }, A = A || 1, e = Math.max(3, Math.floor(e) || 8), t = Math.max(2, Math.floor(t) || 6), i = void 0 !== i ? i : 0, o = void 0 !== o ? o : 2 * Math.PI, n = void 0 !== n ? n : 0, r = void 0 !== r ? r : Math.PI; var a, s, l = Math.min(n + r, Math.PI), c = 0, h = [], d = new y, p = new y, g = [], u = [], f = [], m = []; for (s = 0; t >= s; s++) { var C = [], v = s / t, I = 0; for (0 == s && 0 == n ? I = .5 / e : s == t && l == Math.PI && (I = -.5 / e), a = 0; e >= a; a++) { var E = a / e; d.x = -A * Math.cos(i + E * o) * Math.sin(n + v * r), d.y = A * Math.cos(n + v * r), d.z = A * Math.sin(i + E * o) * Math.sin(n + v * r), u.push(d.x, d.y, d.z), p.copy(d).normalize(), f.push(p.x, p.y, p.z), m.push(E + I, 1 - v), C.push(c++) } h.push(C) } for (s = 0; t > s; s++) for (a = 0; e > a; a++) { var B = h[s][a], x = h[s + 1][a], S = h[s + 1][a + 1]; (0 !== s || n > 0) && g.push(h[s][a + 1], B, S), (s !== t - 1 || l < Math.PI) && g.push(B, x, S) } this.setIndex(g), this.setAttribute("position", new Ae(u, 3)), this.setAttribute("normal", new Ae(f, 3)), this.setAttribute("uv", new Ae(m, 2)) } function tr(A, e, t, i, o, n) { De.call(this), this.type = "RingGeometry", this.parameters = { innerRadius: A, outerRadius: e, thetaSegments: t, phiSegments: i, thetaStart: o, thetaLength: n }, this.fromBufferGeometry(new ir(A, e, t, i, o, n)), this.mergeVertices() } function ir(A, e, t, i, o, n) { he.call(this), this.type = "RingBufferGeometry", this.parameters = { innerRadius: A, outerRadius: e, thetaSegments: t, phiSegments: i, thetaStart: o, thetaLength: n }, A = A || .5, e = e || 1, o = void 0 !== o ? o : 0, n = void 0 !== n ? n : 2 * Math.PI, t = void 0 !== t ? Math.max(3, t) : 8; var r, a, l, c = [], h = [], d = [], p = [], g = A, u = (e - A) / (i = void 0 !== i ? Math.max(1, i) : 1), f = new y, m = new s; for (a = 0; i >= a; a++) { for (l = 0; t >= l; l++) r = o + l / t * n, f.x = g * Math.cos(r), f.y = g * Math.sin(r), h.push(f.x, f.y, f.z), d.push(0, 0, 1), m.x = (f.x / e + 1) / 2, m.y = (f.y / e + 1) / 2, p.push(m.x, m.y); g += u } for (a = 0; i > a; a++) { var C = a * (t + 1); for (l = 0; t > l; l++) { var v = (r = l + C) + t + 1, I = r + t + 2, E = r + 1; c.push(r, v, E), c.push(v, I, E) } } this.setIndex(c), this.setAttribute("position", new Ae(h, 3)), this.setAttribute("normal", new Ae(d, 3)), this.setAttribute("uv", new Ae(p, 2)) } function or(A, e, t, i) { De.call(this), this.type = "LatheGeometry", this.parameters = { points: A, segments: e, phiStart: t, phiLength: i }, this.fromBufferGeometry(new nr(A, e, t, i)), this.mergeVertices() } function nr(A, e, t, i) { he.call(this), this.type = "LatheBufferGeometry", this.parameters = { points: A, segments: e, phiStart: t, phiLength: i }, e = Math.floor(e) || 12, t = t || 0, i = i || 2 * Math.PI, i = a.clamp(i, 0, 2 * Math.PI); var o, n, r, l = [], c = [], h = [], d = 1 / e, p = new y, g = new s; for (n = 0; e >= n; n++) { var u = t + n * d * i, f = Math.sin(u), m = Math.cos(u); for (r = 0; A.length - 1 >= r; r++) p.x = A[r].x * f, p.y = A[r].y, p.z = A[r].x * m, c.push(p.x, p.y, p.z), g.x = n / e, g.y = r / (A.length - 1), h.push(g.x, g.y) } for (n = 0; e > n; n++) for (r = 0; A.length - 1 > r; r++) { var C = (o = r + n * A.length) + A.length, v = o + A.length + 1, I = o + 1; l.push(o, C, I), l.push(C, v, I) } if (this.setIndex(l), this.setAttribute("position", new Ae(c, 3)), this.setAttribute("uv", new Ae(h, 2)), this.computeVertexNormals(), i === 2 * Math.PI) { var E = this.attributes.normal.array, B = new y, x = new y, S = new y; for (o = e * A.length * 3, n = 0, r = 0; A.length > n; n++, r += 3) B.x = E[r + 0], B.y = E[r + 1], B.z = E[r + 2], x.x = E[o + r + 0], x.y = E[o + r + 1], x.z = E[o + r + 2], S.addVectors(B, x).normalize(), E[r + 0] = E[o + r + 0] = S.x, E[r + 1] = E[o + r + 1] = S.y, E[r + 2] = E[o + r + 2] = S.z } } function rr(A, e) { De.call(this), this.type = "ShapeGeometry", "object" == typeof e && (console.warn("THREE.ShapeGeometry: Options parameter has been removed."), e = e.curveSegments), this.parameters = { shapes: A, curveSegments: e }, this.fromBufferGeometry(new ar(A, e)), this.mergeVertices() } function ar(A, e) { he.call(this), this.type = "ShapeBufferGeometry", this.parameters = { shapes: A, curveSegments: e }, e = e || 12; var t = [], i = [], o = [], n = [], r = 0, a = 0; if (!1 === Array.isArray(A)) l(A); else for (var s = 0; A.length > s; s++) l(A[s]), this.addGroup(r, a, s), r += a, a = 0; function l(A) { var r, s, l, c = i.length / 3, h = A.extractPoints(e), d = h.shape, p = h.holes; for (!1 === Hn.isClockWise(d) && (d = d.reverse()), r = 0, s = p.length; s > r; r++) !0 === Hn.isClockWise(l = p[r]) && (p[r] = l.reverse()); var g = Hn.triangulateShape(d, p); for (r = 0, s = p.length; s > r; r++) d = d.concat(l = p[r]); for (r = 0, s = d.length; s > r; r++) { var u = d[r]; i.push(u.x, u.y, 0), o.push(0, 0, 1), n.push(u.x, u.y) } for (r = 0, s = g.length; s > r; r++) { var f = g[r]; t.push(f[0] + c, f[1] + c, f[2] + c), a += 3 } } this.setIndex(t), this.setAttribute("position", new Ae(i, 3)), this.setAttribute("normal", new Ae(o, 3)), this.setAttribute("uv", new Ae(n, 2)) } function sr(A, e) { if (e.shapes = [], Array.isArray(A)) for (var t = 0, i = A.length; i > t; t++) { e.shapes.push(A[t].uuid) } else e.shapes.push(A.uuid); return e } function lr(A, e) { he.call(this), this.type = "EdgesGeometry", this.parameters = { thresholdAngle: e }, e = void 0 !== e ? e : 1; var t, i, o, n, r = [], s = Math.cos(a.DEG2RAD * e), l = [0, 0], c = {}, h = ["a", "b", "c"]; A.isBufferGeometry ? (n = new De).fromBufferGeometry(A) : n = A.clone(), n.mergeVertices(), n.computeFaceNormals(); for (var d = n.vertices, p = n.faces, g = 0, u = p.length; u > g; g++) for (var f = p[g], m = 0; 3 > m; m++) t = f[h[m]], i = f[h[(m + 1) % 3]], l[0] = Math.min(t, i), l[1] = Math.max(t, i), void 0 === c[o = l[0] + "," + l[1]] ? c[o] = { index1: l[0], index2: l[1], face1: g, face2: void 0 } : c[o].face2 = g; for (o in c) { var C = c[o]; if (void 0 === C.face2 || p[C.face1].normal.dot(p[C.face2].normal) <= s) { var y = d[C.index1]; r.push(y.x, y.y, y.z), r.push((y = d[C.index2]).x, y.y, y.z) } } this.setAttribute("position", new Ae(r, 3)) } function cr(A, e, t, i, o, n, r, a) { De.call(this), this.type = "CylinderGeometry", this.parameters = { radiusTop: A, radiusBottom: e, height: t, radialSegments: i, heightSegments: o, openEnded: n, thetaStart: r, thetaLength: a }, this.fromBufferGeometry(new hr(A, e, t, i, o, n, r, a)), this.mergeVertices() } function hr(A, e, t, i, o, n, r, a) { he.call(this), this.type = "CylinderBufferGeometry", this.parameters = { radiusTop: A, radiusBottom: e, height: t, radialSegments: i, heightSegments: o, openEnded: n, thetaStart: r, thetaLength: a }; var l = this; A = void 0 !== A ? A : 1, e = void 0 !== e ? e : 1, t = t || 1, i = Math.floor(i) || 8, o = Math.floor(o) || 1, n = void 0 !== n && n, r = void 0 !== r ? r : 0, a = void 0 !== a ? a : 2 * Math.PI; var c = [], h = [], d = [], p = [], g = 0, u = [], f = t / 2, m = 0; function C(t) { var o, n, u, C = new s, v = new y, I = 0, E = !0 === t ? A : e, B = !0 === t ? 1 : -1; for (n = g, o = 1; i >= o; o++) h.push(0, f * B, 0), d.push(0, B, 0), p.push(.5, .5), g++; for (u = g, o = 0; i >= o; o++) { var x = o / i * a + r, S = Math.cos(x), w = Math.sin(x); v.x = E * w, v.y = f * B, v.z = E * S, h.push(v.x, v.y, v.z), d.push(0, B, 0), C.x = .5 * S + .5, C.y = .5 * w * B + .5, p.push(C.x, C.y), g++ } for (o = 0; i > o; o++) { var M = n + o, b = u + o; !0 === t ? c.push(b, b + 1, M) : c.push(b + 1, b, M), I += 3 } l.addGroup(m, I, !0 === t ? 1 : 2), m += I }! function () { var n, s, C = new y, v = new y, I = 0, E = (e - A) / t; for (s = 0; o >= s; s++) { var B = [], x = s / o, S = x * (e - A) + A; for (n = 0; i >= n; n++) { var w = n / i, M = w * a + r, b = Math.sin(M), U = Math.cos(M); v.x = S * b, v.y = -x * t + f, v.z = S * U, h.push(v.x, v.y, v.z), C.set(b, E, U).normalize(), d.push(C.x, C.y, C.z), p.push(w, 1 - x), B.push(g++) } u.push(B) } for (n = 0; i > n; n++) for (s = 0; o > s; s++) { var F = u[s + 1][n], K = u[s + 1][n + 1], Q = u[s][n + 1]; c.push(u[s][n], F, Q), c.push(F, K, Q), I += 6 } l.addGroup(m, I, 0), m += I }(), !1 === n && (A > 0 && C(!0), e > 0 && C(!1)), this.setIndex(c), this.setAttribute("position", new Ae(h, 3)), this.setAttribute("normal", new Ae(d, 3)), this.setAttribute("uv", new Ae(p, 2)) } function dr(A, e, t, i, o, n, r) { cr.call(this, 0, A, e, t, i, o, n, r), this.type = "ConeGeometry", this.parameters = { radius: A, height: e, radialSegments: t, heightSegments: i, openEnded: o, thetaStart: n, thetaLength: r } } function pr(A, e, t, i, o, n, r) { hr.call(this, 0, A, e, t, i, o, n, r), this.type = "ConeBufferGeometry", this.parameters = { radius: A, height: e, radialSegments: t, heightSegments: i, openEnded: o, thetaStart: n, thetaLength: r } } function gr(A, e, t, i) { De.call(this), this.type = "CircleGeometry", this.parameters = { radius: A, segments: e, thetaStart: t, thetaLength: i }, this.fromBufferGeometry(new ur(A, e, t, i)), this.mergeVertices() } function ur(A, e, t, i) { he.call(this), this.type = "CircleBufferGeometry", this.parameters = { radius: A, segments: e, thetaStart: t, thetaLength: i }, A = A || 1, e = void 0 !== e ? Math.max(3, e) : 8, t = void 0 !== t ? t : 0, i = void 0 !== i ? i : 2 * Math.PI; var o, n, r = [], a = [], l = [], c = [], h = new y, d = new s; for (a.push(0, 0, 0), l.push(0, 0, 1), c.push(.5, .5), n = 0, o = 3; e >= n; n++, o += 3) { var p = t + n / e * i; h.x = A * Math.cos(p), h.y = A * Math.sin(p), a.push(h.x, h.y, h.z), l.push(0, 0, 1), d.x = (a[o] / A + 1) / 2, d.y = (a[o + 1] / A + 1) / 2, c.push(d.x, d.y) } for (o = 1; e >= o; o++) r.push(o, o + 1, 0); this.setIndex(r), this.setAttribute("position", new Ae(a, 3)), this.setAttribute("normal", new Ae(l, 3)), this.setAttribute("uv", new Ae(c, 2)) } (_n.prototype = Object.create(De.prototype)).constructor = _n, ($n.prototype = Object.create(zn.prototype)).constructor = $n, (Ar.prototype = Object.create(De.prototype)).constructor = Ar, (er.prototype = Object.create(he.prototype)).constructor = er, (tr.prototype = Object.create(De.prototype)).constructor = tr, (ir.prototype = Object.create(he.prototype)).constructor = ir, (or.prototype = Object.create(De.prototype)).constructor = or, (nr.prototype = Object.create(he.prototype)).constructor = nr, (rr.prototype = Object.create(De.prototype)).constructor = rr, rr.prototype.toJSON = function () { var A = De.prototype.toJSON.call(this); return sr(this.parameters.shapes, A) }, (ar.prototype = Object.create(he.prototype)).constructor = ar, ar.prototype.toJSON = function () { var A = he.prototype.toJSON.call(this); return sr(this.parameters.shapes, A) }, (lr.prototype = Object.create(he.prototype)).constructor = lr, (cr.prototype = Object.create(De.prototype)).constructor = cr, (hr.prototype = Object.create(he.prototype)).constructor = hr, (dr.prototype = Object.create(cr.prototype)).constructor = dr, (pr.prototype = Object.create(hr.prototype)).constructor = pr, (gr.prototype = Object.create(De.prototype)).constructor = gr, (ur.prototype = Object.create(he.prototype)).constructor = ur; var fr = Object.freeze({ __proto__: null, WireframeGeometry: on, ParametricGeometry: nn, ParametricBufferGeometry: rn, TetrahedronGeometry: ln, TetrahedronBufferGeometry: cn, OctahedronGeometry: hn, OctahedronBufferGeometry: dn, IcosahedronGeometry: pn, IcosahedronBufferGeometry: gn, DodecahedronGeometry: un, DodecahedronBufferGeometry: fn, PolyhedronGeometry: an, PolyhedronBufferGeometry: sn, TubeGeometry: mn, TubeBufferGeometry: Cn, TorusKnotGeometry: yn, TorusKnotBufferGeometry: vn, TorusGeometry: In, TorusBufferGeometry: En, TextGeometry: _n, TextBufferGeometry: $n, SphereGeometry: Ar, SphereBufferGeometry: er, RingGeometry: tr, RingBufferGeometry: ir, PlaneGeometry: At, PlaneBufferGeometry: et, LatheGeometry: or, LatheBufferGeometry: nr, ShapeGeometry: rr, ShapeBufferGeometry: ar, ExtrudeGeometry: Jn, ExtrudeBufferGeometry: zn, EdgesGeometry: lr, ConeGeometry: dr, ConeBufferGeometry: pr, CylinderGeometry: cr, CylinderBufferGeometry: hr, CircleGeometry: gr, CircleBufferGeometry: ur, BoxGeometry: Le, BoxBufferGeometry: Ne }); function mr(A) { qA.call(this), this.type = "ShadowMaterial", this.color = new LA(0), this.transparent = !0, this.setValues(A) } function Cr(A) { Pe.call(this, A), this.type = "RawShaderMaterial" } function yr(A) { qA.call(this), this.defines = { STANDARD: "" }, this.type = "MeshStandardMaterial", this.color = new LA(16777215), this.roughness = 1, this.metalness = 0, this.map = null, this.lightMap = null, this.lightMapIntensity = 1, this.aoMap = null, this.aoMapIntensity = 1, this.emissive = new LA(0), this.emissiveIntensity = 1, this.emissiveMap = null, this.bumpMap = null, this.bumpScale = 1, this.normalMap = null, this.normalMapType = 0, this.normalScale = new s(1, 1), this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.roughnessMap = null, this.metalnessMap = null, this.alphaMap = null, this.envMap = null, this.envMapIntensity = 1, this.refractionRatio = .98, this.wireframe = !1, this.wireframeLinewidth = 1, this.wireframeLinecap = "round", this.wireframeLinejoin = "round", this.skinning = !1, this.morphTargets = !1, this.morphNormals = !1, this.vertexTangents = !1, this.setValues(A) } function vr(A) { yr.call(this), this.defines = { STANDARD: "", PHYSICAL: "" }, this.type = "MeshPhysicalMaterial", this.clearcoat = 0, this.clearcoatMap = null, this.clearcoatRoughness = 0, this.clearcoatRoughnessMap = null, this.clearcoatNormalScale = new s(1, 1), this.clearcoatNormalMap = null, this.reflectivity = .5, this.sheen = null, this.transparency = 0, this.setValues(A) } function Ir(A) { qA.call(this), this.type = "MeshPhongMaterial", this.color = new LA(16777215), this.specular = new LA(1118481), this.shininess = 30, this.map = null, this.lightMap = null, this.lightMapIntensity = 1, this.aoMap = null, this.aoMapIntensity = 1, this.emissive = new LA(0), this.emissiveIntensity = 1, this.emissiveMap = null, this.bumpMap = null, this.bumpScale = 1, this.normalMap = null, this.normalMapType = 0, this.normalScale = new s(1, 1), this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.specularMap = null, this.alphaMap = null, this.envMap = null, this.combine = 0, this.reflectivity = 1, this.refractionRatio = .98, this.wireframe = !1, this.wireframeLinewidth = 1, this.wireframeLinecap = "round", this.wireframeLinejoin = "round", this.skinning = !1, this.morphTargets = !1, this.morphNormals = !1, this.setValues(A) } function Er(A) { qA.call(this), this.defines = { TOON: "" }, this.type = "MeshToonMaterial", this.color = new LA(16777215), this.specular = new LA(1118481), this.shininess = 30, this.map = null, this.gradientMap = null, this.lightMap = null, this.lightMapIntensity = 1, this.aoMap = null, this.aoMapIntensity = 1, this.emissive = new LA(0), this.emissiveIntensity = 1, this.emissiveMap = null, this.bumpMap = null, this.bumpScale = 1, this.normalMap = null, this.normalMapType = 0, this.normalScale = new s(1, 1), this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.specularMap = null, this.alphaMap = null, this.wireframe = !1, this.wireframeLinewidth = 1, this.wireframeLinecap = "round", this.wireframeLinejoin = "round", this.skinning = !1, this.morphTargets = !1, this.morphNormals = !1, this.setValues(A) } function Br(A) { qA.call(this), this.type = "MeshNormalMaterial", this.bumpMap = null, this.bumpScale = 1, this.normalMap = null, this.normalMapType = 0, this.normalScale = new s(1, 1), this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.wireframe = !1, this.wireframeLinewidth = 1, this.fog = !1, this.skinning = !1, this.morphTargets = !1, this.morphNormals = !1, this.setValues(A) } function xr(A) { qA.call(this), this.type = "MeshLambertMaterial", this.color = new LA(16777215), this.map = null, this.lightMap = null, this.lightMapIntensity = 1, this.aoMap = null, this.aoMapIntensity = 1, this.emissive = new LA(0), this.emissiveIntensity = 1, this.emissiveMap = null, this.specularMap = null, this.alphaMap = null, this.envMap = null, this.combine = 0, this.reflectivity = 1, this.refractionRatio = .98, this.wireframe = !1, this.wireframeLinewidth = 1, this.wireframeLinecap = "round", this.wireframeLinejoin = "round", this.skinning = !1, this.morphTargets = !1, this.morphNormals = !1, this.setValues(A) } function Sr(A) { qA.call(this), this.defines = { MATCAP: "" }, this.type = "MeshMatcapMaterial", this.color = new LA(16777215), this.matcap = null, this.map = null, this.bumpMap = null, this.bumpScale = 1, this.normalMap = null, this.normalMapType = 0, this.normalScale = new s(1, 1), this.displacementMap = null, this.displacementScale = 1, this.displacementBias = 0, this.alphaMap = null, this.skinning = !1, this.morphTargets = !1, this.morphNormals = !1, this.setValues(A) } function wr(A) { ko.call(this), this.type = "LineDashedMaterial", this.scale = 1, this.dashSize = 3, this.gapSize = 1, this.setValues(A) } (mr.prototype = Object.create(qA.prototype)).constructor = mr, mr.prototype.isShadowMaterial = !0, mr.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.color.copy(A.color), this }, (Cr.prototype = Object.create(Pe.prototype)).constructor = Cr, Cr.prototype.isRawShaderMaterial = !0, (yr.prototype = Object.create(qA.prototype)).constructor = yr, yr.prototype.isMeshStandardMaterial = !0, yr.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.defines = { STANDARD: "" }, this.color.copy(A.color), this.roughness = A.roughness, this.metalness = A.metalness, this.map = A.map, this.lightMap = A.lightMap, this.lightMapIntensity = A.lightMapIntensity, this.aoMap = A.aoMap, this.aoMapIntensity = A.aoMapIntensity, this.emissive.copy(A.emissive), this.emissiveMap = A.emissiveMap, this.emissiveIntensity = A.emissiveIntensity, this.bumpMap = A.bumpMap, this.bumpScale = A.bumpScale, this.normalMap = A.normalMap, this.normalMapType = A.normalMapType, this.normalScale.copy(A.normalScale), this.displacementMap = A.displacementMap, this.displacementScale = A.displacementScale, this.displacementBias = A.displacementBias, this.roughnessMap = A.roughnessMap, this.metalnessMap = A.metalnessMap, this.alphaMap = A.alphaMap, this.envMap = A.envMap, this.envMapIntensity = A.envMapIntensity, this.refractionRatio = A.refractionRatio, this.wireframe = A.wireframe, this.wireframeLinewidth = A.wireframeLinewidth, this.wireframeLinecap = A.wireframeLinecap, this.wireframeLinejoin = A.wireframeLinejoin, this.skinning = A.skinning, this.morphTargets = A.morphTargets, this.morphNormals = A.morphNormals, this.vertexTangents = A.vertexTangents, this }, (vr.prototype = Object.create(yr.prototype)).constructor = vr, vr.prototype.isMeshPhysicalMaterial = !0, vr.prototype.copy = function (A) { return yr.prototype.copy.call(this, A), this.defines = { STANDARD: "", PHYSICAL: "" }, this.clearcoat = A.clearcoat, this.clearcoatMap = A.clearcoatMap, this.clearcoatRoughness = A.clearcoatRoughness, this.clearcoatRoughnessMap = A.clearcoatRoughnessMap, this.clearcoatNormalMap = A.clearcoatNormalMap, this.clearcoatNormalScale.copy(A.clearcoatNormalScale), this.reflectivity = A.reflectivity, this.sheen = A.sheen ? (this.sheen || new LA).copy(A.sheen) : null, this.transparency = A.transparency, this }, (Ir.prototype = Object.create(qA.prototype)).constructor = Ir, Ir.prototype.isMeshPhongMaterial = !0, Ir.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.color.copy(A.color), this.specular.copy(A.specular), this.shininess = A.shininess, this.map = A.map, this.lightMap = A.lightMap, this.lightMapIntensity = A.lightMapIntensity, this.aoMap = A.aoMap, this.aoMapIntensity = A.aoMapIntensity, this.emissive.copy(A.emissive), this.emissiveMap = A.emissiveMap, this.emissiveIntensity = A.emissiveIntensity, this.bumpMap = A.bumpMap, this.bumpScale = A.bumpScale, this.normalMap = A.normalMap, this.normalMapType = A.normalMapType, this.normalScale.copy(A.normalScale), this.displacementMap = A.displacementMap, this.displacementScale = A.displacementScale, this.displacementBias = A.displacementBias, this.specularMap = A.specularMap, this.alphaMap = A.alphaMap, this.envMap = A.envMap, this.combine = A.combine, this.reflectivity = A.reflectivity, this.refractionRatio = A.refractionRatio, this.wireframe = A.wireframe, this.wireframeLinewidth = A.wireframeLinewidth, this.wireframeLinecap = A.wireframeLinecap, this.wireframeLinejoin = A.wireframeLinejoin, this.skinning = A.skinning, this.morphTargets = A.morphTargets, this.morphNormals = A.morphNormals, this }, (Er.prototype = Object.create(qA.prototype)).constructor = Er, Er.prototype.isMeshToonMaterial = !0, Er.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.color.copy(A.color), this.specular.copy(A.specular), this.shininess = A.shininess, this.map = A.map, this.gradientMap = A.gradientMap, this.lightMap = A.lightMap, this.lightMapIntensity = A.lightMapIntensity, this.aoMap = A.aoMap, this.aoMapIntensity = A.aoMapIntensity, this.emissive.copy(A.emissive), this.emissiveMap = A.emissiveMap, this.emissiveIntensity = A.emissiveIntensity, this.bumpMap = A.bumpMap, this.bumpScale = A.bumpScale, this.normalMap = A.normalMap, this.normalMapType = A.normalMapType, this.normalScale.copy(A.normalScale), this.displacementMap = A.displacementMap, this.displacementScale = A.displacementScale, this.displacementBias = A.displacementBias, this.specularMap = A.specularMap, this.alphaMap = A.alphaMap, this.wireframe = A.wireframe, this.wireframeLinewidth = A.wireframeLinewidth, this.wireframeLinecap = A.wireframeLinecap, this.wireframeLinejoin = A.wireframeLinejoin, this.skinning = A.skinning, this.morphTargets = A.morphTargets, this.morphNormals = A.morphNormals, this }, (Br.prototype = Object.create(qA.prototype)).constructor = Br, Br.prototype.isMeshNormalMaterial = !0, Br.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.bumpMap = A.bumpMap, this.bumpScale = A.bumpScale, this.normalMap = A.normalMap, this.normalMapType = A.normalMapType, this.normalScale.copy(A.normalScale), this.displacementMap = A.displacementMap, this.displacementScale = A.displacementScale, this.displacementBias = A.displacementBias, this.wireframe = A.wireframe, this.wireframeLinewidth = A.wireframeLinewidth, this.skinning = A.skinning, this.morphTargets = A.morphTargets, this.morphNormals = A.morphNormals, this }, (xr.prototype = Object.create(qA.prototype)).constructor = xr, xr.prototype.isMeshLambertMaterial = !0, xr.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.color.copy(A.color), this.map = A.map, this.lightMap = A.lightMap, this.lightMapIntensity = A.lightMapIntensity, this.aoMap = A.aoMap, this.aoMapIntensity = A.aoMapIntensity, this.emissive.copy(A.emissive), this.emissiveMap = A.emissiveMap, this.emissiveIntensity = A.emissiveIntensity, this.specularMap = A.specularMap, this.alphaMap = A.alphaMap, this.envMap = A.envMap, this.combine = A.combine, this.reflectivity = A.reflectivity, this.refractionRatio = A.refractionRatio, this.wireframe = A.wireframe, this.wireframeLinewidth = A.wireframeLinewidth, this.wireframeLinecap = A.wireframeLinecap, this.wireframeLinejoin = A.wireframeLinejoin, this.skinning = A.skinning, this.morphTargets = A.morphTargets, this.morphNormals = A.morphNormals, this }, (Sr.prototype = Object.create(qA.prototype)).constructor = Sr, Sr.prototype.isMeshMatcapMaterial = !0, Sr.prototype.copy = function (A) { return qA.prototype.copy.call(this, A), this.defines = { MATCAP: "" }, this.color.copy(A.color), this.matcap = A.matcap, this.map = A.map, this.bumpMap = A.bumpMap, this.bumpScale = A.bumpScale, this.normalMap = A.normalMap, this.normalMapType = A.normalMapType, this.normalScale.copy(A.normalScale), this.displacementMap = A.displacementMap, this.displacementScale = A.displacementScale, this.displacementBias = A.displacementBias, this.alphaMap = A.alphaMap, this.skinning = A.skinning, this.morphTargets = A.morphTargets, this.morphNormals = A.morphNormals, this }, (wr.prototype = Object.create(ko.prototype)).constructor = wr, wr.prototype.isLineDashedMaterial = !0, wr.prototype.copy = function (A) { return ko.prototype.copy.call(this, A), this.scale = A.scale, this.dashSize = A.dashSize, this.gapSize = A.gapSize, this }; var Mr = Object.freeze({ __proto__: null, ShadowMaterial: mr, SpriteMaterial: ro, RawShaderMaterial: Cr, ShaderMaterial: Pe, PointsMaterial: Yo, MeshPhysicalMaterial: vr, MeshStandardMaterial: yr, MeshPhongMaterial: Ir, MeshToonMaterial: Er, MeshNormalMaterial: Br, MeshLambertMaterial: xr, MeshDepthMaterial: ji, MeshDistanceMaterial: Hi, MeshBasicMaterial: jA, MeshMatcapMaterial: Sr, LineDashedMaterial: wr, LineBasicMaterial: ko, Material: qA }), br = { arraySlice: function (A, e, t) { return br.isTypedArray(A) ? new A.constructor(A.subarray(e, void 0 !== t ? t : A.length)) : A.slice(e, t) }, convertArray: function (A, e, t) { return !A || !t && A.constructor === e ? A : "number" == typeof e.BYTES_PER_ELEMENT ? new e(A) : Array.prototype.slice.call(A) }, isTypedArray: function (A) { return ArrayBuffer.isView(A) && !(A instanceof DataView) }, getKeyframeOrder: function (A) { for (var e = A.length, t = new Array(e), i = 0; i !== e; ++i) t[i] = i; return t.sort((function (e, t) { return A[e] - A[t] })), t }, sortedArray: function (A, e, t) { for (var i = A.length, o = new A.constructor(i), n = 0, r = 0; r !== i; ++n) for (var a = t[n] * e, s = 0; s !== e; ++s) o[r++] = A[a + s]; return o }, flattenJSON: function (A, e, t, i) { for (var o = 1, n = A[0]; void 0 !== n && void 0 === n[i];) n = A[o++]; if (void 0 !== n) { var r = n[i]; if (void 0 !== r) if (Array.isArray(r)) do { void 0 !== (r = n[i]) && (e.push(n.time), t.push.apply(t, r)), n = A[o++] } while (void 0 !== n); else if (void 0 !== r.toArray) do { void 0 !== (r = n[i]) && (e.push(n.time), r.toArray(t, t.length)), n = A[o++] } while (void 0 !== n); else do { void 0 !== (r = n[i]) && (e.push(n.time), t.push(r)), n = A[o++] } while (void 0 !== n) } }, subclip: function (A, e, t, i, o) { o = o || 30; var n = A.clone(); n.name = e; for (var r = [], a = 0; n.tracks.length > a; ++a) { for (var s = n.tracks[a], l = s.getValueSize(), c = [], h = [], d = 0; s.times.length > d; ++d) { var p = s.times[d] * o; if (p >= t && i > p) { c.push(s.times[d]); for (var g = 0; l > g; ++g) h.push(s.values[d * l + g]) } } 0 !== c.length && (s.times = br.convertArray(c, s.times.constructor), s.values = br.convertArray(h, s.values.constructor), r.push(s)) } n.tracks = r; var u = 1 / 0; for (a = 0; n.tracks.length > a; ++a) u > n.tracks[a].times[0] && (u = n.tracks[a].times[0]); for (a = 0; n.tracks.length > a; ++a) n.tracks[a].shift(-1 * u); return n.resetDuration(), n } }; function Ur(A, e, t, i) { this.parameterPositions = A, this._cachedIndex = 0, this.resultBuffer = void 0 !== i ? i : new e.constructor(t), this.sampleValues = e, this.valueSize = t } function Fr(A, e, t, i) { Ur.call(this, A, e, t, i), this._weightPrev = -0, this._offsetPrev = -0, this._weightNext = -0, this._offsetNext = -0 } function Kr(A, e, t, i) { Ur.call(this, A, e, t, i) } function Qr(A, e, t, i) { Ur.call(this, A, e, t, i) } function Rr(A, e, t, i) { if (void 0 === A) throw new Error("THREE.KeyframeTrack: track name is undefined"); if (void 0 === e || 0 === e.length) throw new Error("THREE.KeyframeTrack: no keyframes in track named " + A); this.name = A, this.times = br.convertArray(e, this.TimeBufferType), this.values = br.convertArray(t, this.ValueBufferType), this.setInterpolation(i || this.DefaultInterpolation) } function Tr(A, e, t) { Rr.call(this, A, e, t) } function kr(A, e, t, i) { Rr.call(this, A, e, t, i) } function Dr(A, e, t, i) { Rr.call(this, A, e, t, i) } function Lr(A, e, t, i) { Ur.call(this, A, e, t, i) } function Nr(A, e, t, i) { Rr.call(this, A, e, t, i) } function Or(A, e, t, i) { Rr.call(this, A, e, t, i) } function Vr(A, e, t, i) { Rr.call(this, A, e, t, i) } function Gr(A, e, t) { this.name = A, this.tracks = t, this.duration = void 0 !== e ? e : -1, this.uuid = a.generateUUID(), 0 > this.duration && this.resetDuration() } function Pr(A) { if (void 0 === A.type) throw new Error("THREE.KeyframeTrack: track type undefined, can not parse"); var e = function (A) { switch (A.toLowerCase()) { case "scalar": case "double": case "float": case "number": case "integer": return Dr; case "vector": case "vector2": case "vector3": case "vector4": return Vr; case "color": return kr; case "quaternion": return Nr; case "bool": case "boolean": return Tr; case "string": return Or } throw new Error("THREE.KeyframeTrack: Unsupported typeName: " + A) }(A.type); if (void 0 === A.times) { var t = [], i = []; br.flattenJSON(A.keys, t, i, "value"), A.times = t, A.values = i } return void 0 !== e.parse ? e.parse(A) : new e(A.name, A.times, A.values, A.interpolation) } Object.assign(Ur.prototype, { evaluate: function (A) { var e = this.parameterPositions, t = this._cachedIndex, i = e[t], o = e[t - 1]; A: { e: { var n; t: { i: if (i <= A) { for (var r = t + 2;;) { if (void 0 === i) { if (o > A) break i; return this._cachedIndex = t = e.length, this.afterEnd_(t - 1, A, o) } if (t === r) break; if (o = i, (i = e[++t]) > A) break e } n = e.length; break t } if (A >= o) break A; var a = e[1]; a > A && (t = 2, o = a); for (r = t - 2;;) { if (void 0 === o) return this._cachedIndex = 0, this.beforeStart_(0, A, i); if (t === r) break; if (i = o, A >= (o = e[--t - 1])) break e } n = t, t = 0 } for (; n > t;) { var s = t + n >>> 1; e[s] > A ? n = s : t = s + 1 } if (i = e[t], void 0 === (o = e[t - 1])) return this._cachedIndex = 0, this.beforeStart_(0, A, i); if (void 0 === i) return this._cachedIndex = t = e.length, this.afterEnd_(t - 1, o, A) } this._cachedIndex = t, this.intervalChanged_(t, o, i) } return this.interpolate_(t, o, A, i) }, settings: null, DefaultSettings_: {}, getSettings_: function () { return this.settings || this.DefaultSettings_ }, copySampleValue_: function (A) { for (var e = this.resultBuffer, t = this.sampleValues, i = this.valueSize, o = A * i, n = 0; n !== i; ++n) e[n] = t[o + n]; return e }, interpolate_: function () { throw new Error("call to abstract method") }, intervalChanged_: function () {} }), Object.assign(Ur.prototype, { beforeStart_: Ur.prototype.copySampleValue_, afterEnd_: Ur.prototype.copySampleValue_ }), Fr.prototype = Object.assign(Object.create(Ur.prototype), { constructor: Fr, DefaultSettings_: { endingStart: 2400, endingEnd: 2400 }, intervalChanged_: function (A, e, t) { var i = this.parameterPositions, o = A - 2, n = A + 1, r = i[o], a = i[n]; if (void 0 === r) switch (this.getSettings_().endingStart) { case 2401: o = A, r = 2 * e - t; break; case 2402: r = e + i[o = i.length - 2] - i[o + 1]; break; default: o = A, r = t } if (void 0 === a) switch (this.getSettings_().endingEnd) { case 2401: n = A, a = 2 * t - e; break; case 2402: n = 1, a = t + i[1] - i[0]; break; default: n = A - 1, a = e } var s = .5 * (t - e), l = this.valueSize; this._weightPrev = s / (e - r), this._weightNext = s / (a - t), this._offsetPrev = o * l, this._offsetNext = n * l }, interpolate_: function (A, e, t, i) { for (var o = this.resultBuffer, n = this.sampleValues, r = this.valueSize, a = A * r, s = a - r, l = this._offsetPrev, c = this._offsetNext, h = this._weightPrev, d = this._weightNext, p = (t - e) / (i - e), g = p * p, u = g * p, f = -h * u + 2 * h * g - h * p, m = (1 + h) * u + (-1.5 - 2 * h) * g + (-.5 + h) * p + 1, C = (-1 - d) * u + (1.5 + d) * g + .5 * p, y = d * u - d * g, v = 0; v !== r; ++v) o[v] = f * n[l + v] + m * n[s + v] + C * n[a + v] + y * n[c + v]; return o } }), Kr.prototype = Object.assign(Object.create(Ur.prototype), { constructor: Kr, interpolate_: function (A, e, t, i) { for (var o = this.resultBuffer, n = this.sampleValues, r = this.valueSize, a = A * r, s = a - r, l = (t - e) / (i - e), c = 1 - l, h = 0; h !== r; ++h) o[h] = n[s + h] * c + n[a + h] * l; return o } }), Qr.prototype = Object.assign(Object.create(Ur.prototype), { constructor: Qr, interpolate_: function (A) { return this.copySampleValue_(A - 1) } }), Object.assign(Rr, { toJSON: function (A) { var e, t = A.constructor; if (void 0 !== t.toJSON) e = t.toJSON(A); else { e = { name: A.name, times: br.convertArray(A.times, Array), values: br.convertArray(A.values, Array) }; var i = A.getInterpolation(); i !== A.DefaultInterpolation && (e.interpolation = i) } return e.type = A.ValueTypeName, e } }), Object.assign(Rr.prototype, { constructor: Rr, TimeBufferType: Float32Array, ValueBufferType: Float32Array, DefaultInterpolation: 2301, InterpolantFactoryMethodDiscrete: function (A) { return new Qr(this.times, this.values, this.getValueSize(), A) }, InterpolantFactoryMethodLinear: function (A) { return new Kr(this.times, this.values, this.getValueSize(), A) }, InterpolantFactoryMethodSmooth: function (A) { return new Fr(this.times, this.values, this.getValueSize(), A) }, setInterpolation: function (A) { var e; switch (A) { case 2300: e = this.InterpolantFactoryMethodDiscrete; break; case 2301: e = this.InterpolantFactoryMethodLinear; break; case 2302: e = this.InterpolantFactoryMethodSmooth } if (void 0 === e) { var t = "unsupported interpolation for " + this.ValueTypeName + " keyframe track named " + this.name; if (void 0 === this.createInterpolant) { if (A === this.DefaultInterpolation) throw new Error(t); this.setInterpolation(this.DefaultInterpolation) } return console.warn("THREE.KeyframeTrack:", t), this } return this.createInterpolant = e, this }, getInterpolation: function () { switch (this.createInterpolant) { case this.InterpolantFactoryMethodDiscrete: return 2300; case this.InterpolantFactoryMethodLinear: return 2301; case this.InterpolantFactoryMethodSmooth: return 2302 } }, getValueSize: function () { return this.values.length / this.times.length }, shift: function (A) { if (0 !== A) for (var e = this.times, t = 0, i = e.length; t !== i; ++t) e[t] += A; return this }, scale: function (A) { if (1 !== A) for (var e = this.times, t = 0, i = e.length; t !== i; ++t) e[t] *= A; return this }, trim: function (A, e) { for (var t = this.times, i = t.length, o = 0, n = i - 1; o !== i && A > t[o];) ++o; for (; - 1 !== n && t[n] > e;) --n; if (++n, 0 !== o || n !== i) { n > o || (o = (n = Math.max(n, 1)) - 1); var r = this.getValueSize(); this.times = br.arraySlice(t, o, n), this.values = br.arraySlice(this.values, o * r, n * r) } return this }, validate: function () { var A = !0, e = this.getValueSize(); e - Math.floor(e) != 0 && (console.error("THREE.KeyframeTrack: Invalid value size in track.", this), A = !1); var t = this.times, i = this.values, o = t.length; 0 === o && (console.error("THREE.KeyframeTrack: Track is empty.", this), A = !1); for (var n = null, r = 0; r !== o; r++) { var a = t[r]; if ("number" == typeof a && isNaN(a)) { console.error("THREE.KeyframeTrack: Time is not a valid number.", this, r, a), A = !1; break } if (null !== n && n > a) { console.error("THREE.KeyframeTrack: Out of order keys.", this, r, a, n), A = !1; break } n = a } if (void 0 !== i && br.isTypedArray(i)) { r = 0; for (var s = i.length; r !== s; ++r) { var l = i[r]; if (isNaN(l)) { console.error("THREE.KeyframeTrack: Value is not a valid number.", this, r, l), A = !1; break } } } return A }, optimize: function () { for (var A = br.arraySlice(this.times), e = br.arraySlice(this.values), t = this.getValueSize(), i = 2302 === this.getInterpolation(), o = 1, n = A.length - 1, r = 1; n > r; ++r) { var a = !1, s = A[r]; if (s !== A[r + 1] && (1 !== r || s !== s[0])) if (i) a = !0; else for (var l = r * t, c = l - t, h = l + t, d = 0; d !== t; ++d) { var p = e[l + d]; if (p !== e[c + d] || p !== e[h + d]) { a = !0; break } } if (a) { if (r !== o) { A[o] = A[r]; var g = r * t, u = o * t; for (d = 0; d !== t; ++d) e[u + d] = e[g + d] } ++o } } if (n > 0) { A[o] = A[n]; for (g = n * t, u = o * t, d = 0; d !== t; ++d) e[u + d] = e[g + d]; ++o } return o !== A.length ? (this.times = br.arraySlice(A, 0, o), this.values = br.arraySlice(e, 0, o * t)) : (this.times = A, this.values = e), this }, clone: function () { var A = br.arraySlice(this.times, 0), e = br.arraySlice(this.values, 0), t = new(0, this.constructor)(this.name, A, e); return t.createInterpolant = this.createInterpolant, t } }), Tr.prototype = Object.assign(Object.create(Rr.prototype), { constructor: Tr, ValueTypeName: "bool", ValueBufferType: Array, DefaultInterpolation: 2300, InterpolantFactoryMethodLinear: void 0, InterpolantFactoryMethodSmooth: void 0 }), kr.prototype = Object.assign(Object.create(Rr.prototype), { constructor: kr, ValueTypeName: "color" }), Dr.prototype = Object.assign(Object.create(Rr.prototype), { constructor: Dr, ValueTypeName: "number" }), Lr.prototype = Object.assign(Object.create(Ur.prototype), { constructor: Lr, interpolate_: function (A, e, t, i) { for (var o = this.resultBuffer, n = this.sampleValues, r = this.valueSize, a = A * r, s = (t - e) / (i - e), l = a + r; a !== l; a += 4) f.slerpFlat(o, 0, n, a - r, n, a, s); return o } }), Nr.prototype = Object.assign(Object.create(Rr.prototype), { constructor: Nr, ValueTypeName: "quaternion", DefaultInterpolation: 2301, InterpolantFactoryMethodLinear: function (A) { return new Lr(this.times, this.values, this.getValueSize(), A) }, InterpolantFactoryMethodSmooth: void 0 }), Or.prototype = Object.assign(Object.create(Rr.prototype), { constructor: Or, ValueTypeName: "string", ValueBufferType: Array, DefaultInterpolation: 2300, InterpolantFactoryMethodLinear: void 0, InterpolantFactoryMethodSmooth: void 0 }), Vr.prototype = Object.assign(Object.create(Rr.prototype), { constructor: Vr, ValueTypeName: "vector" }), Object.assign(Gr, { parse: function (A) { for (var e = [], t = A.tracks, i = 1 / (A.fps || 1), o = 0, n = t.length; o !== n; ++o) e.push(Pr(t[o]).scale(i)); return new Gr(A.name, A.duration, e) }, toJSON: function (A) { for (var e = [], t = A.tracks, i = { name: A.name, duration: A.duration, tracks: e, uuid: A.uuid }, o = 0, n = t.length; o !== n; ++o) e.push(Rr.toJSON(t[o])); return i }, CreateFromMorphTargetSequence: function (A, e, t, i) { for (var o = e.length, n = [], r = 0; o > r; r++) { var a = [], s = []; a.push((r + o - 1) % o, r, (r + 1) % o), s.push(0, 1, 0); var l = br.getKeyframeOrder(a); a = br.sortedArray(a, 1, l), s = br.sortedArray(s, 1, l), i || 0 !== a[0] || (a.push(o), s.push(s[0])), n.push(new Dr(".morphTargetInfluences[" + e[r].name + "]", a, s).scale(1 / t)) } return new Gr(A, -1, n) }, findByName: function (A, e) { var t = A; if (!Array.isArray(A)) { t = A.geometry && A.geometry.animations || A.animations } for (var i = 0; t.length > i; i++) if (t[i].name === e) return t[i]; return null }, CreateClipsFromMorphTargetSequences: function (A, e, t) { for (var i = {}, o = /^([\w-]*?)([\d]+)$/, n = 0, r = A.length; r > n; n++) { var a = A[n], s = a.name.match(o); if (s && s.length > 1) { var l = i[h = s[1]]; l || (i[h] = l = []), l.push(a) } } var c = []; for (var h in i) c.push(Gr.CreateFromMorphTargetSequence(h, i[h], e, t)); return c }, parseAnimation: function (A, e) { if (!A) return console.error("THREE.AnimationClip: No animation in JSONLoader data."), null; for (var t = function (A, e, t, i, o) { if (0 !== t.length) { var n = [], r = []; br.flattenJSON(t, n, r, i), 0 !== n.length && o.push(new A(e, n, r)) } }, i = [], o = A.name || "default", n = A.length || -1, r = A.fps || 30, a = A.hierarchy || [], s = 0; a.length > s; s++) { var l = a[s].keys; if (l && 0 !== l.length) if (l[0].morphTargets) { for (var c = {}, h = 0; l.length > h; h++) if (l[h].morphTargets) for (var d = 0; l[h].morphTargets.length > d; d++) c[l[h].morphTargets[d]] = -1; for (var p in c) { var g = [], u = []; for (d = 0; d !== l[h].morphTargets.length; ++d) { var f = l[h]; g.push(f.time), u.push(f.morphTarget === p ? 1 : 0) } i.push(new Dr(".morphTargetInfluence[" + p + "]", g, u)) } n = c.length * (r || 1) } else { var m = ".bones[" + e[s].name + "]"; t(Vr, m + ".position", l, "pos", i), t(Nr, m + ".quaternion", l, "rot", i), t(Vr, m + ".scale", l, "scl", i) } } return 0 === i.length ? null : new Gr(o, n, i) } }), Object.assign(Gr.prototype, { resetDuration: function () { for (var A = 0, e = 0, t = this.tracks.length; e !== t; ++e) { var i = this.tracks[e]; A = Math.max(A, i.times[i.times.length - 1]) } return this.duration = A, this }, trim: function () { for (var A = 0; this.tracks.length > A; A++) this.tracks[A].trim(0, this.duration); return this }, validate: function () { for (var A = !0, e = 0; this.tracks.length > e; e++) A = A && this.tracks[e].validate(); return A }, optimize: function () { for (var A = 0; this.tracks.length > A; A++) this.tracks[A].optimize(); return this }, clone: function () { for (var A = [], e = 0; this.tracks.length > e; e++) A.push(this.tracks[e].clone()); return new Gr(this.name, this.duration, A) } }); var qr = { enabled: !1, files: {}, add: function (A, e) { !1 !== this.enabled && (this.files[A] = e) }, get: function (A) { if (!1 !== this.enabled) return this.files[A] }, remove: function (A) { delete this.files[A] }, clear: function () { this.files = {} } }; function jr(A, e, t) { var i = this, o = !1, n = 0, r = 0, a = void 0, s = []; this.onStart = void 0, this.onLoad = A, this.onProgress = e, this.onError = t, this.itemStart = function (A) { r++, !1 === o && void 0 !== i.onStart && i.onStart(A, n, r), o = !0 }, this.itemEnd = function (A) { n++, void 0 !== i.onProgress && i.onProgress(A, n, r), n === r && (o = !1, void 0 !== i.onLoad && i.onLoad()) }, this.itemError = function (A) { void 0 !== i.onError && i.onError(A) }, this.resolveURL = function (A) { return a ? a(A) : A }, this.setURLModifier = function (A) { return a = A, this }, this.addHandler = function (A, e) { return s.push(A, e), this }, this.removeHandler = function (A) { var e = s.indexOf(A); return -1 !== e && s.splice(e, 2), this }, this.getHandler = function (A) { for (var e = 0, t = s.length; t > e; e += 2) { var i = s[e], o = s[e + 1]; if (i.global && (i.lastIndex = 0), i.test(A)) return o } return null } } var Hr = new jr; function Yr(A) { this.manager = void 0 !== A ? A : Hr, this.crossOrigin = "anonymous", this.path = "", this.resourcePath = "" } Object.assign(Yr.prototype, { load: function () {}, parse: function () {}, setCrossOrigin: function (A) { return this.crossOrigin = A, this }, setPath: function (A) { return this.path = A, this }, setResourcePath: function (A) { return this.resourcePath = A, this } }); var Wr = {}; function Jr(A) { Yr.call(this, A) } function zr(A) { Yr.call(this, A) } function Zr(A) { Yr.call(this, A) } function Xr(A) { Yr.call(this, A) } function _r(A) { Yr.call(this, A) } function $r(A) { Yr.call(this, A) } function Aa(A) { Yr.call(this, A) } function ea() { this.type = "Curve", this.arcLengthDivisions = 200 } function ta(A, e, t, i, o, n, r, a) { ea.call(this), this.type = "EllipseCurve", this.aX = A || 0, this.aY = e || 0, this.xRadius = t || 1, this.yRadius = i || 1, this.aStartAngle = o || 0, this.aEndAngle = n || 2 * Math.PI, this.aClockwise = r || !1, this.aRotation = a || 0 } function ia(A, e, t, i, o, n) { ta.call(this, A, e, t, t, i, o, n), this.type = "ArcCurve" } function oa() { var A = 0, e = 0, t = 0, i = 0; function o(o, n, r, a) { A = o, e = r, t = -3 * o + 3 * n - 2 * r - a, i = 2 * o - 2 * n + r + a } return { initCatmullRom: function (A, e, t, i, n) { o(e, t, n * (t - A), n * (i - e)) }, initNonuniformCatmullRom: function (A, e, t, i, n, r, a) { var s = (e - A) / n - (t - A) / (n + r) + (t - e) / r, l = (t - e) / r - (i - e) / (r + a) + (i - t) / a; o(e, t, s *= r, l *= r) }, calc: function (o) { var n = o * o; return A + e * o + t * n + i * (n * o) } } } Jr.prototype = Object.assign(Object.create(Yr.prototype), { constructor: Jr, load: function (A, e, t, i) { void 0 === A && (A = ""), void 0 !== this.path && (A = this.path + A), A = this.manager.resolveURL(A); var o = this, n = qr.get(A); if (void 0 !== n) return o.manager.itemStart(A), setTimeout((function () { e && e(n), o.manager.itemEnd(A) }), 0), n; if (void 0 === Wr[A]) { var r = A.match(/^data:(.*?)(;base64)?,(.*)$/); if (r) { var a = r[1], s = !!r[2], l = r[3]; l = decodeURIComponent(l), s && (l = atob(l)); try { var c, h = (this.responseType || "").toLowerCase(); switch (h) { case "arraybuffer": case "blob": for (var d = new Uint8Array(l.length), p = 0; l.length > p; p++) d[p] = l.charCodeAt(p); c = "blob" === h ? new Blob([d.buffer], { type: a }) : d.buffer; break; case "document": var g = new DOMParser; c = g.parseFromString(l, a); break; case "json": c = JSON.parse(l); break; default: c = l } setTimeout((function () { e && e(c), o.manager.itemEnd(A) }), 0) } catch (e) { setTimeout((function () { i && i(e), o.manager.itemError(A), o.manager.itemEnd(A) }), 0) } } else { Wr[A] = [], Wr[A].push({ onLoad: e, onProgress: t, onError: i }); var u = new XMLHttpRequest; for (var f in u.open("GET", A, !0), u.addEventListener("load", (function (e) { var t = this.response, i = Wr[A]; if (delete Wr[A], 200 === this.status || 0 === this.status) { 0 === this.status && console.warn("THREE.FileLoader: HTTP Status 0 received."), qr.add(A, t); for (var n = 0, r = i.length; r > n; n++) { (a = i[n]).onLoad && a.onLoad(t) } o.manager.itemEnd(A) } else { for (n = 0, r = i.length; r > n; n++) { var a; (a = i[n]).onError && a.onError(e) } o.manager.itemError(A), o.manager.itemEnd(A) } }), !1), u.addEventListener("progress", (function (e) { for (var t = Wr[A], i = 0, o = t.length; o > i; i++) { var n = t[i]; n.onProgress && n.onProgress(e) } }), !1), u.addEventListener("error", (function (e) { var t = Wr[A]; delete Wr[A]; for (var i = 0, n = t.length; n > i; i++) { var r = t[i]; r.onError && r.onError(e) } o.manager.itemError(A), o.manager.itemEnd(A) }), !1), u.addEventListener("abort", (function (e) { var t = Wr[A]; delete Wr[A]; for (var i = 0, n = t.length; n > i; i++) { var r = t[i]; r.onError && r.onError(e) } o.manager.itemError(A), o.manager.itemEnd(A) }), !1), void 0 !== this.responseType && (u.responseType = this.responseType), void 0 !== this.withCredentials && (u.withCredentials = this.withCredentials), u.overrideMimeType && u.overrideMimeType(void 0 !== this.mimeType ? this.mimeType : "text/plain"), this.requestHeader) u.setRequestHeader(f, this.requestHeader[f]); u.send(null) } return o.manager.itemStart(A), u } Wr[A].push({ onLoad: e, onProgress: t, onError: i }) }, setResponseType: function (A) { return this.responseType = A, this }, setWithCredentials: function (A) { return this.withCredentials = A, this }, setMimeType: function (A) { return this.mimeType = A, this }, setRequestHeader: function (A) { return this.requestHeader = A, this } }), zr.prototype = Object.assign(Object.create(Yr.prototype), { constructor: zr, load: function (A, e, t, i) { var o = this, n = new Jr(o.manager); n.setPath(o.path), n.load(A, (function (A) { e(o.parse(JSON.parse(A))) }), t, i) }, parse: function (A) { for (var e = [], t = 0; A.length > t; t++) { var i = Gr.parse(A[t]); e.push(i) } return e } }), Zr.prototype = Object.assign(Object.create(Yr.prototype), { constructor: Zr, load: function (A, e, t, i) { var o = this, n = [], r = new An; r.image = n; var a = new Jr(this.manager); function s(s) { a.load(A[s], (function (A) { var t = o.parse(A, !0); n[s] = { width: t.width, height: t.height, format: t.format, mipmaps: t.mipmaps }, 6 === (l += 1) && (1 === t.mipmapCount && (r.minFilter = 1006), r.format = t.format, r.needsUpdate = !0, e && e(r)) }), t, i) } if (a.setPath(this.path), a.setResponseType("arraybuffer"), Array.isArray(A)) for (var l = 0, c = 0, h = A.length; h > c; ++c) s(c); else a.load(A, (function (A) { var t = o.parse(A, !0); if (t.isCubemap) for (var i = t.mipmaps.length / t.mipmapCount, a = 0; i > a; a++) { n[a] = { mipmaps: [] }; for (var s = 0; t.mipmapCount > s; s++) n[a].mipmaps.push(t.mipmaps[a * t.mipmapCount + s]), n[a].format = t.format, n[a].width = t.width, n[a].height = t.height } else r.image.width = t.width, r.image.height = t.height, r.mipmaps = t.mipmaps; 1 === t.mipmapCount && (r.minFilter = 1006), r.format = t.format, r.needsUpdate = !0, e && e(r) }), t, i); return r } }), Xr.prototype = Object.assign(Object.create(Yr.prototype), { constructor: Xr, load: function (A, e, t, i) { var o = this, n = new We, r = new Jr(this.manager); return r.setResponseType("arraybuffer"), r.setPath(this.path), r.load(A, (function (A) { var t = o.parse(A); t && (void 0 !== t.image ? n.image = t.image : void 0 !== t.data && (n.image.width = t.width, n.image.height = t.height, n.image.data = t.data), n.wrapS = void 0 !== t.wrapS ? t.wrapS : 1001, n.wrapT = void 0 !== t.wrapT ? t.wrapT : 1001, n.magFilter = void 0 !== t.magFilter ? t.magFilter : 1006, n.minFilter = void 0 !== t.minFilter ? t.minFilter : 1006, n.anisotropy = void 0 !== t.anisotropy ? t.anisotropy : 1, void 0 !== t.format && (n.format = t.format), void 0 !== t.type && (n.type = t.type), void 0 !== t.mipmaps && (n.mipmaps = t.mipmaps, n.minFilter = 1008), 1 === t.mipmapCount && (n.minFilter = 1006), n.needsUpdate = !0, e && e(n, t)) }), t, i), n } }), _r.prototype = Object.assign(Object.create(Yr.prototype), { constructor: _r, load: function (A, e, t, i) { void 0 !== this.path && (A = this.path + A), A = this.manager.resolveURL(A); var o = this, n = qr.get(A); if (void 0 !== n) return o.manager.itemStart(A), setTimeout((function () { e && e(n), o.manager.itemEnd(A) }), 0), n; var r = document.createElementNS("http://www.w3.org/1999/xhtml", "img"); function a() { r.removeEventListener("load", a, !1), r.removeEventListener("error", s, !1), qr.add(A, this), e && e(this), o.manager.itemEnd(A) } function s(e) { r.removeEventListener("load", a, !1), r.removeEventListener("error", s, !1), i && i(e), o.manager.itemError(A), o.manager.itemEnd(A) } return r.addEventListener("load", a, !1), r.addEventListener("error", s, !1), "data:" !== A.substr(0, 5) && void 0 !== this.crossOrigin && (r.crossOrigin = this.crossOrigin), o.manager.itemStart(A), r.src = A, r } }), $r.prototype = Object.assign(Object.create(Yr.prototype), { constructor: $r, load: function (A, e, t, i) { var o = new ut, n = new _r(this.manager); n.setCrossOrigin(this.crossOrigin), n.setPath(this.path); var r = 0; function a(t) { n.load(A[t], (function (A) { o.images[t] = A, 6 === ++r && (o.needsUpdate = !0, e && e(o)) }), void 0, i) } for (var s = 0; A.length > s; ++s) a(s); return o } }), Aa.prototype = Object.assign(Object.create(Yr.prototype), { constructor: Aa, load: function (A, e, t, i) { var o = new d, n = new _r(this.manager); return n.setCrossOrigin(this.crossOrigin), n.setPath(this.path), n.load(A, (function (t) { o.image = t; var i = A.search(/\.jpe?g($|\?)/i) > 0 || 0 === A.search(/^data\:image\/jpeg/); o.format = i ? 1022 : 1023, o.needsUpdate = !0, void 0 !== e && e(o) }), t, i), o } }), Object.assign(ea.prototype, { getPoint: function () { return console.warn("THREE.Curve: .getPoint() not implemented."), null }, getPointAt: function (A, e) { var t = this.getUtoTmapping(A); return this.getPoint(t, e) }, getPoints: function (A) { void 0 === A && (A = 5); for (var e = [], t = 0; A >= t; t++) e.push(this.getPoint(t / A)); return e }, getSpacedPoints: function (A) { void 0 === A && (A = 5); for (var e = [], t = 0; A >= t; t++) e.push(this.getPointAt(t / A)); return e }, getLength: function () { var A = this.getLengths(); return A[A.length - 1] }, getLengths: function (A) { if (void 0 === A && (A = this.arcLengthDivisions), this.cacheArcLengths && this.cacheArcLengths.length === A + 1 && !this.needsUpdate) return this.cacheArcLengths; this.needsUpdate = !1; var e, t, i = [], o = this.getPoint(0), n = 0; for (i.push(0), t = 1; A >= t; t++) n += (e = this.getPoint(t / A)).distanceTo(o), i.push(n), o = e; return this.cacheArcLengths = i, i }, updateArcLengths: function () { this.needsUpdate = !0, this.getLengths() }, getUtoTmapping: function (A, e) { var t, i = this.getLengths(), o = 0, n = i.length; t = e || A * i[n - 1]; for (var r, a = 0, s = n - 1; s >= a;) if (0 > (r = i[o = Math.floor(a + (s - a) / 2)] - t)) a = o + 1; else { if (0 >= r) { s = o; break } s = o - 1 } if (i[o = s] === t) return o / (n - 1); var l = i[o]; return (o + (t - l) / (i[o + 1] - l)) / (n - 1) }, getTangent: function (A) { var e = A - 1e-4, t = A + 1e-4; 0 > e && (e = 0), t > 1 && (t = 1); var i = this.getPoint(e); return this.getPoint(t).clone().sub(i).normalize() }, getTangentAt: function (A) { var e = this.getUtoTmapping(A); return this.getTangent(e) }, computeFrenetFrames: function (A, e) { var t, i, o = new y, n = [], r = [], s = [], l = new y, c = new M; for (t = 0; A >= t; t++) n[t] = this.getTangentAt(t / A), n[t].normalize(); r[0] = new y, s[0] = new y; var h = Number.MAX_VALUE, d = Math.abs(n[0].x), p = Math.abs(n[0].y), g = Math.abs(n[0].z); for (d > h || (h = d, o.set(1, 0, 0)), p > h || (h = p, o.set(0, 1, 0)), g > h || o.set(0, 0, 1), l.crossVectors(n[0], o).normalize(), r[0].crossVectors(n[0], l), s[0].crossVectors(n[0], r[0]), t = 1; A >= t; t++) r[t] = r[t - 1].clone(), s[t] = s[t - 1].clone(), l.crossVectors(n[t - 1], n[t]), l.length() > Number.EPSILON && (l.normalize(), i = Math.acos(a.clamp(n[t - 1].dot(n[t]), -1, 1)), r[t].applyMatrix4(c.makeRotationAxis(l, i))), s[t].crossVectors(n[t], r[t]); if (!0 === e) for (i = Math.acos(a.clamp(r[0].dot(r[A]), -1, 1)), i /= A, n[0].dot(l.crossVectors(r[0], r[A])) > 0 && (i = -i), t = 1; A >= t; t++) r[t].applyMatrix4(c.makeRotationAxis(n[t], i * t)), s[t].crossVectors(n[t], r[t]); return { tangents: n, normals: r, binormals: s } }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.arcLengthDivisions = A.arcLengthDivisions, this }, toJSON: function () { var A = { metadata: { version: 4.5, type: "Curve", generator: "Curve.toJSON" } }; return A.arcLengthDivisions = this.arcLengthDivisions, A.type = this.type, A }, fromJSON: function (A) { return this.arcLengthDivisions = A.arcLengthDivisions, this } }), (ta.prototype = Object.create(ea.prototype)).constructor = ta, ta.prototype.isEllipseCurve = !0, ta.prototype.getPoint = function (A, e) { for (var t = e || new s, i = 2 * Math.PI, o = this.aEndAngle - this.aStartAngle, n = Math.abs(o) < Number.EPSILON; 0 > o;) o += i; for (; o > i;) o -= i; Number.EPSILON > o && (o = n ? 0 : i), !0 !== this.aClockwise || n || (o === i ? o = -i : o -= i); var r = this.aStartAngle + A * o, a = this.aX + this.xRadius * Math.cos(r), l = this.aY + this.yRadius * Math.sin(r); if (0 !== this.aRotation) { var c = Math.cos(this.aRotation), h = Math.sin(this.aRotation), d = a - this.aX, p = l - this.aY; a = d * c - p * h + this.aX, l = d * h + p * c + this.aY } return t.set(a, l) }, ta.prototype.copy = function (A) { return ea.prototype.copy.call(this, A), this.aX = A.aX, this.aY = A.aY, this.xRadius = A.xRadius, this.yRadius = A.yRadius, this.aStartAngle = A.aStartAngle, this.aEndAngle = A.aEndAngle, this.aClockwise = A.aClockwise, this.aRotation = A.aRotation, this }, ta.prototype.toJSON = function () { var A = ea.prototype.toJSON.call(this); return A.aX = this.aX, A.aY = this.aY, A.xRadius = this.xRadius, A.yRadius = this.yRadius, A.aStartAngle = this.aStartAngle, A.aEndAngle = this.aEndAngle, A.aClockwise = this.aClockwise, A.aRotation = this.aRotation, A }, ta.prototype.fromJSON = function (A) { return ea.prototype.fromJSON.call(this, A), this.aX = A.aX, this.aY = A.aY, this.xRadius = A.xRadius, this.yRadius = A.yRadius, this.aStartAngle = A.aStartAngle, this.aEndAngle = A.aEndAngle, this.aClockwise = A.aClockwise, this.aRotation = A.aRotation, this }, (ia.prototype = Object.create(ta.prototype)).constructor = ia, ia.prototype.isArcCurve = !0; var na = new y, ra = new oa, aa = new oa, sa = new oa; function la(A, e, t, i) { ea.call(this), this.type = "CatmullRomCurve3", this.points = A || [], this.closed = e || !1, this.curveType = t || "centripetal", this.tension = i || .5 } function ca(A, e, t, i, o) { var n = .5 * (i - e), r = .5 * (o - t), a = A * A; return (2 * t - 2 * i + n + r) * (A * a) + (-3 * t + 3 * i - 2 * n - r) * a + n * A + t } function ha(A, e, t, i) { return function (A, e) { var t = 1 - A; return t * t * e }(A, e) + function (A, e) { return 2 * (1 - A) * A * e }(A, t) + function (A, e) { return A * A * e }(A, i) } function da(A, e, t, i, o) { return function (A, e) { var t = 1 - A; return t * t * t * e }(A, e) + function (A, e) { var t = 1 - A; return 3 * t * t * A * e }(A, t) + function (A, e) { return 3 * (1 - A) * A * A * e }(A, i) + function (A, e) { return A * A * A * e }(A, o) } function pa(A, e, t, i) { ea.call(this), this.type = "CubicBezierCurve", this.v0 = A || new s, this.v1 = e || new s, this.v2 = t || new s, this.v3 = i || new s } function ga(A, e, t, i) { ea.call(this), this.type = "CubicBezierCurve3", this.v0 = A || new y, this.v1 = e || new y, this.v2 = t || new y, this.v3 = i || new y } function ua(A, e) { ea.call(this), this.type = "LineCurve", this.v1 = A || new s, this.v2 = e || new s } function fa(A, e) { ea.call(this), this.type = "LineCurve3", this.v1 = A || new y, this.v2 = e || new y } function ma(A, e, t) { ea.call(this), this.type = "QuadraticBezierCurve", this.v0 = A || new s, this.v1 = e || new s, this.v2 = t || new s } function Ca(A, e, t) { ea.call(this), this.type = "QuadraticBezierCurve3", this.v0 = A || new y, this.v1 = e || new y, this.v2 = t || new y } function ya(A) { ea.call(this), this.type = "SplineCurve", this.points = A || [] } (la.prototype = Object.create(ea.prototype)).constructor = la, la.prototype.isCatmullRomCurve3 = !0, la.prototype.getPoint = function (A, e) { var t, i, o, n, r = e || new y, a = this.points, s = a.length, l = (s - (this.closed ? 0 : 1)) * A, c = Math.floor(l), h = l - c; if (this.closed ? c += c > 0 ? 0 : (Math.floor(Math.abs(c) / s) + 1) * s : 0 === h && c === s - 1 && (c = s - 2, h = 1), this.closed || c > 0 ? t = a[(c - 1) % s] : (na.subVectors(a[0], a[1]).add(a[0]), t = na), i = a[c % s], o = a[(c + 1) % s], this.closed || s > c + 2 ? n = a[(c + 2) % s] : (na.subVectors(a[s - 1], a[s - 2]).add(a[s - 1]), n = na), "centripetal" === this.curveType || "chordal" === this.curveType) { var d = "chordal" === this.curveType ? .5 : .25, p = Math.pow(t.distanceToSquared(i), d), g = Math.pow(i.distanceToSquared(o), d), u = Math.pow(o.distanceToSquared(n), d); 1e-4 > g && (g = 1), 1e-4 > p && (p = g), 1e-4 > u && (u = g), ra.initNonuniformCatmullRom(t.x, i.x, o.x, n.x, p, g, u), aa.initNonuniformCatmullRom(t.y, i.y, o.y, n.y, p, g, u), sa.initNonuniformCatmullRom(t.z, i.z, o.z, n.z, p, g, u) } else "catmullrom" === this.curveType && (ra.initCatmullRom(t.x, i.x, o.x, n.x, this.tension), aa.initCatmullRom(t.y, i.y, o.y, n.y, this.tension), sa.initCatmullRom(t.z, i.z, o.z, n.z, this.tension)); return r.set(ra.calc(h), aa.calc(h), sa.calc(h)), r }, la.prototype.copy = function (A) { ea.prototype.copy.call(this, A), this.points = []; for (var e = 0, t = A.points.length; t > e; e++) { this.points.push(A.points[e].clone()) } return this.closed = A.closed, this.curveType = A.curveType, this.tension = A.tension, this }, la.prototype.toJSON = function () { var A = ea.prototype.toJSON.call(this); A.points = []; for (var e = 0, t = this.points.length; t > e; e++) { A.points.push(this.points[e].toArray()) } return A.closed = this.closed, A.curveType = this.curveType, A.tension = this.tension, A }, la.prototype.fromJSON = function (A) { ea.prototype.fromJSON.call(this, A), this.points = []; for (var e = 0, t = A.points.length; t > e; e++) { var i = A.points[e]; this.points.push((new y).fromArray(i)) } return this.closed = A.closed, this.curveType = A.curveType, this.tension = A.tension, this }, (pa.prototype = Object.create(ea.prototype)).constructor = pa, pa.prototype.isCubicBezierCurve = !0, pa.prototype.getPoint = function (A, e) { var t = e || new s, i = this.v0, o = this.v1, n = this.v2, r = this.v3; return t.set(da(A, i.x, o.x, n.x, r.x), da(A, i.y, o.y, n.y, r.y)), t }, pa.prototype.copy = function (A) { return ea.prototype.copy.call(this, A), this.v0.copy(A.v0), this.v1.copy(A.v1), this.v2.copy(A.v2), this.v3.copy(A.v3), this }, pa.prototype.toJSON = function () { var A = ea.prototype.toJSON.call(this); return A.v0 = this.v0.toArray(), A.v1 = this.v1.toArray(), A.v2 = this.v2.toArray(), A.v3 = this.v3.toArray(), A }, pa.prototype.fromJSON = function (A) { return ea.prototype.fromJSON.call(this, A), this.v0.fromArray(A.v0), this.v1.fromArray(A.v1), this.v2.fromArray(A.v2), this.v3.fromArray(A.v3), this }, (ga.prototype = Object.create(ea.prototype)).constructor = ga, ga.prototype.isCubicBezierCurve3 = !0, ga.prototype.getPoint = function (A, e) { var t = e || new y, i = this.v0, o = this.v1, n = this.v2, r = this.v3; return t.set(da(A, i.x, o.x, n.x, r.x), da(A, i.y, o.y, n.y, r.y), da(A, i.z, o.z, n.z, r.z)), t }, ga.prototype.copy = function (A) { return ea.prototype.copy.call(this, A), this.v0.copy(A.v0), this.v1.copy(A.v1), this.v2.copy(A.v2), this.v3.copy(A.v3), this }, ga.prototype.toJSON = function () { var A = ea.prototype.toJSON.call(this); return A.v0 = this.v0.toArray(), A.v1 = this.v1.toArray(), A.v2 = this.v2.toArray(), A.v3 = this.v3.toArray(), A }, ga.prototype.fromJSON = function (A) { return ea.prototype.fromJSON.call(this, A), this.v0.fromArray(A.v0), this.v1.fromArray(A.v1), this.v2.fromArray(A.v2), this.v3.fromArray(A.v3), this }, (ua.prototype = Object.create(ea.prototype)).constructor = ua, ua.prototype.isLineCurve = !0, ua.prototype.getPoint = function (A, e) { var t = e || new s; return 1 === A ? t.copy(this.v2) : (t.copy(this.v2).sub(this.v1), t.multiplyScalar(A).add(this.v1)), t }, ua.prototype.getPointAt = function (A, e) { return this.getPoint(A, e) }, ua.prototype.getTangent = function () { return this.v2.clone().sub(this.v1).normalize() }, ua.prototype.copy = function (A) { return ea.prototype.copy.call(this, A), this.v1.copy(A.v1), this.v2.copy(A.v2), this }, ua.prototype.toJSON = function () { var A = ea.prototype.toJSON.call(this); return A.v1 = this.v1.toArray(), A.v2 = this.v2.toArray(), A }, ua.prototype.fromJSON = function (A) { return ea.prototype.fromJSON.call(this, A), this.v1.fromArray(A.v1), this.v2.fromArray(A.v2), this }, (fa.prototype = Object.create(ea.prototype)).constructor = fa, fa.prototype.isLineCurve3 = !0, fa.prototype.getPoint = function (A, e) { var t = e || new y; return 1 === A ? t.copy(this.v2) : (t.copy(this.v2).sub(this.v1), t.multiplyScalar(A).add(this.v1)), t }, fa.prototype.getPointAt = function (A, e) { return this.getPoint(A, e) }, fa.prototype.copy = function (A) { return ea.prototype.copy.call(this, A), this.v1.copy(A.v1), this.v2.copy(A.v2), this }, fa.prototype.toJSON = function () { var A = ea.prototype.toJSON.call(this); return A.v1 = this.v1.toArray(), A.v2 = this.v2.toArray(), A }, fa.prototype.fromJSON = function (A) { return ea.prototype.fromJSON.call(this, A), this.v1.fromArray(A.v1), this.v2.fromArray(A.v2), this }, (ma.prototype = Object.create(ea.prototype)).constructor = ma, ma.prototype.isQuadraticBezierCurve = !0, ma.prototype.getPoint = function (A, e) { var t = e || new s, i = this.v0, o = this.v1, n = this.v2; return t.set(ha(A, i.x, o.x, n.x), ha(A, i.y, o.y, n.y)), t }, ma.prototype.copy = function (A) { return ea.prototype.copy.call(this, A), this.v0.copy(A.v0), this.v1.copy(A.v1), this.v2.copy(A.v2), this }, ma.prototype.toJSON = function () { var A = ea.prototype.toJSON.call(this); return A.v0 = this.v0.toArray(), A.v1 = this.v1.toArray(), A.v2 = this.v2.toArray(), A }, ma.prototype.fromJSON = function (A) { return ea.prototype.fromJSON.call(this, A), this.v0.fromArray(A.v0), this.v1.fromArray(A.v1), this.v2.fromArray(A.v2), this }, (Ca.prototype = Object.create(ea.prototype)).constructor = Ca, Ca.prototype.isQuadraticBezierCurve3 = !0, Ca.prototype.getPoint = function (A, e) { var t = e || new y, i = this.v0, o = this.v1, n = this.v2; return t.set(ha(A, i.x, o.x, n.x), ha(A, i.y, o.y, n.y), ha(A, i.z, o.z, n.z)), t }, Ca.prototype.copy = function (A) { return ea.prototype.copy.call(this, A), this.v0.copy(A.v0), this.v1.copy(A.v1), this.v2.copy(A.v2), this }, Ca.prototype.toJSON = function () { var A = ea.prototype.toJSON.call(this); return A.v0 = this.v0.toArray(), A.v1 = this.v1.toArray(), A.v2 = this.v2.toArray(), A }, Ca.prototype.fromJSON = function (A) { return ea.prototype.fromJSON.call(this, A), this.v0.fromArray(A.v0), this.v1.fromArray(A.v1), this.v2.fromArray(A.v2), this }, (ya.prototype = Object.create(ea.prototype)).constructor = ya, ya.prototype.isSplineCurve = !0, ya.prototype.getPoint = function (A, e) { var t = e || new s, i = this.points, o = (i.length - 1) * A, n = Math.floor(o), r = o - n, a = i[0 === n ? n : n - 1], l = i[n], c = i[n > i.length - 2 ? i.length - 1 : n + 1], h = i[n > i.length - 3 ? i.length - 1 : n + 2]; return t.set(ca(r, a.x, l.x, c.x, h.x), ca(r, a.y, l.y, c.y, h.y)), t }, ya.prototype.copy = function (A) { ea.prototype.copy.call(this, A), this.points = []; for (var e = 0, t = A.points.length; t > e; e++) { this.points.push(A.points[e].clone()) } return this }, ya.prototype.toJSON = function () { var A = ea.prototype.toJSON.call(this); A.points = []; for (var e = 0, t = this.points.length; t > e; e++) { A.points.push(this.points[e].toArray()) } return A }, ya.prototype.fromJSON = function (A) { ea.prototype.fromJSON.call(this, A), this.points = []; for (var e = 0, t = A.points.length; t > e; e++) { var i = A.points[e]; this.points.push((new s).fromArray(i)) } return this }; var va = Object.freeze({ __proto__: null, ArcCurve: ia, CatmullRomCurve3: la, CubicBezierCurve: pa, CubicBezierCurve3: ga, EllipseCurve: ta, LineCurve: ua, LineCurve3: fa, QuadraticBezierCurve: ma, QuadraticBezierCurve3: Ca, SplineCurve: ya }); function Ia() { ea.call(this), this.type = "CurvePath", this.curves = [], this.autoClose = !1 } function Ea(A) { Ia.call(this), this.type = "Path", this.currentPoint = new s, A && this.setFromPoints(A) } function Ba(A) { Ea.call(this, A), this.uuid = a.generateUUID(), this.type = "Shape", this.holes = [] } function xa(A, e) { H.call(this), this.type = "Light", this.color = new LA(A), this.intensity = void 0 !== e ? e : 1, this.receiveShadow = void 0 } function Sa(A, e, t) { xa.call(this, A, t), this.type = "HemisphereLight", this.castShadow = void 0, this.position.copy(H.DefaultUp), this.updateMatrix(), this.groundColor = new LA(e) } function wa(A) { this.camera = A, this.bias = 0, this.radius = 1, this.mapSize = new s(512, 512), this.map = null, this.mapPass = null, this.matrix = new M, this._frustum = new Ze, this._frameExtents = new s(1, 1), this._viewportCount = 1, this._viewports = [new p(0, 0, 1, 1)] } function Ma() { wa.call(this, new je(50, 1, .5, 500)) } function ba(A, e, t, i, o, n) { xa.call(this, A, e), this.type = "SpotLight", this.position.copy(H.DefaultUp), this.updateMatrix(), this.target = new H, Object.defineProperty(this, "power", { get: function () { return this.intensity * Math.PI }, set: function (A) { this.intensity = A / Math.PI } }), this.distance = void 0 !== t ? t : 0, this.angle = void 0 !== i ? i : Math.PI / 3, this.penumbra = void 0 !== o ? o : 0, this.decay = void 0 !== n ? n : 1, this.shadow = new Ma } function Ua() { wa.call(this, new je(90, 1, .5, 500)), this._frameExtents = new s(4, 2), this._viewportCount = 6, this._viewports = [new p(2, 1, 1, 1), new p(0, 1, 1, 1), new p(3, 1, 1, 1), new p(1, 1, 1, 1), new p(3, 0, 1, 1), new p(1, 0, 1, 1)], this._cubeDirections = [new y(1, 0, 0), new y(-1, 0, 0), new y(0, 0, 1), new y(0, 0, -1), new y(0, 1, 0), new y(0, -1, 0)], this._cubeUps = [new y(0, 1, 0), new y(0, 1, 0), new y(0, 1, 0), new y(0, 1, 0), new y(0, 0, 1), new y(0, 0, -1)] } function Fa(A, e, t, i) { xa.call(this, A, e), this.type = "PointLight", Object.defineProperty(this, "power", { get: function () { return 4 * this.intensity * Math.PI }, set: function (A) { this.intensity = A / (4 * Math.PI) } }), this.distance = void 0 !== t ? t : 0, this.decay = void 0 !== i ? i : 1, this.shadow = new Ua } function Ka(A, e, t, i, o, n) { qe.call(this), this.type = "OrthographicCamera", this.zoom = 1, this.view = null, this.left = void 0 !== A ? A : -1, this.right = void 0 !== e ? e : 1, this.top = void 0 !== t ? t : 1, this.bottom = void 0 !== i ? i : -1, this.near = void 0 !== o ? o : .1, this.far = void 0 !== n ? n : 2e3, this.updateProjectionMatrix() } function Qa() { wa.call(this, new Ka(-5, 5, 5, -5, .5, 500)) } function Ra(A, e) { xa.call(this, A, e), this.type = "DirectionalLight", this.position.copy(H.DefaultUp), this.updateMatrix(), this.target = new H, this.shadow = new Qa } function Ta(A, e) { xa.call(this, A, e), this.type = "AmbientLight", this.castShadow = void 0 } function ka(A, e, t, i) { xa.call(this, A, e), this.type = "RectAreaLight", this.width = void 0 !== t ? t : 10, this.height = void 0 !== i ? i : 10 } function Da(A) { Yr.call(this, A), this.textures = {} } Ia.prototype = Object.assign(Object.create(ea.prototype), { constructor: Ia, add: function (A) { this.curves.push(A) }, closePath: function () { var A = this.curves[0].getPoint(0), e = this.curves[this.curves.length - 1].getPoint(1); A.equals(e) || this.curves.push(new ua(e, A)) }, getPoint: function (A) { for (var e = A * this.getLength(), t = this.getCurveLengths(), i = 0; t.length > i;) { if (t[i] >= e) { var o = t[i] - e, n = this.curves[i], r = n.getLength(); return n.getPointAt(0 === r ? 0 : 1 - o / r) } i++ } return null }, getLength: function () { var A = this.getCurveLengths(); return A[A.length - 1] }, updateArcLengths: function () { this.needsUpdate = !0, this.cacheLengths = null, this.getCurveLengths() }, getCurveLengths: function () { if (this.cacheLengths && this.cacheLengths.length === this.curves.length) return this.cacheLengths; for (var A = [], e = 0, t = 0, i = this.curves.length; i > t; t++) e += this.curves[t].getLength(), A.push(e); return this.cacheLengths = A, A }, getSpacedPoints: function (A) { void 0 === A && (A = 40); for (var e = [], t = 0; A >= t; t++) e.push(this.getPoint(t / A)); return this.autoClose && e.push(e[0]), e }, getPoints: function (A) { A = A || 12; for (var e, t = [], i = 0, o = this.curves; o.length > i; i++) for (var n = o[i], r = n.getPoints(n && n.isEllipseCurve ? 2 * A : n && (n.isLineCurve || n.isLineCurve3) ? 1 : n && n.isSplineCurve ? A * n.points.length : A), a = 0; r.length > a; a++) { var s = r[a]; e && e.equals(s) || (t.push(s), e = s) } return this.autoClose && t.length > 1 && !t[t.length - 1].equals(t[0]) && t.push(t[0]), t }, copy: function (A) { ea.prototype.copy.call(this, A), this.curves = []; for (var e = 0, t = A.curves.length; t > e; e++) { this.curves.push(A.curves[e].clone()) } return this.autoClose = A.autoClose, this }, toJSON: function () { var A = ea.prototype.toJSON.call(this); A.autoClose = this.autoClose, A.curves = []; for (var e = 0, t = this.curves.length; t > e; e++) { A.curves.push(this.curves[e].toJSON()) } return A }, fromJSON: function (A) { ea.prototype.fromJSON.call(this, A), this.autoClose = A.autoClose, this.curves = []; for (var e = 0, t = A.curves.length; t > e; e++) { var i = A.curves[e]; this.curves.push((new va[i.type]).fromJSON(i)) } return this } }), Ea.prototype = Object.assign(Object.create(Ia.prototype), { constructor: Ea, setFromPoints: function (A) { this.moveTo(A[0].x, A[0].y); for (var e = 1, t = A.length; t > e; e++) this.lineTo(A[e].x, A[e].y); return this }, moveTo: function (A, e) { return this.currentPoint.set(A, e), this }, lineTo: function (A, e) { var t = new ua(this.currentPoint.clone(), new s(A, e)); return this.curves.push(t), this.currentPoint.set(A, e), this }, quadraticCurveTo: function (A, e, t, i) { var o = new ma(this.currentPoint.clone(), new s(A, e), new s(t, i)); return this.curves.push(o), this.currentPoint.set(t, i), this }, bezierCurveTo: function (A, e, t, i, o, n) { var r = new pa(this.currentPoint.clone(), new s(A, e), new s(t, i), new s(o, n)); return this.curves.push(r), this.currentPoint.set(o, n), this }, splineThru: function (A) { var e = new ya([this.currentPoint.clone()].concat(A)); return this.curves.push(e), this.currentPoint.copy(A[A.length - 1]), this }, arc: function (A, e, t, i, o, n) { return this.absarc(A + this.currentPoint.x, e + this.currentPoint.y, t, i, o, n), this }, absarc: function (A, e, t, i, o, n) { return this.absellipse(A, e, t, t, i, o, n), this }, ellipse: function (A, e, t, i, o, n, r, a) { return this.absellipse(A + this.currentPoint.x, e + this.currentPoint.y, t, i, o, n, r, a), this }, absellipse: function (A, e, t, i, o, n, r, a) { var s = new ta(A, e, t, i, o, n, r, a); if (this.curves.length > 0) { var l = s.getPoint(0); l.equals(this.currentPoint) || this.lineTo(l.x, l.y) } this.curves.push(s); var c = s.getPoint(1); return this.currentPoint.copy(c), this }, copy: function (A) { return Ia.prototype.copy.call(this, A), this.currentPoint.copy(A.currentPoint), this }, toJSON: function () { var A = Ia.prototype.toJSON.call(this); return A.currentPoint = this.currentPoint.toArray(), A }, fromJSON: function (A) { return Ia.prototype.fromJSON.call(this, A), this.currentPoint.fromArray(A.currentPoint), this } }), Ba.prototype = Object.assign(Object.create(Ea.prototype), { constructor: Ba, getPointsHoles: function (A) { for (var e = [], t = 0, i = this.holes.length; i > t; t++) e[t] = this.holes[t].getPoints(A); return e }, extractPoints: function (A) { return { shape: this.getPoints(A), holes: this.getPointsHoles(A) } }, copy: function (A) { Ea.prototype.copy.call(this, A), this.holes = []; for (var e = 0, t = A.holes.length; t > e; e++) { this.holes.push(A.holes[e].clone()) } return this }, toJSON: function () { var A = Ea.prototype.toJSON.call(this); A.uuid = this.uuid, A.holes = []; for (var e = 0, t = this.holes.length; t > e; e++) { A.holes.push(this.holes[e].toJSON()) } return A }, fromJSON: function (A) { Ea.prototype.fromJSON.call(this, A), this.uuid = A.uuid, this.holes = []; for (var e = 0, t = A.holes.length; t > e; e++) { var i = A.holes[e]; this.holes.push((new Ea).fromJSON(i)) } return this } }), xa.prototype = Object.assign(Object.create(H.prototype), { constructor: xa, isLight: !0, copy: function (A) { return H.prototype.copy.call(this, A), this.color.copy(A.color), this.intensity = A.intensity, this }, toJSON: function (A) { var e = H.prototype.toJSON.call(this, A); return e.object.color = this.color.getHex(), e.object.intensity = this.intensity, void 0 !== this.groundColor && (e.object.groundColor = this.groundColor.getHex()), void 0 !== this.distance && (e.object.distance = this.distance), void 0 !== this.angle && (e.object.angle = this.angle), void 0 !== this.decay && (e.object.decay = this.decay), void 0 !== this.penumbra && (e.object.penumbra = this.penumbra), void 0 !== this.shadow && (e.object.shadow = this.shadow.toJSON()), e } }), Sa.prototype = Object.assign(Object.create(xa.prototype), { constructor: Sa, isHemisphereLight: !0, copy: function (A) { return xa.prototype.copy.call(this, A), this.groundColor.copy(A.groundColor), this } }), Object.assign(wa.prototype, { _projScreenMatrix: new M, _lightPositionWorld: new y, _lookTarget: new y, getViewportCount: function () { return this._viewportCount }, getFrustum: function () { return this._frustum }, updateMatrices: function (A) { var e = this.camera, t = this.matrix, i = this._projScreenMatrix, o = this._lookTarget, n = this._lightPositionWorld; n.setFromMatrixPosition(A.matrixWorld), e.position.copy(n), o.setFromMatrixPosition(A.target.matrixWorld), e.lookAt(o), e.updateMatrixWorld(), i.multiplyMatrices(e.projectionMatrix, e.matrixWorldInverse), this._frustum.setFromProjectionMatrix(i), t.set(.5, 0, 0, .5, 0, .5, 0, .5, 0, 0, .5, .5, 0, 0, 0, 1), t.multiply(e.projectionMatrix), t.multiply(e.matrixWorldInverse) }, getViewport: function (A) { return this._viewports[A] }, getFrameExtents: function () { return this._frameExtents }, copy: function (A) { return this.camera = A.camera.clone(), this.bias = A.bias, this.radius = A.radius, this.mapSize.copy(A.mapSize), this }, clone: function () { return (new this.constructor).copy(this) }, toJSON: function () { var A = {}; return 0 !== this.bias && (A.bias = this.bias), 1 !== this.radius && (A.radius = this.radius), 512 === this.mapSize.x && 512 === this.mapSize.y || (A.mapSize = this.mapSize.toArray()), A.camera = this.camera.toJSON(!1).object, delete A.camera.matrix, A } }), Ma.prototype = Object.assign(Object.create(wa.prototype), { constructor: Ma, isSpotLightShadow: !0, updateMatrices: function (A) { var e = this.camera, t = 2 * a.RAD2DEG * A.angle, i = this.mapSize.width / this.mapSize.height, o = A.distance || e.far; t === e.fov && i === e.aspect && o === e.far || (e.fov = t, e.aspect = i, e.far = o, e.updateProjectionMatrix()), wa.prototype.updateMatrices.call(this, A) } }), ba.prototype = Object.assign(Object.create(xa.prototype), { constructor: ba, isSpotLight: !0, copy: function (A) { return xa.prototype.copy.call(this, A), this.distance = A.distance, this.angle = A.angle, this.penumbra = A.penumbra, this.decay = A.decay, this.target = A.target.clone(), this.shadow = A.shadow.clone(), this } }), Ua.prototype = Object.assign(Object.create(wa.prototype), { constructor: Ua, isPointLightShadow: !0, updateMatrices: function (A, e) { void 0 === e && (e = 0); var t = this.camera, i = this.matrix, o = this._lightPositionWorld, n = this._lookTarget, r = this._projScreenMatrix; o.setFromMatrixPosition(A.matrixWorld), t.position.copy(o), n.copy(t.position), n.add(this._cubeDirections[e]), t.up.copy(this._cubeUps[e]), t.lookAt(n), t.updateMatrixWorld(), i.makeTranslation(-o.x, -o.y, -o.z), r.multiplyMatrices(t.projectionMatrix, t.matrixWorldInverse), this._frustum.setFromProjectionMatrix(r) } }), Fa.prototype = Object.assign(Object.create(xa.prototype), { constructor: Fa, isPointLight: !0, copy: function (A) { return xa.prototype.copy.call(this, A), this.distance = A.distance, this.decay = A.decay, this.shadow = A.shadow.clone(), this } }), Ka.prototype = Object.assign(Object.create(qe.prototype), { constructor: Ka, isOrthographicCamera: !0, copy: function (A, e) { return qe.prototype.copy.call(this, A, e), this.left = A.left, this.right = A.right, this.top = A.top, this.bottom = A.bottom, this.near = A.near, this.far = A.far, this.zoom = A.zoom, this.view = null === A.view ? null : Object.assign({}, A.view), this }, setViewOffset: function (A, e, t, i, o, n) { null === this.view && (this.view = { enabled: !0, fullWidth: 1, fullHeight: 1, offsetX: 0, offsetY: 0, width: 1, height: 1 }), this.view.enabled = !0, this.view.fullWidth = A, this.view.fullHeight = e, this.view.offsetX = t, this.view.offsetY = i, this.view.width = o, this.view.height = n, this.updateProjectionMatrix() }, clearViewOffset: function () { null !== this.view && (this.view.enabled = !1), this.updateProjectionMatrix() }, updateProjectionMatrix: function () { var A = (this.right - this.left) / (2 * this.zoom), e = (this.top - this.bottom) / (2 * this.zoom), t = (this.right + this.left) / 2, i = (this.top + this.bottom) / 2, o = t - A, n = t + A, r = i + e, a = i - e; if (null !== this.view && this.view.enabled) { var s = (this.right - this.left) / this.view.fullWidth / this.zoom, l = (this.top - this.bottom) / this.view.fullHeight / this.zoom; n = (o += s * this.view.offsetX) + s * this.view.width, a = (r -= l * this.view.offsetY) - l * this.view.height } this.projectionMatrix.makeOrthographic(o, n, r, a, this.near, this.far), this.projectionMatrixInverse.getInverse(this.projectionMatrix) }, toJSON: function (A) { var e = H.prototype.toJSON.call(this, A); return e.object.zoom = this.zoom, e.object.left = this.left, e.object.right = this.right, e.object.top = this.top, e.object.bottom = this.bottom, e.object.near = this.near, e.object.far = this.far, null !== this.view && (e.object.view = Object.assign({}, this.view)), e } }), Qa.prototype = Object.assign(Object.create(wa.prototype), { constructor: Qa, isDirectionalLightShadow: !0, updateMatrices: function (A) { wa.prototype.updateMatrices.call(this, A) } }), Ra.prototype = Object.assign(Object.create(xa.prototype), { constructor: Ra, isDirectionalLight: !0, copy: function (A) { return xa.prototype.copy.call(this, A), this.target = A.target.clone(), this.shadow = A.shadow.clone(), this } }), Ta.prototype = Object.assign(Object.create(xa.prototype), { constructor: Ta, isAmbientLight: !0 }), ka.prototype = Object.assign(Object.create(xa.prototype), { constructor: ka, isRectAreaLight: !0, copy: function (A) { return xa.prototype.copy.call(this, A), this.width = A.width, this.height = A.height, this }, toJSON: function (A) { var e = xa.prototype.toJSON.call(this, A); return e.object.width = this.width, e.object.height = this.height, e } }), Da.prototype = Object.assign(Object.create(Yr.prototype), { constructor: Da, load: function (A, e, t, i) { var o = this, n = new Jr(o.manager); n.setPath(o.path), n.load(A, (function (A) { e(o.parse(JSON.parse(A))) }), t, i) }, parse: function (A) { var e = this.textures; function t(A) { return void 0 === e[A] && console.warn("THREE.MaterialLoader: Undefined texture", A), e[A] } var i = new Mr[A.type]; if (void 0 !== A.uuid && (i.uuid = A.uuid), void 0 !== A.name && (i.name = A.name), void 0 !== A.color && i.color.setHex(A.color), void 0 !== A.roughness && (i.roughness = A.roughness), void 0 !== A.metalness && (i.metalness = A.metalness), void 0 !== A.sheen && (i.sheen = (new LA).setHex(A.sheen)), void 0 !== A.emissive && i.emissive.setHex(A.emissive), void 0 !== A.specular && i.specular.setHex(A.specular), void 0 !== A.shininess && (i.shininess = A.shininess), void 0 !== A.clearcoat && (i.clearcoat = A.clearcoat), void 0 !== A.clearcoatRoughness && (i.clearcoatRoughness = A.clearcoatRoughness), void 0 !== A.fog && (i.fog = A.fog), void 0 !== A.flatShading && (i.flatShading = A.flatShading), void 0 !== A.blending && (i.blending = A.blending), void 0 !== A.combine && (i.combine = A.combine), void 0 !== A.side && (i.side = A.side), void 0 !== A.opacity && (i.opacity = A.opacity), void 0 !== A.transparent && (i.transparent = A.transparent), void 0 !== A.alphaTest && (i.alphaTest = A.alphaTest), void 0 !== A.depthTest && (i.depthTest = A.depthTest), void 0 !== A.depthWrite && (i.depthWrite = A.depthWrite), void 0 !== A.colorWrite && (i.colorWrite = A.colorWrite), void 0 !== A.stencilWrite && (i.stencilWrite = A.stencilWrite), void 0 !== A.stencilWriteMask && (i.stencilWriteMask = A.stencilWriteMask), void 0 !== A.stencilFunc && (i.stencilFunc = A.stencilFunc), void 0 !== A.stencilRef && (i.stencilRef = A.stencilRef), void 0 !== A.stencilFuncMask && (i.stencilFuncMask = A.stencilFuncMask), void 0 !== A.stencilFail && (i.stencilFail = A.stencilFail), void 0 !== A.stencilZFail && (i.stencilZFail = A.stencilZFail), void 0 !== A.stencilZPass && (i.stencilZPass = A.stencilZPass), void 0 !== A.wireframe && (i.wireframe = A.wireframe), void 0 !== A.wireframeLinewidth && (i.wireframeLinewidth = A.wireframeLinewidth), void 0 !== A.wireframeLinecap && (i.wireframeLinecap = A.wireframeLinecap), void 0 !== A.wireframeLinejoin && (i.wireframeLinejoin = A.wireframeLinejoin), void 0 !== A.rotation && (i.rotation = A.rotation), 1 !== A.linewidth && (i.linewidth = A.linewidth), void 0 !== A.dashSize && (i.dashSize = A.dashSize), void 0 !== A.gapSize && (i.gapSize = A.gapSize), void 0 !== A.scale && (i.scale = A.scale), void 0 !== A.polygonOffset && (i.polygonOffset = A.polygonOffset), void 0 !== A.polygonOffsetFactor && (i.polygonOffsetFactor = A.polygonOffsetFactor), void 0 !== A.polygonOffsetUnits && (i.polygonOffsetUnits = A.polygonOffsetUnits), void 0 !== A.skinning && (i.skinning = A.skinning), void 0 !== A.morphTargets && (i.morphTargets = A.morphTargets), void 0 !== A.morphNormals && (i.morphNormals = A.morphNormals), void 0 !== A.dithering && (i.dithering = A.dithering), void 0 !== A.vertexTangents && (i.vertexTangents = A.vertexTangents), void 0 !== A.visible && (i.visible = A.visible), void 0 !== A.toneMapped && (i.toneMapped = A.toneMapped), void 0 !== A.userData && (i.userData = A.userData), void 0 !== A.vertexColors && (i.vertexColors = "number" == typeof A.vertexColors ? A.vertexColors > 0 : A.vertexColors), void 0 !== A.uniforms) for (var o in A.uniforms) { var n = A.uniforms[o]; switch (i.uniforms[o] = {}, n.type) { case "t": i.uniforms[o].value = t(n.value); break; case "c": i.uniforms[o].value = (new LA).setHex(n.value); break; case "v2": i.uniforms[o].value = (new s).fromArray(n.value); break; case "v3": i.uniforms[o].value = (new y).fromArray(n.value); break; case "v4": i.uniforms[o].value = (new p).fromArray(n.value); break; case "m3": i.uniforms[o].value = (new l).fromArray(n.value); case "m4": i.uniforms[o].value = (new M).fromArray(n.value); break; default: i.uniforms[o].value = n.value } } if (void 0 !== A.defines && (i.defines = A.defines), void 0 !== A.vertexShader && (i.vertexShader = A.vertexShader), void 0 !== A.fragmentShader && (i.fragmentShader = A.fragmentShader), void 0 !== A.extensions) for (var r in A.extensions) i.extensions[r] = A.extensions[r]; if (void 0 !== A.shading && (i.flatShading = 1 === A.shading), void 0 !== A.size && (i.size = A.size), void 0 !== A.sizeAttenuation && (i.sizeAttenuation = A.sizeAttenuation), void 0 !== A.map && (i.map = t(A.map)), void 0 !== A.matcap && (i.matcap = t(A.matcap)), void 0 !== A.alphaMap && (i.alphaMap = t(A.alphaMap)), void 0 !== A.bumpMap && (i.bumpMap = t(A.bumpMap)), void 0 !== A.bumpScale && (i.bumpScale = A.bumpScale), void 0 !== A.normalMap && (i.normalMap = t(A.normalMap)), void 0 !== A.normalMapType && (i.normalMapType = A.normalMapType), void 0 !== A.normalScale) { var a = A.normalScale; !1 === Array.isArray(a) && (a = [a, a]), i.normalScale = (new s).fromArray(a) } return void 0 !== A.displacementMap && (i.displacementMap = t(A.displacementMap)), void 0 !== A.displacementScale && (i.displacementScale = A.displacementScale), void 0 !== A.displacementBias && (i.displacementBias = A.displacementBias), void 0 !== A.roughnessMap && (i.roughnessMap = t(A.roughnessMap)), void 0 !== A.metalnessMap && (i.metalnessMap = t(A.metalnessMap)), void 0 !== A.emissiveMap && (i.emissiveMap = t(A.emissiveMap)), void 0 !== A.emissiveIntensity && (i.emissiveIntensity = A.emissiveIntensity), void 0 !== A.specularMap && (i.specularMap = t(A.specularMap)), void 0 !== A.envMap && (i.envMap = t(A.envMap)), void 0 !== A.envMapIntensity && (i.envMapIntensity = A.envMapIntensity), void 0 !== A.reflectivity && (i.reflectivity = A.reflectivity), void 0 !== A.refractionRatio && (i.refractionRatio = A.refractionRatio), void 0 !== A.lightMap && (i.lightMap = t(A.lightMap)), void 0 !== A.lightMapIntensity && (i.lightMapIntensity = A.lightMapIntensity), void 0 !== A.aoMap && (i.aoMap = t(A.aoMap)), void 0 !== A.aoMapIntensity && (i.aoMapIntensity = A.aoMapIntensity), void 0 !== A.gradientMap && (i.gradientMap = t(A.gradientMap)), void 0 !== A.clearcoatMap && (i.clearcoatMap = t(A.clearcoatMap)), void 0 !== A.clearcoatRoughnessMap && (i.clearcoatRoughnessMap = t(A.clearcoatRoughnessMap)), void 0 !== A.clearcoatNormalMap && (i.clearcoatNormalMap = t(A.clearcoatNormalMap)), void 0 !== A.clearcoatNormalScale && (i.clearcoatNormalScale = (new s).fromArray(A.clearcoatNormalScale)), i }, setTextures: function (A) { return this.textures = A, this } }); var La = { decodeText: function (A) { if ("undefined" != typeof TextDecoder) return (new TextDecoder).decode(A); for (var e = "", t = 0, i = A.length; i > t; t++) e += String.fromCharCode(A[t]); try { return decodeURIComponent(escape(e)) } catch (A) { return e } }, extractUrlBase: function (A) { var e = A.lastIndexOf("/"); return -1 === e ? "./" : A.substr(0, e + 1) } }; function Na() { he.call(this), this.type = "InstancedBufferGeometry", this.maxInstancedCount = void 0 } function Oa(A, e, t, i) { "number" == typeof t && (i = t, t = !1, console.error("THREE.InstancedBufferAttribute: The constructor now expects normalized as the third argument.")), YA.call(this, A, e, t), this.meshPerAttribute = i || 1 } function Va(A) { Yr.call(this, A) } Na.prototype = Object.assign(Object.create(he.prototype), { constructor: Na, isInstancedBufferGeometry: !0, copy: function (A) { return he.prototype.copy.call(this, A), this.maxInstancedCount = A.maxInstancedCount, this }, clone: function () { return (new this.constructor).copy(this) }, toJSON: function () { var A = he.prototype.toJSON.call(this); return A.maxInstancedCount = this.maxInstancedCount, A.isInstancedBufferGeometry = !0, A } }), Oa.prototype = Object.assign(Object.create(YA.prototype), { constructor: Oa, isInstancedBufferAttribute: !0, copy: function (A) { return YA.prototype.copy.call(this, A), this.meshPerAttribute = A.meshPerAttribute, this }, toJSON: function () { var A = YA.prototype.toJSON.call(this); return A.meshPerAttribute = this.meshPerAttribute, A.isInstancedBufferAttribute = !0, A } }), Va.prototype = Object.assign(Object.create(Yr.prototype), { constructor: Va, load: function (A, e, t, i) { var o = this, n = new Jr(o.manager); n.setPath(o.path), n.load(A, (function (A) { e(o.parse(JSON.parse(A))) }), t, i) }, parse: function (A) { var e = A.isInstancedBufferGeometry ? new Na : new he, t = A.data.index; if (void 0 !== t) { var i = new Ga[t.type](t.array); e.setIndex(new YA(i, 1)) } var o = A.data.attributes; for (var n in o) { i = new Ga[(d = o[n]).type](d.array); var r = new(d.isInstancedBufferAttribute ? Oa : YA)(i, d.itemSize, d.normalized); void 0 !== d.name && (r.name = d.name), e.setAttribute(n, r) } var a = A.data.morphAttributes; if (a) for (var n in a) { for (var s = a[n], l = [], c = 0, h = s.length; h > c; c++) { var d; r = new YA(i = new Ga[(d = s[c]).type](d.array), d.itemSize, d.normalized); void 0 !== d.name && (r.name = d.name), l.push(r) } e.morphAttributes[n] = l } A.data.morphTargetsRelative && (e.morphTargetsRelative = !0); var p = A.data.groups || A.data.drawcalls || A.data.offsets; if (void 0 !== p) { c = 0; for (var g = p.length; c !== g; ++c) { var u = p[c]; e.addGroup(u.start, u.count, u.materialIndex) } } var f = A.data.boundingSphere; if (void 0 !== f) { var m = new y; void 0 !== f.center && m.fromArray(f.center), e.boundingSphere = new cA(m, f.radius) } return A.name && (e.name = A.name), A.userData && (e.userData = A.userData), e } }); var Ga = { Int8Array: Int8Array, Uint8Array: Uint8Array, Uint8ClampedArray: "undefined" != typeof Uint8ClampedArray ? Uint8ClampedArray : Uint8Array, Int16Array: Int16Array, Uint16Array: Uint16Array, Int32Array: Int32Array, Uint32Array: Uint32Array, Float32Array: Float32Array, Float64Array: Float64Array }; function Pa(A) { Yr.call(this, A) } Pa.prototype = Object.assign(Object.create(Yr.prototype), { constructor: Pa, load: function (A, e, t, i) { var o = this, n = "" === this.path ? La.extractUrlBase(A) : this.path; this.resourcePath = this.resourcePath || n; var r = new Jr(o.manager); r.setPath(this.path), r.load(A, (function (t) { var n = null; try { n = JSON.parse(t) } catch (e) { return void 0 !== i && i(e), void console.error("THREE:ObjectLoader: Can't parse " + A + ".", e.message) } var r = n.metadata; void 0 !== r && void 0 !== r.type && "geometry" !== r.type.toLowerCase() ? o.parse(n, e) : console.error("THREE.ObjectLoader: Can't load " + A) }), t, i) }, parse: function (A, e) { var t = this.parseShape(A.shapes), i = this.parseGeometries(A.geometries, t), o = this.parseImages(A.images, (function () { void 0 !== e && e(a) })), n = this.parseTextures(A.textures, o), r = this.parseMaterials(A.materials, n), a = this.parseObject(A.object, i, r); return A.animations && (a.animations = this.parseAnimations(A.animations)), void 0 !== A.images && 0 !== A.images.length || void 0 !== e && e(a), a }, parseShape: function (A) { var e = {}; if (void 0 !== A) for (var t = 0, i = A.length; i > t; t++) { var o = (new Ba).fromJSON(A[t]); e[o.uuid] = o } return e }, parseGeometries: function (A, e) { var t = {}; if (void 0 !== A) for (var i = new Va, o = 0, n = A.length; n > o; o++) { var r, a = A[o]; switch (a.type) { case "PlaneGeometry": case "PlaneBufferGeometry": r = new fr[a.type](a.width, a.height, a.widthSegments, a.heightSegments); break; case "BoxGeometry": case "BoxBufferGeometry": case "CubeGeometry": r = new fr[a.type](a.width, a.height, a.depth, a.widthSegments, a.heightSegments, a.depthSegments); break; case "CircleGeometry": case "CircleBufferGeometry": r = new fr[a.type](a.radius, a.segments, a.thetaStart, a.thetaLength); break; case "CylinderGeometry": case "CylinderBufferGeometry": r = new fr[a.type](a.radiusTop, a.radiusBottom, a.height, a.radialSegments, a.heightSegments, a.openEnded, a.thetaStart, a.thetaLength); break; case "ConeGeometry": case "ConeBufferGeometry": r = new fr[a.type](a.radius, a.height, a.radialSegments, a.heightSegments, a.openEnded, a.thetaStart, a.thetaLength); break; case "SphereGeometry": case "SphereBufferGeometry": r = new fr[a.type](a.radius, a.widthSegments, a.heightSegments, a.phiStart, a.phiLength, a.thetaStart, a.thetaLength); break; case "DodecahedronGeometry": case "DodecahedronBufferGeometry": case "IcosahedronGeometry": case "IcosahedronBufferGeometry": case "OctahedronGeometry": case "OctahedronBufferGeometry": case "TetrahedronGeometry": case "TetrahedronBufferGeometry": r = new fr[a.type](a.radius, a.detail); break; case "RingGeometry": case "RingBufferGeometry": r = new fr[a.type](a.innerRadius, a.outerRadius, a.thetaSegments, a.phiSegments, a.thetaStart, a.thetaLength); break; case "TorusGeometry": case "TorusBufferGeometry": r = new fr[a.type](a.radius, a.tube, a.radialSegments, a.tubularSegments, a.arc); break; case "TorusKnotGeometry": case "TorusKnotBufferGeometry": r = new fr[a.type](a.radius, a.tube, a.tubularSegments, a.radialSegments, a.p, a.q); break; case "TubeGeometry": case "TubeBufferGeometry": r = new fr[a.type]((new va[a.path.type]).fromJSON(a.path), a.tubularSegments, a.radius, a.radialSegments, a.closed); break; case "LatheGeometry": case "LatheBufferGeometry": r = new fr[a.type](a.points, a.segments, a.phiStart, a.phiLength); break; case "PolyhedronGeometry": case "PolyhedronBufferGeometry": r = new fr[a.type](a.vertices, a.indices, a.radius, a.details); break; case "ShapeGeometry": case "ShapeBufferGeometry": for (var s = [], l = 0, c = a.shapes.length; c > l; l++) { s.push(e[a.shapes[l]]) } r = new fr[a.type](s, a.curveSegments); break; case "ExtrudeGeometry": case "ExtrudeBufferGeometry": for (s = [], l = 0, c = a.shapes.length; c > l; l++) { s.push(e[a.shapes[l]]) } var h = a.options.extrudePath; void 0 !== h && (a.options.extrudePath = (new va[h.type]).fromJSON(h)), r = new fr[a.type](s, a.options); break; case "BufferGeometry": case "InstancedBufferGeometry": r = i.parse(a); break; case "Geometry": console.error('THREE.ObjectLoader: Loading "Geometry" is not supported anymore.'); break; default: console.warn('THREE.ObjectLoader: Unsupported geometry type "' + a.type + '"'); continue } r.uuid = a.uuid, void 0 !== a.name && (r.name = a.name), !0 === r.isBufferGeometry && void 0 !== a.userData && (r.userData = a.userData), t[a.uuid] = r } return t }, parseMaterials: function (A, e) { var t = {}, i = {}; if (void 0 !== A) { var o = new Da; o.setTextures(e); for (var n = 0, r = A.length; r > n; n++) { var a = A[n]; if ("MultiMaterial" === a.type) { for (var s = [], l = 0; a.materials.length > l; l++) { var c = a.materials[l]; void 0 === t[c.uuid] && (t[c.uuid] = o.parse(c)), s.push(t[c.uuid]) } i[a.uuid] = s } else void 0 === t[a.uuid] && (t[a.uuid] = o.parse(a)), i[a.uuid] = t[a.uuid] } } return i }, parseAnimations: function (A) { for (var e = [], t = 0; A.length > t; t++) { var i = A[t], o = Gr.parse(i); void 0 !== i.uuid && (o.uuid = i.uuid), e.push(o) } return e }, parseImages: function (A, e) { var t = this, i = {}; function o(A) { return t.manager.itemStart(A), n.load(A, (function () { t.manager.itemEnd(A) }), void 0, (function () { t.manager.itemError(A), t.manager.itemEnd(A) })) } if (void 0 !== A && A.length > 0) { var n = new _r(new jr(e)); n.setCrossOrigin(this.crossOrigin); for (var r = 0, a = A.length; a > r; r++) { var s = A[r], l = s.url; if (Array.isArray(l)) { i[s.uuid] = []; for (var c = 0, h = l.length; h > c; c++) { var d = l[c], p = /^(\/\/)|([a-z]+:(\/\/)?)/i.test(d) ? d : t.resourcePath + d; i[s.uuid].push(o(p)) } } else { p = /^(\/\/)|([a-z]+:(\/\/)?)/i.test(s.url) ? s.url : t.resourcePath + s.url; i[s.uuid] = o(p) } } } return i }, parseTextures: function (A, e) { function t(A, e) { return "number" == typeof A ? A : (console.warn("THREE.ObjectLoader.parseTexture: Constant should be in numeric form.", A), e[A]) } var i = {}; if (void 0 !== A) for (var o = 0, n = A.length; n > o; o++) { var r, a = A[o]; void 0 === a.image && console.warn('THREE.ObjectLoader: No "image" specified for', a.uuid), void 0 === e[a.image] && console.warn("THREE.ObjectLoader: Undefined image", a.image), (r = Array.isArray(e[a.image]) ? new ut(e[a.image]) : new d(e[a.image])).needsUpdate = !0, r.uuid = a.uuid, void 0 !== a.name && (r.name = a.name), void 0 !== a.mapping && (r.mapping = t(a.mapping, ja)), void 0 !== a.offset && r.offset.fromArray(a.offset), void 0 !== a.repeat && r.repeat.fromArray(a.repeat), void 0 !== a.center && r.center.fromArray(a.center), void 0 !== a.rotation && (r.rotation = a.rotation), void 0 !== a.wrap && (r.wrapS = t(a.wrap[0], Ha), r.wrapT = t(a.wrap[1], Ha)), void 0 !== a.format && (r.format = a.format), void 0 !== a.type && (r.type = a.type), void 0 !== a.encoding && (r.encoding = a.encoding), void 0 !== a.minFilter && (r.minFilter = t(a.minFilter, Ya)), void 0 !== a.magFilter && (r.magFilter = t(a.magFilter, Ya)), void 0 !== a.anisotropy && (r.anisotropy = a.anisotropy), void 0 !== a.flipY && (r.flipY = a.flipY), void 0 !== a.premultiplyAlpha && (r.premultiplyAlpha = a.premultiplyAlpha), void 0 !== a.unpackAlignment && (r.unpackAlignment = a.unpackAlignment), i[a.uuid] = r } return i }, parseObject: function (A, e, t) { var i; function o(A) { return void 0 === e[A] && console.warn("THREE.ObjectLoader: Undefined geometry", A), e[A] } function n(A) { if (void 0 !== A) { if (Array.isArray(A)) { for (var e = [], i = 0, o = A.length; o > i; i++) { var n = A[i]; void 0 === t[n] && console.warn("THREE.ObjectLoader: Undefined material", n), e.push(t[n]) } return e } return void 0 === t[A] && console.warn("THREE.ObjectLoader: Undefined material", A), t[A] } } switch (A.type) { case "Scene": i = new Y, void 0 !== A.background && Number.isInteger(A.background) && (i.background = new LA(A.background)), void 0 !== A.fog && ("Fog" === A.fog.type ? i.fog = new eo(A.fog.color, A.fog.near, A.fog.far) : "FogExp2" === A.fog.type && (i.fog = new Ao(A.fog.color, A.fog.density))); break; case "PerspectiveCamera": i = new je(A.fov, A.aspect, A.near, A.far), void 0 !== A.focus && (i.focus = A.focus), void 0 !== A.zoom && (i.zoom = A.zoom), void 0 !== A.filmGauge && (i.filmGauge = A.filmGauge), void 0 !== A.filmOffset && (i.filmOffset = A.filmOffset), void 0 !== A.view && (i.view = Object.assign({}, A.view)); break; case "OrthographicCamera": i = new Ka(A.left, A.right, A.top, A.bottom, A.near, A.far), void 0 !== A.zoom && (i.zoom = A.zoom), void 0 !== A.view && (i.view = Object.assign({}, A.view)); break; case "AmbientLight": i = new Ta(A.color, A.intensity); break; case "DirectionalLight": i = new Ra(A.color, A.intensity); break; case "PointLight": i = new Fa(A.color, A.intensity, A.distance, A.decay); break; case "RectAreaLight": i = new ka(A.color, A.intensity, A.width, A.height); break; case "SpotLight": i = new ba(A.color, A.intensity, A.distance, A.angle, A.penumbra, A.decay); break; case "HemisphereLight": i = new Sa(A.color, A.groundColor, A.intensity); break; case "SkinnedMesh": console.warn("THREE.ObjectLoader.parseObject() does not support SkinnedMesh yet."); case "Mesh": i = new Ue(r = o(A.geometry), a = n(A.material)); break; case "InstancedMesh": var r = o(A.geometry), a = n(A.material), s = A.instanceMatrix; (i = new To(r, a, A.count)).instanceMatrix = new YA(new Float32Array(s.array), 16); break; case "LOD": i = new xo; break; case "Line": i = new Go(o(A.geometry), n(A.material), A.mode); break; case "LineLoop": i = new Ho(o(A.geometry), n(A.material)); break; case "LineSegments": i = new jo(o(A.geometry), n(A.material)); break; case "PointCloud": case "Points": i = new Xo(o(A.geometry), n(A.material)); break; case "Sprite": i = new vo(n(A.material)); break; case "Group": i = new Xi; break; default: i = new H } if (i.uuid = A.uuid, void 0 !== A.name && (i.name = A.name), void 0 !== A.matrix ? (i.matrix.fromArray(A.matrix), void 0 !== A.matrixAutoUpdate && (i.matrixAutoUpdate = A.matrixAutoUpdate), i.matrixAutoUpdate && i.matrix.decompose(i.position, i.quaternion, i.scale)) : (void 0 !== A.position && i.position.fromArray(A.position), void 0 !== A.rotation && i.rotation.fromArray(A.rotation), void 0 !== A.quaternion && i.quaternion.fromArray(A.quaternion), void 0 !== A.scale && i.scale.fromArray(A.scale)), void 0 !== A.castShadow && (i.castShadow = A.castShadow), void 0 !== A.receiveShadow && (i.receiveShadow = A.receiveShadow), A.shadow && (void 0 !== A.shadow.bias && (i.shadow.bias = A.shadow.bias), void 0 !== A.shadow.radius && (i.shadow.radius = A.shadow.radius), void 0 !== A.shadow.mapSize && i.shadow.mapSize.fromArray(A.shadow.mapSize), void 0 !== A.shadow.camera && (i.shadow.camera = this.parseObject(A.shadow.camera))), void 0 !== A.visible && (i.visible = A.visible), void 0 !== A.frustumCulled && (i.frustumCulled = A.frustumCulled), void 0 !== A.renderOrder && (i.renderOrder = A.renderOrder), void 0 !== A.userData && (i.userData = A.userData), void 0 !== A.layers && (i.layers.mask = A.layers), void 0 !== A.children) for (var l = A.children, c = 0; l.length > c; c++) i.add(this.parseObject(l[c], e, t)); if ("LOD" === A.type) { void 0 !== A.autoUpdate && (i.autoUpdate = A.autoUpdate); for (var h = A.levels, d = 0; h.length > d; d++) { var p = h[d], g = i.getObjectByProperty("uuid", p.object); void 0 !== g && i.addLevel(g, p.distance) } } return i } }); var qa, ja = { UVMapping: 300, CubeReflectionMapping: 301, CubeRefractionMapping: 302, EquirectangularReflectionMapping: 303, EquirectangularRefractionMapping: 304, SphericalReflectionMapping: 305, CubeUVReflectionMapping: 306, CubeUVRefractionMapping: 307 }, Ha = { RepeatWrapping: 1e3, ClampToEdgeWrapping: 1001, MirroredRepeatWrapping: 1002 }, Ya = { NearestFilter: 1003, NearestMipmapNearestFilter: 1004, NearestMipmapLinearFilter: 1005, LinearFilter: 1006, LinearMipmapNearestFilter: 1007, LinearMipmapLinearFilter: 1008 }; function Wa(A) { "undefined" == typeof createImageBitmap && console.warn("THREE.ImageBitmapLoader: createImageBitmap() not supported."), "undefined" == typeof fetch && console.warn("THREE.ImageBitmapLoader: fetch() not supported."), Yr.call(this, A), this.options = void 0 } function Ja() { this.type = "ShapePath", this.color = new LA, this.subPaths = [], this.currentPath = null } function za(A) { this.type = "Font", this.data = A } function Za(A, e, t, i, o) { var n = o.glyphs[A] || o.glyphs["?"]; if (n) { var r, a, s, l, c, h, d, p, g = new Ja; if (n.o) for (var u = n._cachedOutline || (n._cachedOutline = n.o.split(" ")), f = 0, m = u.length; m > f;) { switch (u[f++]) { case "m": r = u[f++] * e + t, a = u[f++] * e + i, g.moveTo(r, a); break; case "l": r = u[f++] * e + t, a = u[f++] * e + i, g.lineTo(r, a); break; case "q": s = u[f++] * e + t, l = u[f++] * e + i, c = u[f++] * e + t, h = u[f++] * e + i, g.quadraticCurveTo(c, h, s, l); break; case "b": s = u[f++] * e + t, l = u[f++] * e + i, c = u[f++] * e + t, h = u[f++] * e + i, d = u[f++] * e + t, p = u[f++] * e + i, g.bezierCurveTo(c, h, d, p, s, l) } } return { offsetX: n.ha * e, path: g } } console.error('THREE.Font: character "' + A + '" does not exists in font family ' + o.familyName + ".") } function Xa(A) { Yr.call(this, A) } Wa.prototype = Object.assign(Object.create(Yr.prototype), { constructor: Wa, setOptions: function (A) { return this.options = A, this }, load: function (A, e, t, i) { void 0 === A && (A = ""), void 0 !== this.path && (A = this.path + A), A = this.manager.resolveURL(A); var o = this, n = qr.get(A); if (void 0 !== n) return o.manager.itemStart(A), setTimeout((function () { e && e(n), o.manager.itemEnd(A) }), 0), n; fetch(A).then((function (A) { return A.blob() })).then((function (A) { return void 0 === o.options ? createImageBitmap(A) : createImageBitmap(A, o.options) })).then((function (t) { qr.add(A, t), e && e(t), o.manager.itemEnd(A) })).catch((function (e) { i && i(e), o.manager.itemError(A), o.manager.itemEnd(A) })), o.manager.itemStart(A) } }), Object.assign(Ja.prototype, { moveTo: function (A, e) { return this.currentPath = new Ea, this.subPaths.push(this.currentPath), this.currentPath.moveTo(A, e), this }, lineTo: function (A, e) { return this.currentPath.lineTo(A, e), this }, quadraticCurveTo: function (A, e, t, i) { return this.currentPath.quadraticCurveTo(A, e, t, i), this }, bezierCurveTo: function (A, e, t, i, o, n) { return this.currentPath.bezierCurveTo(A, e, t, i, o, n), this }, splineThru: function (A) { return this.currentPath.splineThru(A), this }, toShapes: function (A, e) { function t(A) { for (var e = [], t = 0, i = A.length; i > t; t++) { var o = A[t], n = new Ba; n.curves = o.curves, e.push(n) } return e } function i(A, e) { for (var t = e.length, i = !1, o = t - 1, n = 0; t > n; o = n++) { var r = e[o], a = e[n], s = a.x - r.x, l = a.y - r.y; if (Math.abs(l) > Number.EPSILON) { if (0 > l && (r = e[n], s = -s, a = e[o], l = -l), r.y > A.y || A.y > a.y) continue; if (A.y === r.y) { if (A.x === r.x) return !0 } else { var c = l * (A.x - r.x) - s * (A.y - r.y); if (0 === c) return !0; if (0 > c) continue; i = !i } } else { if (A.y !== r.y) continue; if (A.x >= a.x && r.x >= A.x || A.x >= r.x && a.x >= A.x) return !0 } } return i } var o = Hn.isClockWise, n = this.subPaths; if (0 === n.length) return []; if (!0 === e) return t(n); var r, a, s, l = []; if (1 === n.length) return a = n[0], (s = new Ba).curves = a.curves, l.push(s), l; var c = !o(n[0].getPoints()); c = A ? !c : c; var h, d, p = [], g = [], u = [], f = 0; g[f] = void 0, u[f] = []; for (var m = 0, C = n.length; C > m; m++) r = o(h = (a = n[m]).getPoints()), (r = A ? !r : r) ? (!c && g[f] && f++, g[f] = { s: new Ba, p: h }, g[f].s.curves = a.curves, c && f++, u[f] = []) : u[f].push({ h: a, p: h[0] }); if (!g[0]) return t(n); if (g.length > 1) { for (var y = !1, v = [], I = 0, E = g.length; E > I; I++) p[I] = []; for (I = 0, E = g.length; E > I; I++) for (var B = u[I], x = 0; B.length > x; x++) { for (var S = B[x], w = !0, M = 0; g.length > M; M++) i(S.p, g[M].p) && (I !== M && v.push({ froms: I, tos: M, hole: x }), w ? (w = !1, p[M].push(S)) : y = !0); w && p[I].push(S) } v.length > 0 && (y || (u = p)) } m = 0; for (var b = g.length; b > m; m++) { l.push(s = g[m].s); for (var U = 0, F = (d = u[m]).length; F > U; U++) s.holes.push(d[U].h) } return l } }), Object.assign(za.prototype, { isFont: !0, generateShapes: function (A, e) { void 0 === e && (e = 100); for (var t = [], i = function (A, e, t) { for (var i = Array.from ? Array.from(A) : String(A).split(""), o = e / t.resolution, n = (t.boundingBox.yMax - t.boundingBox.yMin + t.underlineThickness) * o, r = [], a = 0, s = 0, l = 0; i.length > l; l++) { var c = i[l]; if ("\n" === c) a = 0, s -= n; else { var h = Za(c, o, a, s, t); a += h.offsetX, r.push(h.path) } } return r }(A, e, this.data), o = 0, n = i.length; n > o; o++) Array.prototype.push.apply(t, i[o].toShapes()); return t } }), Xa.prototype = Object.assign(Object.create(Yr.prototype), { constructor: Xa, load: function (A, e, t, i) { var o = this, n = new Jr(this.manager); n.setPath(this.path), n.load(A, (function (A) { var t; try { t = JSON.parse(A) } catch (e) { console.warn("THREE.FontLoader: typeface.js support is being deprecated. Use typeface.json instead."), t = JSON.parse(A.substring(65, A.length - 2)) } var i = o.parse(t); e && e(i) }), t, i) }, parse: function (A) { return new za(A) } }); var _a = { getContext: function () { return void 0 === qa && (qa = new(window.AudioContext || window.webkitAudioContext)), qa }, setContext: function (A) { qa = A } }; function $a(A) { Yr.call(this, A) } function As() { this.coefficients = []; for (var A = 0; 9 > A; A++) this.coefficients.push(new y) } function es(A, e) { xa.call(this, void 0, e), this.sh = void 0 !== A ? A : new As } function ts(A, e, t) { es.call(this, void 0, t); var i = (new LA).set(A), o = (new LA).set(e), n = new y(i.r, i.g, i.b), r = new y(o.r, o.g, o.b), a = Math.sqrt(Math.PI), s = a * Math.sqrt(.75); this.sh.coefficients[0].copy(n).add(r).multiplyScalar(a), this.sh.coefficients[1].copy(n).sub(r).multiplyScalar(s) } function is(A, e) { es.call(this, void 0, e); var t = (new LA).set(A); this.sh.coefficients[0].set(t.r, t.g, t.b).multiplyScalar(2 * Math.sqrt(Math.PI)) } $a.prototype = Object.assign(Object.create(Yr.prototype), { constructor: $a, load: function (A, e, t, i) { var o = new Jr(this.manager); o.setResponseType("arraybuffer"), o.setPath(this.path), o.load(A, (function (A) { var t = A.slice(0); _a.getContext().decodeAudioData(t, (function (A) { e(A) })) }), t, i) } }), Object.assign(As.prototype, { isSphericalHarmonics3: !0, set: function (A) { for (var e = 0; 9 > e; e++) this.coefficients[e].copy(A[e]); return this }, zero: function () { for (var A = 0; 9 > A; A++) this.coefficients[A].set(0, 0, 0); return this }, getAt: function (A, e) { var t = A.x, i = A.y, o = A.z, n = this.coefficients; return e.copy(n[0]).multiplyScalar(.282095), e.addScaledVector(n[1], .488603 * i), e.addScaledVector(n[2], .488603 * o), e.addScaledVector(n[3], .488603 * t), e.addScaledVector(n[4], t * i * 1.092548), e.addScaledVector(n[5], i * o * 1.092548), e.addScaledVector(n[6], .315392 * (3 * o * o - 1)), e.addScaledVector(n[7], t * o * 1.092548), e.addScaledVector(n[8], .546274 * (t * t - i * i)), e }, getIrradianceAt: function (A, e) { var t = A.x, i = A.y, o = A.z, n = this.coefficients; return e.copy(n[0]).multiplyScalar(.886227), e.addScaledVector(n[1], 1.023328 * i), e.addScaledVector(n[2], 1.023328 * o), e.addScaledVector(n[3], 1.023328 * t), e.addScaledVector(n[4], .858086 * t * i), e.addScaledVector(n[5], .858086 * i * o), e.addScaledVector(n[6], .743125 * o * o - .247708), e.addScaledVector(n[7], .858086 * t * o), e.addScaledVector(n[8], .429043 * (t * t - i * i)), e }, add: function (A) { for (var e = 0; 9 > e; e++) this.coefficients[e].add(A.coefficients[e]); return this }, addScaledSH: function (A, e) { for (var t = 0; 9 > t; t++) this.coefficients[t].addScaledVector(A.coefficients[t], e); return this }, scale: function (A) { for (var e = 0; 9 > e; e++) this.coefficients[e].multiplyScalar(A); return this }, lerp: function (A, e) { for (var t = 0; 9 > t; t++) this.coefficients[t].lerp(A.coefficients[t], e); return this }, equals: function (A) { for (var e = 0; 9 > e; e++) if (!this.coefficients[e].equals(A.coefficients[e])) return !1; return !0 }, copy: function (A) { return this.set(A.coefficients) }, clone: function () { return (new this.constructor).copy(this) }, fromArray: function (A, e) { void 0 === e && (e = 0); for (var t = this.coefficients, i = 0; 9 > i; i++) t[i].fromArray(A, e + 3 * i); return this }, toArray: function (A, e) { void 0 === A && (A = []), void 0 === e && (e = 0); for (var t = this.coefficients, i = 0; 9 > i; i++) t[i].toArray(A, e + 3 * i); return A } }), Object.assign(As, { getBasisAt: function (A, e) { var t = A.x, i = A.y, o = A.z; e[0] = .282095, e[1] = .488603 * i, e[2] = .488603 * o, e[3] = .488603 * t, e[4] = 1.092548 * t * i, e[5] = 1.092548 * i * o, e[6] = .315392 * (3 * o * o - 1), e[7] = 1.092548 * t * o, e[8] = .546274 * (t * t - i * i) } }), es.prototype = Object.assign(Object.create(xa.prototype), { constructor: es, isLightProbe: !0, copy: function (A) { return xa.prototype.copy.call(this, A), this.sh.copy(A.sh), this.intensity = A.intensity, this }, toJSON: function (A) { return xa.prototype.toJSON.call(this, A) } }), ts.prototype = Object.assign(Object.create(es.prototype), { constructor: ts, isHemisphereLightProbe: !0, copy: function (A) { return es.prototype.copy.call(this, A), this }, toJSON: function (A) { return es.prototype.toJSON.call(this, A) } }), is.prototype = Object.assign(Object.create(es.prototype), { constructor: is, isAmbientLightProbe: !0, copy: function (A) { return es.prototype.copy.call(this, A), this }, toJSON: function (A) { return es.prototype.toJSON.call(this, A) } }); var os = new M, ns = new M; function rs() { this.type = "StereoCamera", this.aspect = 1, this.eyeSep = .064, this.cameraL = new je, this.cameraL.layers.enable(1), this.cameraL.matrixAutoUpdate = !1, this.cameraR = new je, this.cameraR.layers.enable(2), this.cameraR.matrixAutoUpdate = !1, this._cache = { focus: null, fov: null, aspect: null, near: null, far: null, zoom: null, eyeSep: null } } function as(A) { this.autoStart = void 0 === A || A, this.startTime = 0, this.oldTime = 0, this.elapsedTime = 0, this.running = !1 } Object.assign(rs.prototype, { update: function (A) { var e = this._cache; if (e.focus !== A.focus || e.fov !== A.fov || e.aspect !== A.aspect * this.aspect || e.near !== A.near || e.far !== A.far || e.zoom !== A.zoom || e.eyeSep !== this.eyeSep) { e.focus = A.focus, e.fov = A.fov, e.aspect = A.aspect * this.aspect, e.near = A.near, e.far = A.far, e.zoom = A.zoom, e.eyeSep = this.eyeSep; var t, i, o = A.projectionMatrix.clone(), n = e.eyeSep / 2, r = n * e.near / e.focus, s = e.near * Math.tan(a.DEG2RAD * e.fov * .5) / e.zoom; ns.elements[12] = -n, os.elements[12] = n, o.elements[0] = 2 * e.near / ((i = s * e.aspect + r) - (t = -s * e.aspect + r)), o.elements[8] = (i + t) / (i - t), this.cameraL.projectionMatrix.copy(o), o.elements[0] = 2 * e.near / ((i = s * e.aspect - r) - (t = -s * e.aspect - r)), o.elements[8] = (i + t) / (i - t), this.cameraR.projectionMatrix.copy(o) } this.cameraL.matrixWorld.copy(A.matrixWorld).multiply(ns), this.cameraR.matrixWorld.copy(A.matrixWorld).multiply(os) } }), Object.assign(as.prototype, { start: function () { this.startTime = ("undefined" == typeof performance ? Date : performance).now(), this.oldTime = this.startTime, this.elapsedTime = 0, this.running = !0 }, stop: function () { this.getElapsedTime(), this.running = !1, this.autoStart = !1 }, getElapsedTime: function () { return this.getDelta(), this.elapsedTime }, getDelta: function () { var A = 0; if (this.autoStart && !this.running) return this.start(), 0; if (this.running) { var e = ("undefined" == typeof performance ? Date : performance).now(); A = (e - this.oldTime) / 1e3, this.oldTime = e, this.elapsedTime += A } return A } }); var ss = new y, ls = new f, cs = new y, hs = new y; function ds() { H.call(this), this.type = "AudioListener", this.context = _a.getContext(), this.gain = this.context.createGain(), this.gain.connect(this.context.destination), this.filter = null, this.timeDelta = 0, this._clock = new as } function ps(A) { H.call(this), this.type = "Audio", this.listener = A, this.context = A.context, this.gain = this.context.createGain(), this.gain.connect(A.getInput()), this.autoplay = !1, this.buffer = null, this.detune = 0, this.loop = !1, this.loopStart = 0, this.loopEnd = 0, this.offset = 0, this.duration = void 0, this.playbackRate = 1, this.isPlaying = !1, this.hasPlaybackControl = !0, this.sourceType = "empty", this._startedAt = 0, this._pausedAt = 0, this.filters = [] } ds.prototype = Object.assign(Object.create(H.prototype), { constructor: ds, getInput: function () { return this.gain }, removeFilter: function () { return null !== this.filter && (this.gain.disconnect(this.filter), this.filter.disconnect(this.context.destination), this.gain.connect(this.context.destination), this.filter = null), this }, getFilter: function () { return this.filter }, setFilter: function (A) { return null !== this.filter ? (this.gain.disconnect(this.filter), this.filter.disconnect(this.context.destination)) : this.gain.disconnect(this.context.destination), this.filter = A, this.gain.connect(this.filter), this.filter.connect(this.context.destination), this }, getMasterVolume: function () { return this.gain.gain.value }, setMasterVolume: function (A) { return this.gain.gain.setTargetAtTime(A, this.context.currentTime, .01), this }, updateMatrixWorld: function (A) { H.prototype.updateMatrixWorld.call(this, A); var e = this.context.listener, t = this.up; if (this.timeDelta = this._clock.getDelta(), this.matrixWorld.decompose(ss, ls, cs), hs.set(0, 0, -1).applyQuaternion(ls), e.positionX) { var i = this.context.currentTime + this.timeDelta; e.positionX.linearRampToValueAtTime(ss.x, i), e.positionY.linearRampToValueAtTime(ss.y, i), e.positionZ.linearRampToValueAtTime(ss.z, i), e.forwardX.linearRampToValueAtTime(hs.x, i), e.forwardY.linearRampToValueAtTime(hs.y, i), e.forwardZ.linearRampToValueAtTime(hs.z, i), e.upX.linearRampToValueAtTime(t.x, i), e.upY.linearRampToValueAtTime(t.y, i), e.upZ.linearRampToValueAtTime(t.z, i) } else e.setPosition(ss.x, ss.y, ss.z), e.setOrientation(hs.x, hs.y, hs.z, t.x, t.y, t.z) } }), ps.prototype = Object.assign(Object.create(H.prototype), { constructor: ps, getOutput: function () { return this.gain }, setNodeSource: function (A) { return this.hasPlaybackControl = !1, this.sourceType = "audioNode", this.source = A, this.connect(), this }, setMediaElementSource: function (A) { return this.hasPlaybackControl = !1, this.sourceType = "mediaNode", this.source = this.context.createMediaElementSource(A), this.connect(), this }, setMediaStreamSource: function (A) { return this.hasPlaybackControl = !1, this.sourceType = "mediaStreamNode", this.source = this.context.createMediaStreamSource(A), this.connect(), this }, setBuffer: function (A) { return this.buffer = A, this.sourceType = "buffer", this.autoplay && this.play(), this }, play: function (A) { if (void 0 === A && (A = 0), !0 !== this.isPlaying) { if (!1 !== this.hasPlaybackControl) { this._startedAt = this.context.currentTime + A; var e = this.context.createBufferSource(); return e.buffer = this.buffer, e.loop = this.loop, e.loopStart = this.loopStart, e.loopEnd = this.loopEnd, e.onended = this.onEnded.bind(this), e.start(this._startedAt, this._pausedAt + this.offset, this.duration), this.isPlaying = !0, this.source = e, this.setDetune(this.detune), this.setPlaybackRate(this.playbackRate), this.connect() } console.warn("THREE.Audio: this Audio has no playback control.") } else console.warn("THREE.Audio: Audio is already playing.") }, pause: function () { if (!1 !== this.hasPlaybackControl) return !0 === this.isPlaying && (this._pausedAt += Math.max(this.context.currentTime - this._startedAt, 0) * this.playbackRate, this.source.stop(), this.source.onended = null, this.isPlaying = !1), this; console.warn("THREE.Audio: this Audio has no playback control.") }, stop: function () { if (!1 !== this.hasPlaybackControl) return this._pausedAt = 0, this.source.stop(), this.source.onended = null, this.isPlaying = !1, this; console.warn("THREE.Audio: this Audio has no playback control.") }, connect: function () { if (this.filters.length > 0) { this.source.connect(this.filters[0]); for (var A = 1, e = this.filters.length; e > A; A++) this.filters[A - 1].connect(this.filters[A]); this.filters[this.filters.length - 1].connect(this.getOutput()) } else this.source.connect(this.getOutput()); return this }, disconnect: function () { if (this.filters.length > 0) { this.source.disconnect(this.filters[0]); for (var A = 1, e = this.filters.length; e > A; A++) this.filters[A - 1].disconnect(this.filters[A]); this.filters[this.filters.length - 1].disconnect(this.getOutput()) } else this.source.disconnect(this.getOutput()); return this }, getFilters: function () { return this.filters }, setFilters: function (A) { return A || (A = []), !0 === this.isPlaying ? (this.disconnect(), this.filters = A, this.connect()) : this.filters = A, this }, setDetune: function (A) { if (this.detune = A, void 0 !== this.source.detune) return !0 === this.isPlaying && this.source.detune.setTargetAtTime(this.detune, this.context.currentTime, .01), this }, getDetune: function () { return this.detune }, getFilter: function () { return this.getFilters()[0] }, setFilter: function (A) { return this.setFilters(A ? [A] : []) }, setPlaybackRate: function (A) { if (!1 !== this.hasPlaybackControl) return this.playbackRate = A, !0 === this.isPlaying && this.source.playbackRate.setTargetAtTime(this.playbackRate, this.context.currentTime, .01), this; console.warn("THREE.Audio: this Audio has no playback control.") }, getPlaybackRate: function () { return this.playbackRate }, onEnded: function () { this.isPlaying = !1 }, getLoop: function () { return !1 === this.hasPlaybackControl ? (console.warn("THREE.Audio: this Audio has no playback control."), !1) : this.loop }, setLoop: function (A) { if (!1 !== this.hasPlaybackControl) return this.loop = A, !0 === this.isPlaying && (this.source.loop = this.loop), this; console.warn("THREE.Audio: this Audio has no playback control.") }, setLoopStart: function (A) { return this.loopStart = A, this }, setLoopEnd: function (A) { return this.loopEnd = A, this }, getVolume: function () { return this.gain.gain.value }, setVolume: function (A) { return this.gain.gain.setTargetAtTime(A, this.context.currentTime, .01), this } }); var gs = new y, us = new f, fs = new y, ms = new y; function Cs(A) { ps.call(this, A), this.panner = this.context.createPanner(), this.panner.panningModel = "HRTF", this.panner.connect(this.gain) } function ys(A, e) { this.analyser = A.context.createAnalyser(), this.analyser.fftSize = void 0 !== e ? e : 2048, this.data = new Uint8Array(this.analyser.frequencyBinCount), A.getOutput().connect(this.analyser) } function vs(A, e, t) { this.binding = A, this.valueSize = t; var i, o = Float64Array; switch (e) { case "quaternion": i = this._slerp; break; case "string": case "bool": o = Array, i = this._select; break; default: i = this._lerp } this.buffer = new o(4 * t), this._mixBufferRegion = i, this.cumulativeWeight = 0, this.useCount = 0, this.referenceCount = 0 } Cs.prototype = Object.assign(Object.create(ps.prototype), { constructor: Cs, getOutput: function () { return this.panner }, getRefDistance: function () { return this.panner.refDistance }, setRefDistance: function (A) { return this.panner.refDistance = A, this }, getRolloffFactor: function () { return this.panner.rolloffFactor }, setRolloffFactor: function (A) { return this.panner.rolloffFactor = A, this }, getDistanceModel: function () { return this.panner.distanceModel }, setDistanceModel: function (A) { return this.panner.distanceModel = A, this }, getMaxDistance: function () { return this.panner.maxDistance }, setMaxDistance: function (A) { return this.panner.maxDistance = A, this }, setDirectionalCone: function (A, e, t) { return this.panner.coneInnerAngle = A, this.panner.coneOuterAngle = e, this.panner.coneOuterGain = t, this }, updateMatrixWorld: function (A) { if (H.prototype.updateMatrixWorld.call(this, A), !0 !== this.hasPlaybackControl || !1 !== this.isPlaying) { this.matrixWorld.decompose(gs, us, fs), ms.set(0, 0, 1).applyQuaternion(us); var e = this.panner; if (e.positionX) { var t = this.context.currentTime + this.listener.timeDelta; e.positionX.linearRampToValueAtTime(gs.x, t), e.positionY.linearRampToValueAtTime(gs.y, t), e.positionZ.linearRampToValueAtTime(gs.z, t), e.orientationX.linearRampToValueAtTime(ms.x, t), e.orientationY.linearRampToValueAtTime(ms.y, t), e.orientationZ.linearRampToValueAtTime(ms.z, t) } else e.setPosition(gs.x, gs.y, gs.z), e.setOrientation(ms.x, ms.y, ms.z) } } }), Object.assign(ys.prototype, { getFrequencyData: function () { return this.analyser.getByteFrequencyData(this.data), this.data }, getAverageFrequency: function () { for (var A = 0, e = this.getFrequencyData(), t = 0; e.length > t; t++) A += e[t]; return A / e.length } }), Object.assign(vs.prototype, { accumulate: function (A, e) { var t = this.buffer, i = this.valueSize, o = A * i + i, n = this.cumulativeWeight; if (0 === n) { for (var r = 0; r !== i; ++r) t[o + r] = t[r]; n = e } else { this._mixBufferRegion(t, o, 0, e / (n += e), i) } this.cumulativeWeight = n }, apply: function (A) { var e = this.valueSize, t = this.buffer, i = A * e + e, o = this.cumulativeWeight, n = this.binding; (this.cumulativeWeight = 0, 1 > o) && this._mixBufferRegion(t, i, 3 * e, 1 - o, e); for (var r = e, a = e + e; r !== a; ++r) if (t[r] !== t[r + e]) { n.setValue(t, i); break } }, saveOriginalState: function () { var A = this.buffer, e = this.valueSize, t = 3 * e; this.binding.getValue(A, t); for (var i = e, o = t; i !== o; ++i) A[i] = A[t + i % e]; this.cumulativeWeight = 0 }, restoreOriginalState: function () { this.binding.setValue(this.buffer, 3 * this.valueSize) }, _select: function (A, e, t, i, o) { if (i >= .5) for (var n = 0; n !== o; ++n) A[e + n] = A[t + n] }, _slerp: function (A, e, t, i) { f.slerpFlat(A, e, A, e, A, t, i) }, _lerp: function (A, e, t, i, o) { for (var n = 1 - i, r = 0; r !== o; ++r) { var a = e + r; A[a] = A[a] * n + A[t + r] * i } } }); var Is = new RegExp("[\\[\\]\\.:\\/]", "g"), Es = "[^" + "\\[\\]\\.:\\/".replace("\\.", "") + "]", Bs = /((?:WC+[\/:])*)/.source.replace("WC", "[^\\[\\]\\.:\\/]"), xs = /(WCOD+)?/.source.replace("WCOD", Es), Ss = /(?:\.(WC+)(?:\[(.+)\])?)?/.source.replace("WC", "[^\\[\\]\\.:\\/]"), ws = /\.(WC+)(?:\[(.+)\])?/.source.replace("WC", "[^\\[\\]\\.:\\/]"), Ms = new RegExp("^" + Bs + xs + Ss + ws + "$"), bs = ["material", "materials", "bones"]; function Us(A, e, t) { var i = t || Fs.parseTrackName(e); this._targetGroup = A, this._bindings = A.subscribe_(e, i) } function Fs(A, e, t) { this.path = e, this.parsedPath = t || Fs.parseTrackName(e), this.node = Fs.findNode(A, this.parsedPath.nodeName) || A, this.rootNode = A } function Ks() { this.uuid = a.generateUUID(), this._objects = Array.prototype.slice.call(arguments), this.nCachedObjects_ = 0; var A = {}; this._indicesByUUID = A; for (var e = 0, t = arguments.length; e !== t; ++e) A[arguments[e].uuid] = e; this._paths = [], this._parsedPaths = [], this._bindings = [], this._bindingsIndicesByPath = {}; var i = this; this.stats = { objects: { get total() { return i._objects.length }, get inUse() { return this.total - i.nCachedObjects_ } }, get bindingsPerObject() { return i._bindings.length } } } function Qs(A, e, t) { this._mixer = A, this._clip = e, this._localRoot = t || null; for (var i = e.tracks, o = i.length, n = new Array(o), r = { endingStart: 2400, endingEnd: 2400 }, a = 0; a !== o; ++a) { var s = i[a].createInterpolant(null); n[a] = s, s.settings = r } this._interpolantSettings = r, this._interpolants = n, this._propertyBindings = new Array(o), this._cacheIndex = null, this._byClipCacheIndex = null, this._timeScaleInterpolant = null, this._weightInterpolant = null, this.loop = 2201, this._loopCount = -1, this._startTime = null, this.time = 0, this.timeScale = 1, this._effectiveTimeScale = 1, this.weight = 1, this._effectiveWeight = 1, this.repetitions = 1 / 0, this.paused = !1, this.enabled = !0, this.clampWhenFinished = !1, this.zeroSlopeAtStart = !0, this.zeroSlopeAtEnd = !0 } function Rs(A) { this._root = A, this._initMemoryManager(), this._accuIndex = 0, this.time = 0, this.timeScale = 1 } function Ts(A) { "string" == typeof A && (console.warn("THREE.Uniform: Type parameter is no longer needed."), A = arguments[1]), this.value = A } function ks(A, e, t) { to.call(this, A, e), this.meshPerAttribute = t || 1 } function Ds(A, e, t, i) { this.ray = new CA(A, e), this.near = t || 0, this.far = i || 1 / 0, this.camera = null, this.layers = new K, this.params = { Mesh: {}, Line: { threshold: 1 }, LOD: {}, Points: { threshold: 1 }, Sprite: {} }, Object.defineProperties(this.params, { PointCloud: { get: function () { return console.warn("THREE.Raycaster: params.PointCloud has been renamed to params.Points."), this.Points } } }) } function Ls(A, e) { return A.distance - e.distance } function Ns(A, e, t, i) { if (A.layers.test(e.layers) && A.raycast(e, t), !0 === i) for (var o = A.children, n = 0, r = o.length; r > n; n++) Ns(o[n], e, t, !0) } function Os(A, e, t) { return this.radius = void 0 !== A ? A : 1, this.phi = void 0 !== e ? e : 0, this.theta = void 0 !== t ? t : 0, this } function Vs(A, e, t) { return this.radius = void 0 !== A ? A : 1, this.theta = void 0 !== e ? e : 0, this.y = void 0 !== t ? t : 0, this } Object.assign(Us.prototype, { getValue: function (A, e) { this.bind(); var t = this._bindings[this._targetGroup.nCachedObjects_]; void 0 !== t && t.getValue(A, e) }, setValue: function (A, e) { for (var t = this._bindings, i = this._targetGroup.nCachedObjects_, o = t.length; i !== o; ++i) t[i].setValue(A, e) }, bind: function () { for (var A = this._bindings, e = this._targetGroup.nCachedObjects_, t = A.length; e !== t; ++e) A[e].bind() }, unbind: function () { for (var A = this._bindings, e = this._targetGroup.nCachedObjects_, t = A.length; e !== t; ++e) A[e].unbind() } }), Object.assign(Fs, { Composite: Us, create: function (A, e, t) { return A && A.isAnimationObjectGroup ? new Fs.Composite(A, e, t) : new Fs(A, e, t) }, sanitizeNodeName: function (A) { return A.replace(/\s/g, "_").replace(Is, "") }, parseTrackName: function (A) { var e = Ms.exec(A); if (!e) throw new Error("PropertyBinding: Cannot parse trackName: " + A); var t = { nodeName: e[2], objectName: e[3], objectIndex: e[4], propertyName: e[5], propertyIndex: e[6] }, i = t.nodeName && t.nodeName.lastIndexOf("."); if (void 0 !== i && -1 !== i) { var o = t.nodeName.substring(i + 1); - 1 !== bs.indexOf(o) && (t.nodeName = t.nodeName.substring(0, i), t.objectName = o) } if (null === t.propertyName || 0 === t.propertyName.length) throw new Error("PropertyBinding: can not parse propertyName from trackName: " + A); return t }, findNode: function (A, e) { if (!e || "" === e || "." === e || -1 === e || e === A.name || e === A.uuid) return A; if (A.skeleton) { var t = A.skeleton.getBoneByName(e); if (void 0 !== t) return t } if (A.children) { var i = function (A) { for (var t = 0; A.length > t; t++) { var o = A[t]; if (o.name === e || o.uuid === e) return o; var n = i(o.children); if (n) return n } return null }, o = i(A.children); if (o) return o } return null } }), Object.assign(Fs.prototype, { _getValue_unavailable: function () {}, _setValue_unavailable: function () {}, BindingType: { Direct: 0, EntireArray: 1, ArrayElement: 2, HasFromToArray: 3 }, Versioning: { None: 0, NeedsUpdate: 1, MatrixWorldNeedsUpdate: 2 }, GetterByBindingType: [function (A, e) { A[e] = this.node[this.propertyName] }, function (A, e) { for (var t = this.resolvedProperty, i = 0, o = t.length; i !== o; ++i) A[e++] = t[i] }, function (A, e) { A[e] = this.resolvedProperty[this.propertyIndex] }, function (A, e) { this.resolvedProperty.toArray(A, e) }], SetterByBindingTypeAndVersioning: [ [function (A, e) { this.targetObject[this.propertyName] = A[e] }, function (A, e) { this.targetObject[this.propertyName] = A[e], this.targetObject.needsUpdate = !0 }, function (A, e) { this.targetObject[this.propertyName] = A[e], this.targetObject.matrixWorldNeedsUpdate = !0 }], [function (A, e) { for (var t = this.resolvedProperty, i = 0, o = t.length; i !== o; ++i) t[i] = A[e++] }, function (A, e) { for (var t = this.resolvedProperty, i = 0, o = t.length; i !== o; ++i) t[i] = A[e++]; this.targetObject.needsUpdate = !0 }, function (A, e) { for (var t = this.resolvedProperty, i = 0, o = t.length; i !== o; ++i) t[i] = A[e++]; this.targetObject.matrixWorldNeedsUpdate = !0 }], [function (A, e) { this.resolvedProperty[this.propertyIndex] = A[e] }, function (A, e) { this.resolvedProperty[this.propertyIndex] = A[e], this.targetObject.needsUpdate = !0 }, function (A, e) { this.resolvedProperty[this.propertyIndex] = A[e], this.targetObject.matrixWorldNeedsUpdate = !0 }], [function (A, e) { this.resolvedProperty.fromArray(A, e) }, function (A, e) { this.resolvedProperty.fromArray(A, e), this.targetObject.needsUpdate = !0 }, function (A, e) { this.resolvedProperty.fromArray(A, e), this.targetObject.matrixWorldNeedsUpdate = !0 }] ], getValue: function (A, e) { this.bind(), this.getValue(A, e) }, setValue: function (A, e) { this.bind(), this.setValue(A, e) }, bind: function () { var A = this.node, e = this.parsedPath, t = e.objectName, i = e.propertyName, o = e.propertyIndex; if (A || (A = Fs.findNode(this.rootNode, e.nodeName) || this.rootNode, this.node = A), this.getValue = this._getValue_unavailable, this.setValue = this._setValue_unavailable, A) { if (t) { var n = e.objectIndex; switch (t) { case "materials": if (!A.material) return void console.error("THREE.PropertyBinding: Can not bind to material as node does not have a material.", this); if (!A.material.materials) return void console.error("THREE.PropertyBinding: Can not bind to material.materials as node.material does not have a materials array.", this); A = A.material.materials; break; case "bones": if (!A.skeleton) return void console.error("THREE.PropertyBinding: Can not bind to bones as node does not have a skeleton.", this); A = A.skeleton.bones; for (var r = 0; A.length > r; r++) if (A[r].name === n) { n = r; break } break; default: if (void 0 === A[t]) return void console.error("THREE.PropertyBinding: Can not bind to objectName of node undefined.", this); A = A[t] } if (void 0 !== n) { if (void 0 === A[n]) return void console.error("THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.", this, A); A = A[n] } } var a = A[i]; if (void 0 !== a) { var s = this.Versioning.None; this.targetObject = A, void 0 !== A.needsUpdate ? s = this.Versioning.NeedsUpdate : void 0 !== A.matrixWorldNeedsUpdate && (s = this.Versioning.MatrixWorldNeedsUpdate); var l = this.BindingType.Direct; if (void 0 !== o) { if ("morphTargetInfluences" === i) { if (!A.geometry) return void console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.", this); if (A.geometry.isBufferGeometry) { if (!A.geometry.morphAttributes) return void console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphAttributes.", this); for (r = 0; this.node.geometry.morphAttributes.position.length > r; r++) if (A.geometry.morphAttributes.position[r].name === o) { o = r; break } } else { if (!A.geometry.morphTargets) return void console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphTargets.", this); for (r = 0; this.node.geometry.morphTargets.length > r; r++) if (A.geometry.morphTargets[r].name === o) { o = r; break } } } l = this.BindingType.ArrayElement, this.resolvedProperty = a, this.propertyIndex = o } else void 0 !== a.fromArray && void 0 !== a.toArray ? (l = this.BindingType.HasFromToArray, this.resolvedProperty = a) : Array.isArray(a) ? (l = this.BindingType.EntireArray, this.resolvedProperty = a) : this.propertyName = i; this.getValue = this.GetterByBindingType[l], this.setValue = this.SetterByBindingTypeAndVersioning[l][s] } else { console.error("THREE.PropertyBinding: Trying to update property for track: " + e.nodeName + "." + i + " but it wasn't found.", A) } } else console.error("THREE.PropertyBinding: Trying to update node for track: " + this.path + " but it wasn't found.") }, unbind: function () { this.node = null, this.getValue = this._getValue_unbound, this.setValue = this._setValue_unbound } }), Object.assign(Fs.prototype, { _getValue_unbound: Fs.prototype.getValue, _setValue_unbound: Fs.prototype.setValue }), Object.assign(Ks.prototype, { isAnimationObjectGroup: !0, add: function () { for (var A = this._objects, e = A.length, t = this.nCachedObjects_, i = this._indicesByUUID, o = this._paths, n = this._parsedPaths, r = this._bindings, a = r.length, s = void 0, l = 0, c = arguments.length; l !== c; ++l) { var h = arguments[l], d = h.uuid, p = i[d]; if (void 0 === p) { p = e++, i[d] = p, A.push(h); for (var g = 0, u = a; g !== u; ++g) r[g].push(new Fs(h, o[g], n[g])) } else if (t > p) { s = A[p]; var f = --t, m = A[f]; i[m.uuid] = p, A[p] = m, i[d] = f, A[f] = h; for (g = 0, u = a; g !== u; ++g) { var C = r[g], y = C[f], v = C[p]; C[p] = y, void 0 === v && (v = new Fs(h, o[g], n[g])), C[f] = v } } else A[p] !== s && console.error("THREE.AnimationObjectGroup: Different objects with the same UUID detected. Clean the caches or recreate your infrastructure when reloading scenes.") } this.nCachedObjects_ = t }, remove: function () { for (var A = this._objects, e = this.nCachedObjects_, t = this._indicesByUUID, i = this._bindings, o = i.length, n = 0, r = arguments.length; n !== r; ++n) { var a = arguments[n], s = a.uuid, l = t[s]; if (void 0 !== l && l >= e) { var c = e++, h = A[c]; t[h.uuid] = l, A[l] = h, t[s] = c, A[c] = a; for (var d = 0, p = o; d !== p; ++d) { var g = i[d], u = g[c], f = g[l]; g[l] = u, g[c] = f } } } this.nCachedObjects_ = e }, uncache: function () { for (var A = this._objects, e = A.length, t = this.nCachedObjects_, i = this._indicesByUUID, o = this._bindings, n = o.length, r = 0, a = arguments.length; r !== a; ++r) { var s = arguments[r], l = s.uuid, c = i[l]; if (void 0 !== c) if (delete i[l], t > c) { var h = --t, d = A[h], p = A[C = --e]; i[d.uuid] = c, A[c] = d, i[p.uuid] = h, A[h] = p, A.pop(); for (var g = 0, u = n; g !== u; ++g) { var f = (y = o[g])[h], m = y[C]; y[c] = f, y[h] = m, y.pop() } } else { var C; i[(p = A[C = --e]).uuid] = c, A[c] = p, A.pop(); for (g = 0, u = n; g !== u; ++g) { var y; (y = o[g])[c] = y[C], y.pop() } } } this.nCachedObjects_ = t }, subscribe_: function (A, e) { var t = this._bindingsIndicesByPath, i = t[A], o = this._bindings; if (void 0 !== i) return o[i]; var n = this._paths, r = this._parsedPaths, a = this._objects, s = this.nCachedObjects_, l = new Array(a.length); t[A] = i = o.length, n.push(A), r.push(e), o.push(l); for (var c = s, h = a.length; c !== h; ++c) { l[c] = new Fs(a[c], A, e) } return l }, unsubscribe_: function (A) { var e = this._bindingsIndicesByPath, t = e[A]; if (void 0 !== t) { var i = this._paths, o = this._parsedPaths, n = this._bindings, r = n.length - 1, a = n[r]; e[A[r]] = t, n[t] = a, n.pop(), o[t] = o[r], o.pop(), i[t] = i[r], i.pop() } } }), Object.assign(Qs.prototype, { play: function () { return this._mixer._activateAction(this), this }, stop: function () { return this._mixer._deactivateAction(this), this.reset() }, reset: function () { return this.paused = !1, this.enabled = !0, this.time = 0, this._loopCount = -1, this._startTime = null, this.stopFading().stopWarping() }, isRunning: function () { return this.enabled && !this.paused && 0 !== this.timeScale && null === this._startTime && this._mixer._isActiveAction(this) }, isScheduled: function () { return this._mixer._isActiveAction(this) }, startAt: function (A) { return this._startTime = A, this }, setLoop: function (A, e) { return this.loop = A, this.repetitions = e, this }, setEffectiveWeight: function (A) { return this.weight = A, this._effectiveWeight = this.enabled ? A : 0, this.stopFading() }, getEffectiveWeight: function () { return this._effectiveWeight }, fadeIn: function (A) { return this._scheduleFading(A, 0, 1) }, fadeOut: function (A) { return this._scheduleFading(A, 1, 0) }, crossFadeFrom: function (A, e, t) { if (A.fadeOut(e), this.fadeIn(e), t) { var i = this._clip.duration, o = A._clip.duration, n = i / o; A.warp(1, o / i, e), this.warp(n, 1, e) } return this }, crossFadeTo: function (A, e, t) { return A.crossFadeFrom(this, e, t) }, stopFading: function () { var A = this._weightInterpolant; return null !== A && (this._weightInterpolant = null, this._mixer._takeBackControlInterpolant(A)), this }, setEffectiveTimeScale: function (A) { return this.timeScale = A, this._effectiveTimeScale = this.paused ? 0 : A, this.stopWarping() }, getEffectiveTimeScale: function () { return this._effectiveTimeScale }, setDuration: function (A) { return this.timeScale = this._clip.duration / A, this.stopWarping() }, syncWith: function (A) { return this.time = A.time, this.timeScale = A.timeScale, this.stopWarping() }, halt: function (A) { return this.warp(this._effectiveTimeScale, 0, A) }, warp: function (A, e, t) { var i = this._mixer, o = i.time, n = this._timeScaleInterpolant, r = this.timeScale; null === n && (n = i._lendControlInterpolant(), this._timeScaleInterpolant = n); var a = n.parameterPositions, s = n.sampleValues; return a[0] = o, a[1] = o + t, s[0] = A / r, s[1] = e / r, this }, stopWarping: function () { var A = this._timeScaleInterpolant; return null !== A && (this._timeScaleInterpolant = null, this._mixer._takeBackControlInterpolant(A)), this }, getMixer: function () { return this._mixer }, getClip: function () { return this._clip }, getRoot: function () { return this._localRoot || this._mixer._root }, _update: function (A, e, t, i) { if (this.enabled) { var o = this._startTime; if (null !== o) { var n = (A - o) * t; if (0 > n || 0 === t) return; this._startTime = null, e = t * n } e *= this._updateTimeScale(A); var r = this._updateTime(e), a = this._updateWeight(A); if (a > 0) for (var s = this._interpolants, l = this._propertyBindings, c = 0, h = s.length; c !== h; ++c) s[c].evaluate(r), l[c].accumulate(i, a) } else this._updateWeight(A) }, _updateWeight: function (A) { var e = 0; if (this.enabled) { e = this.weight; var t = this._weightInterpolant; if (null !== t) { var i = t.evaluate(A)[0]; e *= i, A > t.parameterPositions[1] && (this.stopFading(), 0 === i && (this.enabled = !1)) } } return this._effectiveWeight = e, e }, _updateTimeScale: function (A) { var e = 0; if (!this.paused) { e = this.timeScale; var t = this._timeScaleInterpolant; if (null !== t) e *= t.evaluate(A)[0], A > t.parameterPositions[1] && (this.stopWarping(), 0 === e ? this.paused = !0 : this.timeScale = e) } return this._effectiveTimeScale = e, e }, _updateTime: function (A) { var e = this.time + A, t = this._clip.duration, i = this.loop, o = this._loopCount, n = 2202 === i; if (0 === A) return -1 === o ? e : n && 1 == (1 & o) ? t - e : e; if (2200 === i) { -1 === o && (this._loopCount = 0, this._setEndings(!0, !0, !1)); A: { if (e < t) { if (e >= 0) { this.time = e; break A } e = 0 } else e = t; this.clampWhenFinished ? this.paused = !0 : this.enabled = !1, this.time = e, this._mixer.dispatchEvent({ type: "finished", action: this, direction: 0 > A ? -1 : 1 }) } } else { if (-1 === o && (0 > A ? this._setEndings(0 === this.repetitions, !0, n) : (o = 0, this._setEndings(!0, 0 === this.repetitions, n))), e >= t || 0 > e) { var r = Math.floor(e / t); e -= t * r, o += Math.abs(r); var a = this.repetitions - o; if (0 < a) { if (1 === a) { var s = 0 > A; this._setEndings(s, !s, n) } else this._setEndings(!1, !1, n); this._loopCount = o, this.time = e, this._mixer.dispatchEvent({ type: "loop", action: this, loopDelta: r }) } else this.clampWhenFinished ? this.paused = !0 : this.enabled = !1, this.time = e = A > 0 ? t : 0, this._mixer.dispatchEvent({ type: "finished", action: this, direction: A > 0 ? 1 : -1 }) } else this.time = e; if (n && 1 == (1 & o)) return t - e } return e }, _setEndings: function (A, e, t) { var i = this._interpolantSettings; t ? (i.endingStart = 2401, i.endingEnd = 2401) : (i.endingStart = A ? this.zeroSlopeAtStart ? 2401 : 2400 : 2402, i.endingEnd = e ? this.zeroSlopeAtEnd ? 2401 : 2400 : 2402) }, _scheduleFading: function (A, e, t) { var i = this._mixer, o = i.time, n = this._weightInterpolant; null === n && (n = i._lendControlInterpolant(), this._weightInterpolant = n); var r = n.parameterPositions, a = n.sampleValues; return r[0] = o, a[0] = e, r[1] = o + A, a[1] = t, this } }), Rs.prototype = Object.assign(Object.create(i.prototype), { constructor: Rs, _bindAction: function (A, e) { var t = A._localRoot || this._root, i = A._clip.tracks, o = i.length, n = A._propertyBindings, r = A._interpolants, a = t.uuid, s = this._bindingsByRootAndName, l = s[a]; void 0 === l && (s[a] = l = {}); for (var c = 0; c !== o; ++c) { var h = i[c], d = h.name, p = l[d]; if (void 0 !== p) n[c] = p; else { if (void 0 !== (p = n[c])) { null === p._cacheIndex && (++p.referenceCount, this._addInactiveBinding(p, a, d)); continue } ++(p = new vs(Fs.create(t, d, e && e._propertyBindings[c].binding.parsedPath), h.ValueTypeName, h.getValueSize())).referenceCount, this._addInactiveBinding(p, a, d), n[c] = p } r[c].resultBuffer = p.buffer } }, _activateAction: function (A) { if (!this._isActiveAction(A)) { if (null === A._cacheIndex) { var e = (A._localRoot || this._root).uuid, t = A._clip.uuid, i = this._actionsByClip[t]; this._bindAction(A, i && i.knownActions[0]), this._addInactiveAction(A, t, e) } for (var o = A._propertyBindings, n = 0, r = o.length; n !== r; ++n) { var a = o[n]; 0 == a.useCount++ && (this._lendBinding(a), a.saveOriginalState()) } this._lendAction(A) } }, _deactivateAction: function (A) { if (this._isActiveAction(A)) { for (var e = A._propertyBindings, t = 0, i = e.length; t !== i; ++t) { var o = e[t]; 0 == --o.useCount && (o.restoreOriginalState(), this._takeBackBinding(o)) } this._takeBackAction(A) } }, _initMemoryManager: function () { this._actions = [], this._nActiveActions = 0, this._actionsByClip = {}, this._bindings = [], this._nActiveBindings = 0, this._bindingsByRootAndName = {}, this._controlInterpolants = [], this._nActiveControlInterpolants = 0; var A = this; this.stats = { actions: { get total() { return A._actions.length }, get inUse() { return A._nActiveActions } }, bindings: { get total() { return A._bindings.length }, get inUse() { return A._nActiveBindings } }, controlInterpolants: { get total() { return A._controlInterpolants.length }, get inUse() { return A._nActiveControlInterpolants } } } }, _isActiveAction: function (A) { var e = A._cacheIndex; return null !== e && this._nActiveActions > e }, _addInactiveAction: function (A, e, t) { var i = this._actions, o = this._actionsByClip, n = o[e]; if (void 0 === n) n = { knownActions: [A], actionByRoot: {} }, A._byClipCacheIndex = 0, o[e] = n; else { var r = n.knownActions; A._byClipCacheIndex = r.length, r.push(A) } A._cacheIndex = i.length, i.push(A), n.actionByRoot[t] = A }, _removeInactiveAction: function (A) { var e = this._actions, t = e[e.length - 1], i = A._cacheIndex; t._cacheIndex = i, e[i] = t, e.pop(), A._cacheIndex = null; var o = A._clip.uuid, n = this._actionsByClip, r = n[o], a = r.knownActions, s = a[a.length - 1], l = A._byClipCacheIndex; s._byClipCacheIndex = l, a[l] = s, a.pop(), A._byClipCacheIndex = null, delete r.actionByRoot[(A._localRoot || this._root).uuid], 0 === a.length && delete n[o], this._removeInactiveBindingsForAction(A) }, _removeInactiveBindingsForAction: function (A) { for (var e = A._propertyBindings, t = 0, i = e.length; t !== i; ++t) { var o = e[t]; 0 == --o.referenceCount && this._removeInactiveBinding(o) } }, _lendAction: function (A) { var e = this._actions, t = A._cacheIndex, i = this._nActiveActions++, o = e[i]; A._cacheIndex = i, e[i] = A, o._cacheIndex = t, e[t] = o }, _takeBackAction: function (A) { var e = this._actions, t = A._cacheIndex, i = --this._nActiveActions, o = e[i]; A._cacheIndex = i, e[i] = A, o._cacheIndex = t, e[t] = o }, _addInactiveBinding: function (A, e, t) { var i = this._bindingsByRootAndName, o = i[e], n = this._bindings; void 0 === o && (i[e] = o = {}), o[t] = A, A._cacheIndex = n.length, n.push(A) }, _removeInactiveBinding: function (A) { var e = this._bindings, t = A.binding, i = t.rootNode.uuid, o = t.path, n = this._bindingsByRootAndName, r = n[i], a = e[e.length - 1], s = A._cacheIndex; a._cacheIndex = s, e[s] = a, e.pop(), delete r[o], 0 === Object.keys(r).length && delete n[i] }, _lendBinding: function (A) { var e = this._bindings, t = A._cacheIndex, i = this._nActiveBindings++, o = e[i]; A._cacheIndex = i, e[i] = A, o._cacheIndex = t, e[t] = o }, _takeBackBinding: function (A) { var e = this._bindings, t = A._cacheIndex, i = --this._nActiveBindings, o = e[i]; A._cacheIndex = i, e[i] = A, o._cacheIndex = t, e[t] = o }, _lendControlInterpolant: function () { var A = this._controlInterpolants, e = this._nActiveControlInterpolants++, t = A[e]; return void 0 === t && ((t = new Kr(new Float32Array(2), new Float32Array(2), 1, this._controlInterpolantsResultBuffer)).__cacheIndex = e, A[e] = t), t }, _takeBackControlInterpolant: function (A) { var e = this._controlInterpolants, t = A.__cacheIndex, i = --this._nActiveControlInterpolants, o = e[i]; A.__cacheIndex = i, e[i] = A, o.__cacheIndex = t, e[t] = o }, _controlInterpolantsResultBuffer: new Float32Array(1), clipAction: function (A, e) { var t = e || this._root, i = t.uuid, o = "string" == typeof A ? Gr.findByName(t, A) : A, n = null !== o ? o.uuid : A, r = this._actionsByClip[n], a = null; if (void 0 !== r) { var s = r.actionByRoot[i]; if (void 0 !== s) return s; a = r.knownActions[0], null === o && (o = a._clip) } if (null === o) return null; var l = new Qs(this, o, e); return this._bindAction(l, a), this._addInactiveAction(l, n, i), l }, existingAction: function (A, e) { var t = e || this._root, i = t.uuid, o = "string" == typeof A ? Gr.findByName(t, A) : A, n = this._actionsByClip[o ? o.uuid : A]; return void 0 !== n && n.actionByRoot[i] || null }, stopAllAction: function () { var A = this._actions, e = this._nActiveActions, t = this._bindings, i = this._nActiveBindings; this._nActiveActions = 0, this._nActiveBindings = 0; for (var o = 0; o !== e; ++o) A[o].reset(); for (o = 0; o !== i; ++o) t[o].useCount = 0; return this }, update: function (A) { for (var e = this._actions, t = this._nActiveActions, i = this.time += A *= this.timeScale, o = Math.sign(A), n = this._accuIndex ^= 1, r = 0; r !== t; ++r) { e[r]._update(i, A, o, n) } var a = this._bindings, s = this._nActiveBindings; for (r = 0; r !== s; ++r) a[r].apply(n); return this }, setTime: function (A) { this.time = 0; for (var e = 0; this._actions.length > e; e++) this._actions[e].time = 0; return this.update(A) }, getRoot: function () { return this._root }, uncacheClip: function (A) { var e = this._actions, t = A.uuid, i = this._actionsByClip, o = i[t]; if (void 0 !== o) { for (var n = o.knownActions, r = 0, a = n.length; r !== a; ++r) { var s = n[r]; this._deactivateAction(s); var l = s._cacheIndex, c = e[e.length - 1]; s._cacheIndex = null, s._byClipCacheIndex = null, c._cacheIndex = l, e[l] = c, e.pop(), this._removeInactiveBindingsForAction(s) } delete i[t] } }, uncacheRoot: function (A) { var e = A.uuid, t = this._actionsByClip; for (var i in t) { var o = t[i].actionByRoot[e]; void 0 !== o && (this._deactivateAction(o), this._removeInactiveAction(o)) } var n = this._bindingsByRootAndName[e]; if (void 0 !== n) for (var r in n) { var a = n[r]; a.restoreOriginalState(), this._removeInactiveBinding(a) } }, uncacheAction: function (A, e) { var t = this.existingAction(A, e); null !== t && (this._deactivateAction(t), this._removeInactiveAction(t)) } }), Ts.prototype.clone = function () { return new Ts(void 0 === this.value.clone ? this.value : this.value.clone()) }, ks.prototype = Object.assign(Object.create(to.prototype), { constructor: ks, isInstancedInterleavedBuffer: !0, copy: function (A) { return to.prototype.copy.call(this, A), this.meshPerAttribute = A.meshPerAttribute, this } }), Object.assign(Ds.prototype, { set: function (A, e) { this.ray.set(A, e) }, setFromCamera: function (A, e) { e && e.isPerspectiveCamera ? (this.ray.origin.setFromMatrixPosition(e.matrixWorld), this.ray.direction.set(A.x, A.y, .5).unproject(e).sub(this.ray.origin).normalize(), this.camera = e) : e && e.isOrthographicCamera ? (this.ray.origin.set(A.x, A.y, (e.near + e.far) / (e.near - e.far)).unproject(e), this.ray.direction.set(0, 0, -1).transformDirection(e.matrixWorld), this.camera = e) : console.error("THREE.Raycaster: Unsupported camera type.") }, intersectObject: function (A, e, t) { var i = t || []; return Ns(A, this, i, e), i.sort(Ls), i }, intersectObjects: function (A, e, t) { var i = t || []; if (!1 === Array.isArray(A)) return console.warn("THREE.Raycaster.intersectObjects: objects is not an Array."), i; for (var o = 0, n = A.length; n > o; o++) Ns(A[o], this, i, e); return i.sort(Ls), i } }), Object.assign(Os.prototype, { set: function (A, e, t) { return this.radius = A, this.phi = e, this.theta = t, this }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.radius = A.radius, this.phi = A.phi, this.theta = A.theta, this }, makeSafe: function () { return this.phi = Math.max(1e-6, Math.min(Math.PI - 1e-6, this.phi)), this }, setFromVector3: function (A) { return this.setFromCartesianCoords(A.x, A.y, A.z) }, setFromCartesianCoords: function (A, e, t) { return this.radius = Math.sqrt(A * A + e * e + t * t), 0 === this.radius ? (this.theta = 0, this.phi = 0) : (this.theta = Math.atan2(A, t), this.phi = Math.acos(a.clamp(e / this.radius, -1, 1))), this } }), Object.assign(Vs.prototype, { set: function (A, e, t) { return this.radius = A, this.theta = e, this.y = t, this }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.radius = A.radius, this.theta = A.theta, this.y = A.y, this }, setFromVector3: function (A) { return this.setFromCartesianCoords(A.x, A.y, A.z) }, setFromCartesianCoords: function (A, e, t) { return this.radius = Math.sqrt(A * A + t * t), this.theta = Math.atan2(A, t), this.y = e, this } }); var Gs = new s; function Ps(A, e) { this.min = void 0 !== A ? A : new s(1 / 0, 1 / 0), this.max = void 0 !== e ? e : new s(-1 / 0, -1 / 0) } Object.assign(Ps.prototype, { set: function (A, e) { return this.min.copy(A), this.max.copy(e), this }, setFromPoints: function (A) { this.makeEmpty(); for (var e = 0, t = A.length; t > e; e++) this.expandByPoint(A[e]); return this }, setFromCenterAndSize: function (A, e) { var t = Gs.copy(e).multiplyScalar(.5); return this.min.copy(A).sub(t), this.max.copy(A).add(t), this }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.min.copy(A.min), this.max.copy(A.max), this }, makeEmpty: function () { return this.min.x = this.min.y = 1 / 0, this.max.x = this.max.y = -1 / 0, this }, isEmpty: function () { return this.min.x > this.max.x || this.min.y > this.max.y }, getCenter: function (A) { return void 0 === A && (console.warn("THREE.Box2: .getCenter() target is now required"), A = new s), this.isEmpty() ? A.set(0, 0) : A.addVectors(this.min, this.max).multiplyScalar(.5) }, getSize: function (A) { return void 0 === A && (console.warn("THREE.Box2: .getSize() target is now required"), A = new s), this.isEmpty() ? A.set(0, 0) : A.subVectors(this.max, this.min) }, expandByPoint: function (A) { return this.min.min(A), this.max.max(A), this }, expandByVector: function (A) { return this.min.sub(A), this.max.add(A), this }, expandByScalar: function (A) { return this.min.addScalar(-A), this.max.addScalar(A), this }, containsPoint: function (A) { return !(this.min.x > A.x || A.x > this.max.x || this.min.y > A.y || A.y > this.max.y) }, containsBox: function (A) { return !(this.min.x > A.min.x || A.max.x > this.max.x || this.min.y > A.min.y || A.max.y > this.max.y) }, getParameter: function (A, e) { return void 0 === e && (console.warn("THREE.Box2: .getParameter() target is now required"), e = new s), e.set((A.x - this.min.x) / (this.max.x - this.min.x), (A.y - this.min.y) / (this.max.y - this.min.y)) }, intersectsBox: function (A) { return !(this.min.x > A.max.x || A.min.x > this.max.x || this.min.y > A.max.y || A.min.y > this.max.y) }, clampPoint: function (A, e) { return void 0 === e && (console.warn("THREE.Box2: .clampPoint() target is now required"), e = new s), e.copy(A).clamp(this.min, this.max) }, distanceToPoint: function (A) { return Gs.copy(A).clamp(this.min, this.max).sub(A).length() }, intersect: function (A) { return this.min.max(A.min), this.max.min(A.max), this }, union: function (A) { return this.min.min(A.min), this.max.max(A.max), this }, translate: function (A) { return this.min.add(A), this.max.add(A), this }, equals: function (A) { return A.min.equals(this.min) && A.max.equals(this.max) } }); var qs = new y, js = new y; function Hs(A, e) { this.start = void 0 !== A ? A : new y, this.end = void 0 !== e ? e : new y } function Ys(A) { H.call(this), this.material = A, this.render = function () {} } Object.assign(Hs.prototype, { set: function (A, e) { return this.start.copy(A), this.end.copy(e), this }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.start.copy(A.start), this.end.copy(A.end), this }, getCenter: function (A) { return void 0 === A && (console.warn("THREE.Line3: .getCenter() target is now required"), A = new y), A.addVectors(this.start, this.end).multiplyScalar(.5) }, delta: function (A) { return void 0 === A && (console.warn("THREE.Line3: .delta() target is now required"), A = new y), A.subVectors(this.end, this.start) }, distanceSq: function () { return this.start.distanceToSquared(this.end) }, distance: function () { return this.start.distanceTo(this.end) }, at: function (A, e) { return void 0 === e && (console.warn("THREE.Line3: .at() target is now required"), e = new y), this.delta(e).multiplyScalar(A).add(this.start) }, closestPointToPointParameter: function (A, e) { qs.subVectors(A, this.start), js.subVectors(this.end, this.start); var t = js.dot(js), i = js.dot(qs) / t; return e && (i = a.clamp(i, 0, 1)), i }, closestPointToPoint: function (A, e, t) { var i = this.closestPointToPointParameter(A, e); return void 0 === t && (console.warn("THREE.Line3: .closestPointToPoint() target is now required"), t = new y), this.delta(t).multiplyScalar(i).add(this.start) }, applyMatrix4: function (A) { return this.start.applyMatrix4(A), this.end.applyMatrix4(A), this }, equals: function (A) { return A.start.equals(this.start) && A.end.equals(this.end) } }), (Ys.prototype = Object.create(H.prototype)).constructor = Ys, Ys.prototype.isImmediateRenderObject = !0; var Ws = new y; function Js(A, e) { H.call(this), this.light = A, this.light.updateMatrixWorld(), this.matrix = A.matrixWorld, this.matrixAutoUpdate = !1, this.color = e; for (var t = new he, i = [0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1, 0, 0, 0, -1, 0, 1, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, -1, 1], o = 0, n = 1; 32 > o; o++, n++) { var r = o / 32 * Math.PI * 2, a = n / 32 * Math.PI * 2; i.push(Math.cos(r), Math.sin(r), 1, Math.cos(a), Math.sin(a), 1) } t.setAttribute("position", new Ae(i, 3)); var s = new ko({ fog: !1, toneMapped: !1 }); this.cone = new jo(t, s), this.add(this.cone), this.update() } (Js.prototype = Object.create(H.prototype)).constructor = Js, Js.prototype.dispose = function () { this.cone.geometry.dispose(), this.cone.material.dispose() }, Js.prototype.update = function () { this.light.updateMatrixWorld(); var A = this.light.distance ? this.light.distance : 1e3, e = A * Math.tan(this.light.angle); this.cone.scale.set(e, e, A), Ws.setFromMatrixPosition(this.light.target.matrixWorld), this.cone.lookAt(Ws), void 0 !== this.color ? this.cone.material.color.set(this.color) : this.cone.material.color.copy(this.light.color) }; var zs = new y, Zs = new M, Xs = new M; function _s(A) { for (var e = function A(e) { var t = []; e && e.isBone && t.push(e); for (var i = 0; e.children.length > i; i++) t.push.apply(t, A(e.children[i])); return t }(A), t = new he, i = [], o = [], n = new LA(0, 0, 1), r = new LA(0, 1, 0), a = 0; e.length > a; a++) { var s = e[a]; s.parent && s.parent.isBone && (i.push(0, 0, 0), i.push(0, 0, 0), o.push(n.r, n.g, n.b), o.push(r.r, r.g, r.b)) } t.setAttribute("position", new Ae(i, 3)), t.setAttribute("color", new Ae(o, 3)); var l = new ko({ vertexColors: !0, depthTest: !1, depthWrite: !1, toneMapped: !1, transparent: !0 }); jo.call(this, t, l), this.root = A, this.bones = e, this.matrix = A.matrixWorld, this.matrixAutoUpdate = !1 } function $s(A, e, t) { this.light = A, this.light.updateMatrixWorld(), this.color = t; var i = new er(e, 4, 2), o = new jA({ wireframe: !0, fog: !1, toneMapped: !1 }); Ue.call(this, i, o), this.matrix = this.light.matrixWorld, this.matrixAutoUpdate = !1, this.update() } (_s.prototype = Object.create(jo.prototype)).constructor = _s, _s.prototype.isSkeletonHelper = !0, _s.prototype.updateMatrixWorld = function (A) { var e = this.bones, t = this.geometry, i = t.getAttribute("position"); Xs.getInverse(this.root.matrixWorld); for (var o = 0, n = 0; e.length > o; o++) { var r = e[o]; r.parent && r.parent.isBone && (Zs.multiplyMatrices(Xs, r.matrixWorld), zs.setFromMatrixPosition(Zs), i.setXYZ(n, zs.x, zs.y, zs.z), Zs.multiplyMatrices(Xs, r.parent.matrixWorld), zs.setFromMatrixPosition(Zs), i.setXYZ(n + 1, zs.x, zs.y, zs.z), n += 2) } t.getAttribute("position").needsUpdate = !0, H.prototype.updateMatrixWorld.call(this, A) }, ($s.prototype = Object.create(Ue.prototype)).constructor = $s, $s.prototype.dispose = function () { this.geometry.dispose(), this.material.dispose() }, $s.prototype.update = function () { void 0 !== this.color ? this.material.color.set(this.color) : this.material.color.copy(this.light.color) }; var Al = new y, el = new LA, tl = new LA; function il(A, e, t) { H.call(this), this.light = A, this.light.updateMatrixWorld(), this.matrix = A.matrixWorld, this.matrixAutoUpdate = !1, this.color = t; var i = new dn(e); i.rotateY(.5 * Math.PI), this.material = new jA({ wireframe: !0, fog: !1, toneMapped: !1 }), void 0 === this.color && (this.material.vertexColors = !0); var o = i.getAttribute("position"), n = new Float32Array(3 * o.count); i.setAttribute("color", new YA(n, 3)), this.add(new Ue(i, this.material)), this.update() } function ol(A, e, t, i) { A = A || 10, e = e || 10, t = new LA(void 0 !== t ? t : 4473924), i = new LA(void 0 !== i ? i : 8947848); for (var o = e / 2, n = A / e, r = A / 2, a = [], s = [], l = 0, c = 0, h = -r; e >= l; l++, h += n) { a.push(-r, 0, h, r, 0, h), a.push(h, 0, -r, h, 0, r); var d = l === o ? t : i; d.toArray(s, c), d.toArray(s, c += 3), d.toArray(s, c += 3), d.toArray(s, c += 3), c += 3 } var p = new he; p.setAttribute("position", new Ae(a, 3)), p.setAttribute("color", new Ae(s, 3)); var g = new ko({ vertexColors: !0, toneMapped: !1 }); jo.call(this, p, g) } function nl(A, e, t, i, o, n) { A = A || 10, e = e || 16, t = t || 8, i = i || 64, o = new LA(void 0 !== o ? o : 4473924), n = new LA(void 0 !== n ? n : 8947848); var r, a, s, l, c, h, d, p = [], g = []; for (l = 0; e >= l; l++) s = l / e * (2 * Math.PI), r = Math.sin(s) * A, a = Math.cos(s) * A, p.push(0, 0, 0), p.push(r, 0, a), g.push((d = 1 & l ? o : n).r, d.g, d.b), g.push(d.r, d.g, d.b); for (l = 0; t >= l; l++) for (d = 1 & l ? o : n, h = A - A / t * l, c = 0; i > c; c++) s = c / i * (2 * Math.PI), r = Math.sin(s) * h, a = Math.cos(s) * h, p.push(r, 0, a), g.push(d.r, d.g, d.b), s = (c + 1) / i * (2 * Math.PI), r = Math.sin(s) * h, a = Math.cos(s) * h, p.push(r, 0, a), g.push(d.r, d.g, d.b); var u = new he; u.setAttribute("position", new Ae(p, 3)), u.setAttribute("color", new Ae(g, 3)); var f = new ko({ vertexColors: !0, toneMapped: !1 }); jo.call(this, u, f) } (il.prototype = Object.create(H.prototype)).constructor = il, il.prototype.dispose = function () { this.children[0].geometry.dispose(), this.children[0].material.dispose() }, il.prototype.update = function () { var A = this.children[0]; if (void 0 !== this.color) this.material.color.set(this.color); else { var e = A.geometry.getAttribute("color"); el.copy(this.light.color), tl.copy(this.light.groundColor); for (var t = 0, i = e.count; i > t; t++) { var o = i / 2 > t ? el : tl; e.setXYZ(t, o.r, o.g, o.b) } e.needsUpdate = !0 } A.lookAt(Al.setFromMatrixPosition(this.light.matrixWorld).negate()) }, ol.prototype = Object.assign(Object.create(jo.prototype), { constructor: ol, copy: function (A) { return jo.prototype.copy.call(this, A), this.geometry.copy(A.geometry), this.material.copy(A.material), this }, clone: function () { return (new this.constructor).copy(this) } }), (nl.prototype = Object.create(jo.prototype)).constructor = nl; var rl = new y, al = new y, sl = new y; function ll(A, e, t) { H.call(this), this.light = A, this.light.updateMatrixWorld(), this.matrix = A.matrixWorld, this.matrixAutoUpdate = !1, this.color = t, void 0 === e && (e = 1); var i = new he; i.setAttribute("position", new Ae([-e, e, 0, e, e, 0, e, -e, 0, -e, -e, 0, -e, e, 0], 3)); var o = new ko({ fog: !1, toneMapped: !1 }); this.lightPlane = new Go(i, o), this.add(this.lightPlane), (i = new he).setAttribute("position", new Ae([0, 0, 0, 0, 0, 1], 3)), this.targetLine = new Go(i, o), this.add(this.targetLine), this.update() } (ll.prototype = Object.create(H.prototype)).constructor = ll, ll.prototype.dispose = function () { this.lightPlane.geometry.dispose(), this.lightPlane.material.dispose(), this.targetLine.geometry.dispose(), this.targetLine.material.dispose() }, ll.prototype.update = function () { rl.setFromMatrixPosition(this.light.matrixWorld), al.setFromMatrixPosition(this.light.target.matrixWorld), sl.subVectors(al, rl), this.lightPlane.lookAt(al), void 0 !== this.color ? (this.lightPlane.material.color.set(this.color), this.targetLine.material.color.set(this.color)) : (this.lightPlane.material.color.copy(this.light.color), this.targetLine.material.color.copy(this.light.color)), this.targetLine.lookAt(al), this.targetLine.scale.z = sl.length() }; var cl = new y, hl = new qe; function dl(A) { var e = new he, t = new ko({ color: 16777215, vertexColors: !0, toneMapped: !1 }), i = [], o = [], n = {}, r = new LA(16755200), a = new LA(16711680), s = new LA(43775), l = new LA(16777215), c = new LA(3355443); function h(A, e, t) { d(A, t), d(e, t) } function d(A, e) { i.push(0, 0, 0), o.push(e.r, e.g, e.b), void 0 === n[A] && (n[A] = []), n[A].push(i.length / 3 - 1) } h("n1", "n2", r), h("n2", "n4", r), h("n4", "n3", r), h("n3", "n1", r), h("f1", "f2", r), h("f2", "f4", r), h("f4", "f3", r), h("f3", "f1", r), h("n1", "f1", r), h("n2", "f2", r), h("n3", "f3", r), h("n4", "f4", r), h("p", "n1", a), h("p", "n2", a), h("p", "n3", a), h("p", "n4", a), h("u1", "u2", s), h("u2", "u3", s), h("u3", "u1", s), h("c", "t", l), h("p", "c", c), h("cn1", "cn2", c), h("cn3", "cn4", c), h("cf1", "cf2", c), h("cf3", "cf4", c), e.setAttribute("position", new Ae(i, 3)), e.setAttribute("color", new Ae(o, 3)), jo.call(this, e, t), this.camera = A, this.camera.updateProjectionMatrix && this.camera.updateProjectionMatrix(), this.matrix = A.matrixWorld, this.matrixAutoUpdate = !1, this.pointMap = n, this.update() } function pl(A, e, t, i, o, n, r) { cl.set(o, n, r).unproject(i); var a = e[A]; if (void 0 !== a) for (var s = t.getAttribute("position"), l = 0, c = a.length; c > l; l++) s.setXYZ(a[l], cl.x, cl.y, cl.z) } (dl.prototype = Object.create(jo.prototype)).constructor = dl, dl.prototype.update = function () { var A = this.geometry, e = this.pointMap; hl.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse), pl("c", e, A, hl, 0, 0, -1), pl("t", e, A, hl, 0, 0, 1), pl("n1", e, A, hl, -1, -1, -1), pl("n2", e, A, hl, 1, -1, -1), pl("n3", e, A, hl, -1, 1, -1), pl("n4", e, A, hl, 1, 1, -1), pl("f1", e, A, hl, -1, -1, 1), pl("f2", e, A, hl, 1, -1, 1), pl("f3", e, A, hl, -1, 1, 1), pl("f4", e, A, hl, 1, 1, 1), pl("u1", e, A, hl, .7, 1.1, -1), pl("u2", e, A, hl, -.7, 1.1, -1), pl("u3", e, A, hl, 0, 2, -1), pl("cf1", e, A, hl, -1, 0, 1), pl("cf2", e, A, hl, 1, 0, 1), pl("cf3", e, A, hl, 0, -1, 1), pl("cf4", e, A, hl, 0, 1, 1), pl("cn1", e, A, hl, -1, 0, -1), pl("cn2", e, A, hl, 1, 0, -1), pl("cn3", e, A, hl, 0, -1, -1), pl("cn4", e, A, hl, 0, 1, -1), A.getAttribute("position").needsUpdate = !0 }; var gl = new aA; function ul(A, e) { this.object = A, void 0 === e && (e = 16776960); var t = new Uint16Array([0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7]), i = new Float32Array(24), o = new he; o.setIndex(new YA(t, 1)), o.setAttribute("position", new YA(i, 3)), jo.call(this, o, new ko({ color: e, toneMapped: !1 })), this.matrixAutoUpdate = !1, this.update() } function fl(A, e) { this.type = "Box3Helper", this.box = A, e = e || 16776960; var t = new Uint16Array([0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7]), i = new he; i.setIndex(new YA(t, 1)), i.setAttribute("position", new Ae([1, 1, 1, -1, 1, 1, -1, -1, 1, 1, -1, 1, 1, 1, -1, -1, 1, -1, -1, -1, -1, 1, -1, -1], 3)), jo.call(this, i, new ko({ color: e, toneMapped: !1 })), this.geometry.computeBoundingSphere() } function ml(A, e, t) { this.type = "PlaneHelper", this.plane = A, this.size = void 0 === e ? 1 : e; var i = void 0 !== t ? t : 16776960, o = new he; o.setAttribute("position", new Ae([1, -1, 1, -1, 1, 1, -1, -1, 1, 1, 1, 1, -1, 1, 1, -1, -1, 1, 1, -1, 1, 1, 1, 1, 0, 0, 1, 0, 0, 0], 3)), o.computeBoundingSphere(), Go.call(this, o, new ko({ color: i, toneMapped: !1 })); var n = new he; n.setAttribute("position", new Ae([1, 1, 1, -1, 1, 1, -1, -1, 1, 1, 1, 1, -1, -1, 1, 1, -1, 1], 3)), n.computeBoundingSphere(), this.add(new Ue(n, new jA({ color: i, opacity: .2, transparent: !0, depthWrite: !1, toneMapped: !1 }))) } (ul.prototype = Object.create(jo.prototype)).constructor = ul, ul.prototype.update = function (A) { if (void 0 !== A && console.warn("THREE.BoxHelper: .update() has no longer arguments."), void 0 !== this.object && gl.setFromObject(this.object), !gl.isEmpty()) { var e = gl.min, t = gl.max, i = this.geometry.attributes.position, o = i.array; o[0] = t.x, o[1] = t.y, o[2] = t.z, o[3] = e.x, o[4] = t.y, o[5] = t.z, o[6] = e.x, o[7] = e.y, o[8] = t.z, o[9] = t.x, o[10] = e.y, o[11] = t.z, o[12] = t.x, o[13] = t.y, o[14] = e.z, o[15] = e.x, o[16] = t.y, o[17] = e.z, o[18] = e.x, o[19] = e.y, o[20] = e.z, o[21] = t.x, o[22] = e.y, o[23] = e.z, i.needsUpdate = !0, this.geometry.computeBoundingSphere() } }, ul.prototype.setFromObject = function (A) { return this.object = A, this.update(), this }, ul.prototype.copy = function (A) { return jo.prototype.copy.call(this, A), this.object = A.object, this }, ul.prototype.clone = function () { return (new this.constructor).copy(this) }, (fl.prototype = Object.create(jo.prototype)).constructor = fl, fl.prototype.updateMatrixWorld = function (A) { var e = this.box; e.isEmpty() || (e.getCenter(this.position), e.getSize(this.scale), this.scale.multiplyScalar(.5), H.prototype.updateMatrixWorld.call(this, A)) }, (ml.prototype = Object.create(Go.prototype)).constructor = ml, ml.prototype.updateMatrixWorld = function (A) { var e = -this.plane.constant; 1e-8 > Math.abs(e) && (e = 1e-8), this.scale.set(.5 * this.size, .5 * this.size, e), this.children[0].material.side = 0 > e ? 1 : 0, this.lookAt(this.plane.normal), H.prototype.updateMatrixWorld.call(this, A) }; var Cl, yl, vl = new y; function Il(A, e, t, i, o, n) { H.call(this), void 0 === A && (A = new y(0, 0, 1)), void 0 === e && (e = new y(0, 0, 0)), void 0 === t && (t = 1), void 0 === i && (i = 16776960), void 0 === o && (o = .2 * t), void 0 === n && (n = .2 * o), void 0 === Cl && ((Cl = new he).setAttribute("position", new Ae([0, 0, 0, 0, 1, 0], 3)), (yl = new hr(0, .5, 1, 5, 1)).translate(0, -.5, 0)), this.position.copy(e), this.line = new Go(Cl, new ko({ color: i, toneMapped: !1 })), this.line.matrixAutoUpdate = !1, this.add(this.line), this.cone = new Ue(yl, new jA({ color: i, toneMapped: !1 })), this.cone.matrixAutoUpdate = !1, this.add(this.cone), this.setDirection(A), this.setLength(t, o, n) } function El(A) { var e = [0, 0, 0, A = A || 1, 0, 0, 0, 0, 0, 0, A, 0, 0, 0, 0, 0, 0, A], t = new he; t.setAttribute("position", new Ae(e, 3)), t.setAttribute("color", new Ae([1, 0, 0, 1, .6, 0, 0, 1, 0, .6, 1, 0, 0, 0, 1, 0, .6, 1], 3)); var i = new ko({ vertexColors: !0, toneMapped: !1 }); jo.call(this, t, i) } (Il.prototype = Object.create(H.prototype)).constructor = Il, Il.prototype.setDirection = function (A) { if (A.y > .99999) this.quaternion.set(0, 0, 0, 1); else if (-.99999 > A.y) this.quaternion.set(1, 0, 0, 0); else { vl.set(A.z, 0, -A.x).normalize(); var e = Math.acos(A.y); this.quaternion.setFromAxisAngle(vl, e) } }, Il.prototype.setLength = function (A, e, t) { void 0 === e && (e = .2 * A), void 0 === t && (t = .2 * e), this.line.scale.set(1, Math.max(1e-4, A - e), 1), this.line.updateMatrix(), this.cone.scale.set(t, e, t), this.cone.position.y = A, this.cone.updateMatrix() }, Il.prototype.setColor = function (A) { this.line.material.color.set(A), this.cone.material.color.set(A) }, Il.prototype.copy = function (A) { return H.prototype.copy.call(this, A, !1), this.line.copy(A.line), this.cone.copy(A.cone), this }, Il.prototype.clone = function () { return (new this.constructor).copy(this) }, (El.prototype = Object.create(jo.prototype)).constructor = El; var Bl, xl, Sl, wl, Ml = Math.pow(2, 8), bl = [.125, .215, .35, .446, .526, .582], Ul = 5 + bl.length, Fl = { 3e3: 0, 3001: 1, 3002: 2, 3004: 3, 3005: 4, 3006: 5, 3007: 6 }, Kl = new Ka, Ql = (Bl = 20, xl = new Float32Array(Bl), Sl = new y(0, 1, 0), (wl = new Cr({ defines: { n: Bl }, uniforms: { envMap: { value: null }, samples: { value: 1 }, weights: { value: xl }, latitudinal: { value: !1 }, dTheta: { value: 0 }, mipInt: { value: 0 }, poleAxis: { value: Sl }, inputEncoding: { value: Fl[3e3] }, outputEncoding: { value: Fl[3e3] } }, vertexShader: ec(), fragmentShader: `\nprecision mediump float;\nprecision mediump int;\nvarying vec3 vOutputDirection;\nuniform sampler2D envMap;\nuniform int samples;\nuniform float weights[n];\nuniform bool latitudinal;\nuniform float dTheta;\nuniform float mipInt;\nuniform vec3 poleAxis;\n\n${tc()}\n\n#define ENVMAP_TYPE_CUBE_UV\n#include \n\nvec3 getSample(float theta, vec3 axis) {\n\tfloat cosTheta = cos(theta);\n\t// Rodrigues' axis-angle rotation\n\tvec3 sampleDirection = vOutputDirection * cosTheta\n\t\t+ cross(axis, vOutputDirection) * sin(theta)\n\t\t+ axis * dot(axis, vOutputDirection) * (1.0 - cosTheta);\n\treturn bilinearCubeUV(envMap, sampleDirection, mipInt);\n}\n\nvoid main() {\n\tvec3 axis = latitudinal ? poleAxis : cross(poleAxis, vOutputDirection);\n\tif (all(equal(axis, vec3(0.0))))\n\t\taxis = vec3(vOutputDirection.z, 0.0, - vOutputDirection.x);\n\taxis = normalize(axis);\n\tgl_FragColor = vec4(0.0);\n\tgl_FragColor.rgb += weights[0] * getSample(0.0, axis);\n\tfor (int i = 1; i < n; i++) {\n\t\tif (i >= samples)\n\t\t\tbreak;\n\t\tfloat theta = dTheta * float(i);\n\t\tgl_FragColor.rgb += weights[i] * getSample(-1.0 * theta, axis);\n\t\tgl_FragColor.rgb += weights[i] * getSample(theta, axis);\n\t}\n\tgl_FragColor = linearToOutputTexel(gl_FragColor);\n}\n\t\t`, blending: 0, depthTest: !1, depthWrite: !1 })).type = "SphericalGaussianBlur", wl), Rl = null, Tl = null, { _lodPlanes: kl, _sizeLods: Dl, _sigmas: Ll } = function () { for (var A = [], e = [], t = [], i = 8, o = 0; Ul > o; o++) { var n = Math.pow(2, i); e.push(n); var r = 1 / n; o > 4 ? r = bl[o - 8 + 4 - 1] : 0 == o && (r = 0), t.push(r); for (var a = 1 / (n - 1), s = -a / 2, l = 1 + a / 2, c = [s, s, l, s, l, l, s, s, l, l, s, l], h = new Float32Array(108), d = new Float32Array(72), p = new Float32Array(36), g = 0; 6 > g; g++) { var u = g % 3 * 2 / 3 - 1, f = g > 2 ? 0 : -1; h.set([u, f, 0, u + 2 / 3, f, 0, u + 2 / 3, f + 1, 0, u, f, 0, u + 2 / 3, f + 1, 0, u, f + 1, 0], 18 * g), d.set(c, 12 * g), p.set([g, g, g, g, g, g], 6 * g) } var m = new he; m.setAttribute("position", new YA(h, 3)), m.setAttribute("uv", new YA(d, 2)), m.setAttribute("faceIndex", new YA(p, 1)), A.push(m), i > 4 && i-- } return { _lodPlanes: A, _sizeLods: e, _sigmas: t } }(), Nl = null, Ol = null, Vl = null, Gl = (1 + Math.sqrt(5)) / 2, Pl = 1 / Gl, ql = [new y(1, 1, 1), new y(-1, 1, 1), new y(1, 1, -1), new y(-1, 1, -1), new y(0, Gl, Pl), new y(0, Gl, -Pl), new y(Pl, 0, Gl), new y(-Pl, 0, Gl), new y(Gl, Pl, 0), new y(-Gl, Pl, 0)]; function jl(A) { Ol = A, Wl(Ql) } function Hl(A) { var e = { magFilter: 1003, minFilter: 1003, generateMipmaps: !1, type: A ? A.type : 1009, format: A ? A.format : 1023, encoding: A ? A.encoding : 3002, depthBuffer: !1, stencilBuffer: !1 }, t = Jl(e); return t.depthBuffer = !A, Nl = Jl(e), t } function Yl(A) { Nl.dispose(), Ol.setRenderTarget(Vl), A.scissorTest = !1, A.setSize(A.width, A.height) } function Wl(A) { var e = new Y; e.add(new Ue(kl[0], A)), Ol.compile(e, Kl) } function Jl(A) { var e = new g(3 * Ml, 3 * Ml, A); return e.texture.mapping = 306, e.texture.name = "PMREM.cubeUv", e.scissorTest = !0, e } function zl(A, e, t, i, o) { A.viewport.set(e, t, i, o), A.scissor.set(e, t, i, o) } function Zl(A) { var e = Ol.autoClear; Ol.autoClear = !1; for (var t = 1; Ul > t; t++) { Xl(A, t - 1, t, Math.sqrt(Ll[t] * Ll[t] - Ll[t - 1] * Ll[t - 1]), ql[(t - 1) % ql.length]) } Ol.autoClear = e } function Xl(A, e, t, i, o) { _l(A, Nl, e, t, i, "latitudinal", o), _l(Nl, A, t, t, i, "longitudinal", o) } function _l(A, e, t, i, o, n, r) { "latitudinal" !== n && "longitudinal" !== n && console.error("blur direction must be either latitudinal or longitudinal!"); var a = new Y; a.add(new Ue(kl[i], Ql)); var s = Ql.uniforms, l = Dl[t] - 1, c = isFinite(o) ? Math.PI / (2 * l) : 2 * Math.PI / 39, h = o / c, d = isFinite(o) ? 1 + Math.floor(3 * h) : 20; d > 20 && console.warn(`sigmaRadians, ${o}, is too large and will clip, as it requested ${d} samples when the maximum is set to 20`); for (var p = [], g = 0, u = 0; 20 > u; ++u) { var f = u / h, m = Math.exp(-f * f / 2); p.push(m), 0 == u ? g += m : d > u && (g += 2 * m) } for (u = 0; p.length > u; u++) p[u] = p[u] / g; s.envMap.value = A.texture, s.samples.value = d, s.weights.value = p, s.latitudinal.value = "latitudinal" === n, r && (s.poleAxis.value = r), s.dTheta.value = c, s.mipInt.value = 8 - t, s.inputEncoding.value = Fl[A.texture.encoding], s.outputEncoding.value = Fl[A.texture.encoding]; var C = Dl[i]; zl(e, f = 3 * Math.max(0, Ml - 2 * C), (0 === i ? 0 : 2 * Ml) + 2 * C * (i > 4 ? i - 8 + 4 : 0), 3 * C, 2 * C), Ol.setRenderTarget(e), Ol.render(a, Kl) } function $l() { var A = new Cr({ uniforms: { envMap: { value: null }, texelSize: { value: new s(1, 1) }, inputEncoding: { value: Fl[3e3] }, outputEncoding: { value: Fl[3e3] } }, vertexShader: ec(), fragmentShader: `\nprecision mediump float;\nprecision mediump int;\nvarying vec3 vOutputDirection;\nuniform sampler2D envMap;\nuniform vec2 texelSize;\n\n${tc()}\n\n#define RECIPROCAL_PI 0.31830988618\n#define RECIPROCAL_PI2 0.15915494\n\nvoid main() {\n\tgl_FragColor = vec4(0.0);\n\tvec3 outputDirection = normalize(vOutputDirection);\n\tvec2 uv;\n\tuv.y = asin(clamp(outputDirection.y, -1.0, 1.0)) * RECIPROCAL_PI + 0.5;\n\tuv.x = atan(outputDirection.z, outputDirection.x) * RECIPROCAL_PI2 + 0.5;\n\tvec2 f = fract(uv / texelSize - 0.5);\n\tuv -= f * texelSize;\n\tvec3 tl = envMapTexelToLinear(texture2D(envMap, uv)).rgb;\n\tuv.x += texelSize.x;\n\tvec3 tr = envMapTexelToLinear(texture2D(envMap, uv)).rgb;\n\tuv.y += texelSize.y;\n\tvec3 br = envMapTexelToLinear(texture2D(envMap, uv)).rgb;\n\tuv.x -= texelSize.x;\n\tvec3 bl = envMapTexelToLinear(texture2D(envMap, uv)).rgb;\n\tvec3 tm = mix(tl, tr, f.x);\n\tvec3 bm = mix(bl, br, f.x);\n\tgl_FragColor.rgb = mix(tm, bm, f.y);\n\tgl_FragColor = linearToOutputTexel(gl_FragColor);\n}\n\t\t`, blending: 0, depthTest: !1, depthWrite: !1 }); return A.type = "EquirectangularToCubeUV", A } function Ac() { var A = new Cr({ uniforms: { envMap: { value: null }, inputEncoding: { value: Fl[3e3] }, outputEncoding: { value: Fl[3e3] } }, vertexShader: ec(), fragmentShader: `\nprecision mediump float;\nprecision mediump int;\nvarying vec3 vOutputDirection;\nuniform samplerCube envMap;\n\n${tc()}\n\nvoid main() {\n\tgl_FragColor = vec4(0.0);\n\tgl_FragColor.rgb = envMapTexelToLinear(textureCube(envMap, vec3( - vOutputDirection.x, vOutputDirection.yz ))).rgb;\n\tgl_FragColor = linearToOutputTexel(gl_FragColor);\n}\n\t\t`, blending: 0, depthTest: !1, depthWrite: !1 }); return A.type = "CubemapToCubeUV", A } function ec() { return "\nprecision mediump float;\nprecision mediump int;\nattribute vec3 position;\nattribute vec2 uv;\nattribute float faceIndex;\nvarying vec3 vOutputDirection;\nvec3 getDirection(vec2 uv, float face) {\n\tuv = 2.0 * uv - 1.0;\n\tvec3 direction = vec3(uv, 1.0);\n\tif (face == 0.0) {\n\t\tdirection = direction.zyx;\n\t\tdirection.z *= -1.0;\n\t} else if (face == 1.0) {\n\t\tdirection = direction.xzy;\n\t\tdirection.z *= -1.0;\n\t} else if (face == 3.0) {\n\t\tdirection = direction.zyx;\n\t\tdirection.x *= -1.0;\n\t} else if (face == 4.0) {\n\t\tdirection = direction.xzy;\n\t\tdirection.y *= -1.0;\n\t} else if (face == 5.0) {\n\t\tdirection.xz *= -1.0;\n\t}\n\treturn direction;\n}\nvoid main() {\n\tvOutputDirection = getDirection(uv, faceIndex);\n\tgl_Position = vec4( position, 1.0 );\n}\n\t" } function tc() { return "\nuniform int inputEncoding;\nuniform int outputEncoding;\n\n#include \n\nvec4 inputTexelToLinear(vec4 value){\n\tif(inputEncoding == 0){\n\t\treturn value;\n\t}else if(inputEncoding == 1){\n\t\treturn sRGBToLinear(value);\n\t}else if(inputEncoding == 2){\n\t\treturn RGBEToLinear(value);\n\t}else if(inputEncoding == 3){\n\t\treturn RGBMToLinear(value, 7.0);\n\t}else if(inputEncoding == 4){\n\t\treturn RGBMToLinear(value, 16.0);\n\t}else if(inputEncoding == 5){\n\t\treturn RGBDToLinear(value, 256.0);\n\t}else{\n\t\treturn GammaToLinear(value, 2.2);\n\t}\n}\n\nvec4 linearToOutputTexel(vec4 value){\n\tif(outputEncoding == 0){\n\t\treturn value;\n\t}else if(outputEncoding == 1){\n\t\treturn LinearTosRGB(value);\n\t}else if(outputEncoding == 2){\n\t\treturn LinearToRGBE(value);\n\t}else if(outputEncoding == 3){\n\t\treturn LinearToRGBM(value, 7.0);\n\t}else if(outputEncoding == 4){\n\t\treturn LinearToRGBM(value, 16.0);\n\t}else if(outputEncoding == 5){\n\t\treturn LinearToRGBD(value, 256.0);\n\t}else{\n\t\treturn LinearToGamma(value, 2.2);\n\t}\n}\n\nvec4 envMapTexelToLinear(vec4 color) {\n\treturn inputTexelToLinear(color);\n}\n\t" } jl.prototype = { constructor: jl, fromScene: function (A, e = 0, t = .1, i = 100) { Vl = Ol.getRenderTarget(); var o = Hl(); return function (A, e, t, i) { var o = new je(90, 1, e, t), n = [1, 1, 1, 1, -1, 1], r = [1, 1, -1, -1, -1, 1], a = Ol.outputEncoding, s = Ol.toneMapping, l = Ol.toneMappingExposure, c = Ol.getClearColor(), h = Ol.getClearAlpha(); Ol.toneMapping = 1, Ol.toneMappingExposure = 1, Ol.outputEncoding = 3e3, A.scale.z *= -1; var d = A.background; if (d && d.isColor) { d.convertSRGBToLinear(); var p = Math.max(d.r, d.g, d.b), g = Math.min(Math.max(Math.ceil(Math.log2(p)), -128), 127); d = d.multiplyScalar(Math.pow(2, -g)), Ol.setClearColor(d, (g + 128) / 255), A.background = null } for (var u = 0; 6 > u; u++) { var f = u % 3; 0 == f ? (o.up.set(0, n[u], 0), o.lookAt(r[u], 0, 0)) : 1 == f ? (o.up.set(0, 0, n[u]), o.lookAt(0, r[u], 0)) : (o.up.set(0, n[u], 0), o.lookAt(0, 0, r[u])), zl(i, f * Ml, u > 2 ? Ml : 0, Ml, Ml), Ol.setRenderTarget(i), Ol.render(A, o) } Ol.toneMapping = s, Ol.toneMappingExposure = l, Ol.outputEncoding = a, Ol.setClearColor(c, h), A.scale.z *= -1 }(A, t, i, o), e > 0 && Xl(o, 0, 0, e), Zl(o), Yl(o), o }, fromEquirectangular: function (A) { return A.magFilter = 1003, A.minFilter = 1003, A.generateMipmaps = !1, this.fromCubemap(A) }, fromCubemap: function (A) { Vl = Ol.getRenderTarget(); var e = Hl(A); return function (A, e) { var t = new Y; A.isCubeTexture ? null == Tl && (Tl = Ac()) : null == Rl && (Rl = $l()); var i = A.isCubeTexture ? Tl : Rl; t.add(new Ue(kl[0], i)); var o = i.uniforms; o.envMap.value = A, A.isCubeTexture || o.texelSize.value.set(1 / A.image.width, 1 / A.image.height); o.inputEncoding.value = Fl[A.encoding], o.outputEncoding.value = Fl[A.encoding], zl(e, 0, 0, 3 * Ml, 2 * Ml), Ol.setRenderTarget(e), Ol.render(t, Kl) }(A, e), Zl(e), Yl(e), e }, compileCubemapShader: function () { null == Tl && Wl(Tl = Ac()) }, compileEquirectangularShader: function () { null == Rl && Wl(Rl = $l()) }, dispose: function () { Ql.dispose(), null != Tl && Tl.dispose(), null != Rl && Rl.dispose(); for (var A = 0; kl.length > A; A++) kl[A].dispose() } }; function ic(A) { console.warn("THREE.ClosedSplineCurve3 has been deprecated. Use THREE.CatmullRomCurve3 instead."), la.call(this, A), this.type = "catmullrom", this.closed = !0 } function oc(A) { console.warn("THREE.SplineCurve3 has been deprecated. Use THREE.CatmullRomCurve3 instead."), la.call(this, A), this.type = "catmullrom" } function nc(A) { console.warn("THREE.Spline has been removed. Use THREE.CatmullRomCurve3 instead."), la.call(this, A), this.type = "catmullrom" } ea.create = function (A, e) { return console.log("THREE.Curve.create() has been deprecated"), A.prototype = Object.create(ea.prototype), A.prototype.constructor = A, A.prototype.getPoint = e, A }, Object.assign(Ia.prototype, { createPointsGeometry: function (A) { console.warn("THREE.CurvePath: .createPointsGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead."); var e = this.getPoints(A); return this.createGeometry(e) }, createSpacedPointsGeometry: function (A) { console.warn("THREE.CurvePath: .createSpacedPointsGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead."); var e = this.getSpacedPoints(A); return this.createGeometry(e) }, createGeometry: function (A) { console.warn("THREE.CurvePath: .createGeometry() has been removed. Use new THREE.Geometry().setFromPoints( points ) instead."); for (var e = new De, t = 0, i = A.length; i > t; t++) { var o = A[t]; e.vertices.push(new y(o.x, o.y, o.z || 0)) } return e } }), Object.assign(Ea.prototype, { fromPoints: function (A) { return console.warn("THREE.Path: .fromPoints() has been renamed to .setFromPoints()."), this.setFromPoints(A) } }), ic.prototype = Object.create(la.prototype), oc.prototype = Object.create(la.prototype), nc.prototype = Object.create(la.prototype), Object.assign(nc.prototype, { initFromArray: function () { console.error("THREE.Spline: .initFromArray() has been removed.") }, getControlPointsArray: function () { console.error("THREE.Spline: .getControlPointsArray() has been removed.") }, reparametrizeByArcLength: function () { console.error("THREE.Spline: .reparametrizeByArcLength() has been removed.") } }), ol.prototype.setColors = function () { console.error("THREE.GridHelper: setColors() has been deprecated, pass them in the constructor instead.") }, _s.prototype.update = function () { console.error("THREE.SkeletonHelper: update() no longer needs to be called.") }, Object.assign(Yr.prototype, { extractUrlBase: function (A) { return console.warn("THREE.Loader: .extractUrlBase() has been deprecated. Use THREE.LoaderUtils.extractUrlBase() instead."), La.extractUrlBase(A) } }), Yr.Handlers = { add: function () { console.error("THREE.Loader: Handlers.add() has been removed. Use LoadingManager.addHandler() instead.") }, get: function () { console.error("THREE.Loader: Handlers.get() has been removed. Use LoadingManager.getHandler() instead.") } }, Object.assign(Pa.prototype, { setTexturePath: function (A) { return console.warn("THREE.ObjectLoader: .setTexturePath() has been renamed to .setResourcePath()."), this.setResourcePath(A) } }), Object.assign(Ps.prototype, { center: function (A) { return console.warn("THREE.Box2: .center() has been renamed to .getCenter()."), this.getCenter(A) }, empty: function () { return console.warn("THREE.Box2: .empty() has been renamed to .isEmpty()."), this.isEmpty() }, isIntersectionBox: function (A) { return console.warn("THREE.Box2: .isIntersectionBox() has been renamed to .intersectsBox()."), this.intersectsBox(A) }, size: function (A) { return console.warn("THREE.Box2: .size() has been renamed to .getSize()."), this.getSize(A) } }), Object.assign(aA.prototype, { center: function (A) { return console.warn("THREE.Box3: .center() has been renamed to .getCenter()."), this.getCenter(A) }, empty: function () { return console.warn("THREE.Box3: .empty() has been renamed to .isEmpty()."), this.isEmpty() }, isIntersectionBox: function (A) { return console.warn("THREE.Box3: .isIntersectionBox() has been renamed to .intersectsBox()."), this.intersectsBox(A) }, isIntersectionSphere: function (A) { return console.warn("THREE.Box3: .isIntersectionSphere() has been renamed to .intersectsSphere()."), this.intersectsSphere(A) }, size: function (A) { return console.warn("THREE.Box3: .size() has been renamed to .getSize()."), this.getSize(A) } }), Ze.prototype.setFromMatrix = function (A) { return console.warn("THREE.Frustum: .setFromMatrix() has been renamed to .setFromProjectionMatrix()."), this.setFromProjectionMatrix(A) }, Hs.prototype.center = function (A) { return console.warn("THREE.Line3: .center() has been renamed to .getCenter()."), this.getCenter(A) }, Object.assign(a, { random16: function () { return console.warn("THREE.Math: .random16() has been deprecated. Use Math.random() instead."), Math.random() }, nearestPowerOfTwo: function (A) { return console.warn("THREE.Math: .nearestPowerOfTwo() has been renamed to .floorPowerOfTwo()."), a.floorPowerOfTwo(A) }, nextPowerOfTwo: function (A) { return console.warn("THREE.Math: .nextPowerOfTwo() has been renamed to .ceilPowerOfTwo()."), a.ceilPowerOfTwo(A) } }), Object.assign(l.prototype, { flattenToArrayOffset: function (A, e) { return console.warn("THREE.Matrix3: .flattenToArrayOffset() has been deprecated. Use .toArray() instead."), this.toArray(A, e) }, multiplyVector3: function (A) { return console.warn("THREE.Matrix3: .multiplyVector3() has been removed. Use vector.applyMatrix3( matrix ) instead."), A.applyMatrix3(this) }, multiplyVector3Array: function () { console.error("THREE.Matrix3: .multiplyVector3Array() has been removed.") }, applyToBufferAttribute: function (A) { return console.warn("THREE.Matrix3: .applyToBufferAttribute() has been removed. Use attribute.applyMatrix3( matrix ) instead."), A.applyMatrix3(this) }, applyToVector3Array: function () { console.error("THREE.Matrix3: .applyToVector3Array() has been removed.") } }), Object.assign(M.prototype, { extractPosition: function (A) { return console.warn("THREE.Matrix4: .extractPosition() has been renamed to .copyPosition()."), this.copyPosition(A) }, flattenToArrayOffset: function (A, e) { return console.warn("THREE.Matrix4: .flattenToArrayOffset() has been deprecated. Use .toArray() instead."), this.toArray(A, e) }, getPosition: function () { return console.warn("THREE.Matrix4: .getPosition() has been removed. Use Vector3.setFromMatrixPosition( matrix ) instead."), (new y).setFromMatrixColumn(this, 3) }, setRotationFromQuaternion: function (A) { return console.warn("THREE.Matrix4: .setRotationFromQuaternion() has been renamed to .makeRotationFromQuaternion()."), this.makeRotationFromQuaternion(A) }, multiplyToArray: function () { console.warn("THREE.Matrix4: .multiplyToArray() has been removed.") }, multiplyVector3: function (A) { return console.warn("THREE.Matrix4: .multiplyVector3() has been removed. Use vector.applyMatrix4( matrix ) instead."), A.applyMatrix4(this) }, multiplyVector4: function (A) { return console.warn("THREE.Matrix4: .multiplyVector4() has been removed. Use vector.applyMatrix4( matrix ) instead."), A.applyMatrix4(this) }, multiplyVector3Array: function () { console.error("THREE.Matrix4: .multiplyVector3Array() has been removed.") }, rotateAxis: function (A) { console.warn("THREE.Matrix4: .rotateAxis() has been removed. Use Vector3.transformDirection( matrix ) instead."), A.transformDirection(this) }, crossVector: function (A) { return console.warn("THREE.Matrix4: .crossVector() has been removed. Use vector.applyMatrix4( matrix ) instead."), A.applyMatrix4(this) }, translate: function () { console.error("THREE.Matrix4: .translate() has been removed.") }, rotateX: function () { console.error("THREE.Matrix4: .rotateX() has been removed.") }, rotateY: function () { console.error("THREE.Matrix4: .rotateY() has been removed.") }, rotateZ: function () { console.error("THREE.Matrix4: .rotateZ() has been removed.") }, rotateByAxis: function () { console.error("THREE.Matrix4: .rotateByAxis() has been removed.") }, applyToBufferAttribute: function (A) { return console.warn("THREE.Matrix4: .applyToBufferAttribute() has been removed. Use attribute.applyMatrix4( matrix ) instead."), A.applyMatrix4(this) }, applyToVector3Array: function () { console.error("THREE.Matrix4: .applyToVector3Array() has been removed.") }, makeFrustum: function (A, e, t, i, o, n) { return console.warn("THREE.Matrix4: .makeFrustum() has been removed. Use .makePerspective( left, right, top, bottom, near, far ) instead."), this.makePerspective(A, e, i, t, o, n) } }), EA.prototype.isIntersectionLine = function (A) { return console.warn("THREE.Plane: .isIntersectionLine() has been renamed to .intersectsLine()."), this.intersectsLine(A) }, f.prototype.multiplyVector3 = function (A) { return console.warn("THREE.Quaternion: .multiplyVector3() has been removed. Use is now vector.applyQuaternion( quaternion ) instead."), A.applyQuaternion(this) }, Object.assign(CA.prototype, { isIntersectionBox: function (A) { return console.warn("THREE.Ray: .isIntersectionBox() has been renamed to .intersectsBox()."), this.intersectsBox(A) }, isIntersectionPlane: function (A) { return console.warn("THREE.Ray: .isIntersectionPlane() has been renamed to .intersectsPlane()."), this.intersectsPlane(A) }, isIntersectionSphere: function (A) { return console.warn("THREE.Ray: .isIntersectionSphere() has been renamed to .intersectsSphere()."), this.intersectsSphere(A) } }), Object.assign(RA.prototype, { area: function () { return console.warn("THREE.Triangle: .area() has been renamed to .getArea()."), this.getArea() }, barycoordFromPoint: function (A, e) { return console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord()."), this.getBarycoord(A, e) }, midpoint: function (A) { return console.warn("THREE.Triangle: .midpoint() has been renamed to .getMidpoint()."), this.getMidpoint(A) }, normal: function (A) { return console.warn("THREE.Triangle: .normal() has been renamed to .getNormal()."), this.getNormal(A) }, plane: function (A) { return console.warn("THREE.Triangle: .plane() has been renamed to .getPlane()."), this.getPlane(A) } }), Object.assign(RA, { barycoordFromPoint: function (A, e, t, i, o) { return console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord()."), RA.getBarycoord(A, e, t, i, o) }, normal: function (A, e, t, i) { return console.warn("THREE.Triangle: .normal() has been renamed to .getNormal()."), RA.getNormal(A, e, t, i) } }), Object.assign(Ba.prototype, { extractAllPoints: function (A) { return console.warn("THREE.Shape: .extractAllPoints() has been removed. Use .extractPoints() instead."), this.extractPoints(A) }, extrude: function (A) { return console.warn("THREE.Shape: .extrude() has been removed. Use ExtrudeGeometry() instead."), new Jn(this, A) }, makeGeometry: function (A) { return console.warn("THREE.Shape: .makeGeometry() has been removed. Use ShapeGeometry() instead."), new rr(this, A) } }), Object.assign(s.prototype, { fromAttribute: function (A, e, t) { return console.warn("THREE.Vector2: .fromAttribute() has been renamed to .fromBufferAttribute()."), this.fromBufferAttribute(A, e, t) }, distanceToManhattan: function (A) { return console.warn("THREE.Vector2: .distanceToManhattan() has been renamed to .manhattanDistanceTo()."), this.manhattanDistanceTo(A) }, lengthManhattan: function () { return console.warn("THREE.Vector2: .lengthManhattan() has been renamed to .manhattanLength()."), this.manhattanLength() } }), Object.assign(y.prototype, { setEulerFromRotationMatrix: function () { console.error("THREE.Vector3: .setEulerFromRotationMatrix() has been removed. Use Euler.setFromRotationMatrix() instead.") }, setEulerFromQuaternion: function () { console.error("THREE.Vector3: .setEulerFromQuaternion() has been removed. Use Euler.setFromQuaternion() instead.") }, getPositionFromMatrix: function (A) { return console.warn("THREE.Vector3: .getPositionFromMatrix() has been renamed to .setFromMatrixPosition()."), this.setFromMatrixPosition(A) }, getScaleFromMatrix: function (A) { return console.warn("THREE.Vector3: .getScaleFromMatrix() has been renamed to .setFromMatrixScale()."), this.setFromMatrixScale(A) }, getColumnFromMatrix: function (A, e) { return console.warn("THREE.Vector3: .getColumnFromMatrix() has been renamed to .setFromMatrixColumn()."), this.setFromMatrixColumn(e, A) }, applyProjection: function (A) { return console.warn("THREE.Vector3: .applyProjection() has been removed. Use .applyMatrix4( m ) instead."), this.applyMatrix4(A) }, fromAttribute: function (A, e, t) { return console.warn("THREE.Vector3: .fromAttribute() has been renamed to .fromBufferAttribute()."), this.fromBufferAttribute(A, e, t) }, distanceToManhattan: function (A) { return console.warn("THREE.Vector3: .distanceToManhattan() has been renamed to .manhattanDistanceTo()."), this.manhattanDistanceTo(A) }, lengthManhattan: function () { return console.warn("THREE.Vector3: .lengthManhattan() has been renamed to .manhattanLength()."), this.manhattanLength() } }), Object.assign(p.prototype, { fromAttribute: function (A, e, t) { return console.warn("THREE.Vector4: .fromAttribute() has been renamed to .fromBufferAttribute()."), this.fromBufferAttribute(A, e, t) }, lengthManhattan: function () { return console.warn("THREE.Vector4: .lengthManhattan() has been renamed to .manhattanLength()."), this.manhattanLength() } }), Object.assign(De.prototype, { computeTangents: function () { console.error("THREE.Geometry: .computeTangents() has been removed.") }, computeLineDistances: function () { console.error("THREE.Geometry: .computeLineDistances() has been removed. Use THREE.Line.computeLineDistances() instead.") }, applyMatrix: function (A) { return console.warn("THREE.Geometry: .applyMatrix() has been renamed to .applyMatrix4()."), this.applyMatrix4(A) } }), Object.assign(H.prototype, { getChildByName: function (A) { return console.warn("THREE.Object3D: .getChildByName() has been renamed to .getObjectByName()."), this.getObjectByName(A) }, renderDepth: function () { console.warn("THREE.Object3D: .renderDepth has been removed. Use .renderOrder, instead.") }, translate: function (A, e) { return console.warn("THREE.Object3D: .translate() has been removed. Use .translateOnAxis( axis, distance ) instead."), this.translateOnAxis(e, A) }, getWorldRotation: function () { console.error("THREE.Object3D: .getWorldRotation() has been removed. Use THREE.Object3D.getWorldQuaternion( target ) instead.") }, applyMatrix: function (A) { return console.warn("THREE.Object3D: .applyMatrix() has been renamed to .applyMatrix4()."), this.applyMatrix4(A) } }), Object.defineProperties(H.prototype, { eulerOrder: { get: function () { return console.warn("THREE.Object3D: .eulerOrder is now .rotation.order."), this.rotation.order }, set: function (A) { console.warn("THREE.Object3D: .eulerOrder is now .rotation.order."), this.rotation.order = A } }, useQuaternion: { get: function () { console.warn("THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.") }, set: function () { console.warn("THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.") } } }), Object.assign(Ue.prototype, { setDrawMode: function () { console.error("THREE.Mesh: .setDrawMode() has been removed. The renderer now always assumes THREE.TrianglesDrawMode. Transform your geometry via BufferGeometryUtils.toTrianglesDrawMode() if necessary.") } }), Object.defineProperties(Ue.prototype, { drawMode: { get: function () { return console.error("THREE.Mesh: .drawMode has been removed. The renderer now always assumes THREE.TrianglesDrawMode."), 0 }, set: function () { console.error("THREE.Mesh: .drawMode has been removed. The renderer now always assumes THREE.TrianglesDrawMode. Transform your geometry via BufferGeometryUtils.toTrianglesDrawMode() if necessary.") } } }), Object.defineProperties(xo.prototype, { objects: { get: function () { return console.warn("THREE.LOD: .objects has been renamed to .levels."), this.levels } } }), Object.defineProperty(bo.prototype, "useVertexTexture", { get: function () { console.warn("THREE.Skeleton: useVertexTexture has been removed.") }, set: function () { console.warn("THREE.Skeleton: useVertexTexture has been removed.") } }), So.prototype.initBones = function () { console.error("THREE.SkinnedMesh: initBones() has been removed.") }, Object.defineProperty(ea.prototype, "__arcLengthDivisions", { get: function () { return console.warn("THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions."), this.arcLengthDivisions }, set: function (A) { console.warn("THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions."), this.arcLengthDivisions = A } }), je.prototype.setLens = function (A, e) { console.warn("THREE.PerspectiveCamera.setLens is deprecated. Use .setFocalLength and .filmGauge for a photographic setup."), void 0 !== e && (this.filmGauge = e), this.setFocalLength(A) }, Object.defineProperties(xa.prototype, { onlyShadow: { set: function () { console.warn("THREE.Light: .onlyShadow has been removed.") } }, shadowCameraFov: { set: function (A) { console.warn("THREE.Light: .shadowCameraFov is now .shadow.camera.fov."), this.shadow.camera.fov = A } }, shadowCameraLeft: { set: function (A) { console.warn("THREE.Light: .shadowCameraLeft is now .shadow.camera.left."), this.shadow.camera.left = A } }, shadowCameraRight: { set: function (A) { console.warn("THREE.Light: .shadowCameraRight is now .shadow.camera.right."), this.shadow.camera.right = A } }, shadowCameraTop: { set: function (A) { console.warn("THREE.Light: .shadowCameraTop is now .shadow.camera.top."), this.shadow.camera.top = A } }, shadowCameraBottom: { set: function (A) { console.warn("THREE.Light: .shadowCameraBottom is now .shadow.camera.bottom."), this.shadow.camera.bottom = A } }, shadowCameraNear: { set: function (A) { console.warn("THREE.Light: .shadowCameraNear is now .shadow.camera.near."), this.shadow.camera.near = A } }, shadowCameraFar: { set: function (A) { console.warn("THREE.Light: .shadowCameraFar is now .shadow.camera.far."), this.shadow.camera.far = A } }, shadowCameraVisible: { set: function () { console.warn("THREE.Light: .shadowCameraVisible has been removed. Use new THREE.CameraHelper( light.shadow.camera ) instead.") } }, shadowBias: { set: function (A) { console.warn("THREE.Light: .shadowBias is now .shadow.bias."), this.shadow.bias = A } }, shadowDarkness: { set: function () { console.warn("THREE.Light: .shadowDarkness has been removed.") } }, shadowMapWidth: { set: function (A) { console.warn("THREE.Light: .shadowMapWidth is now .shadow.mapSize.width."), this.shadow.mapSize.width = A } }, shadowMapHeight: { set: function (A) { console.warn("THREE.Light: .shadowMapHeight is now .shadow.mapSize.height."), this.shadow.mapSize.height = A } } }), Object.defineProperties(YA.prototype, { length: { get: function () { return console.warn("THREE.BufferAttribute: .length has been deprecated. Use .count instead."), this.array.length } }, dynamic: { get: function () { return console.warn("THREE.BufferAttribute: .dynamic has been deprecated. Use .usage instead."), 35048 === this.usage }, set: function () { console.warn("THREE.BufferAttribute: .dynamic has been deprecated. Use .usage instead."), this.setUsage(35048) } } }), Object.assign(YA.prototype, { setDynamic: function (A) { return console.warn("THREE.BufferAttribute: .setDynamic() has been deprecated. Use .setUsage() instead."), this.setUsage(!0 === A ? 35048 : 35044), this }, copyIndicesArray: function () { console.error("THREE.BufferAttribute: .copyIndicesArray() has been removed.") }, setArray: function () { console.error("THREE.BufferAttribute: .setArray has been removed. Use BufferGeometry .setAttribute to replace/resize attribute buffers") } }), Object.assign(he.prototype, { addIndex: function (A) { console.warn("THREE.BufferGeometry: .addIndex() has been renamed to .setIndex()."), this.setIndex(A) }, addAttribute: function (A, e) { return console.warn("THREE.BufferGeometry: .addAttribute() has been renamed to .setAttribute()."), e && e.isBufferAttribute || e && e.isInterleavedBufferAttribute ? "index" === A ? (console.warn("THREE.BufferGeometry.addAttribute: Use .setIndex() for index attribute."), this.setIndex(e), this) : this.setAttribute(A, e) : (console.warn("THREE.BufferGeometry: .addAttribute() now expects ( name, attribute )."), this.setAttribute(A, new YA(arguments[1], arguments[2]))) }, addDrawCall: function (A, e, t) { void 0 !== t && console.warn("THREE.BufferGeometry: .addDrawCall() no longer supports indexOffset."), console.warn("THREE.BufferGeometry: .addDrawCall() is now .addGroup()."), this.addGroup(A, e) }, clearDrawCalls: function () { console.warn("THREE.BufferGeometry: .clearDrawCalls() is now .clearGroups()."), this.clearGroups() }, computeTangents: function () { console.warn("THREE.BufferGeometry: .computeTangents() has been removed.") }, computeOffsets: function () { console.warn("THREE.BufferGeometry: .computeOffsets() has been removed.") }, removeAttribute: function (A) { return console.warn("THREE.BufferGeometry: .removeAttribute() has been renamed to .deleteAttribute()."), this.deleteAttribute(A) }, applyMatrix: function (A) { return console.warn("THREE.BufferGeometry: .applyMatrix() has been renamed to .applyMatrix4()."), this.applyMatrix4(A) } }), Object.defineProperties(he.prototype, { drawcalls: { get: function () { return console.error("THREE.BufferGeometry: .drawcalls has been renamed to .groups."), this.groups } }, offsets: { get: function () { return console.warn("THREE.BufferGeometry: .offsets has been renamed to .groups."), this.groups } } }), Object.defineProperties(Ds.prototype, { linePrecision: { get: function () { return console.warn("THREE.Raycaster: .linePrecision has been deprecated. Use .params.Line.threshold instead."), this.params.Line.threshold }, set: function (A) { console.warn("THREE.Raycaster: .linePrecision has been deprecated. Use .params.Line.threshold instead."), this.params.Line.threshold = A } } }), Object.defineProperties(to.prototype, { dynamic: { get: function () { return console.warn("THREE.InterleavedBuffer: .length has been deprecated. Use .usage instead."), 35048 === this.usage }, set: function (A) { console.warn("THREE.InterleavedBuffer: .length has been deprecated. Use .usage instead."), this.setUsage(A) } } }), Object.assign(to.prototype, { setDynamic: function (A) { return console.warn("THREE.InterleavedBuffer: .setDynamic() has been deprecated. Use .setUsage() instead."), this.setUsage(!0 === A ? 35048 : 35044), this }, setArray: function () { console.error("THREE.InterleavedBuffer: .setArray has been removed. Use BufferGeometry .setAttribute to replace/resize attribute buffers") } }), Object.assign(zn.prototype, { getArrays: function () { console.error("THREE.ExtrudeBufferGeometry: .getArrays() has been removed.") }, addShapeList: function () { console.error("THREE.ExtrudeBufferGeometry: .addShapeList() has been removed.") }, addShape: function () { console.error("THREE.ExtrudeBufferGeometry: .addShape() has been removed.") } }), Object.defineProperties(Ts.prototype, { dynamic: { set: function () { console.warn("THREE.Uniform: .dynamic has been removed. Use object.onBeforeRender() instead.") } }, onUpdate: { value: function () { return console.warn("THREE.Uniform: .onUpdate() has been removed. Use object.onBeforeRender() instead."), this } } }), Object.defineProperties(qA.prototype, { wrapAround: { get: function () { console.warn("THREE.Material: .wrapAround has been removed.") }, set: function () { console.warn("THREE.Material: .wrapAround has been removed.") } }, overdraw: { get: function () { console.warn("THREE.Material: .overdraw has been removed.") }, set: function () { console.warn("THREE.Material: .overdraw has been removed.") } }, wrapRGB: { get: function () { return console.warn("THREE.Material: .wrapRGB has been removed."), new LA } }, shading: { get: function () { console.error("THREE." + this.type + ": .shading has been removed. Use the boolean .flatShading instead.") }, set: function (A) { console.warn("THREE." + this.type + ": .shading has been removed. Use the boolean .flatShading instead."), this.flatShading = 1 === A } }, stencilMask: { get: function () { return console.warn("THREE." + this.type + ": .stencilMask has been removed. Use .stencilFuncMask instead."), this.stencilFuncMask }, set: function (A) { console.warn("THREE." + this.type + ": .stencilMask has been removed. Use .stencilFuncMask instead."), this.stencilFuncMask = A } } }), Object.defineProperties(Ir.prototype, { metal: { get: function () { return console.warn("THREE.MeshPhongMaterial: .metal has been removed. Use THREE.MeshStandardMaterial instead."), !1 }, set: function () { console.warn("THREE.MeshPhongMaterial: .metal has been removed. Use THREE.MeshStandardMaterial instead") } } }), Object.defineProperties(Pe.prototype, { derivatives: { get: function () { return console.warn("THREE.ShaderMaterial: .derivatives has been moved to .extensions.derivatives."), this.extensions.derivatives }, set: function (A) { console.warn("THREE. ShaderMaterial: .derivatives has been moved to .extensions.derivatives."), this.extensions.derivatives = A } } }), Object.assign($i.prototype, { clearTarget: function (A, e, t, i) { console.warn("THREE.WebGLRenderer: .clearTarget() has been deprecated. Use .setRenderTarget() and .clear() instead."), this.setRenderTarget(A), this.clear(e, t, i) }, animate: function (A) { console.warn("THREE.WebGLRenderer: .animate() is now .setAnimationLoop()."), this.setAnimationLoop(A) }, getCurrentRenderTarget: function () { return console.warn("THREE.WebGLRenderer: .getCurrentRenderTarget() is now .getRenderTarget()."), this.getRenderTarget() }, getMaxAnisotropy: function () { return console.warn("THREE.WebGLRenderer: .getMaxAnisotropy() is now .capabilities.getMaxAnisotropy()."), this.capabilities.getMaxAnisotropy() }, getPrecision: function () { return console.warn("THREE.WebGLRenderer: .getPrecision() is now .capabilities.precision."), this.capabilities.precision }, resetGLState: function () { return console.warn("THREE.WebGLRenderer: .resetGLState() is now .state.reset()."), this.state.reset() }, supportsFloatTextures: function () { return console.warn("THREE.WebGLRenderer: .supportsFloatTextures() is now .extensions.get( 'OES_texture_float' )."), this.extensions.get("OES_texture_float") }, supportsHalfFloatTextures: function () { return console.warn("THREE.WebGLRenderer: .supportsHalfFloatTextures() is now .extensions.get( 'OES_texture_half_float' )."), this.extensions.get("OES_texture_half_float") }, supportsStandardDerivatives: function () { return console.warn("THREE.WebGLRenderer: .supportsStandardDerivatives() is now .extensions.get( 'OES_standard_derivatives' )."), this.extensions.get("OES_standard_derivatives") }, supportsCompressedTextureS3TC: function () { return console.warn("THREE.WebGLRenderer: .supportsCompressedTextureS3TC() is now .extensions.get( 'WEBGL_compressed_texture_s3tc' )."), this.extensions.get("WEBGL_compressed_texture_s3tc") }, supportsCompressedTexturePVRTC: function () { return console.warn("THREE.WebGLRenderer: .supportsCompressedTexturePVRTC() is now .extensions.get( 'WEBGL_compressed_texture_pvrtc' )."), this.extensions.get("WEBGL_compressed_texture_pvrtc") }, supportsBlendMinMax: function () { return console.warn("THREE.WebGLRenderer: .supportsBlendMinMax() is now .extensions.get( 'EXT_blend_minmax' )."), this.extensions.get("EXT_blend_minmax") }, supportsVertexTextures: function () { return console.warn("THREE.WebGLRenderer: .supportsVertexTextures() is now .capabilities.vertexTextures."), this.capabilities.vertexTextures }, supportsInstancedArrays: function () { return console.warn("THREE.WebGLRenderer: .supportsInstancedArrays() is now .extensions.get( 'ANGLE_instanced_arrays' )."), this.extensions.get("ANGLE_instanced_arrays") }, enableScissorTest: function (A) { console.warn("THREE.WebGLRenderer: .enableScissorTest() is now .setScissorTest()."), this.setScissorTest(A) }, initMaterial: function () { console.warn("THREE.WebGLRenderer: .initMaterial() has been removed.") }, addPrePlugin: function () { console.warn("THREE.WebGLRenderer: .addPrePlugin() has been removed.") }, addPostPlugin: function () { console.warn("THREE.WebGLRenderer: .addPostPlugin() has been removed.") }, updateShadowMap: function () { console.warn("THREE.WebGLRenderer: .updateShadowMap() has been removed.") }, setFaceCulling: function () { console.warn("THREE.WebGLRenderer: .setFaceCulling() has been removed.") }, allocTextureUnit: function () { console.warn("THREE.WebGLRenderer: .allocTextureUnit() has been removed.") }, setTexture: function () { console.warn("THREE.WebGLRenderer: .setTexture() has been removed.") }, setTexture2D: function () { console.warn("THREE.WebGLRenderer: .setTexture2D() has been removed.") }, setTextureCube: function () { console.warn("THREE.WebGLRenderer: .setTextureCube() has been removed.") }, getActiveMipMapLevel: function () { return console.warn("THREE.WebGLRenderer: .getActiveMipMapLevel() is now .getActiveMipmapLevel()."), this.getActiveMipmapLevel() } }), Object.defineProperties($i.prototype, { shadowMapEnabled: { get: function () { return this.shadowMap.enabled }, set: function (A) { console.warn("THREE.WebGLRenderer: .shadowMapEnabled is now .shadowMap.enabled."), this.shadowMap.enabled = A } }, shadowMapType: { get: function () { return this.shadowMap.type }, set: function (A) { console.warn("THREE.WebGLRenderer: .shadowMapType is now .shadowMap.type."), this.shadowMap.type = A } }, shadowMapCullFace: { get: function () { console.warn("THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.") }, set: function () { console.warn("THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.") } }, context: { get: function () { return console.warn("THREE.WebGLRenderer: .context has been removed. Use .getContext() instead."), this.getContext() } }, vr: { get: function () { return console.warn("THREE.WebGLRenderer: .vr has been renamed to .xr"), this.xr } }, gammaInput: { get: function () { return console.warn("THREE.WebGLRenderer: .gammaInput has been removed. Set the encoding for textures via Texture.encoding instead."), !1 }, set: function () { console.warn("THREE.WebGLRenderer: .gammaInput has been removed. Set the encoding for textures via Texture.encoding instead.") } }, gammaOutput: { get: function () { return console.warn("THREE.WebGLRenderer: .gammaOutput has been removed. Set WebGLRenderer.outputEncoding instead."), !1 }, set: function (A) { console.warn("THREE.WebGLRenderer: .gammaOutput has been removed. Set WebGLRenderer.outputEncoding instead."), this.outputEncoding = !0 === A ? 3001 : 3e3 } } }), Object.defineProperties(Yi.prototype, { cullFace: { get: function () { console.warn("THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.") }, set: function () { console.warn("THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.") } }, renderReverseSided: { get: function () { console.warn("THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.") }, set: function () { console.warn("THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.") } }, renderSingleSided: { get: function () { console.warn("THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.") }, set: function () { console.warn("THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.") } } }), Object.defineProperties(g.prototype, { wrapS: { get: function () { return console.warn("THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS."), this.texture.wrapS }, set: function (A) { console.warn("THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS."), this.texture.wrapS = A } }, wrapT: { get: function () { return console.warn("THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT."), this.texture.wrapT }, set: function (A) { console.warn("THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT."), this.texture.wrapT = A } }, magFilter: { get: function () { return console.warn("THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter."), this.texture.magFilter }, set: function (A) { console.warn("THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter."), this.texture.magFilter = A } }, minFilter: { get: function () { return console.warn("THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter."), this.texture.minFilter }, set: function (A) { console.warn("THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter."), this.texture.minFilter = A } }, anisotropy: { get: function () { return console.warn("THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy."), this.texture.anisotropy }, set: function (A) { console.warn("THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy."), this.texture.anisotropy = A } }, offset: { get: function () { return console.warn("THREE.WebGLRenderTarget: .offset is now .texture.offset."), this.texture.offset }, set: function (A) { console.warn("THREE.WebGLRenderTarget: .offset is now .texture.offset."), this.texture.offset = A } }, repeat: { get: function () { return console.warn("THREE.WebGLRenderTarget: .repeat is now .texture.repeat."), this.texture.repeat }, set: function (A) { console.warn("THREE.WebGLRenderTarget: .repeat is now .texture.repeat."), this.texture.repeat = A } }, format: { get: function () { return console.warn("THREE.WebGLRenderTarget: .format is now .texture.format."), this.texture.format }, set: function (A) { console.warn("THREE.WebGLRenderTarget: .format is now .texture.format."), this.texture.format = A } }, type: { get: function () { return console.warn("THREE.WebGLRenderTarget: .type is now .texture.type."), this.texture.type }, set: function (A) { console.warn("THREE.WebGLRenderTarget: .type is now .texture.type."), this.texture.type = A } }, generateMipmaps: { get: function () { return console.warn("THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps."), this.texture.generateMipmaps }, set: function (A) { console.warn("THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps."), this.texture.generateMipmaps = A } } }), Object.defineProperties(ps.prototype, { load: { value: function (A) { console.warn("THREE.Audio: .load has been deprecated. Use THREE.AudioLoader instead."); var e = this; return (new $a).load(A, (function (A) { e.setBuffer(A) })), this } }, startTime: { set: function () { console.warn("THREE.Audio: .startTime is now .play( delay ).") } } }), ys.prototype.getData = function () { return console.warn("THREE.AudioAnalyser: .getData() is now .getFrequencyData()."), this.getFrequencyData() }, He.prototype.updateCubeMap = function (A, e) { return console.warn("THREE.CubeCamera: .updateCubeMap() is now .update()."), this.update(A, e) }; var rc = { merge: function (A, e, t) { var i; console.warn("THREE.GeometryUtils: .merge() has been moved to Geometry. Use geometry.merge( geometry2, matrix, materialIndexOffset ) instead."), e.isMesh && (e.matrixAutoUpdate && e.updateMatrix(), i = e.matrix, e = e.geometry), A.merge(e, i, t) }, center: function (A) { return console.warn("THREE.GeometryUtils: .center() has been moved to Geometry. Use geometry.center() instead."), A.center() } }; c.crossOrigin = void 0, c.loadTexture = function (A, e, t, i) { console.warn("THREE.ImageUtils.loadTexture has been deprecated. Use THREE.TextureLoader() instead."); var o = new Aa; o.setCrossOrigin(this.crossOrigin); var n = o.load(A, t, void 0, i); return e && (n.mapping = e), n }, c.loadTextureCube = function (A, e, t, i) { console.warn("THREE.ImageUtils.loadTextureCube has been deprecated. Use THREE.CubeTextureLoader() instead."); var o = new $r; o.setCrossOrigin(this.crossOrigin); var n = o.load(A, t, void 0, i); return e && (n.mapping = e), n }, c.loadCompressedTexture = function () { console.error("THREE.ImageUtils.loadCompressedTexture has been removed. Use THREE.DDSLoader instead.") }, c.loadCompressedTextureCube = function () { console.error("THREE.ImageUtils.loadCompressedTextureCube has been removed. Use THREE.DDSLoader instead.") }; var ac = { createMultiMaterialObject: function () { console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js") }, detach: function () { console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js") }, attach: function () { console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js") } }; "undefined" != typeof __THREE_DEVTOOLS__ && __THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("register", { detail: { revision: "115" } })); var sc = Object.freeze({ ACESFilmicToneMapping: 5, AddEquation: 100, AddOperation: 2, AdditiveBlending: 2, AlphaFormat: 1021, AlwaysDepth: 1, AlwaysStencilFunc: 519, AmbientLight: Ta, AmbientLightProbe: is, AnimationClip: Gr, AnimationLoader: zr, AnimationMixer: Rs, AnimationObjectGroup: Ks, AnimationUtils: br, ArcCurve: ia, ArrayCamera: Zi, ArrowHelper: Il, Audio: ps, AudioAnalyser: ys, AudioContext: _a, AudioListener: ds, AudioLoader: $a, AxesHelper: El, AxisHelper: function (A) { return console.warn("THREE.AxisHelper has been renamed to THREE.AxesHelper."), new El(A) }, BackSide: 1, BasicDepthPacking: 3200, BasicShadowMap: 0, BinaryTextureLoader: function (A) { return console.warn("THREE.BinaryTextureLoader has been renamed to THREE.DataTextureLoader."), new Xr(A) }, Bone: Uo, BooleanKeyframeTrack: Tr, BoundingBoxHelper: function (A, e) { return console.warn("THREE.BoundingBoxHelper has been deprecated. Creating a THREE.BoxHelper instead."), new ul(A, e) }, Box2: Ps, Box3: aA, Box3Helper: fl, BoxBufferGeometry: Ne, BoxGeometry: Le, BoxHelper: ul, BufferAttribute: YA, BufferGeometry: he, BufferGeometryLoader: Va, ByteType: 1010, Cache: qr, Camera: qe, CameraHelper: dl, CanvasRenderer: function () { console.error("THREE.CanvasRenderer has been removed") }, CanvasTexture: en, CatmullRomCurve3: la, CineonToneMapping: 4, CircleBufferGeometry: ur, CircleGeometry: gr, ClampToEdgeWrapping: 1001, Clock: as, ClosedSplineCurve3: ic, Color: LA, ColorKeyframeTrack: kr, CompressedTexture: An, CompressedTextureLoader: Zr, ConeBufferGeometry: pr, ConeGeometry: dr, CubeCamera: He, CubeGeometry: Le, CubeReflectionMapping: 301, CubeRefractionMapping: 302, CubeTexture: ut, CubeTextureLoader: $r, CubeUVReflectionMapping: 306, CubeUVRefractionMapping: 307, CubicBezierCurve: pa, CubicBezierCurve3: ga, CubicInterpolant: Fr, CullFaceBack: 1, CullFaceFront: 2, CullFaceFrontBack: 3, CullFaceNone: 0, Curve: ea, CurvePath: Ia, CustomBlending: 5, CylinderBufferGeometry: hr, CylinderGeometry: cr, Cylindrical: Vs, DataTexture: We, DataTexture2DArray: ft, DataTexture3D: mt, DataTextureLoader: Xr, DecrementStencilOp: 7683, DecrementWrapStencilOp: 34056, DefaultLoadingManager: Hr, DepthFormat: 1026, DepthStencilFormat: 1027, DepthTexture: tn, DirectionalLight: Ra, DirectionalLightHelper: ll, DirectionalLightShadow: Qa, DiscreteInterpolant: Qr, DodecahedronBufferGeometry: fn, DodecahedronGeometry: un, DoubleSide: 2, DstAlphaFactor: 206, DstColorFactor: 208, DynamicBufferAttribute: function (A, e) { return console.warn("THREE.DynamicBufferAttribute has been removed. Use new THREE.BufferAttribute().setUsage( THREE.DynamicDrawUsage ) instead."), new YA(A, e).setUsage(35048) }, DynamicCopyUsage: 35050, DynamicDrawUsage: 35048, DynamicReadUsage: 35049, EdgesGeometry: lr, EdgesHelper: function (A, e) { return console.warn("THREE.EdgesHelper has been removed. Use THREE.EdgesGeometry instead."), new jo(new lr(A.geometry), new ko({ color: void 0 !== e ? e : 16777215 })) }, EllipseCurve: ta, EqualDepth: 4, EqualStencilFunc: 514, EquirectangularReflectionMapping: 303, EquirectangularRefractionMapping: 304, Euler: F, EventDispatcher: i, ExtrudeBufferGeometry: zn, ExtrudeGeometry: Jn, Face3: GA, Face4: function (A, e, t, i, o, n, r) { return console.warn("THREE.Face4 has been removed. A THREE.Face3 will be created instead."), new GA(A, e, t, o, n, r) }, FaceColors: 1, FileLoader: Jr, FlatShading: 1, Float32Attribute: function (A, e) { return console.warn("THREE.Float32Attribute has been removed. Use new THREE.Float32BufferAttribute() instead."), new Ae(A, e) }, Float32BufferAttribute: Ae, Float64Attribute: function (A, e) { return console.warn("THREE.Float64Attribute has been removed. Use new THREE.Float64BufferAttribute() instead."), new ee(A, e) }, Float64BufferAttribute: ee, FloatType: 1015, Fog: eo, FogExp2: Ao, Font: za, FontLoader: Xa, FrontFaceDirectionCCW: 1, FrontFaceDirectionCW: 0, FrontSide: 0, Frustum: Ze, GammaEncoding: 3007, Geometry: De, GeometryUtils: rc, GreaterDepth: 6, GreaterEqualDepth: 5, GreaterEqualStencilFunc: 518, GreaterStencilFunc: 516, GridHelper: ol, Group: Xi, HalfFloatType: 1016, HemisphereLight: Sa, HemisphereLightHelper: il, HemisphereLightProbe: ts, IcosahedronBufferGeometry: gn, IcosahedronGeometry: pn, ImageBitmapLoader: Wa, ImageLoader: _r, ImageUtils: c, ImmediateRenderObject: Ys, IncrementStencilOp: 7682, IncrementWrapStencilOp: 34055, InstancedBufferAttribute: Oa, InstancedBufferGeometry: Na, InstancedInterleavedBuffer: ks, InstancedMesh: To, Int16Attribute: function (A, e) { return console.warn("THREE.Int16Attribute has been removed. Use new THREE.Int16BufferAttribute() instead."), new ZA(A, e) }, Int16BufferAttribute: ZA, Int32Attribute: function (A, e) { return console.warn("THREE.Int32Attribute has been removed. Use new THREE.Int32BufferAttribute() instead."), new _A(A, e) }, Int32BufferAttribute: _A, Int8Attribute: function (A, e) { return console.warn("THREE.Int8Attribute has been removed. Use new THREE.Int8BufferAttribute() instead."), new WA(A, e) }, Int8BufferAttribute: WA, IntType: 1013, InterleavedBuffer: to, InterleavedBufferAttribute: no, Interpolant: Ur, InterpolateDiscrete: 2300, InterpolateLinear: 2301, InterpolateSmooth: 2302, InvertStencilOp: 5386, JSONLoader: function () { console.error("THREE.JSONLoader has been removed.") }, KeepStencilOp: 7680, KeyframeTrack: Rr, LOD: xo, LatheBufferGeometry: nr, LatheGeometry: or, Layers: K, LensFlare: function () { console.error("THREE.LensFlare has been moved to /examples/jsm/objects/Lensflare.js") }, LessDepth: 2, LessEqualDepth: 3, LessEqualStencilFunc: 515, LessStencilFunc: 513, Light: xa, LightProbe: es, LightShadow: wa, Line: Go, Line3: Hs, LineBasicMaterial: ko, LineCurve: ua, LineCurve3: fa, LineDashedMaterial: wr, LineLoop: Ho, LinePieces: 1, LineSegments: jo, LineStrip: 0, LinearEncoding: 3e3, LinearFilter: 1006, LinearInterpolant: Kr, LinearMipMapLinearFilter: 1008, LinearMipMapNearestFilter: 1007, LinearMipmapLinearFilter: 1008, LinearMipmapNearestFilter: 1007, LinearToneMapping: 1, Loader: Yr, LoaderUtils: La, LoadingManager: jr, LogLuvEncoding: 3003, LoopOnce: 2200, LoopPingPong: 2202, LoopRepeat: 2201, LuminanceAlphaFormat: 1025, LuminanceFormat: 1024, MOUSE: t, Material: qA, MaterialLoader: Da, Math: a, MathUtils: a, Matrix3: l, Matrix4: M, MaxEquation: 104, Mesh: Ue, MeshBasicMaterial: jA, MeshDepthMaterial: ji, MeshDistanceMaterial: Hi, MeshFaceMaterial: function (A) { return console.warn("THREE.MeshFaceMaterial has been removed. Use an Array instead."), A }, MeshLambertMaterial: xr, MeshMatcapMaterial: Sr, MeshNormalMaterial: Br, MeshPhongMaterial: Ir, MeshPhysicalMaterial: vr, MeshStandardMaterial: yr, MeshToonMaterial: Er, MinEquation: 103, MirroredRepeatWrapping: 1002, MixOperation: 1, MultiMaterial: function (A) { return void 0 === A && (A = []), console.warn("THREE.MultiMaterial has been removed. Use an Array instead."), A.isMultiMaterial = !0, A.materials = A, A.clone = function () { return A.slice() }, A }, MultiplyBlending: 4, MultiplyOperation: 0, NearestFilter: 1003, NearestMipMapLinearFilter: 1005, NearestMipMapNearestFilter: 1004, NearestMipmapLinearFilter: 1005, NearestMipmapNearestFilter: 1004, NeverDepth: 0, NeverStencilFunc: 512, NoBlending: 0, NoColors: 0, NoToneMapping: 0, NormalBlending: 1, NotEqualDepth: 7, NotEqualStencilFunc: 517, NumberKeyframeTrack: Dr, Object3D: H, ObjectLoader: Pa, ObjectSpaceNormalMap: 1, OctahedronBufferGeometry: dn, OctahedronGeometry: hn, OneFactor: 201, OneMinusDstAlphaFactor: 207, OneMinusDstColorFactor: 209, OneMinusSrcAlphaFactor: 205, OneMinusSrcColorFactor: 203, OrthographicCamera: Ka, PCFShadowMap: 1, PCFSoftShadowMap: 2, PMREMGenerator: jl, ParametricBufferGeometry: rn, ParametricGeometry: nn, Particle: function (A) { return console.warn("THREE.Particle has been renamed to THREE.Sprite."), new vo(A) }, ParticleBasicMaterial: function (A) { return console.warn("THREE.ParticleBasicMaterial has been renamed to THREE.PointsMaterial."), new Yo(A) }, ParticleSystem: function (A, e) { return console.warn("THREE.ParticleSystem has been renamed to THREE.Points."), new Xo(A, e) }, ParticleSystemMaterial: function (A) { return console.warn("THREE.ParticleSystemMaterial has been renamed to THREE.PointsMaterial."), new Yo(A) }, Path: Ea, PerspectiveCamera: je, Plane: EA, PlaneBufferGeometry: et, PlaneGeometry: At, PlaneHelper: ml, PointCloud: function (A, e) { return console.warn("THREE.PointCloud has been renamed to THREE.Points."), new Xo(A, e) }, PointCloudMaterial: function (A) { return console.warn("THREE.PointCloudMaterial has been renamed to THREE.PointsMaterial."), new Yo(A) }, PointLight: Fa, PointLightHelper: $s, Points: Xo, PointsMaterial: Yo, PolarGridHelper: nl, PolyhedronBufferGeometry: sn, PolyhedronGeometry: an, PositionalAudio: Cs, PropertyBinding: Fs, PropertyMixer: vs, QuadraticBezierCurve: ma, QuadraticBezierCurve3: Ca, Quaternion: f, QuaternionKeyframeTrack: Nr, QuaternionLinearInterpolant: Lr, REVISION: "115", RGBADepthPacking: 3201, RGBAFormat: 1023, RGBAIntegerFormat: 1033, RGBA_ASTC_10x10_Format: 37819, RGBA_ASTC_10x5_Format: 37816, RGBA_ASTC_10x6_Format: 37817, RGBA_ASTC_10x8_Format: 37818, RGBA_ASTC_12x10_Format: 37820, RGBA_ASTC_12x12_Format: 37821, RGBA_ASTC_4x4_Format: 37808, RGBA_ASTC_5x4_Format: 37809, RGBA_ASTC_5x5_Format: 37810, RGBA_ASTC_6x5_Format: 37811, RGBA_ASTC_6x6_Format: 37812, RGBA_ASTC_8x5_Format: 37813, RGBA_ASTC_8x6_Format: 37814, RGBA_ASTC_8x8_Format: 37815, RGBA_BPTC_Format: 36492, RGBA_ETC2_EAC_Format: 37496, RGBA_PVRTC_2BPPV1_Format: 35843, RGBA_PVRTC_4BPPV1_Format: 35842, RGBA_S3TC_DXT1_Format: 33777, RGBA_S3TC_DXT3_Format: 33778, RGBA_S3TC_DXT5_Format: 33779, RGBDEncoding: 3006, RGBEEncoding: 3002, RGBEFormat: 1023, RGBFormat: 1022, RGBIntegerFormat: 1032, RGBM16Encoding: 3005, RGBM7Encoding: 3004, RGB_ETC1_Format: 36196, RGB_ETC2_Format: 37492, RGB_PVRTC_2BPPV1_Format: 35841, RGB_PVRTC_4BPPV1_Format: 35840, RGB_S3TC_DXT1_Format: 33776, RGFormat: 1030, RGIntegerFormat: 1031, RawShaderMaterial: Cr, Ray: CA, Raycaster: Ds, RectAreaLight: ka, RedFormat: 1028, RedIntegerFormat: 1029, ReinhardToneMapping: 2, RepeatWrapping: 1e3, ReplaceStencilOp: 7681, ReverseSubtractEquation: 102, RingBufferGeometry: ir, RingGeometry: tr, SRGB8_ALPHA8_ASTC_10x10_Format: 37851, SRGB8_ALPHA8_ASTC_10x5_Format: 37848, SRGB8_ALPHA8_ASTC_10x6_Format: 37849, SRGB8_ALPHA8_ASTC_10x8_Format: 37850, SRGB8_ALPHA8_ASTC_12x10_Format: 37852, SRGB8_ALPHA8_ASTC_12x12_Format: 37853, SRGB8_ALPHA8_ASTC_4x4_Format: 37840, SRGB8_ALPHA8_ASTC_5x4_Format: 37841, SRGB8_ALPHA8_ASTC_5x5_Format: 37842, SRGB8_ALPHA8_ASTC_6x5_Format: 37843, SRGB8_ALPHA8_ASTC_6x6_Format: 37844, SRGB8_ALPHA8_ASTC_8x5_Format: 37845, SRGB8_ALPHA8_ASTC_8x6_Format: 37846, SRGB8_ALPHA8_ASTC_8x8_Format: 37847, Scene: Y, SceneUtils: ac, ShaderChunk: tt, ShaderLib: it, ShaderMaterial: Pe, ShadowMaterial: mr, Shape: Ba, ShapeBufferGeometry: ar, ShapeGeometry: rr, ShapePath: Ja, ShapeUtils: Hn, ShortType: 1011, Skeleton: bo, SkeletonHelper: _s, SkinnedMesh: So, SmoothShading: 2, Sphere: cA, SphereBufferGeometry: er, SphereGeometry: Ar, Spherical: Os, SphericalHarmonics3: As, SphericalReflectionMapping: 305, Spline: nc, SplineCurve: ya, SplineCurve3: oc, SpotLight: ba, SpotLightHelper: Js, SpotLightShadow: Ma, Sprite: vo, SpriteMaterial: ro, SrcAlphaFactor: 204, SrcAlphaSaturateFactor: 210, SrcColorFactor: 202, StaticCopyUsage: 35046, StaticDrawUsage: 35044, StaticReadUsage: 35045, StereoCamera: rs, StreamCopyUsage: 35042, StreamDrawUsage: 35040, StreamReadUsage: 35041, StringKeyframeTrack: Or, SubtractEquation: 101, SubtractiveBlending: 3, TOUCH: { ROTATE: 0, PAN: 1, DOLLY_PAN: 2, DOLLY_ROTATE: 3 }, TangentSpaceNormalMap: 0, TetrahedronBufferGeometry: cn, TetrahedronGeometry: ln, TextBufferGeometry: $n, TextGeometry: _n, Texture: d, TextureLoader: Aa, TorusBufferGeometry: En, TorusGeometry: In, TorusKnotBufferGeometry: vn, TorusKnotGeometry: yn, Triangle: RA, TriangleFanDrawMode: 2, TriangleStripDrawMode: 1, TrianglesDrawMode: 0, TubeBufferGeometry: Cn, TubeGeometry: mn, UVMapping: 300, Uint16Attribute: function (A, e) { return console.warn("THREE.Uint16Attribute has been removed. Use new THREE.Uint16BufferAttribute() instead."), new XA(A, e) }, Uint16BufferAttribute: XA, Uint32Attribute: function (A, e) { return console.warn("THREE.Uint32Attribute has been removed. Use new THREE.Uint32BufferAttribute() instead."), new $A(A, e) }, Uint32BufferAttribute: $A, Uint8Attribute: function (A, e) { return console.warn("THREE.Uint8Attribute has been removed. Use new THREE.Uint8BufferAttribute() instead."), new JA(A, e) }, Uint8BufferAttribute: JA, Uint8ClampedAttribute: function (A, e) { return console.warn("THREE.Uint8ClampedAttribute has been removed. Use new THREE.Uint8ClampedBufferAttribute() instead."), new zA(A, e) }, Uint8ClampedBufferAttribute: zA, Uncharted2ToneMapping: 3, Uniform: Ts, UniformsLib: Xe, UniformsUtils: Ge, UnsignedByteType: 1009, UnsignedInt248Type: 1020, UnsignedIntType: 1014, UnsignedShort4444Type: 1017, UnsignedShort5551Type: 1018, UnsignedShort565Type: 1019, UnsignedShortType: 1012, VSMShadowMap: 3, Vector2: s, Vector3: y, Vector4: p, VectorKeyframeTrack: Vr, Vertex: function (A, e, t) { return console.warn("THREE.Vertex has been removed. Use THREE.Vector3 instead."), new y(A, e, t) }, VertexColors: 2, VideoTexture: $o, WebGLCubeRenderTarget: Ye, WebGLMultisampleRenderTarget: u, WebGLRenderTarget: g, WebGLRenderTargetCube: function (A, e, t) { return console.warn("THREE.WebGLRenderTargetCube( width, height, options ) is now WebGLCubeRenderTarget( size, options )."), new Ye(A, t) }, WebGLRenderer: $i, WebGLUtils: zi, WireframeGeometry: on, WireframeHelper: function (A, e) { return console.warn("THREE.WireframeHelper has been removed. Use THREE.WireframeGeometry instead."), new jo(new on(A.geometry), new ko({ color: void 0 !== e ? e : 16777215 })) }, WrapAroundEnding: 2402, XHRLoader: function (A) { return console.warn("THREE.XHRLoader has been renamed to THREE.FileLoader."), new Jr(A) }, ZeroCurvatureEnding: 2400, ZeroFactor: 200, ZeroSlopeEnding: 2401, ZeroStencilOp: 0, sRGBEncoding: 3001 }); function lc(A) { return (lc = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (A) { return typeof A } : function (A) { return A && "function" == typeof Symbol && A.constructor === Symbol && A !== Symbol.prototype ? "symbol" : typeof A } )(A) } function cc(A, e) { if (!(A instanceof e)) throw new TypeError("Cannot call a class as a function") } function hc(A, e) { for (var t = 0; e.length > t; t++) { var i = e[t]; i.enumerable = i.enumerable || !1, i.configurable = !0, "value" in i && (i.writable = !0), Object.defineProperty(A, i.key, i) } } function dc(A, e, t) { return e && hc(A.prototype, e), t && hc(A, t), A } function pc(A, e, t) { return e in A ? Object.defineProperty(A, e, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : A[e] = t, A } function gc(A) { for (var e = 1; arguments.length > e; e++) { var t = null != arguments[e] ? Object(arguments[e]) : {}, i = Object.keys(t); "function" == typeof Object.getOwnPropertySymbols && (i = i.concat(Object.getOwnPropertySymbols(t).filter((function (A) { return Object.getOwnPropertyDescriptor(t, A).enumerable })))), i.forEach((function (e) { pc(A, e, t[e]) })) } return A } function uc(A, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); A.prototype = Object.create(e && e.prototype, { constructor: { value: A, writable: !0, configurable: !0 } }), e && mc(A, e) } function fc(A) { return (fc = Object.setPrototypeOf ? Object.getPrototypeOf : function (A) { return A.__proto__ || Object.getPrototypeOf(A) })(A) } function mc(A, e) { return (mc = Object.setPrototypeOf || function (A, e) { return A.__proto__ = e, A })(A, e) } function Cc(A, e) { return !e || "object" != typeof e && "function" != typeof e ? function (A) { if (void 0 === A) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return A }(A) : e } function yc(A) { return function (A) { if (Array.isArray(A)) { for (var e = 0, t = new Array(A.length); A.length > e; e++) t[e] = A[e]; return t } }(A) || function (A) { if (Symbol.iterator in Object(A) || "[object Arguments]" === Object.prototype.toString.call(A)) return Array.from(A) }(A) || function () { throw new TypeError("Invalid attempt to spread non-iterable instance") }() } var vc = { SceneSize: 1e3, getDataFromIndexedDB: !0, TextureResRoot: "images/", UserControlView: !1, FillCavity: !1, EnableClippingCaps: !0, EnableBoxClippingCaps: !1, EnableTextureMapping: !0, EnableTextureLoading: !0, EnableLightmap: !1, EnableTransformAoMap: !0, LightmapIntensity: 1, ClippingCaps: !1, SelectionColor: { color: 2205669, side: 2, opacity: .8, transparent: !0 }, DisableAntialias: !1, EnableDemolishByDClick: !1, IsMobile: !1, UseWorker: !1, ZipResourcePostfix: "", HasLayerData: !1, Renderer: 1, Instance: !0, MergeComponent: !1, AutoMergeComponent: !0, AutoMergeComponentCount: 1e4, MaxMergeCount: 1e3, MergedTriangleNumberThreshold: 2e7, MaxMergedTriangleNumber: 2e7, IncrementRender: !1, EnableRenderPass: !1, LimitFrameTime: 250, maxObjectNumInPool: 1e3, maxDrawCacheNum: 4e4, OctantDepth: 15, MaximumDepth: 0, TargetDistance: 1e4, ConcurrencyRequestCount: 16, ShowOctant: !1, EnableOctant: !1, EnableViewController: !0, DirectionalLight: !0, LightPreset: 2, IBL: !1, ToneMapping: 4, LightIntensityFactor: 1, Hover: !1, OcclusionTranslucentEnabled: !1, OcclusionOpacity: .5, OcclusionDistanceToCamera: 1e3, LineSelectRange: 30, DrawingStyle: 0, DrawingBoardlineEnabled: !0, InitWireframeData: !1, EnableHitDetection: !1, TranslucentDepthDisabled: !1, SharedMeshInstanceEnable: !1, DataProvider: 0, EnableSelectionOutline: !0, EnableSelectionByTranslucent: !1, EnableSelectionBoundingBox: !1, EnableShadow: !1, EnableAnimation: !0, UseLods: !1, AutoPrepare: !0, DEBUG: !1, WalkingWithGravity: !1, WalkingWithViewLock: !1, RendererWhenLoad: !1, language: "zh-cn", LoadComponentOnDemand: !1, logarithmicDepthBuffer: !1, InfluencedByLight: !0, geometricErrorThresholdValue: 80, MaximumAvailableMemory: 500, DataReduction: !1, ConstraintZoom: !1, stepLoad: !1, useGzip: !1, notDepthWriteByTransparent: !1, PickingEffect: !0, PickingLineWidthEnabled: !0, loadBatch: !0, MiniMapSize: 1024, alphaTest: .5, EnableCreateMiniMap: !1, MultipleSelectComponents: !0 }, Ic = F.RotationOrders, Ec = { ORTHOGRAPHIC: "orth", PERSPECTIVE: "persp" }, Bc = { elements: [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1] }, xc = { elements: [1, 0, 0, 0, 1, 0, 0, 0, 1] }, Sc = { IfcOpeningElement: !0, IfcSpace: !0, OST_Rooms: !0, "房间": !0 }; Object.defineProperties(Sc, { "房间": { get: function () { return Sc.OST_Rooms }, set: function (A) { Sc.OST_Rooms = A } } }); var wc, Mc, bc = new(Proxy || function (A) { return A })(Sc, { deleteProperty: function (A, e) { e in A && ("房间" === e && delete A.OST_Rooms, delete A[e]) } }), Uc = { Keep: 0, Home: 135, Top: 1, Bottom: 2, Front: 3, Back: 4, Right: 5, Left: 6, TopFrontRight: 135, TopFrontLeft: 136, TopBackRight: 145, TopBackLeft: 146, BottomFrontRight: 235, BottomFrontLeft: 236, BottomBackRight: 245, BottomBackLeft: 246, TopFront: 13, TopBack: 14, TopRight: 15, TopLeft: 16, BottomFront: 23, BottomBack: 24, BottomRight: 25, BottomLeft: 26, FrontRight: 35, FrontLeft: 36, BackRight: 45, BackLeft: 46, TopToRight: 105, TopToLeft: 106, TopToFront: 103, TopToBack: 104, BottomToRight: 205, BottomToLeft: 206, BottomToFront: 203, BottomToBack: 204, FrontToTop: 301, FrontToBottom: 302, FrontToRight: 305, FrontToLeft: 306, BackToTop: 401, BackToBottom: 402, BackToRight: 405, BackToLeft: 406, RightToTop: 501, RightToBottom: 502, RightToFront: 503, RightToBack: 504, LeftToTop: 601, LeftTopBottom: 602, LeftTopFront: 603, LeftTopBack: 604 }, Fc = { DirectionalLight: "directional", AmbientLight: "ambient", PointLight: "point", SpotLight: "spot" }, Kc = { Clear: 0, Add: 1, Remove: 2 }, Qc = { Geometry: 1, Marker3d: 2, Room: 3, ExternalComponent: 4, UnPickable: 0 }, Rc = { ON_LOAD_START: "ON_LOAD_START", ON_LOAD_PROGRESS: "ON_LOAD_PROGRESS", ON_LOAD_COMPLETE: "ON_LOAD_COMPLETE", ON_DEMAND_LOAD_COMPLETE: "ON_DEMAND_LOAD_COMPLETE", ON_LOAD_EMPTY_SCENE: "ON_LOAD_EMPTY_SCENE", ON_LOAD_CONFIG_FINISH: "ON_LOAD_CONFIG_FINISH", ON_LOAD_INVALID_SCENE: "ON_LOAD_INVALID_SCENE", ON_LOAD_INVALID_DATA: "ON_LOAD_INVALID_DATA", ON_NETWORK_ERROR: "ON_NETWORK_ERROR", ACCOUNT_NO_EXIST: "ACCOUNT_NO_EXIST", NO_PERMISSION: "NO_PERMISSION", ON_LOAD_ERROR: "ON_LOAD_ERROR", ON_SELECTION_CHANGED: "ON_SELECTION_CHANGED", ON_RECTPICK_ADD: "ON_RECTPICK_ADD", ON_RECTPICK_REMOVE: "ON_RECTPICK_REMOVE", ON_CLICK_PICK: "ON_CLICK_PICK", ON_HOVER_PICK: "ON_HOVER_PICK", ON_MEASURE_PICK: "ON_MEASURE_PICK", ON_SELECTION_FAILED: "ON_SELECTION_FAILED", ON_CLIP_HOVER: "ON_CLIP_HOVER", ON_HOVER_SNAP: "ON_HOVER_SNAP", ON_CLIP_MOUSE_MOVE: "ON_CLIP_MOUSE_MOVE", ON_CLIP_MOUSE_DOWN: "ON_CLIP_MOUSE_DOWN", ON_VERSION_NO_MATCH: "ON_VERSION_NO_MATCH", ON_VIEWER_RESTORED: "ON_VIEWER_RESTORED", ON_CAMERA_HEIGHT_CHANGED: "ON_CAMERA_HEIGHT_CHANGED", ON_CAMERA_CHANGED_AND_RENDERED: "ON_CAMERA_CHANGED_AND_RENDERED", ON_DATABASE_OPEN: "ON_DATABASE_OPEN", ON_DATABASE_CLOSE: "ON_DATABASE_CLOSE", ON_DATABASE_ADD: "ON_DATABASE_ADD", ON_DATABASE_DELETE: "ON_DATABASE_DELETE", ON_DATABASE_CLERA: "ON_DATABASE_CLERA", ON_DATABASE_EEEOR: "ON_DATABASE_EEEOR", BEFORE_RESETSCENE: "BEFORE_RESETSCENE", AFTER_RESETSCENE: "AFTER_RESETSCENE", ON_CAMERA_CHANGE: "ON_CAMERA_CHANGE", ON_CONTROL_ENTER: "ON_CONTROL_ENTER", ON_CONTROL_EXIST: "ON_CONTROL_EXIST", ON_POINTERLOCK_EXIST: "ON_POINTERLOCK_EXIST", ON_CONTROL_BEGIN: "ON_CONTROL_BEGIN", ON_CONTROL_END: "ON_CONTROL_END", ON_CONTROL_ZOOM: "ON_CONTROL_ZOOM", ON_CONTROL_UPDATEUI: "ON_CONTROL_UPDATEUI", ON_CONTROL_KEYDOWN: "ON_CONTROL_KEYDOWN", ON_CONTROL_KEYUP: "ON_CONTROL_KEYUP", ON_CAMERA_ANIMATION_UPDATE: "ON_CAMERA_ANIMATION_UPDATE", ON_MOUSE_DRAGGED: "ON_MOUSE_DRAGGED" }, Tc = { LOAD_COMPONENT_ERROR: "LOAD_COMPONENT_ERROR", LOAD_MATERIAL_ERROR: "LOAD_MATERIAL_ERROR", LOAD_GEOMETRY_ERROR: "LOAD_GEOMETRY_ERROR", LOAD_COMPONENTNODE_ERROR: "LOAD_COMPONENTNODE_ERROR", LOAD_TEXTURE_ERROR: "LOAD_TEXTURE_ERROR", LOAD_AXISNET_ERROR: "LOAD_AXISNET_ERROR", LOAD_FLOORINFO_ERROR: "LOAD_FLOORINFO_ERROR", PARSEFAILE: "PARSEFAILE", PARSING: "PARSING", IS2D: "IS2D", LOAD_ERROR: "LOAD_ERROR", SCENE_NOT_CLOSE: "SCENE_NOT_CLOSE", SCENE_NOTHING_TO_LOAD: "SCENE_NOTHING_TO_LOAD", LOAD_SCENE_ERROR: "LOAD_SCENE_ERROR", LOAD_SYMBOL_ERROR: "LOAD_SYMBOL_ERROR", LOAD_OCTREEINNER_ERROR: "LOAD_OCTREEINNER_ERROR", LOAD_OCTREEOUTER_ERROR: "LOAD_OCTREEOUTER_ERROR", LOAD_USERID_ERROR: "LOAD_USERID_ERROR", LOAD_USERDATA_ERROR: "LOAD_USERDATA_ERROR", LOAD_CAMERA_ERROR: "LOAD_CAMERA_ERROR", LOAD_MPK_ERROR: "LOAD_MPK_ERROR", LOAD_IBLCONFIG_ERROR: "LOAD_IBLCONFIG_ERROR" }, kc = { MOUSEPOINT: 0, SELECTION: 1, CENTER: 2, CAMERA: 3 }, Dc = { FILE_VISIBLE: 0, FILE_HIDDEN: 1, SELECTED: 2, VISIBLE: 3, HIDDEN: 4, TRANSLUCENT: 5, TRANSLUCENT_OTHERS: 6, WIREFRAME: 7, COLORFUL: 8 }, Lc = { Visible: 1, HideByIsolate: 2, Transparent: 4, TransparentByIsolate: 8 }, Nc = { HIDDEN: 0, HIDDEN_OTHERS: 1, TRANSLUCENT: 2, TRANSLUCENT_OTHERS: 3 }, Oc = { TRANSLUCENT: "TRANSLUCENT", OPAQUE: "OPAQUE" }, Vc = { DISABLED: 0, TRANSLUCENT: 1, HIDDEN: 2 }, Gc = { ORBIT: "orbit", PICK: "pick", PAN: "pan", ZOOM: "zoom", FLY: "fly", WALK: "walk" }, Pc = { PICK_BY_RECT: "pickByRect", ZOOM_BY_RECT: "zoomByRect", CLIP_BY_BOX: "clipByBox", CLIP_FILL: "fillClip", PICK_BY_MEASURE: "pickByMeasure", COMPONENT_TRANSFORM: "componentTransform" }, qc = { NONE: 0, UP: 1, DOWN: 2, LEFT: 4, RIGHT: 8, FORWARD: 16, BACK: 32 }, jc = { SHADING: 0, BOARDLINE: 1, SHADINGWITHLINE: 2 }, Hc = { HIDDEN: -1, NONE: 0, HOVER: 1, SELECTED: 2, OVERRIDED: 3, TRANSPARENT: 4, BLINK: 5 }, Yc = { NONE: 0, BLINK: 1, SELECT: 2 }, Wc = { AUTO: 0, DEFAULT: 1, MERGED: 2, LAYER: 3, LAYER_SCENE: 4 }, Jc = { MATCH_RETURN_TRUE: 0, MATCH_RETURN_FALSE: 1, NOMATCH_RETURN_TRUE: 2, NOMATCH_RETURN_FALSE: 3 }, zc = { CLIPPING: -2, HIDDEN: -1, NONE: 0, SELECTED: 1, BLINK: 2, HOVER: 3, TRANSPARENT: 4, OVERRIDED: 5 }, Zc = { RVT: "RVT", IFC: "IFC", I_MODEL: "I-MODEL", THREE_DS: "3DS", MERGE: "MERGE", DAE: "DAE", DWG: "DWG", OBJ: "OBJ", FBX: "FBX" }, Xc = {}; function _c(A, e, t, i) { this._x = A || 0, this._y = e || 0, this._z = t || 0, this._w = void 0 !== i ? i : 1 } function $c(A, e, t) { this.x = A || 0, this.y = e || 0, this.z = t || 0 } Xc.clamp = function (A, e, t) { return Math.max(e, Math.min(t, A)) }, Xc.euclideanModulo = function (A, e) { return (A % e + e) % e }, Object.assign(_c, { slerp: function (A, e, t, i) { return t.copy(A).slerp(e, i) }, slerpFlat: function (A, e, t, i, o, n, r) { var a = t[i + 0], s = t[i + 1], l = t[i + 2], c = t[i + 3], h = o[n + 0], d = o[n + 1], p = o[n + 2], g = o[n + 3]; if (c !== g || a !== h || s !== d || l !== p) { var u = 1 - r, f = a * h + s * d + l * p + c * g, m = 0 > f ? -1 : 1, C = 1 - f * f; if (C > Number.EPSILON) { var y = Math.sqrt(C), v = Math.atan2(y, f * m); u = Math.sin(u * v) / y, r = Math.sin(r * v) / y } var I = r * m; if (a = a * u + h * I, s = s * u + d * I, l = l * u + p * I, c = c * u + g * I, u === 1 - r) { var E = 1 / Math.sqrt(a * a + s * s + l * l + c * c); a *= E, s *= E, l *= E, c *= E } } A[e] = a, A[e + 1] = s, A[e + 2] = l, A[e + 3] = c } }), Object.defineProperties(_c.prototype, { x: { get: function () { return this._x }, set: function (A) { this._x = A, this._onChangeCallback() } }, y: { get: function () { return this._y }, set: function (A) { this._y = A, this._onChangeCallback() } }, z: { get: function () { return this._z }, set: function (A) { this._z = A, this._onChangeCallback() } }, w: { get: function () { return this._w }, set: function (A) { this._w = A, this._onChangeCallback() } } }), Object.assign(_c.prototype, { isQuaternion: !0, set: function (A, e, t, i) { return this._x = A, this._y = e, this._z = t, this._w = i, this._onChangeCallback(), this }, clone: function () { return new this.constructor(this._x, this._y, this._z, this._w) }, copy: function (A) { return this._x = A.x, this._y = A.y, this._z = A.z, this._w = A.w, this._onChangeCallback(), this }, setFromEuler: function (A, e) { if (!A || !A.isEuler) throw new Error("THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order."); var t = A._x, i = A._y, o = A._z, n = A.order, r = Math.cos, a = Math.sin, s = r(t / 2), l = r(i / 2), c = r(o / 2), h = a(t / 2), d = a(i / 2), p = a(o / 2); return "XYZ" === n ? (this._x = h * l * c + s * d * p, this._y = s * d * c - h * l * p, this._z = s * l * p + h * d * c, this._w = s * l * c - h * d * p) : "YXZ" === n ? (this._x = h * l * c + s * d * p, this._y = s * d * c - h * l * p, this._z = s * l * p - h * d * c, this._w = s * l * c + h * d * p) : "ZXY" === n ? (this._x = h * l * c - s * d * p, this._y = s * d * c + h * l * p, this._z = s * l * p + h * d * c, this._w = s * l * c - h * d * p) : "ZYX" === n ? (this._x = h * l * c - s * d * p, this._y = s * d * c + h * l * p, this._z = s * l * p - h * d * c, this._w = s * l * c + h * d * p) : "YZX" === n ? (this._x = h * l * c + s * d * p, this._y = s * d * c + h * l * p, this._z = s * l * p - h * d * c, this._w = s * l * c - h * d * p) : "XZY" === n && (this._x = h * l * c - s * d * p, this._y = s * d * c - h * l * p, this._z = s * l * p + h * d * c, this._w = s * l * c + h * d * p), !1 !== e && this._onChangeCallback(), this }, setFromAxisAngle: function (A, e) { var t = e / 2, i = Math.sin(t); return this._x = A.x * i, this._y = A.y * i, this._z = A.z * i, this._w = Math.cos(t), this._onChangeCallback(), this }, setFromRotationMatrix: function (A) { var e, t = A.elements, i = t[0], o = t[4], n = t[8], r = t[1], a = t[5], s = t[9], l = t[2], c = t[6], h = t[10], d = i + a + h; return d > 0 ? (e = .5 / Math.sqrt(d + 1), this._w = .25 / e, this._x = (c - s) * e, this._y = (n - l) * e, this._z = (r - o) * e) : i > a && i > h ? (e = 2 * Math.sqrt(1 + i - a - h), this._w = (c - s) / e, this._x = .25 * e, this._y = (o + r) / e, this._z = (n + l) / e) : a > h ? (e = 2 * Math.sqrt(1 + a - i - h), this._w = (n - l) / e, this._x = (o + r) / e, this._y = .25 * e, this._z = (s + c) / e) : (e = 2 * Math.sqrt(1 + h - i - a), this._w = (r - o) / e, this._x = (n + l) / e, this._y = (s + c) / e, this._z = .25 * e), this._onChangeCallback(), this }, setFromUnitVectors: function (A, e) { var t = A.dot(e) + 1; return 1e-6 > t ? (t = 0, Math.abs(A.x) > Math.abs(A.z) ? (this._x = -A.y, this._y = A.x, this._z = 0, this._w = t) : (this._x = 0, this._y = -A.z, this._z = A.y, this._w = t)) : (this._x = A.y * e.z - A.z * e.y, this._y = A.z * e.x - A.x * e.z, this._z = A.x * e.y - A.y * e.x, this._w = t), this.normalize() }, angleTo: function (A) { return 2 * Math.acos(Math.abs(Xc.clamp(this.dot(A), -1, 1))) }, rotateTowards: function (A, e) { var t = this.angleTo(A); if (0 === t) return this; var i = Math.min(1, e / t); return this.slerp(A, i), this }, inverse: function () { return this.conjugate() }, conjugate: function () { return this._x *= -1, this._y *= -1, this._z *= -1, this._onChangeCallback(), this }, dot: function (A) { return this._x * A._x + this._y * A._y + this._z * A._z + this._w * A._w }, lengthSq: function () { return this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w }, length: function () { return Math.sqrt(this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w) }, normalize: function () { var A = this.length(); return 0 === A ? (this._x = 0, this._y = 0, this._z = 0, this._w = 1) : (this._x = this._x * (A = 1 / A), this._y = this._y * A, this._z = this._z * A, this._w = this._w * A), this._onChangeCallback(), this }, multiply: function (A, e) { return void 0 !== e ? (console.warn("THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead."), this.multiplyQuaternions(A, e)) : this.multiplyQuaternions(this, A) }, premultiply: function (A) { return this.multiplyQuaternions(A, this) }, multiplyQuaternions: function (A, e) { var t = A._x, i = A._y, o = A._z, n = A._w, r = e._x, a = e._y, s = e._z, l = e._w; return this._x = t * l + n * r + i * s - o * a, this._y = i * l + n * a + o * r - t * s, this._z = o * l + n * s + t * a - i * r, this._w = n * l - t * r - i * a - o * s, this._onChangeCallback(), this }, slerp: function (A, e) { if (0 === e) return this; if (1 === e) return this.copy(A); var t = this._x, i = this._y, o = this._z, n = this._w, r = n * A._w + t * A._x + i * A._y + o * A._z; if (0 > r ? (this._w = -A._w, this._x = -A._x, this._y = -A._y, this._z = -A._z, r = -r) : this.copy(A), r >= 1) return this._w = n, this._x = t, this._y = i, this._z = o, this; var a = 1 - r * r; if (Number.EPSILON >= a) { var s = 1 - e; return this._w = s * n + e * this._w, this._x = s * t + e * this._x, this._y = s * i + e * this._y, this._z = s * o + e * this._z, this.normalize(), this._onChangeCallback(), this } var l = Math.sqrt(a), c = Math.atan2(l, r), h = Math.sin((1 - e) * c) / l, d = Math.sin(e * c) / l; return this._w = n * h + this._w * d, this._x = t * h + this._x * d, this._y = i * h + this._y * d, this._z = o * h + this._z * d, this._onChangeCallback(), this }, equals: function (A) { return A._x === this._x && A._y === this._y && A._z === this._z && A._w === this._w }, fromArray: function (A, e) { return void 0 === e && (e = 0), this._x = A[e], this._y = A[e + 1], this._z = A[e + 2], this._w = A[e + 3], this._onChangeCallback(), this }, toArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = this._x, A[e + 1] = this._y, A[e + 2] = this._z, A[e + 3] = this._w, A }, _onChange: function (A) { return this._onChangeCallback = A, this }, _onChangeCallback: function () {} }), Object.assign($c.prototype, { isVector3: !0, set: function (A, e, t) { return this.x = A, this.y = e, this.z = t, this }, setScalar: function (A) { return this.x = A, this.y = A, this.z = A, this }, setX: function (A) { return this.x = A, this }, setY: function (A) { return this.y = A, this }, setZ: function (A) { return this.z = A, this }, setComponent: function (A, e) { switch (A) { case 0: this.x = e; break; case 1: this.y = e; break; case 2: this.z = e; break; default: throw new Error("index is out of range: " + A) } return this }, getComponent: function (A) { switch (A) { case 0: return this.x; case 1: return this.y; case 2: return this.z; default: throw new Error("index is out of range: " + A) } }, clone: function () { return new this.constructor(this.x, this.y, this.z) }, copy: function (A) { return this.x = A.x, this.y = A.y, this.z = A.z, this }, add: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead."), this.addVectors(A, e)) : (this.x += A.x, this.y += A.y, this.z += A.z, this) }, addScalar: function (A) { return this.x += A, this.y += A, this.z += A, this }, addVectors: function (A, e) { return this.x = A.x + e.x, this.y = A.y + e.y, this.z = A.z + e.z, this }, addScaledVector: function (A, e) { return this.x += A.x * e, this.y += A.y * e, this.z += A.z * e, this }, sub: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."), this.subVectors(A, e)) : (this.x -= A.x, this.y -= A.y, this.z -= A.z, this) }, subScalar: function (A) { return this.x -= A, this.y -= A, this.z -= A, this }, subVectors: function (A, e) { return this.x = A.x - e.x, this.y = A.y - e.y, this.z = A.z - e.z, this }, multiply: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead."), this.multiplyVectors(A, e)) : (this.x *= A.x, this.y *= A.y, this.z *= A.z, this) }, multiplyScalar: function (A) { return this.x *= A, this.y *= A, this.z *= A, this }, multiplyVectors: function (A, e) { return this.x = A.x * e.x, this.y = A.y * e.y, this.z = A.z * e.z, this }, applyEuler: (Mc = new _c, function (A) { return A && A.isEuler || console.error("THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order."), this.applyQuaternion(Mc.setFromEuler(A)) } ), applyAxisAngle: function () { var A = new _c; return function (e, t) { return this.applyQuaternion(A.setFromAxisAngle(e, t)) } }(), applyMatrix3: function (A) { var e = this.x, t = this.y, i = this.z, o = A.elements; return this.x = o[0] * e + o[3] * t + o[6] * i, this.y = o[1] * e + o[4] * t + o[7] * i, this.z = o[2] * e + o[5] * t + o[8] * i, this }, applyMatrix4: function (A) { var e = this.x, t = this.y, i = this.z, o = A.elements, n = 1 / (o[3] * e + o[7] * t + o[11] * i + o[15]); return this.x = (o[0] * e + o[4] * t + o[8] * i + o[12]) * n, this.y = (o[1] * e + o[5] * t + o[9] * i + o[13]) * n, this.z = (o[2] * e + o[6] * t + o[10] * i + o[14]) * n, this }, applyQuaternion: function (A) { var e = this.x, t = this.y, i = this.z, o = A.x, n = A.y, r = A.z, a = A.w, s = a * e + n * i - r * t, l = a * t + r * e - o * i, c = a * i + o * t - n * e, h = -o * e - n * t - r * i; return this.x = s * a + h * -o + l * -r - c * -n, this.y = l * a + h * -n + c * -o - s * -r, this.z = c * a + h * -r + s * -n - l * -o, this }, project: function (A) { return this.applyMatrix4(A.matrixWorldInverse).applyMatrix4(A.projectionMatrix) }, unproject: function (A) { return this.applyMatrix4(A.projectionMatrixInverse).applyMatrix4(A.matrixWorld) }, transformDirection: function (A) { var e = this.x, t = this.y, i = this.z, o = A.elements; return this.x = o[0] * e + o[4] * t + o[8] * i, this.y = o[1] * e + o[5] * t + o[9] * i, this.z = o[2] * e + o[6] * t + o[10] * i, this.normalize() }, divide: function (A) { return this.x /= A.x, this.y /= A.y, this.z /= A.z, this }, divideScalar: function (A) { return this.multiplyScalar(1 / A) }, min: function (A) { return this.x = Math.min(this.x, A.x), this.y = Math.min(this.y, A.y), this.z = Math.min(this.z, A.z), this }, max: function (A) { return this.x = Math.max(this.x, A.x), this.y = Math.max(this.y, A.y), this.z = Math.max(this.z, A.z), this }, clamp: function (A, e) { return this.x = Math.max(A.x, Math.min(e.x, this.x)), this.y = Math.max(A.y, Math.min(e.y, this.y)), this.z = Math.max(A.z, Math.min(e.z, this.z)), this }, clampScalar: function (A, e) { return this.x = Math.max(A, Math.min(e, this.x)), this.y = Math.max(A, Math.min(e, this.y)), this.z = Math.max(A, Math.min(e, this.z)), this }, clampLength: function (A, e) { var t = this.length(); return this.divideScalar(t || 1).multiplyScalar(Math.max(A, Math.min(e, t))) }, floor: function () { return this.x = Math.floor(this.x), this.y = Math.floor(this.y), this.z = Math.floor(this.z), this }, ceil: function () { return this.x = Math.ceil(this.x), this.y = Math.ceil(this.y), this.z = Math.ceil(this.z), this }, round: function () { return this.x = Math.round(this.x), this.y = Math.round(this.y), this.z = Math.round(this.z), this }, roundToZero: function () { return this.x = 0 > this.x ? Math.ceil(this.x) : Math.floor(this.x), this.y = 0 > this.y ? Math.ceil(this.y) : Math.floor(this.y), this.z = 0 > this.z ? Math.ceil(this.z) : Math.floor(this.z), this }, negate: function () { return this.x = -this.x, this.y = -this.y, this.z = -this.z, this }, dot: function (A) { return this.x * A.x + this.y * A.y + this.z * A.z }, lengthSq: function () { return this.x * this.x + this.y * this.y + this.z * this.z }, length: function () { return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z) }, manhattanLength: function () { return Math.abs(this.x) + Math.abs(this.y) + Math.abs(this.z) }, normalize: function () { return this.divideScalar(this.length() || 1) }, setLength: function (A) { return this.normalize().multiplyScalar(A) }, lerp: function (A, e) { return this.x += (A.x - this.x) * e, this.y += (A.y - this.y) * e, this.z += (A.z - this.z) * e, this }, lerpVectors: function (A, e, t) { return this.subVectors(e, A).multiplyScalar(t).add(A) }, cross: function (A, e) { return void 0 !== e ? (console.warn("THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead."), this.crossVectors(A, e)) : this.crossVectors(this, A) }, crossVectors: function (A, e) { var t = A.x, i = A.y, o = A.z, n = e.x, r = e.y, a = e.z; return this.x = i * a - o * r, this.y = o * n - t * a, this.z = t * r - i * n, this }, projectOnVector: function (A) { var e = A.dot(this) / A.lengthSq(); return this.copy(A).multiplyScalar(e) }, projectOnPlane: (wc = new $c, function (A) { return wc.copy(this).projectOnVector(A), this.sub(wc) } ), reflect: function () { var A = new $c; return function (e) { return this.sub(A.copy(e).multiplyScalar(2 * this.dot(e))) } }(), angleTo: function (A) { var e = this.dot(A) / Math.sqrt(this.lengthSq() * A.lengthSq()); return Math.acos(Xc.clamp(e, -1, 1)) }, distanceTo: function (A) { return Math.sqrt(this.distanceToSquared(A)) }, distanceToSquared: function (A) { var e = this.x - A.x, t = this.y - A.y, i = this.z - A.z; return e * e + t * t + i * i }, manhattanDistanceTo: function (A) { return Math.abs(this.x - A.x) + Math.abs(this.y - A.y) + Math.abs(this.z - A.z) }, setFromSpherical: function (A) { return this.setFromSphericalCoords(A.radius, A.phi, A.theta) }, setFromSphericalCoords: function (A, e, t) { var i = Math.sin(e) * A; return this.x = i * Math.sin(t), this.y = Math.cos(e) * A, this.z = i * Math.cos(t), this }, setFromCylindrical: function (A) { return this.setFromCylindricalCoords(A.radius, A.theta, A.y) }, setFromCylindricalCoords: function (A, e, t) { return this.x = A * Math.sin(e), this.y = t, this.z = A * Math.cos(e), this }, setFromMatrixPosition: function (A) { var e = A.elements; return this.x = e[12], this.y = e[13], this.z = e[14], this }, setFromMatrixScale: function (A) { var e = this.setFromMatrixColumn(A, 0).length(), t = this.setFromMatrixColumn(A, 1).length(), i = this.setFromMatrixColumn(A, 2).length(); return this.x = e, this.y = t, this.z = i, this }, setFromMatrixColumn: function (A, e) { return this.fromArray(A.elements, 4 * e) }, equals: function (A) { return A.x === this.x && A.y === this.y && A.z === this.z }, fromArray: function (A, e) { return void 0 === e && (e = 0), this.x = A[e], this.y = A[e + 1], this.z = A[e + 2], this }, toArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = this.x, A[e + 1] = this.y, A[e + 2] = this.z, A }, fromBufferAttribute: function (A, e, t) { return void 0 !== t && console.warn("THREE.Vector3: offset has been removed from .fromBufferAttribute()."), this.x = A.getX(e), this.y = A.getY(e), this.z = A.getZ(e), this } }); var Ah = [new $c, new $c, new $c, new $c, new $c, new $c, new $c, new $c], eh = new $c, th = new $c, ih = new $c, oh = new $c, nh = new $c, rh = new $c, ah = new $c, sh = new $c, lh = new $c, ch = new $c, hh = new $c; function dh(A, e, t, i, o) { var n, r = 0; for (r = 0, n = A.length - 3; n >= r; r += 3) { hh.fromArray(A, r); var a = o.x * Math.abs(hh.x) + o.y * Math.abs(hh.y) + o.z * Math.abs(hh.z), s = e.dot(hh), l = t.dot(hh), c = i.dot(hh); if (Math.max(-Math.max(s, l, c), Math.min(s, l, c)) > a) return !1 } return !0 } function ph(A, e) { this.min = void 0 !== A ? A : new $c(1 / 0, 1 / 0, 1 / 0), this.max = void 0 !== e ? e : new $c(-1 / 0, -1 / 0, -1 / 0) } var gh = new ph; Object.assign(ph.prototype, { isBox3: !0, set: function (A, e) { return this.min.copy(A), this.max.copy(e), this }, setFromArray: function (A) { for (var e = 1 / 0, t = 1 / 0, i = 1 / 0, o = -1 / 0, n = -1 / 0, r = -1 / 0, a = 0, s = A.length; s > a; a += 3) { var l = A[a], c = A[a + 1], h = A[a + 2]; e > l && (e = l), t > c && (t = c), i > h && (i = h), l > o && (o = l), c > n && (n = c), h > r && (r = h) } return this.min.set(e, t, i), this.max.set(o, n, r), this }, toArray: function (A) { return void 0 === A && (A = []), this.min.toArray(A), this.max.toArray(A, 3), A }, setFromBufferAttribute: function (A) { for (var e = 1 / 0, t = 1 / 0, i = 1 / 0, o = -1 / 0, n = -1 / 0, r = -1 / 0, a = 0, s = A.count; s > a; a += 1) { var l = A.getX(a), c = A.getY(a), h = A.getZ(a); e > l && (e = l), t > c && (t = c), i > h && (i = h), l > o && (o = l), c > n && (n = c), h > r && (r = h) } return this.min.set(e, t, i), this.max.set(o, n, r), this }, setFromPoints: function (A) { this.makeEmpty(); for (var e = 0, t = A.length; t > e; e += 1) this.expandByPoint(A[e]); return this }, setFromCenterAndSize: function (A, e) { var t = eh.copy(e).multiplyScalar(.5); return this.min.copy(A).sub(t), this.max.copy(A).add(t), this }, setFromObject: function (A) { return this.makeEmpty(), this.expandByObject(A) }, clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.min.copy(A.min), this.max.copy(A.max), this }, makeEmpty: function () { return this.min.x = this.min.y = this.min.z = 1 / 0, this.max.x = this.max.y = this.max.z = -1 / 0, this }, isEmpty: function () { return this.min.x > this.max.x || this.min.y > this.max.y || this.min.z > this.max.z }, getCenter: function (A) { return void 0 === A && (console.warn("THREE.Box3: .getCenter() target is now required"), A = new $c), this.isEmpty() ? A.set(0, 0, 0) : A.addVectors(this.min, this.max).multiplyScalar(.5) }, getSize: function (A) { return void 0 === A && (console.warn("THREE.Box3: .getSize() target is now required"), A = new $c), this.isEmpty() ? A.set(0, 0, 0) : A.subVectors(this.max, this.min) }, expandByPoint: function (A) { return this.min.min(A), this.max.max(A), this }, expandByVector: function (A) { return this.min.sub(A), this.max.add(A), this }, expandByScalar: function (A) { return this.min.addScalar(-A), this.max.addScalar(A), this }, expandByObject: function (A) { A.updateWorldMatrix(!1, !1); var e = A.geometry; void 0 !== e && (null === e.boundingBox && e.computeBoundingBox(), gh.copy(e.boundingBox), gh.applyMatrix4(A.matrixWorld), this.union(gh)); for (var t = A.children, i = 0, o = t.length; o > i; i += 1) this.expandByObject(t[i]); return this }, containsPoint: function (A) { return !(this.min.x > A.x || A.x > this.max.x || this.min.y > A.y || A.y > this.max.y || this.min.z > A.z || A.z > this.max.z) }, containsBox: function (A) { return !(this.min.x > A.min.x || A.max.x > this.max.x || this.min.y > A.min.y || A.max.y > this.max.y || this.min.z > A.min.z || A.max.z > this.max.z) }, getParameter: function (A, e) { return void 0 === e && (console.warn("THREE.Box3: .getParameter() target is now required"), e = new $c), e.set((A.x - this.min.x) / (this.max.x - this.min.x), (A.y - this.min.y) / (this.max.y - this.min.y), (A.z - this.min.z) / (this.max.z - this.min.z)) }, intersectsBox: function (A) { return !(this.min.x > A.max.x || A.min.x > this.max.x || this.min.y > A.max.y || A.min.y > this.max.y || this.min.z > A.max.z || A.min.z > this.max.z) }, intersectsSphere: function (A) { return this.clampPoint(A.center, eh), eh.distanceToSquared(A.center) <= A.radius * A.radius }, intersectsPlane: function (A) { var e = null, t = null; return A.normal.x > 0 ? (e = A.normal.x * this.min.x, t = A.normal.x * this.max.x) : (e = A.normal.x * this.max.x, t = A.normal.x * this.min.x), A.normal.y > 0 ? (e += A.normal.y * this.min.y, t += A.normal.y * this.max.y) : (e += A.normal.y * this.max.y, t += A.normal.y * this.min.y), A.normal.z > 0 ? (e += A.normal.z * this.min.z, t += A.normal.z * this.max.z) : (e += A.normal.z * this.max.z, t += A.normal.z * this.min.z), -A.constant >= e && t >= -A.constant }, intersectsTriangle: function (A) { if (this.isEmpty()) return !1; this.getCenter(sh), lh.subVectors(this.max, sh), th.subVectors(A.a, sh), ih.subVectors(A.b, sh), oh.subVectors(A.c, sh), nh.subVectors(ih, th), rh.subVectors(oh, ih), ah.subVectors(th, oh); var e = [0, -nh.z, nh.y, 0, -rh.z, rh.y, 0, -ah.z, ah.y, nh.z, 0, -nh.x, rh.z, 0, -rh.x, ah.z, 0, -ah.x, -nh.y, nh.x, 0, -rh.y, rh.x, 0, -ah.y, ah.x, 0]; return !!dh(e, th, ih, oh, lh) && (!!dh(e = [1, 0, 0, 0, 1, 0, 0, 0, 1], th, ih, oh, lh) && (ch.crossVectors(nh, rh), dh(e = [ch.x, ch.y, ch.z], th, ih, oh, lh))) }, clampPoint: function (A, e) { return void 0 === e && (console.warn("THREE.Box3: .clampPoint() target is now required"), e = new $c), e.copy(A).clamp(this.min, this.max) }, distanceToPoint: function (A) { return eh.copy(A).clamp(this.min, this.max).sub(A).length() }, getBoundingSphere: function (A) { return void 0 === A && console.error("THREE.Box3: .getBoundingSphere() target is now required"), this.getCenter(A.center), A.radius = .5 * this.getSize(eh).length(), A }, intersect: function (A) { return this.min.max(A.min), this.max.min(A.max), this.isEmpty() && this.makeEmpty(), this }, union: function (A) { return this.min.min(A.min), this.max.max(A.max), this }, applyMatrix4: function (A) { return this.isEmpty() || (Ah[0].set(this.min.x, this.min.y, this.min.z).applyMatrix4(A), Ah[1].set(this.min.x, this.min.y, this.max.z).applyMatrix4(A), Ah[2].set(this.min.x, this.max.y, this.min.z).applyMatrix4(A), Ah[3].set(this.min.x, this.max.y, this.max.z).applyMatrix4(A), Ah[4].set(this.max.x, this.min.y, this.min.z).applyMatrix4(A), Ah[5].set(this.max.x, this.min.y, this.max.z).applyMatrix4(A), Ah[6].set(this.max.x, this.max.y, this.min.z).applyMatrix4(A), Ah[7].set(this.max.x, this.max.y, this.max.z).applyMatrix4(A), this.setFromPoints(Ah)), this }, translate: function (A) { return this.min.add(A), this.max.add(A), this }, equals: function (A) { return A.min.equals(this.min) && A.max.equals(this.max) } }); var uh = { MinusEpsilon: -1e-6, byteArr2Int: function (A) { return (255 & A[0]) << 24 | (255 & A[1]) << 16 | (255 & A[2]) << 8 | (255 & A[3]) << 0 }, int2ByteArr: function (A) { var e = []; return e[0] = A >> 24, e[1] = A >> 16, e[2] = A >> 8, e[3] = A >> 0, e }, isPlainObject: function (A) { var e, t; return !(!A || "[object Object]" !== Object.prototype.toString.call(A)) && (!(e = Object.getPrototypeOf(A)) || "function" == typeof (t = Object.hasOwnProperty.call(e, "constructor") && e.constructor) && Object.hasOwnProperty.toString.call(t) === Object.hasOwnProperty.toString.call(Object)) }, extend: function () { var A = null, e = null, t = null, i = null, o = null, n = null, r = arguments[0] || {}, a = 1, s = arguments.length, l = !1; for ("boolean" == typeof r && (l = r, r = arguments[a] || {}, a += 1), "object" !== lc(r) && "function" === !lc(r) && (r = {}), a === s && (r = this, a -= 1); s > a; a += 1) if (null !== (A = arguments[a]) && void 0 !== (A = arguments[a])) for (e in A) t = r[e], r !== (i = A[e]) && (l && i && (uh.isPlainObject(i) || (o = Array.isArray(i))) ? (o ? (o = !1, n = t && Array.isArray(t) ? t : []) : n = t && uh.isPlainObject(t) ? t : {}, r[e] = uh.extend(l, n, i)) : null != i && (r[e] = i)); return r }, supportWorker: function () { return "undefined" != typeof Worker || (console.log("Web Worker is not supported."), !1) }, box3FromArray: function (A, e) { if (Array.isArray(A)) { var t = e || new ph; return t.min.fromArray(A, 0), t.max.fromArray(A, 3), t } return null }, box3FromArrayRange: function (A, e, t) { for (var i = new ph, o = Number(1 / 0), n = Number(1 / 0), r = Number(1 / 0), a = -1 / 0, s = -1 / 0, l = -1 / 0, c = e, h = t; h > c; c += 3) { var d = A[c], p = A[c + 1], g = A[c + 2]; o > d && (o = d), n > p && (n = p), r > g && (r = g), d > a && (a = d), p > s && (s = p), g > l && (l = g) } return i.min.set(o, n, r), i.max.set(a, s, l), i }, box3FromObject: function (A, e, t) { if (void 0 !== A && void 0 !== e && void 0 !== A.x && void 0 !== A.y && void 0 !== A.z && void 0 !== e.x && void 0 !== e.y && void 0 !== e.z) { var i = t || new ph; return i.min.set(A.x, A.y, A.z), i.max.set(e.x, e.y, e.z), i } return null }, computeBBox: function (A) { for (var e = new ph, t = new $c, i = 0, o = A.length; o > i; i += 1) t.fromArray(A[i], 0), e.expandByPoint(t); return e }, mergeBBox: function (A) { if (1 > A.length) return null; for (var e = new ph, t = new $c, i = new $c, o = new ph, n = 0, r = A.length; r > n; n += 1) t.set(A[n].max.x, A[n].max.y, A[n].max.z), i.set(A[n].min.x, A[n].min.y, A[n].min.z), o.set(i, t), e.union(o); return e }, parseTransform: function (A, e, t) { var i = !1; if (e.rotation && (A.rotation.fromArray(e.rotation), i = !0), e.position && (A.position.fromArray(e.position), i = !0), e.scale && (A.scale.fromArray(e.scale), i = !0), e.quaternion && (A.quaternion.fromArray(e.quaternion), i = !0), i && A.updateMatrix(), e.matrix && A.matrix.fromArray(e.matrix), t) { var o = A.matrix.clone(); o.multiplyMatrices(t, A.matrix), A.matrix = o } A.matrixAutoUpdate = !1, void 0 !== A.boundingBox && (A.boundingBox = uh.box3FromArray(e.bbox)) }, isEmptyObject: function (A) { if (!A) return !0; if (A.length > 0) return !1; if (0 === A.length) return !0; for (var e in A) if (A.hasOwnProperty(e)) return !1; return !0 }, isEmptyObjectSimple: function (A) { for (var e in A) return !1; return !0 }, isOwnEmptyObject: function (A) { for (var e in A) if (A.hasOwnProperty(e)) return !1; return !0 }, hexStrToRgb: function (A) { var e = A.replace("#", ""), t = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e); return t ? { r: parseInt(t[1], 16) / 255, g: parseInt(t[2], 16) / 255, b: parseInt(t[3], 16) / 255 } : null }, hexToRgb: function (A) { var e = {}; return e.r = (A >> 16 & 255) / 255, e.g = (A >> 8 & 255) / 255, e.b = (255 & A) / 255, e }, getMin: function (A) { for (var e = A.length, t = 1 / 0; (e -= 1) >= 0;) t = t > A[e] ? A[e] : t; return t }, getMax: function (A) { for (var e = A.length, t = -1 / 0; (e -= 1) >= 0;) t = A[e] > t ? A[e] : t; return t }, findRange: function (A, e) { if (e < Math.min.apply(null, A)) return 0; if (e > Math.max.apply(null, A)) return A.length - 1; for (var t = 0, i = 0, o = A.length; o > i; i += 1) if (A[i] > e) { t = i - 1; break } return t }, stringToByte: function (A) { for (var e = [], t = A.length, i = null, o = 0; t > o; o += 1) 65536 > (i = A.charCodeAt(o)) || i > 1114111 ? 2048 > i || i > 65535 ? 128 > i || i > 2047 ? e.push(255 & i) : (e.push(i >> 6 & 31 | 192), e.push(63 & i | 128)) : (e.push(i >> 12 & 15 | 224), e.push(i >> 6 & 63 | 128), e.push(63 & i | 128)) : (e.push(i >> 18 & 7 | 240), e.push(i >> 12 & 63 | 128), e.push(i >> 6 & 63 | 128), e.push(63 & i | 128)); return e }, byteToString: function (A) { if ("string" == typeof A) return A; for (var e = "", t = A, i = 0; t.length > i; i += 1) { var o = t[i].toString(2), n = o.match(/^1+?(?=0)/); if (n && 8 === o.length) { for (var r = n[0].length, a = t[i].toString(2).slice(7 - r), s = 1; r > s; s += 1) a += t[s + i].toString(2).slice(2); e += String.fromCharCode(parseInt(a, 2)), i += r - 1 } else e += String.fromCharCode(t[i]) } return e }, strToBinary: function (A) { for (var e = [], t = A.split(""), i = 0; t.length > i; i += 1) { 0 !== i && e.push(" "); var o = t[i].charCodeAt().toString(2); e.push(o) } return e.join("") }, binaryToStr: function (A) { for (var e = [], t = A.split(" "), i = 0; t.length > i; i += 1) { var o = parseInt(t[i], 2), n = String.fromCharCode(o); e.push(n) } return e.join("") }, isMirror: function (A) { var e = new $c(A[0], A[1], A[2]), t = new $c(A[4], A[5], A[6]), i = new $c(A[8], A[9], A[10]); return 0 > (new $c).crossVectors(e, t).dot(i) }, decodeUTF8: function (A) { for (var e = "", t = 0; A.length > t; t += 1) e += String.fromCharCode(A[t]); return decodeURIComponent(escape(e)) }, unique: function (A) { for (var e, t = [], i = {}, o = 0; null !== (e = A[o]) && void 0 !== (e = A[o]); o += 1) i[e] || (t.push(e), i[e] = !0); return i = null, t }, getValue: function (A, e) { var t = e.split("."), i = A; return t.map((function (A, e) { i = i[A] })), i }, sortByName: function (A, e, t) { t = t || "asc"; var i = !1; e ? e.indexOf(".") > -1 && (i = !0) : e = "name", A = A.sort((function (A, o) { if (i) { var n = uh.getValue(A, e), r = uh.getValue(o, e); return "asc" === t ? n.localeCompare(r) : r.localeCompare(n) } return "asc" === t ? A[e].localeCompare(o[e]) : o[e].localeCompare(A[e]) })); var o = [], n = [], r = [], a = []; return A.map((function (A, t) { var s = null; s = i ? uh.getValue(A, e) : A[e], /^[a-zA-Z]*$/.test(s.slice(0, 1)) ? o.push(A) : /^[\u4e00-\u9fa5]*$/.test(s.slice(0, 1)) ? n.push(A) : /^\d+(\.\d+)?$/.test(s.slice(0, 1)) ? r.push(A) : a.push(A) })), a.concat(r, o, n) }, PointToLineDistance: function (A, e, t, i, o, n) { var r = void 0, a = void 0, s = void 0, l = void 0, c = Math.sqrt((t - A) * (t - A) + (i - e) * (i - e)); if (0 === c) return [0, { x: t, y: i }]; var h = Math.sqrt((o - A) * (o - A) + (n - e) * (n - e)); if (0 === h) return [0, { x: o, y: n }]; var d = Math.sqrt((t - o) * (t - o) + (i - n) * (i - n)); if (0 === d) return [c, { x: t, y: i }]; if (h > c) { if (i === n ? r = o > t ? 0 : Math.PI : ((l = (o - t) / d) - 1 > 1e-5 && (l = 1), r = Math.acos(l), i > n && (r = 2 * Math.PI - r)), (l = (A - t) / c) - 1 > 1e-5 && (l = 1), a = Math.acos(l), i > e && (a = 2 * Math.PI - a), 0 > (s = a - r) && (s = -s), s > Math.PI && (s = 2 * Math.PI - s), s > Math.PI / 2) return [c, { x: t, y: i }]; if (t === o) return [h * Math.sin(s), { x: t, y: e }]; if (i === n) return [h * Math.sin(s), { x: A, y: i }]; var p, g, u = (n - i) / o - t, f = -1 / u, m = e - A * f; return g = f * (p = (n - o * u - m) / (f - u)) + m, [c * Math.sin(s), { x: p, y: g }] } if (i === n ? r = o > t ? Math.PI : 0 : ((l = (t - o) / d) - 1 > 1e-5 && (l = 1), r = Math.acos(l), n > i && (r = 2 * Math.PI - r)), (l = (A - o) / h) - 1 > 1e-5 && (l = 1), a = Math.acos(l), n > e && (a = 2 * Math.PI - a), 0 > (s = a - r) && (s = -s), s > Math.PI && (s = 2 * Math.PI - s), s > Math.PI / 2) return [h, { x: o, y: n }]; if (t === o) return [h * Math.sin(s), { x: t, y: e }]; if (i === n) return [h * Math.sin(s), { x: A, y: i }]; var C, y, v = (n - i) / o - t, I = -1 / v, E = e - A * I; return y = I * (C = (n - o * v - E) / (I - v)) + E, [h * Math.sin(s), { x: C, y: y }] }, freezeObject: function (A) { return Object.freeze ? Object.freeze(A) : A }, getEncodedId: function (A) { return A }, arrayToMap: function (A, e) { e = e || {}; for (var t = 0, i = A.length; i > t; t += 1) e[A[t]] = !0; return e }, getDifferentialIdxs: function (A, e) { var t = null, i = {}, o = {}, n = {}; if (e) if (this.isEmptyObject(A)) o = e; else { for (t in e) A[t] && (n[t] = !0); if (this.isEmptyObject(n)) i = A, o = e; else { for (t in e) n[t] || (o[t] = !0); for (t in A) n[t] || (i[t] = !0) } } else this.isEmptyObject(A) || (i = A); return { objCurrUsedIdxs: A, addIdxs: Object.keys(i), removeIdxs: Object.keys(o) } }, getCombinedKeyString: function (A, e) { return A.join(e = e || "&") }, splitCombinedKeyString: function (A, e) { return A.split(e = e || "&") }, getModelKeyFromComponentKey: function (A) { return A.split("_")[0] }, isGroupObject: function (A) { return !(!A.children || !A.children.length) }, isMeshObject: function (A) { return !!(A.isMesh || A.isLine || A.isPoints) }, asyncProcess: function (A, e, t, i, o) { requestAnimationFrame(function n(r) { var a = r; return function () { var r = null, s = null; for (s = a + t > e ? e : a + t, r = a; s > r; r += 1) { i && i(A, r), r === s - 1 && (s !== e ? requestAnimationFrame(n(r + 1)) : o && o(A)) } } }(0)) }, hasSimilarProperty: function (A, e) { if (!(A instanceof Object && e instanceof Object)) return !1; for (var t in A) if (A.hasOwnProperty(t) && !e.hasOwnProperty(t)) return !1; return !0 }, equalsWithEpsilon: function (A, e) { var t = Math.abs(A.x - e.x), i = Math.abs(A.y - e.y), o = Math.abs(A.z - e.z); return 1e-7 >= t && 1e-7 >= i && 1e-7 >= o }, arrayMax: function (A) { if (0 === A.length) return -1 / 0; for (var e = A[0], t = 1, i = A.length; i > t; t += 1) A[t] > e && (e = A[t]); return e }, arrayMin: function (A) { if (0 === A.length) return 1 / 0; for (var e = A[0], t = 1, i = A.length; i > t; t += 1) e > A[t] && (e = A[t]); return e }, ab2str: function (A) { return (new TextDecoder).decode(new Uint8Array(A)) }, str2ab: function (A) { return (new TextEncoder).encode(A).buffer } }; uh.createUUID = function () { for (var A = [], e = 0; 36 > e; e += 1) A[e] = "0123456789abcdef".substr(Math.floor(16 * Math.random()), 1); return A[14] = "4", A[19] = "0123456789abcdef".substr(3 & A[19] | 8, 1), A[8] = A[13] = A[18] = A[23] = "-", A.join("") }; var fh = { "zh-cn": { YourGraphicsCardDoesNotSeemToSupportWebGL: "您的显卡似乎不支持WebGL", YourBrowserDoesNotSeemToSupportWebGL: "您的浏览器似乎不支持WebGL", FindOutHowToGetItHere: "您可以在这里查看相关信息", SectionBoxLockHint: "请在使用此方法之前调用enableSectionBox。", APIAxisLockHint: "The API supports AxisOption.Z only for now." }, en: { YourGraphicsCardDoesNotSeemToSupportWebGL: "Your graphics card does not seem to support WebGL", YourBrowserDoesNotSeemToSupportWebGL: "Your browser does not seem to support WebGL", FindOutHowToGetItHere: "Find out how to get it here", SectionBoxLockHint: "Please call enableSectionBox before using this method.", APIAxisLockHint: "The API supports AxisOption.Z only for now." } }, mh = { getAndroidVersion: function (A) { var e = (A = A || navigator.userAgent).match(/Android\s([0-9.]*)/); return !!e && e[1] }, isTouchDevice: function () { return "undefined" != typeof window && "ontouchstart" in window }, isBrowser: function () { return "undefined" != typeof navigator }, isIE11: function () { return mh.isBrowser() && Boolean(navigator.userAgent.match(/Edge|Trident\/7\./)) }, isIOSDevice: function () { return !!mh.isBrowser() && /ip(ad|hone|od)/.test(navigator.userAgent.toLowerCase()) }, isAndroidDevice: function () { return !!mh.isBrowser() && -1 !== navigator.userAgent.toLowerCase().indexOf("android") }, isMobileDevice: function () { return !!mh.isBrowser() && (mh.isIOSDevice() || mh.isAndroidDevice()) }, isSafari: function () { if (!mh.isBrowser()) return !1; var A = navigator.userAgent.toLowerCase(); return -1 !== A.indexOf("safari") && -1 === A.indexOf("chrome") }, isFirefox: function () { return !!mh.isBrowser() && -1 !== navigator.userAgent.toLowerCase().indexOf("firefox") }, isChrome: function () { return !!mh.isBrowser() && -1 !== navigator.userAgent.toLowerCase().indexOf("chrome") }, isMac: function () { return !!mh.isBrowser() && -1 !== navigator.userAgent.toLowerCase().indexOf("mac os") }, isLinux: function () { return !!mh.isBrowser() && -1 !== navigator.userAgent.toLowerCase().indexOf("linux x86_64") }, isWindows: function () { if (!mh.isBrowser()) return !1; var A = navigator.userAgent.toLowerCase(); return -1 !== A.indexOf("win32") || -1 !== A.indexOf("windows") }, isWindowsPhone: function () { var A = navigator.userAgent.toLowerCase(); return /(?:Windows Phone)/.test(A) }, isSymbian: function () { var A = navigator.userAgent.toLowerCase(); return /(?:SymbianOS)/.test(A) || mh.isWindowsPhone() }, isTablet: function () { var A = navigator.userAgent.toLowerCase(); return /(?:iPad|PlayBook)/.test(A) || mh.isAndroidDevice() && !/(?:Mobile)/.test(A) || mh.isFirefox() && /(?:Tablet)/.test(A) }, isPc: function () { return !mh.isMobileDevice() && !mh.isTablet() && !mh.isSymbian() }, isOpera: function () { return navigator.userAgent.indexOf("Opera") > -1 } }; mh.isSafari(); mh.detectWebGL = function () { if (window.WebGLRenderingContext) { for (var A = document.createElement("canvas"), e = ["webgl", "experimental-webgl"], t = !1, i = 0; e.length > i; i += 1) try { if ((t = A.getContext(e[i])) && "function" == typeof t.getParameter) return 1 } catch (A) {} return 0 } return -1 }, mh.detectWebGL2 = function () { if (window.WebGL2RenderingContext) { for (var A = document.createElement("canvas"), e = ["webgl2"], t = !1, i = 0; e.length > i; i += 1) try { if ((t = A.getContext(e[i])) && "function" == typeof t.getParameter) return 1 } catch (A) {} return 0 } return -1 }, mh.showWebGLMessage = function (A, e, t) { var i, o = null, n = null; o = void 0 !== (t = t || {}).parent ? t.parent : document.body, i = void 0 !== t.id ? t.id : "oldie", (n = mh.getWebGLErrorMessage(A, e)).id = i, o.appendChild(n) }, mh.language = function () { return (navigator.browserLanguage || navigator.language).toLowerCase() }, mh.getWebGLErrorMessage = function (A, e) { var t = document.createElement("div"); t.id = "webgl-error-message", t.style.fontSize = "16px", t.style.fontWeight = "normal", t.style.textAlign = "center", t.style.background = "#f4c8c8", t.style.color = "#000", t.style.padding = "1.5em", t.style.width = "400px", t.style.position = "absolute", t.style.left = document.body.clientWidth / 2 - 224 + "px"; var i = document.body.clientHeight / 2 - 45; return 0 > i && (i = 0), t.style.top = i + "px", e || (e = "zh-cn"), 0 === A ? t.innerHTML = [' ' + fh[e].YourGraphicsCardDoesNotSeemToSupportWebGL + ".
", ' ' + fh[e].FindOutHowToGetItHere + "."].join("\n") : -1 === A && (t.innerHTML = ['' + fh[e].YourBrowserDoesNotSeemToSupportWebGL + ".
", '' + fh[e].FindOutHowToGetItHere + "."].join("\n")), t }, mh.isSupportIndexedDB = function () { return window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB }, mh.isSupportWorker = function () { return window.Worker }; var Ch = { DEBUG: 6, PERFORMANCE: 5, LOG: 4, INFO: 3, WARNING: 2, ERROR: 1, NONE: 0 }, yh = {}, vh = function (A) { yh[A] ? console.warn("Timer '" + A + "' already exists") : yh[A] = Date.now() }, Ih = function (A) { yh[A] ? (console.warn(A + ":", Date.now() - yh[A], "ms"), delete yh[A]) : console.warn("Timer '" + A + "' does not exist") }; function Eh() { this.level = -1, this.setLevel(Ch.LOG) } Eh.prototype.setLevel = function (A) { if (this.level !== A) { this.level = A; var e = function () {}, t = Ch, i = this; this.debug = t.DEBUG > A ? e : console.debug.bind(console), this.trace = t.DEBUG > A ? e : console.trace.bind(console), this.assert = t.DEBUG > A ? e : console.assert.bind(console), this.count = t.DEBUG > A ? e : console.count.bind(console), this.dir = t.DEBUG > A ? e : console.dir.bind(console), this.time = t.PERFORMANCE > A ? e : vh, this.timeEnd = t.PERFORMANCE > A ? e : Ih, this.log = t.LOG > A ? e : console.log.bind(console), this.info = t.INFO > A ? e : console.info.bind(console), this.warn = t.WARNING > A ? e : console.warn.bind(console), this.error = t.ERROR > A ? e : function () { if (i.callback) { var A = Array.prototype.slice.call(arguments).join(" "); i.callback({ category: "error", message: A }, { adp: !1 }) } console.error.apply(console, arguments) } } }; var Bh = new Eh, xh = { splitStr: function (A) { return A.trim().split(/\s+/g) }, getClientHeight: function () { return document.body.clientHeight && document.documentElement.clientHeight ? document.body.clientHeight < document.documentElement.clientHeight ? document.documentElement.clientHeight : document.body.clientHeight : document.body.clientHeight > document.documentElement.clientHeight ? document.body.clientHeight : document.documentElement.clientHeight }, getClientWidth: function () { return document.body.clientWidth && document.documentElement.clientWidth ? document.body.clientWidth < document.documentElement.clientWidth ? document.body.clientWidth : document.documentElement.clientWidth : document.body.clientWidth > document.documentElement.clientWidth ? document.body.clientWidth : document.documentElement.clientWidth }, getDomOffsetToClient: function (A) { var e, t = null; if (A !== document) { var i = (e = A).getBoundingClientRect ? function (A) { var e = A.getBoundingClientRect(), t = document.body, i = document.documentElement, o = e.left - (i.clientLeft || t.clientLeft); return { top: Math.round(e.top - (i.clientTop || t.clientTop)), left: Math.round(o) } }(e) : function (A) { for (var e = 0, t = 0; A;) e += A.offsetTop, t += A.offsetLeft, A = A.offsetParent; var i = document.body, o = document.documentElement; return { top: e -= window.pageYOffset || o.scrollTop || i.scrollTop, left: t -= window.pageXOffset || o.scrollLeft || i.scrollLeft } }(e); t = { width: A.offsetWidth, height: A.offsetHeight, left: i.left, top: i.top } } else t = { width: window.innerWidth, height: window.innerHeight, left: 0, top: 0 }; return t }, setClassName: function (A, e) { var t = document.getElementById(A); t && (t.className = e) }, addClassName: function (A, e) { var t = null, i = null, o = null, n = null, r = null, a = document.getElementById(A); if (a && (i = a, e && "string" == typeof e && (t = e.split(/\s+/), 1 === i.nodeType))) if (i.className || 1 !== t.length) { for (o = " " + i.className + " ", n = 0, r = t.length; r > n; n += 1) 0 > o.indexOf(" " + t[n] + " ") && (o += t[0] + " "); i.className = String.trim(o) } else i.className = e }, removeClassName: function (A, e) { var t = null, i = null, o = null, n = null, r = null, a = document.getElementById(A); if (a && (o = a, e && "string" == typeof e && (t = (e || "").split(/\s+/), 1 === o.nodeType && o.className))) { for (i = (" " + o.className + " ").replace(0, " "), n = 0, r = t.length; r > n; n += 1) for (; i.indexOf(" " + t[n] + " ") >= 0;) i = i.replace(" " + t[n] + " ", " "); o.className = e ? String.trim(i) : "" } }, showOrHideElement: function (A, e) { var t = document.getElementById(A); t && (t.style.display = e ? "" : "none") }, getStyleString: function (A) { var e = []; for (var t in A) { var i = A[t]; e.push(t), e.push(":"), e.push(i), e.push("; ") } return e.join("") }, cloneStyle: function (A) { var e = {}; for (var t in A) e[t] = A[t]; return e }, removeStyleAttribute: function (A, e) { Array.isArray(e) || (e = [e]), e.forEach((function (e) { e in A && delete A[e] })) }, trimRight: function (A) { if (0 === A.length) return ""; for (var e = A.length - 1, t = e; t >= 0; t -= 1) if (" " !== A.charAt(t)) { e = t; break } return A.substr(0, e + 1) }, trimLeft: function (A) { if (0 === A.length) return ""; for (var e = 0, t = 0; A.length > t; t += 1) if (" " !== A.charAt(t)) { e = t; break } return A.substr(e) }, trim: function (A) { return A.replace(/(^\s*)|(\s*$)/g, "") }, matchesSelector: function (A, e) { if (A.matches) return A.matches(e); if (A.matchesSelector) return A.matchesSelector(e); if (A.webkitMatchesSelector) return A.webkitMatchesSelector(e); if (A.msMatchesSelector) return A.msMatchesSelector(e); if (A.mozMatchesSelector) return A.mozMatchesSelector(e); if (A.oMatchesSelector) return A.oMatchesSelector(e); if (A.querySelectorAll) { for (var t = (A.document || A.ownerDocument).querySelectorAll(e), i = 0; t[i] && void 0 !== t[i];) i += 1; return !!t[i] } return !1 }, toTranslate3d: function (A, e) { return "translate3d(" + A + "px," + e + "px,0)" }, setCursorStyle: function (A, e) { var t = null; switch (e) { case "n": case "s": t = "ns-resize"; break; case "w": case "e": t = "ew-resize"; break; case "ne": case "sw": t = "nesw-resize"; break; case "nw": case "se": t = "nwse-resize" } A.style.cursor = t }, css: function (A, e) { for (var t = A.getAttribute("style") || "", i = Object.keys(e), o = t.split(";"), n = [], r = 0, a = o.length; a > r; r += 1) { "" !== (s = o[r]) ? n.push(s.replace(/:.+/, "")): o.splice(r, 1) } for (r = 0, a = i.length; a > r; r += 1) { var s = i[r], l = -1; o.map((function (A, e) { return A.indexOf(s) > -1 && (l = e), null })), l > -1 ? o[l] = s + ":" + e[s] : o.push(s + ":" + e[s]) } var c = o.join(";"); A.setAttribute("style", c + ";") }, append: function (A, e) { if ("string" == typeof e) { var t = document.createElement("div"); t.innerHTML = e; for (var i = document.createDocumentFragment(); t.firstChild;) i.appendChild(t.firstChild); A.appendChild(i) } else A.appendChild(e) }, scrollTop: function (A, e) { var t = A.scrollTop; if (t > e) var i = setInterval((function () { var t = A.scrollTop, o = Math.floor(-t / 6); A.scrollTop = t = o + t, A.scrollTop > e || (A.scrollTop = A.scrollTop = e, clearTimeout(i)) }), 20); else if (0 === t) var o = setInterval((function () { var i = A.scrollTop, n = Math.floor(70); A.scrollTop = i = n + i, t > A.scrollTop && (A.scrollTop = e, clearTimeout(o)) }), 20); else if (e > t) var n = setInterval((function () { var i = A.scrollTop, o = Math.floor(i / 6); A.scrollTop = i = o + i, t > A.scrollTop && (A.scrollTop = e, clearTimeout(n)) }), 20); else if (e === t) return !1 }, closest: function (A, e) { if (!A) return null; for (var t = A.matches || A.webkitMatchesSelector || A.mozMatchesSelector || A.msMatchesSelector; A && !t.call(A, e);) A = A.parentElement; return A }, addEventListener: function (A, e, t) { if (A) if (A.length) for (var i = 0; A.length > i; i += 1) A[i].addEventListener(e, (function (A) { t && "function" == typeof t && t(A) })); else A.addEventListener(e, (function (A) { t && "function" == typeof t && t(A) })) }, remove: function (A) { if (A) if (A.removeNode = [], void 0 !== A.length) { for (var e = A.length, t = 0; e > t; t += 1) A.removeNode.push({ parent: A[t].parentNode, inner: A[t].outerHTML, next: A[t].nextSibling }); for (t = 0; e > t; t += 1) A[0].parentNode.removeChild(A[0]) } else A.removeNode.push({ parent: A.parentNode, inner: A.outerHTML, next: A.nextSibling }), A.parentNode.removeChild(A) }, getStyleValue: function (A, e) { var t = A.ownerDocument.defaultView; return t && t.opener || (t = window), A.currentStyle ? A.currentStyle[e] : t.getComputedStyle(A)[e] }, isShow: function (A) { return "none" !== this.getStyleValue(A, "display") }, getHeight: function (A) { if (null != A) { if (this.isShow(A)) { if (null != A.style.height && A.style.height.length > 0) return parseFloat(A.style.height); if (parseFloat(this.getStyleValue(A, "height")) > 0) return parseFloat(this.getStyleValue(A, "height")); if (A.offsetHeight > 0) { var e = this.getStyleValue(A, "borderTopWidth"), t = this.getStyleValue(A, "borderBottomWidth"), i = this.getStyleValue(A, "paddingTop"), o = this.getStyleValue(A, "paddingBottom"), n = parseFloat(A.offsetHeight) - parseFloat(e) - parseFloat(t) - parseFloat(i) - parseFloat(o); return parseFloat(n) } return 0 } var r = A.getAttribute("style") || ""; A.setAttribute("style", r + "visibility:hidden;display:block !important;"); var a = this.getHeight(A); return A.setAttribute("style", r), Math.ceil(a) } }, getWidth: function (A) { if (null != A) { if (this.isShow(A)) { if (null != A.style.width && A.style.width.length > 0) return parseFloat(A.style.width); if (parseFloat(this.getStyleValue(A, "width")) > 0) return parseFloat(this.getStyleValue(A, "width")); if (A.offsetWidth > 0) { var e = this.getStyleValue(A, "borderLeftWidth"), t = this.getStyleValue(A, "borderRightWidth"), i = this.getStyleValue(A, "paddingLeft"), o = this.getStyleValue(A, "paddingRight"), n = parseFloat(A.offsetWidth) - parseFloat(e) - parseFloat(t) - parseFloat(i) - parseFloat(o); return parseFloat(n) } return 0 } var r = A.getAttribute("style") || ""; A.setAttribute("style", r + "visibility:hidden;display:inline-block !important;"); var a = this.getWidth(A); return A.setAttribute("style", r), Math.ceil(a) } }, outerHeight: function (A, e) { var t = A.offsetHeight; if (e) { var i = A.currentStyle || getComputedStyle(A); t += parseInt(i.marginTop, 0) + parseInt(i.marginBottom, 0) } return t }, outerWidth: function (A, e) { var t = A.offsetWidth; if (e) { var i = A.currentStyle || getComputedStyle(A); t += parseInt(i.marginLeft, 0) + parseInt(i.marginRight, 0) } return t }, isEmptyObject: function (A) { var e = null; for (e in A) return !1; return !0 }, hasClass: function (A, e) { if (A) { var t = A.className.match && A.className.match(new RegExp("(\\s|^)" + e + "(\\s|$)")); return Boolean(t) } return !1 }, addClass: function (A, e) { A && (this.hasClass(A, e) || (A.className += " " + e)) }, removeClass: function (A, e) { if (this.hasClass(A, e)) { var t = new RegExp("(\\s|^)" + e + "(\\s|$)"); A.className = A.className.replace(t, " ") } }, toggleClass: function (A, e) { this.hasClass(A, e) ? this.removeClass(A, e) : this.addClass(A, e) }, simulateEvent: function (A, e) { var t = document.createEvent("Event"); t.initEvent(e, !0, !0); A.dispatchEvent(t) }, bind: function (A, e, t) { A && (A.addEventListener ? A.addEventListener(e, t, !1) : A.attachEvent ? A.attachEvent("on" + e, t) : A["on" + e] = t) }, delegate: function (A, e, t, i) { if (A) if (A.length) for (var o = 0; A.length > o; o += 1) this.delegateFn(A[o], e, t, i); else this.delegateFn(A, e, t, i) }, delegateFn: function (A, e, t, i) { var o = this; function n(A) { var n = (A = A || window.event).target || A.srcElement; o.matchSelector(n, e) && i && ("mouseenter" === t || "mouseleave" === t ? o.fixedMouse(A, n) && i.call(n, A) : i.call(n, A)) } t = t.toLowerCase(), A.addEventListener ? A.addEventListener("mouseenter" === t ? "mouseover" : "mouseleave" === t ? "mouseout" : t, n) : A.attachEvent("mouseenter" === t ? "onmouseover" : "mouseleave" === t ? "onmouseout" : "on" + t, n) }, matchSelector: function (A, e) { return "#" === e.charAt(0) ? A.id === e.slice(1) : "." === e.charAt(0) ? -1 !== (" " + A.className + " ").indexOf(" " + e.slice(1) + " ") : A.tagName.toLowerCase() === e.toLowerCase() }, contains: function (A, e) { return A.contains ? A !== e && A.contains(e) : Boolean(16 & A.compareDocumentPosition(e)) }, fixedMouse: function (A, e) { var t = null, i = A.type.toLowerCase(); if ("mouseover" === i) t = A.relatedTarget || A.fromElement; else { if ("mouseout" !== i) return !0; t = A.relatedTarget || A.toElement } return t && "xul" !== t.prefix && !this.contains(e, t) && t !== e }, fireEvent: function (A, e) { var t = null; if (A.ownerDocument) t = A.ownerDocument; else { if (9 !== A.nodeType) throw new Error("Invalid node passed to fireEvent: " + A.id); t = A } if (A.dispatchEvent) { var i = ""; switch (e) { case "click": case "mousedown": case "mouseup": i = "MouseEvents"; break; case "focus": case "change": case "blur": case "select": i = "HTMLEvents"; break; default: Bh.error("fireEvent: Couldn't find an event class for event '" + e + "'.") } (o = t.createEvent(i)).initEvent(e, "change" !== e, !0), o.synthetic = !0, A.dispatchEvent(o, !0) } else if (A.fireEvent) { var o; (o = t.createEventObject()).synthetic = !0, A.fireEvent("on" + e, o) } } }; xh.create = function (A, e) { var t = document.createElement(A); return t.setAttribute("class", e), t }; xh.createNS = function (A, e) { var t = document.createElementNS("http://www.w3.org/2000/svg", A); return t.setAttribute("class", e), t }; xh.select = function (A) { return A.indexof("#") ? document.getElementById(A.replace("#", "")) : A.indexof(".") ? document.getElementsByClassName(A.replace(".", "")) : document.getElementsByTagName(A) }; var Sh = function (A) { if ("" === A) return 0; if ("string" == typeof A) { if (-1 === A.indexOf("px")) { var e = Number(A); return isNaN(e) ? 0 : e } var t = A.split("px"), i = Number(t[0]); return isNaN(i) ? 0 : i } return 0 }; xh.drag = function (A) { var e = mh.isPc(), t = Object.assign({ element: null, handle: null, axis: "all", cursor: "move", distance: 0, start: null, move: null, stop: null }, A), i = t.element; if (!i) return !1; var o = t.handle || i, n = void 0, r = !1, a = function (A) { if (e) var o = { x: A.clientX, y: A.clientY }; else o = { x: A.touches[0].clientX, y: A.touches[0].clientY }; var a = { x: o.x - n.x, y: o.y - n.y }; r ? (t.move && t.move(n, o, a), n = o, function (A) { var e = i.offsetLeft, o = i.offsetTop, n = Sh(getComputedStyle(i).marginLeft), r = Sh(getComputedStyle(i).marginTop), a = 0 > (e -= n) + A.x ? 0 : e + A.x, s = 0 > (o -= r) + A.y ? 0 : o + A.y; switch (t.axis) { case "x": i.style.left = a + "px"; break; case "y": i.style.top = s + "px"; break; case "all": default: i.style.left = a + "px", i.style.top = s + "px" } }(a)) : r = function (A) { return Math.pow(A.x, 2) + Math.pow(A.y, 2) > Math.pow(t.distance, 2) && (t.start && t.start(n), !0) }(a) }, s = function (A) { var i, r, s = A; if (e) { if (i = s.button, !((r = navigator.userAgent).indexOf("compatible") > -1 && r.indexOf("MSIE") > -1 && !mh.isOpera() ? 1 === i : 0 === i)) return; n = { x: s.clientX, y: s.clientY }, document.addEventListener("mousemove", a) } else n = { x: s.touches[0].clientX, y: s.touches[0].clientY }, o.addEventListener("touchmove", a); t.start && t.start(n) }, l = function () { r && t.end && t.end(n), r = !1, document.removeEventListener("mousemove", a), o.removeEventListener("touchmove", a) }; e ? (o.style.cursor = t.cursor, o.style.userSelect = "none", o.addEventListener("mousedown", s), document.addEventListener("mouseup", l)) : (o.addEventListener("touchend", l), o.addEventListener("touchstart", s)) }; xh.sizable = function (A) { var e = Object.assign({ element: null, axis: "all", minWidth: 100, minHeight: 100, distance: 0, start: null, sizable: null, stop: null }, A), t = e.element; if (!t) return !1; var i = void 0, o = !1, n = xh.create("div", "yj-resize"), r = void 0, a = void 0, s = function (A) { var n = { x: A.clientX, y: A.clientY }, s = { x: n.x - i.x, y: n.y - i.y }; o ? (e.sizable && e.sizable(i, n, s), function (A) { var i = t.offsetLeft, o = t.offsetTop, n = e.minWidth > r + A.x ? e.minWidth : r + A.x, s = e.minHeight > a + A.y ? e.minHeight : a + A.y; switch (e.resize && e.resize(n, s), t.style.left = i + "px", t.style.top = o + "px", e.axis) { case "x": t.style.width = n + "px"; break; case "y": t.style.height = s + "px"; break; case "all": default: t.style.width = n + "px", t.style.height = s + "px" } }(s)) : o = function (A) { return Math.pow(A.x, 2) + Math.pow(A.y, 2) > Math.pow(e.distance, 2) && (e.start && e.start(i), !0) }(s) }, l = function (A) { r = t.clientWidth, a = t.clientHeight; var e, o, n = A; (e = n.button, (o = navigator.userAgent).indexOf("compatible") > -1 && o.indexOf("MSIE") > -1 && !mh.isOpera() ? 1 === e : 0 === e) && (i = { x: n.clientX, y: n.clientY }, document.addEventListener("mousemove", s), document.addEventListener("touchmove", s)) }, c = function () { o && e.end && e.end(i), o = !1, document.removeEventListener("mousemove", s), document.removeEventListener("touchmove", s) }; xh.addClass(t, "yj-sizable"), t.appendChild(n), n.addEventListener("mousedown", l), n.addEventListener("touchstart", l), document.addEventListener("mouseup", c), document.addEventListener("touchend", c) }; var wh = function (A) { var e = this, t = Object.assign({ element: null, min: 0, max: 100, cur: 50, step: 1, isShowProgress: !0, input: null, change: null, currentColor: "#11dab7", defaultColor: "#999" }, A); this._opt = t; var i = xh.create("div", "yj-range"), o = xh.create("input", "yj-input-range"); e.input = o, o.setAttribute("type", "range"), o.setAttribute("step", t.step), o.setAttribute("min", t.min), o.setAttribute("max", t.max), o.setAttribute("value", t.cur); var n = xh.create("span", "yj-range-min"); n.innerText = t.min; var r = xh.create("span", "yj-range-cur"); e.cur = r, r.innerText = t.cur; var a = xh.create("span", "yj-range-max"); a.innerText = t.max; var s = xh.create("span", "yj-range-progress"); i.appendChild(o), t.isShowProgress && (i.appendChild(n), i.appendChild(r), i.appendChild(a)), i.appendChild(s), t.element.appendChild(i), e.setProgress(t.cur), o.addEventListener("input", (function () { e.setProgress(this.value), t.input && t.input(this.value) })), o.addEventListener("change", (function () { e.setProgress(this.value), t.change && t.change(this.value) })) }; wh.prototype.setProgress = function (A) { var e = this._opt, t = this.input, i = this.cur, o = (A - e.min) / (e.max - e.min) * 100; t.value = A, t.style.background = "linear-gradient(to right," + e.currentColor + " 0%," + e.currentColor + " " + o + "%," + e.defaultColor + " " + o + "%, " + e.defaultColor + " 100%)", i.innerText = A }, wh.prototype.reset = function () { this.setProgress(this._opt.cur) }, xh.range = wh; var Mh = function (A) { this._opt = Object.assign({ element: null, min: 0, max: 100, from: null, to: null, step: 1, currentColor: "#11dab7", defaultColor: "#999", change: null }, A), this._opt.from = this._opt.from || this._opt.min, this._opt.to = this._opt.to || this._opt.max, this.init() }; Mh.prototype = { init: function () { var A = xh.create("div", "yj-multiple-range"), e = xh.create("div", "yj-range-track"), t = xh.create("span", "yj-slider yj-slider-min"); t.id = "minSlider", t.type = "minimum"; var i = xh.create("span", "yj-slider yj-slider-max"); i.id = "maxSlider", i.type = "maximum", this._state = { from: this._opt.from, to: this._opt.to }, e.style.backgroundColor = this._opt.currentColor, A.style.backgroundColor = this._opt.defaultColor, A.appendChild(e), A.appendChild(t), A.appendChild(i), this._opt.element.appendChild(A), this._track = e, this._sliders = { min: t, max: i }, this._element = A, this.bindEvent(), this.update(!1) }, bindEvent: function () { var A = this, e = !1, t = null, i = null, o = function (A) { A = A || event; i = A.screenX, t = this, e = !0 }; this._sliders.min.addEventListener("mousedown", o), this._sliders.max.addEventListener("mousedown", o), document.addEventListener("mousemove", (function (o) { if (e) { o = o || event; var n = Math.round((o.screenX - i) / A._pix / A._opt.step) * A._opt.step; 0 !== n && (i = n * A._pix + i, "minimum" === t.type ? A._state.from += n : A._state.to += n, A.recalculate(t), A.update(!0)) } })), document.addEventListener("mouseup", (function () { t = null, e = !1 })) }, update: function (A) { var e = this._sliders.min.offsetWidth, t = this._sliders.max.offsetWidth; this._pix || (this._pix = (this._element.offsetWidth - e - t) / (this._opt.max - this._opt.min)); var i = (this._state.from - this._opt.min) * this._pix, o = (this._state.to - this._opt.min) * this._pix + e + t; this._track.style.left = i + e / 2 + "px", this._track.style.width = o - i - e / 2 - t / 2 + "px", this._sliders.min.style.left = i + "px", this._sliders.max.style.left = o + "px", this._opt.change && A && this._opt.change(this._state) }, recalculate: function (A) { this._opt.max > this._state.to || (this._state.to = this._opt.max), this._state.from > this._opt.min || (this._state.from = this._opt.min), A && ("maximum" === A.type && (this._state.to > this._state.from || (this._state.to = this._state.from)), "minimum" === A.type && (this._state.to > this._state.from || (this._state.from = this._state.to))) }, getProgress: function () { return this._state }, setProgress: function (A) { this._state = A, this.recalculate(), this.update(!1) } }, xh.multipleRange = Mh; var bh = function () { var A = this; Math.randomString = function (A) { for (var e = "", t = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789", i = 0; A > i; i += 1) e += t.charAt(Math.floor(Math.random() * t.length)); return e }, A.viewport = document.body, A.counter = 0, A.prompt = function (A, e) { return new t(A, e) }, A.confirm = function (A) { return new i(A) }, A.progress = function (A) { return new n(A) }, A.error = {}, A.success = {}, A.warning = {}, A.info = {}, A.alert = function (A, e) { if (["success", "error", "warning", "info"].indexOf(A) > -1) return new o(A, e) }, A.window = function (A) { return new r("window", A) }; var e = { $type: null, $el: null, $options: null, debug: function () { this.$options.debug && window.console.debug.apply(window.console, arguments) }, _processInput: function (e) { if (Array.isArray(e.buttons)) { for (var t = {}, i = 0; e.buttons.length > i; i += 1) t[e.buttons[i]] = A.base.OPTIONS.buttons[e.buttons[i]]; e.buttons = t } for (var i in e.customBtnClass = e.customBtnClass ? e.customBtnClass : A.base.DEFAULTS.customBtnClass, e.buttons) if (e.buttons.hasOwnProperty(i)) { var o = e.buttons[i]; (o = uh.extend(!0, {}, A.base.OPTIONS.buttons[i], o)).class || (o.class = e.customBtnClass), e.buttons[i] = o } return void 0 === (e = uh.extend(!0, {}, A.base.DEFAULTS, e)).showClass && (e.showClass = A.base.OPTIONS.showClass), void 0 === e.hideClass && (e.hideClass = A.base.OPTIONS.hideClass), void 0 === e.baseClass && (e.baseClass = A.base.OPTIONS.baseClass), void 0 === e.delayToRemove && (e.delayToRemove = A.base.OPTIONS.delayToRemove), e.iconClass || (e.iconClass = A.base.OPTIONS.icons[e.iconSource][this.$type]), e }, _init: function () { var A = this; A._createMarkup(), A.setTitle(A.$options.title), A.$options.draggable && (A.$el.classList.add("draggable"), A._enableDrag()), A.$options.closeButton && A._addCloseButton(), A.$options.closeOnEsc && document.addEventListener("keyup.lobibox", (function (e) { 27 === e.which && A.destroy() })), A.$options.baseClass && A.$el.classList.add(A.$options.baseClass), A.$options.showClass && (A.$el.classList.remove(A.$options.hideClass), A.$el.classList.add(A.$options.showClass)), A.$options.id && A.$el.setAttribute("id", A.$options.id), A.$el.dataset.lobibox = A }, _calculatePosition: function (A) { var e; return e = "top" === A ? 30 : "bottom" === A ? window.outerHeight - xh.outerHeight(this.$el) - 30 : (window.outerHeight - xh.outerHeight(this.$el)) / 2, "left:" + (window.outerWidth - xh.outerWidth(this.$el)) / 2 + "px;top:" + e + "px;" }, _createButton: function (A, e) { var t = this, i = document.createElement("button"), o = []; return e && e.class && (o = e.class.split(" ")), o.map((function (A, e) { i.classList.add(A) })), i.dataset.type = A, i.innerHTML = e.text, t.$options.callback && "function" == typeof t.$options.callback && i.addEventListener("click", (function (e) { t._onButtonClick(t.$options.buttons[A], A), t.$options.callback(t, this.dataset.type, e) })), i }, _onButtonClick: function (A, e) { ("ok" === e && "prompt" === this.$type && this.isValid() || "prompt" !== this.$type || "ok" !== e) && A && A.closeOnClick && this.destroy() }, _generateButtons: function () { var A = []; for (var e in this.$options.buttons) if (this.$options.buttons.hasOwnProperty(e)) { var t = this._createButton(e, this.$options.buttons[e]); A.push(t) } return A }, _createMarkup: function () { var e = this, t = document.createElement("div"); t.className = "lobibox", t.dataset.isModal = e.$options.modal, t.dataset.backdrop = !!e.$options.backdrop; var i = document.createElement("div"); i.className = "lobibox-header", t.appendChild(i); var o = document.createElement("span"); o.className = "lobibox-title", i.appendChild(o); var n = document.createElement("div"); if (n.className = "lobibox-body", t.appendChild(n), e.$options.buttons && !uh.isEmptyObject(e.$options.buttons)) { var r = document.createElement("div"); r.className = "lobibox-footer", e._generateButtons().map((function (A, e) { r.appendChild(A) })), t.appendChild(r), A.base.OPTIONS.buttonsAlign.indexOf(e.$options.buttonsAlign) > -1 && r.classList.add("text-" + e.$options.buttonsAlign) } t.classList.add(A.base.OPTIONS.modalClasses[e.$type]), e.$el = t }, _setSize: function () { var A = this; A.setWidth(A.$options.width), A.setHeight("auto" === A.$options.height ? xh.outerHeight(A.$el) : A.$options.height) }, _calculateBodyHeight: function (A) { var e = this.$el.querySelector(".lobibox-header").outerHeight, t = this.$el.querySelector(".lobibox-footer").outerHeight; return A - (e || 0) - (t || 0) }, _addBackdrop: function () { if (0 === document.querySelectorAll(".lobibox-backdrop").length) { var e = document.createElement("div"); e.className = "lobibox-backdrop", A.viewport.appendChild(e) } }, _removeBackdrop: function () { for (var A = document.querySelectorAll(".lobibox-backdrop"), e = 0; A.length > e; e += 1) A[e].remove() }, _triggerEvent: function (A) { this.$options[A] && "function" == typeof this.$options[A] && this.$options[A](this) }, _calculateWidth: function (A) { return (A = Math.min(Math.max(A, this.$options.width), window.outerWidth)) === window.outerWidth && (A -= 2 * this.$options.horizontalOffset), A }, _calculateHeight: function (A) { return (A = Math.min(Math.max(A, this.$options.height), window.outerHeight)) === window.outerHeight && (A -= 2 * this.$options.verticalOffset), A }, _addCloseButton: function () { var A = this, e = document.createElement("span"); e.className = "btn-close", e.innerHTML = "×", A.$el.querySelector(".lobibox-header").appendChild(e), e.addEventListener("mousedown", (function (A) { A.stopPropagation() })), e.addEventListener("click", (function () { A.destroy() })) }, _position: function () { this._setSize(); var A = this._calculatePosition(); this.setPosition(A.left, A.top) }, _isMobileScreen: function () { return 768 > window.outerHeight }, _enableDrag: function () { var A = this.$el, e = A.querySelector(".lobibox-header"); e.addEventListener("mousedown", (function (e) { e.preventDefault(), A.setAttribute("offset-left", e.offsetX), A.setAttribute("offset-top", e.offsetY), A.setAttribute("allow-drag", "true") })), document.addEventListener("mouseup", (function () { A.setAttribute("allow-drag", "false") })), document.addEventListener("mousemove", (function (e) { if ("true" === A.getAttribute("allow-drag")) { var t = e.clientX, i = e.clientY; 0 > i && (i = 5), i > document.body.clientHeight && (i = document.body.clientHeight - 10), 0 > t && (t = 5), t > document.body.clientWidth - A.offsetWidth && (t = document.body.clientWidth - A.offsetWidth), A.style.cssText += "left:" + t + "px;top:" + i + "px;" } })), e.addEventListener("touchstart", (function (e) { var t = A.style.top, i = e.originalEvent.targetTouches[0].clientY; A.setAttribute("offset-left", e.originalEvent.targetTouches[0].clientX - A.style.left), A.setAttribute("offset-top", i - t), A.setAttribute("allow-drag", "true") })), document.addEventListener("touchend", (function () { A.setAttribute("allow-drag", "false") })), document.addEventListener("touchmove", (function (e) { if ("true" === A.getAttribute("allow-drag")) { var t = e.originalEvent.targetTouches[0].clientX, i = e.originalEvent.targetTouches[0].clientY; 0 > i && (i = 5), i > document.body.clientHeight && (i = document.body.clientHeight - 10), 0 > t && (t = 5), t > document.body.clientWidth - A.offsetWidth && (t = document.body.clientWidth - A.offsetWidth), A.style.cssText += "left:" + t + "px;top:" + i + "px;" } })) }, _setContent: function (A) { return A && ("string" == typeof A && A.constructor == String ? this.$el.querySelector(".lobibox-body").innerHTML = A : this.$el.querySelector(".lobibox-body").appendChild(A)), this }, _beforeShow: function () { this._triggerEvent("onShow") }, _afterShow: function () { var e = this; A.counter++, e.$el.setAttribute("data-nth", A.counter), e.$options.draggable || window.addEventListener("resize.lobibox-" + e.$el.getAttribute("data-nth"), (function () { e.refreshWidth(), e.refreshHeight(), e.$el.style.cssText += "left:50%;top:50%;margin-left:" + -e.$el.width / 2 + "px;margin-top:" + -e.$el.height / 2 + "px;" })), e._triggerEvent("shown") }, _beforeClose: function () { this._triggerEvent("beforeClose") }, _afterClose: function () { this.$options.draggable || window.removeEventListener("resize.lobibox-" + this.$el.getAttribute("data-nth")), this._triggerEvent("closed") }, _beforeHide: function () { this._triggerEvent("beforeHide") }, _afterHide: function () { this._triggerEvent("afterHide") }, hide: function () { var e = this; function t() { e.$el.classList.add("lobibox-hidden"); for (var t = document.querySelectorAll(".lobibox"), i = [].slice.call(t), o = 0; i.length > o; o += 1) !0 !== i[o].dataset.isModal && i.splice(o, 1); for (o = 0; i.length > o; o += 1) i[o].classList.contains("lobibox-hidden") && i.splice(o, 1); if (0 === i.length) { var n = document.querySelectorAll(".lobibox-backdrop"); for (o = 0; n.length > o; o += 1) A.viewport.removeChild(n[o]); A.viewport.classList.remove(A.base.OPTIONS.bodyClass) } e._afterHide() } return e._beforeHide(), e.$options.hideClass ? (e.$el.classList.remove(e.$options.showClass), e.$el.classList.add(e.$options.hideClass), setTimeout((function () { t() }), e.$options.delayToRemove)) : t(), this }, destroy: function () { var e = this; function t() { e.$el.remove(); for (var t = document.querySelectorAll(".lobibox"), i = [].slice.call(t), o = 0; i.length > o; o += 1) "true" !== i[o].dataset.isModal && i.splice(o, 1); if (0 === i.length) { var n = document.querySelectorAll(".lobibox-backdrop"); for (o = 0; n.length > o; o += 1) A.viewport.removeChild(n[o]); A.viewport.classList.remove(A.base.OPTIONS.bodyClass) } var r = !1; for (o = 0; i.length > o; o += 1) if ("true" === i[o].dataset.backdrop) { r = !0; break } r || e._removeBackdrop(), e._afterClose() } return e._beforeClose(), e.$options.hideClass ? (xh.removeClass(e.$el, e.$options.showClass), xh.addClass(e.$el, e.$options.hideClass), setTimeout((function () { t() }), e.$options.delayToRemove)) : t(), this }, setWidth: function (A) { return this.$el.style.cssText += "width:" + this._calculateWidth(A) + "px;", this }, refreshWidth: function () { this.setWidth(this.$el.style.width) }, refreshHeight: function () { this.setHeight(this.$el.style.height) }, setHeight: function (A) { var e = this; return e.$el.style.cssText += "height:" + e._calculateHeight(A) + "px", e.$el.querySelector(".lobibox-body").style.cssText += "height:" + (e.$options.height - 41) + "px", e }, setSize: function (A, e) { return this.setWidth(A), this.setHeight(e), this }, setPosition: function (A, e) { var t; return "number" == typeof A && "number" == typeof e ? t = "left:" + A + "px;top:" + e + "px;" : "string" == typeof A ? t = this._calculatePosition(A) : "object" === lc(A) && (t = "left:" + A.left + "px;top:" + A.top + "px;right:" + A.right + "px;bottom:" + A.bottom + "px;"), this.$el.style.cssText += t, this }, setTitle: function (A) { return this.$el.querySelector(".lobibox-title").innerHTML = A }, getTitle: function () { return this.$el.querySelector(".lobibox-title").innerHTML }, show: function () { var e = this, t = A.viewport; (e._beforeShow(), e.$el.classList.remove("lobibox-hidden"), t.appendChild(e.$el), e.$options.buttons) && e.$el.querySelector(".lobibox-footer").children[0].focus(); return (e.$options.modal || e.$options.backdrop) && (t.classList.add(A.base.OPTIONS.bodyClass), e._addBackdrop()), !1 !== e.$options.delay && setTimeout((function () { e.destroy() }), e.$options.delay), e._afterShow(), e } }; function t(e, t) { this.$input = null, this.$type = "prompt", "object" == lc(e) ? t = e : this.$promptType = e, t = uh.extend(!0, {}, A.prompt.DEFAULT_OPTIONS, t), this.$options = this._processInput(t), this._init(), this.debug(this) } function i(A) { this.$type = "confirm", this.$options = this._processInput(A), this._init(), this.debug(this) } function o(A, e) { this.$type = A, this.$options = this._processInput(e), this._init(), this.debug(this) } function n(A) { this.$type = "progress", this.$progressBarElement = null, this.$options = this._processInput(A), this.$progress = 0, this._init(), this.debug(this) } function r(A, e) { this.$type = A, this.$options = this._processInput(e), this._init(), this.debug(this) } A.base = {}, A.base.OPTIONS = { bodyClass: "lobibox-open", modalClasses: { error: "lobibox-error", success: "lobibox-success", info: "lobibox-info", warning: "lobibox-warning", confirm: "lobibox-confirm", progress: "lobibox-progress", prompt: "lobibox-prompt", default: "lobibox-default", window: "lobibox-window" }, buttonsAlign: ["left", "center", "right"], buttons: { ok: { class: "lobibox-btn lobibox-btn-default", text: "OK", closeOnClick: !0 }, cancel: { class: "lobibox-btn lobibox-btn-cancel", text: "Cancel", closeOnClick: !0 }, yes: { class: "lobibox-btn lobibox-btn-yes", text: "确定", closeOnClick: !0 }, no: { class: "lobibox-btn lobibox-btn-no", text: "取消", closeOnClick: !0 } }, icons: { bootstrap: { confirm: "glyphicon glyphicon-question-sign", success: "glyphicon glyphicon-ok-sign", error: "glyphicon glyphicon-remove-sign", warning: "glyphicon glyphicon-exclamation-sign", info: "glyphicon glyphicon-info-sign" }, fontAwesome: { confirm: "fa fa-question-circle", success: "fa fa-check-circle", error: "fa fa-times-circle", warning: "fa fa-exclamation-circle", info: "fa fa-info-circle" } } }, A.base.DEFAULTS = { horizontalOffset: 5, verticalOffset: 5, width: 600, height: "auto", closeButton: !0, draggable: !0, customBtnClass: "lobibox-btn lobibox-btn-default", modal: !1, debug: !1, buttonsAlign: "center", closeOnEsc: !0, delayToRemove: 200, delay: !1, baseClass: "animated-super-fast", showClass: "zoomIn", hideClass: "zoomOut", iconSource: "bootstrap", onShow: null, shown: null, beforeClose: null, closed: null }, t.prototype = uh.extend(!0, {}, e, { constructor: t, _processInput: function (i) { var o = e._processInput.call(this, i); return o.buttons = { ok: A.base.OPTIONS.buttons.ok, cancel: A.base.OPTIONS.buttons.cancel }, i = uh.extend(!0, {}, o, t.DEFAULT_OPTIONS, i) }, _init: function () { e._init.call(this), this._setContent(this.$options.content), this.show() }, _afterShow: function () { var A = this; A._setContent(A._createInput())._position(), A.$input && A.$input.focus(); var t = (window.innerHeight - xh.outerHeight(A.$el)) / 2, i = (window.innerWidth - xh.outerWidth(A.$el)) / 2; A.setPosition(i, t), e._afterShow.call(A) }, _createInput: function () { var A, e = this; if (e.$options.multiline) e.$input = document.createElement("textarea"), e.$input.setAttribute("rows", e.$options.lines); else { if (!e.$promptType) return; e.$input = document.createElement("input"), e.$input.setAttribute("type", "' + me.$promptType + '") } if (e.$input.classList.add("lobibox-input"), "[object Object]" === Object.prototype.toString.call(e.$options.attrs)) for (var t in e.$options.attrs) e.$input.setAttribute(t, e.$options.attrs[t]); e.$options.value && e.setValue(e.$options.value), e.$options.label && ((A = document.createElement("label")).innerHTML = e.$options.label); var i = document.createElement("div"); return e.$options.label && i.appendChild(A), i.appendChild(e.$input), i }, setValue: function (A) { return this.$input.value = A, this }, getValue: function () { return this.$input.value }, isValid: function () { var A = this, e = A.$el.querySelectorAll(".lobibox-input-error-message"); if (A.$options.required && !A.getValue()) { if (A.$input.classList.add("invalid"), 0 === e.length) { var t = document.createElement("p"); t.className = "lobibox-input-error-message", t.innerHTML = A.$options.errorMessage, A.$el.querySelector(".lobibox-body").appendChild(t), A._position(), A.$input.focus() } return !1 } A.$input.classList.remove("invalid"); for (var i = 0; e.length > i; i += 1) e[i].remove(); return A._position(), A.$input.focus(), A._removeBackdrop(), !0 }, _beforePromptShow: function () { this._triggerEvent("beforeWindowShow") }, _beforePromptHide: function () { this._triggerEvent("beforeWindowHide") }, _afterPromptShow: function () { this._triggerEvent("afterWindowShow") }, _afterPromptHide: function () { this._triggerEvent("afterWindowHide") }, promptHide: function () { return this._beforePromptHide(), this.$el.classList.add("hide"), this._afterPromptHide(), this }, promptShow: function () { return this._beforePromptShow(), this.$el.classList.remove("hide"), this._afterPromptShow(), this.$el.style.zIndex = (new Date).getTime() - A.window.startTime, this } }), t.DEFAULT_OPTIONS = { width: 400, attrs: {}, value: "", multiline: !1, lines: 3, type: "text", label: "", required: !0, errorMessage: "The field is required" }, i.prototype = uh.extend(!0, {}, e, { constructor: i, _processInput: function (t) { var i = e._processInput.call(this, t); return i.buttons = { yes: A.base.OPTIONS.buttons.yes, no: A.base.OPTIONS.buttons.no }, t = uh.extend(!0, {}, i, A.confirm.DEFAULTS, t) }, _init: function () { e._init.call(this), this.show() }, _afterShow: function () { var A = this, t = document.createElement("div"); if (A.$options.iconClass) { var i = document.createElement("div"); i.className = "lobibox-icon-wrapper", t.appendChild(i); var o = document.createElement("i"); o.className = "lobibox-icon" + A.$options.iconClass, t.appendChild(o) } var n = document.createElement("div"); n.className = "lobibox-body-text-wrapper", t.appendChild(n); var r = document.createElement("span"); r.className = "lobibox-body-text", r.innerHTML = A.$options.msg, n.appendChild(r), A._setContent(t.innerHTML), A._position(), e._afterShow.call(A) }, _beforeConfirmShow: function () { this._triggerEvent("beforeWindowShow") }, _beforeConfirmHide: function () { this._triggerEvent("beforeWindowHide") }, _afterConfirmShow: function () { this._triggerEvent("afterWindowShow") }, _afterConfirmHide: function () { this._triggerEvent("afterWindowHide") }, confirmHide: function () { return this._beforeConfirmHide(), this.$el.classList.add("hide"), this._afterConfirmHide(), this }, confirmShow: function () { return this._beforeConfirmShow(), this.$el.classList.remove("hide"), this._afterConfirmShow(), this.$el.style.zIndex = (new Date).getTime() - A.window.startTime, this } }), A.confirm.DEFAULTS = { title: "Question", width: 500 }, o.prototype = uh.extend(!0, {}, e, { constructor: o, _processInput: function (t) { var i = e._processInput.call(this, t); return i.buttons = {}, t = uh.extend(!0, {}, i, A.alert.OPTIONS[this.$type], A.alert.DEFAULTS, t) }, _init: function () { e._init.call(this), this.show() }, _afterShow: function () { var A = this, t = document.createElement("div"); if (A.$options.iconClass) { var i = document.createElement("div"); i.className = "lobibox-icon-wrapper", t.appendChild(i); var o = document.createElement("i"); o.className = "lobibox-icon" + A.$options.iconClass, t.appendChild(o) } var n = document.createElement("div"); n.className = "lobibox-body-text-wrapper", t.appendChild(n); var r = document.createElement("span"); r.className = "lobibox-body-text", r.innerHTML = A.$options.msg, n.appendChild(r), A._setContent(t.innerHTML), A._setSize(); var a = (window.innerHeight - xh.outerHeight(A.$el)) / 2, s = (window.innerWidth - xh.outerWidth(A.$el)) / 2; A.setPosition(s, a), e._afterShow.call(A) } }), A.alert.OPTIONS = { warning: { title: "Warning" }, info: { title: "Information" }, success: { title: "Success" }, error: { title: "Error" } }, A.alert.DEFAULTS = {}, n.prototype = uh.extend(!0, {}, e, { constructor: n, _processInput: function (t) { var i = e._processInput.call(this, t); return t = uh.extend(!0, {}, i, A.progress.DEFAULTS, t) }, _init: function () { e._init.call(this), this.show() }, _afterShow: function () { var A, t = this; t.$progressBarElement = t.$options.progressTpl ? t.$options.progressTpl : t._createProgressbar(), t.$options.label && ((A = document.createElement("label")).innerHTML = t.$options.label); var i = document.createElement("div").appendChild(A); i.appendChild(t.$progressBarElement), t._setContent(i), t._position(), e._afterShow.call(t) }, _createProgressbar: function () { var A = document.createElement("div"); A.classList.add("lobibox-progress-bar-wrapper"), A.classList.add("lobibox-progress-outer"); var e = document.createElement("div"); if (e.classList.add("lobibox-progress-bar"), e.classList.add("lobibox-progress-element"), A.appendChild(e), this.$options.showProgressLabel) { var t = document.createElement("span"); t.className = "lobibox-progress-text", t.dataset.role = "progress-text", A.appendChild(t) } return A }, setProgress: function (A) { var e = this; if (100 !== e.$progress) return A = Math.min(100, Math.max(0, A)), e.$progress = A, e._triggerEvent("progressUpdated"), 100 === e.$progress && e._triggerEvent("progressCompleted"), e.$el.querySelector(".lobibox-progress-element").style.cssText += "width" + A.toFixed(1) + "%", e.$el.querySelector(".lobibox-progress-text").innerHTML = A.toFixed(1) + "%", e }, getProgress: function () { return this.$progress } }), A.progress.DEFAULTS = { width: 500, showProgressLabel: !0, label: "", progressTpl: !1, progressUpdated: null, progressCompleted: null }, r.prototype = uh.extend(!0, {}, e, { constructor: r, _processInput: function (t) { var i = e._processInput.call(this, t); return t.content && "function" == typeof t.content && (t.content = t.content()), t = uh.extend(!0, {}, i, A.window.DEFAULTS, t) }, _init: function () { var A = this; e._init.call(A), A.setContent(A.$options.content), A.$options.url && A.$options.autoload ? (A.$options.showAfterLoad || A.show(), A.load((function () { A.$options.showAfterLoad && A.show() }))) : A.show() }, _afterShow: function () { this._position(), e._afterShow.call(this) }, _addCloseButton: function () { var A = this, e = document.createElement("span"); e.className = "btn-close", e.innerHTML = "×", A.$el.querySelector(".lobibox-header").appendChild(e), e.addEventListener("mousedown", (function (A) { A.stopPropagation() })), e.addEventListener("click", (function () { A.windowHide() })) }, _beforeWindowShow: function () { this._triggerEvent("beforeWindowShow") }, _beforeWindowHide: function () { this._triggerEvent("beforeWindowHide") }, _afterWindowShow: function () { this._triggerEvent("afterWindowShow") }, _afterWindowHide: function () { this._triggerEvent("afterWindowHide") }, windowHide: function () { return this._beforeWindowHide(), this.$el.classList.add("hide"), this._afterWindowHide(), this }, windowShow: function () { return this._beforeWindowShow(), this.$el.classList.remove("hide"), this._afterWindowShow(), this.$el.style.zIndex = (new Date).getTime() - A.window.startTime, this }, setParams: function (A) { return this.$options.params = A, this }, getParams: function () { return this.$options.params }, setLoadMethod: function (A) { return this.$options.loadMethod = A, this }, getLoadMethod: function () { return this.$options.loadMethod }, setContent: function (A) { return this.$options.content = A, this.$el.querySelector(".lobibox-body").innerHTML = "", xh.append(this.$el.querySelector(".lobibox-body"), A), this }, getContent: function () { return this.$options.content }, setUrl: function (A) { return this.$options.url = A, this }, getUrl: function () { return this.$options.url }, load: function (A) { var e = this; return e.$options.url ? ($.ajax(e.$options.url, { method: e.$options.loadMethod, data: e.$options.params }).done((function (t) { e.setContent(t), A && "function" == typeof A && A(t) })), e) : e } }), A.window.DEFAULTS = { width: 480, height: 600, content: "", url: "", draggable: !0, autoload: !0, loadMethod: "GET", showAfterLoad: !0, params: {} }, A.window.startTime = (new Date).getTime(); var a = function (e, t) { this.$type = null, this.$options = null, this.$el = null; var i = this, o = function (A) { for (var e = xh.closest(A, ".lb-notify-tabs").childNodes, t = 0; e.length > t; t += 1) "li" == e[t].nodeType && e[t].classList.remove("active"); A.classList.add("active"); var i = A.querySelector("a").getAttribute("href"), o = xh.closest(i, ".lb-notify-wrapper").querySelectorAll(".lb-tab-pane"); for (t = 0; o.length > t; t += 1) o[t].classList.remove("active"); i.addClass("active") }, n = function (e) { var t = document.createElement("li"); t.className = A.notify.OPTIONS[i.$type].class; var o = document.createElement("a"); o.setAttribute("href", "#" + e), t.appendChild(o); var n = document.createElement("i"); return n.className = "tab-control-icon" + i.$options.icon, o.appendChild(n), t }, r = function () { var A = document.createElement("div"); return A.className = "lb-tab-pane", A.id = Math.randomString(10), A }, a = function (A) { if (i.$options.closable) { var e = document.createElement("span"); e.className = "lobibox-close", e.innerHTML = "×", A.appendChild(e), e.addEventListener("click", (function () { i.remove() })) } }, s = function (A) { i.$options.closeOnClick && A.click((function () { i.remove() })) }, l = function (A) { if (i.$options.delay) { if (i.$options.delayIndicator) { var e = document.createElement("div"); e.className = "lobibox-delay-indicator"; var t = document.createElement("div"); e.appendChild(t), A.appendChild(e) } var o = 0, n = 1e3 / 30, r = (new Date).getTime(), a = setInterval((function () { i.$options.continueDelayOnInactiveTab ? o = (new Date).getTime() - r : o += n; var A = 100 * o / i.$options.delay; if (100 > A || (A = 100, i.remove(), a = clearInterval(a)), i.$options.delayIndicator) for (var t = e.querySelectorAll("div"), s = 0; t.length > s; s += 1) t[s].style.cssText += "width:" + A + "%" }), n); i.$options.pauseDelayOnHover && (A.addEventListener("mouseenter.lobibox", (function () { n = 0 })), A.addEventListener("mouseleave.lobibox", (function () { n = 1e3 / 30 }))) } }, c = function (A) { return A = Math.min(window.outerWidth, A) }; this.remove = function () { i.$el.classList.remove(i.$options.showClass), i.$el.classList.add(i.$options.hideClass); var e = i.$el.parentNode, t = xh.closest(e, ".lobibox-notify-wrapper-large") || xh.closest(e, ".lobibox-notify-wrapper"); if (e) { for (var n = "#" + e.getAttribute("id"), r = t.querySelectorAll(".lb-notify-tabs li"), a = 0; r.length > a; a += 1) r[a].querySelector("a").getAttribute("href") !== n && r.splice(1, a); if (r.length > 0) for (a = 0; r.length > a; a += 1) r[a].classList.remove(A.notify.OPTIONS.class), r[a].classList.add(i.$options.hideClass); return setTimeout((function () { if ("normal" === i.$options.size || "mini" === i.$options.size) i.$el.parentElement.removeChild(i.$el); else if ("large" === i.$options.size) { var t = function (A) { var e = A.prev(); return 0 === e.length && (e = A.next()), 0 === e.length ? null : e }(r); t && o(t), r.parentElement.removeChild(r), e.parentElement.removeChild(e) } var n = A.notify.list, a = n.indexOf(i); n.splice(a, 1); var s = n[a]; s && s.$options.showAfterPrevious && s._init() }), 500), i } }, i._init = function () { var e = function () { var e, t, o, n, r, h = A.notify.OPTIONS, d = document.createElement("div"); if (d.classList.add("lobibox-notify"), d.classList.add(h[i.$type].class), d.classList.add(h.class), d.classList.add(i.$options.showClass), (o = document.createElement("div")).className = "lobibox-notify-icon-wrapper", d.appendChild(o), (e = document.createElement("div")).className = "lobibox-notify-icon", o.appendChild(e), t = document.createElement("div"), e.appendChild(t), i.$options.img) { var p = document.createElement("img"); p.src = i.$options.img, t.appendChild(p) } else if (i.$options.icon) { var g = document.createElement("div"); g.className = "icon-el"; var u = document.createElement("i"); u.className = i.$options.icon, g.appendChild(u), t.appendChild(g) } else d.classList.add("without-icon"); if ((r = document.createElement("div")).className = "lobibox-notify-msg", r.innerHTML = i.$options.msg, !1 !== i.$options.messageHeight && (r.style.cssText += "max-height:" + i.$options.messageHeight + "px;"), (n = document.createElement("div")).className = "lobibox-notify-body", n.appendChild(r), d.appendChild(n), i.$options.title) { var f = document.createElement("div"); f.className = "lobibox-notify-title", f.innerHTML = i.$options.title, n.insertBefore(f, r) } return a(d), "normal" !== i.$options.size && "mini" !== i.$options.size || (s(d), l(d)), i.$options.width && (d.style.cssText += "width:" + c(i.$options.width) + "px"), d }(); if ("mini" === i.$options.size && e.classList.add("notify-mini"), "string" == typeof i.$options.position) { var t = function () { var e, t = ("large" === i.$options.size ? ".lobibox-notify-wrapper-large" : ".lobibox-notify-wrapper") + "." + i.$options.position.replace(/\s/gi, "."); if (0 !== (e = document.querySelectorAll(t)).length) return e[0]; e = document.createElement("div"); for (var o = t.split("."), n = 1; o.length > n; n += 1) e.classList.add(o[n]); if (A.viewport.appendChild(e), "large" === i.$options.size) { var r = document.createElement("ul"); r.className = "lb-notify-tabs"; var a = document.createElement("div"); a.className = "lb-notify-wrapper", e.appendChild(r), e.appendChild(a) } return e }(); ! function (A, e) { if ("normal" === i.$options.size) e.classList.contains("bottom") ? e.insertBefore(A, e.firstChild) : e.appendChild(A); else if ("mini" === i.$options.size) e.classList.contains("bottom") ? e.insertBefore(A, e.firstChild) : e.appendChild(A); else if ("large" === i.$options.size) { var t = r().appendChild(A), a = n(t.getAttribute("id")); e.querySelector(".lb-notify-wrapper").appendChild(t), e.querySelector(".lb-notify-tabs").appendChild(a), o(a); for (var s = a.querySelectorAll("a"), l = 0; s.length > l; l += 1) s[l].click((function () { o(a) })) } }(e, t), t.classList.contains("center") && (t.style.cssText += "margin-left:" + -t.offsetWidth / 2 + "px") } else A.viewport.appendChild(e), e.style.cssText += "position:fixed;left:" + i.$options.position.left + "px;top:" + i.$options.position.top + "px;"; (i.$el = e, i.$options.sound) && new Audio(i.$options.sound).play(); i.$options.rounded && i.$el.classList.add("rounded"), i.$el.addEventListener("click", (function (A) { i.$options.onClickUrl && (window.location.href = i.$options.onClickUrl), i.$options.onClick && "function" == typeof i.$options.onClick && i.$options.onClick.call(i, A) })), i.$el.dataset.lobibox = i }, this.$type = e, this.$options = function (e) { return "mini" !== e.size && "large" !== e.size || (e = uh.extend(!0, {}, A.notify.OPTIONS[e.size], e)), "mini" !== (e = uh.extend(!0, {}, A.notify.OPTIONS[i.$type], A.notify.DEFAULTS, e)).size && !0 === e.title ? e.title = A.notify.OPTIONS[i.$type].title : "mini" === e.size && !0 === e.title && (e.title = !1), !0 === e.icon && (e.icon = A.notify.OPTIONS.icons[e.iconSource][i.$type]), !0 === e.sound && (e.sound = A.notify.OPTIONS[i.$type].sound), e.sound && (e.sound = e.soundPath + e.sound + e.soundExt), e }(t), i.$options.showAfterPrevious && 0 !== A.notify.list.length || this._init() }; A.notify = function (e, t) { if (["default", "info", "warning", "error", "success"].indexOf(e) > -1) { var i = new a(e, t); return A.notify.list.push(i), i } }, A.notify.list = [], A.notify.closeAll = function () { var e = A.notify.list; for (var t in e) { e[t].parentNode.removeChild(e[t]) } }, A.notify.DEFAULTS = { title: !0, size: "normal", soundPath: "sounds/", soundExt: ".ogg", showClass: "fadeInDown", hideClass: "zoomOut", icon: !0, msg: "", img: null, closable: !0, hideCloseButton: !1, delay: 5e3, delayIndicator: !0, closeOnClick: !0, width: 400, sound: !0, position: "bottom right", iconSource: "bootstrap", rounded: !1, messageHeight: 60, pauseDelayOnHover: !0, onClickUrl: null, showAfterPrevious: !1, continueDelayOnInactiveTab: !0, onClick: null }, A.notify.OPTIONS = { class: "animated-fast", large: { width: 500, messageHeight: 96 }, mini: { class: "notify-mini", messageHeight: 32 }, default: { class: "lobibox-notify-default", title: "Default", sound: !1 }, success: { class: "lobibox-notify-success", title: "Success", sound: "sound2" }, error: { class: "lobibox-notify-error", title: "Error", sound: "sound4" }, warning: { class: "lobibox-notify-warning", title: "Warning", sound: "sound5" }, info: { class: "lobibox-notify-info", title: "Information", sound: "sound6" }, icons: { bootstrap: { success: "glyphicon glyphicon-ok-sign", error: "glyphicon glyphicon-remove-sign", warning: "glyphicon glyphicon-exclamation-sign", info: "glyphicon glyphicon-info-sign" }, fontAwesome: { success: "fa fa-check-circle", error: "fa fa-times-circle", warning: "fa fa-exclamation-circle", info: "fa fa-info-circle" } } } }, Uh = 37, Fh = 38, Kh = 39, Qh = 40, Rh = 65, Th = 68, kh = 69, Dh = 81, Lh = 83, Nh = 87, Oh = 90, Vh = 187, Gh = 189, Ph = 48, qh = 27, jh = { ReverseWheelDirection: !1, MovementSpeedRate: 1, WalkSpeedRate: 1, RotatePivotMode: kc.MOUSEPOINT, NoPan: !1, NoRotate: !1, NoZoom: !1, NoKey: !1, LockAxisZ: !1, LockAxisZRange: null }, Hh = function (A, e) { this.defaultSetting = { colorRects: !0, picker: !0, colorCode: !0, hasOpacity: !0 }, this.color = { hex: void 0, rgb: void 0, rgba: void 0, hsl: void 0 }, this.colorInputDom = A, this.element = this.create(e) }; Hh.prototype = { constructor: Hh, create: function (A) { var e = this.defaultSetting; A && (e = uh.extend(!0, this.defaultSetting, A)); var t = document.createElement("div"); return t.style.cssText += "width:190px;position:absolute;", e.colorRects && t.appendChild(this.createRects(!!e.hasOpacity)), e.picker && t.appendChild(this.createPicker(!!e.hasOpacity)), e.colorCode && t.appendChild(this.createColorCode()), t.appendChild(this.createBtn()), this.element = t, t }, createBtn: function () { var A = this, e = document.createElement("div"), t = document.createElement("button"); t.className = "btn-yes", t.innerHTML = "确定", t.style.cssText += "display:inline-block;margin:10px;color:#000;background-color: #FFFFFF;border: 2px solid #FFFFFF;border-radius: 4px; width: 73px;height: 32px;", t.addEventListener("click", (function () { A.element.style.display = "none" })); var i = document.createElement("button"); return i.className = "btn-no", i.innerHTML = "取消", i.style.cssText += "display:inline-block;margin:10px;color:#000;background-color: #FFFFFF;border: 2px solid #FFFFFF;border-radius: 4px; width: 73px;height: 32px;", i.addEventListener("click", (function () { A.element.style.display = "none" })), e.appendChild(t), e.appendChild(i), e }, createRects: function (A) { var e = this, t = document.createElement("div"); t.className = "rectFather", t.style.cssText += "width:180px;height:180px;margin-top:10px;margin-left:10px;display:flex;flex-wrap:wrap;align-items:flex-start;"; for (var i = [], o = ["00", "55", "AA", "FF"], n = 0, r = 0, a = 0, s = "", l = 0; 64 > l;) s = "#" + o[n] + o[r] + o[a], i[l] = document.createElement("span"), i[l].className = "spans" + l, i[l].style.cssText += "width:15px;height:15px;margin:1px 2px;border:1px solid #FFFFFF;background-color:" + s + ";", i[l].setAttribute("color", s), t.appendChild(i[l]), (l += 1) % 16 == 0 ? n += 1 : l % 4 == 0 ? (r += 1) > 3 && (r = 0) : (a += 1) > 3 && (a = 0); var c = t.querySelectorAll("span"); return xh.addEventListener(c, "click", (function (t) { for (var i = 0; c.length > i; i += 1) c[i].style.cssText += "border:1px solid #FFFFFF;"; var o = t.target; o.style.cssText += "border:2px solid #000000;"; var n = o.getAttribute("color"); A ? e.setColor(n, 1) : e.setColor(n), t.stopPropagation ? t.stopPropagation() : t.cancelBubble = !0 })), t }, createPicker: function (A) { var e = this, t = document.createElement("div"); t.style.cssText += "width:180px;margin-left:10px;"; var i = document.createElement("span"); i.className = "colorShow", i.style.cssText += "display:block;width:170px;height:30px;border-radius:5px;margin-top:10px;margin-bottom:10px;background-color:#FFFFFF;", t.appendChild(i); var o = document.createElement("span"); o.innerHTML = "红 : ", o.style.color = "#FF0000"; var n = document.createElement("input"); n.type = "range", n.className = "redRange", n.style.cssText += "background:linear-gradient(#FFFFFF, #FFFFFF) no-repeat, #FF0000;", n.setAttribute("step", "1"), n.setAttribute("min", "0"), n.setAttribute("max", "255"), n.setAttribute("value", "255"); var r = document.createElement("div"); r.appendChild(o), r.appendChild(n), t.appendChild(r); var a = document.createElement("span"); a.innerHTML = "绿 : ", a.style.color = "#00FF00"; var s = document.createElement("input"); s.type = "range", s.className = "greenRange", s.style.cssText += "background:linear-gradient(#FFFFFF, #FFFFFF) no-repeat, #00FF00;", s.setAttribute("step", "1"), s.setAttribute("min", "0"), s.setAttribute("max", "255"), s.setAttribute("value", "255"); var l = document.createElement("div"); l.appendChild(a), l.appendChild(s), t.appendChild(l); var c = document.createElement("span"); c.innerHTML = "蓝 : ", c.style.color = "#0000FF"; var h = document.createElement("input"); h.type = "range", h.className = "blueRange", h.style.cssText += "background:linear-gradient(#FFFFFF, #FFFFFF) no-repeat, #0000FF;", h.setAttribute("step", "1"), h.setAttribute("min", "0"), h.setAttribute("max", "255"), h.setAttribute("value", "255"); var d = document.createElement("div"); d.appendChild(c), d.appendChild(h), t.appendChild(d); var p = t.querySelector(".redRange"), g = t.querySelector(".greenRange"), u = t.querySelector(".blueRange"), f = null; if (p.addEventListener("input", (function () { var t = "#" + ((1 << 24) + (Number(p.value) << 16) + (Number(g.value) << 8) + Number(u.value)).toString(16).slice(1); if (A) { var i = Number(f.value); e.setColor(t, i) } else e.setColor(t) })), g.addEventListener("input", (function () { var t = "#" + ((1 << 24) + (Number(p.value) << 16) + (Number(g.value) << 8) + Number(u.value)).toString(16).slice(1); if (A) { var i = Number(f.value); e.setColor(t, i) } else e.setColor(t) })), u.addEventListener("input", (function () { var t = "#" + ((1 << 24) + (Number(p.value) << 16) + (Number(g.value) << 8) + Number(u.value)).toString(16).slice(1); if (A) { var i = Number(f.value); e.setColor(t, i) } else e.setColor(t) })), A) { var m = document.createElement("span"); m.innerHTML = "透明度 : ", m.style.color = "#FFFFFF"; var C = document.createElement("input"); C.type = "range", C.className = "opacityRange", C.style.cssText += "width:97px;background:linear-gradient(#FFFFFF, #FFFFFF) no-repeat, #FFFFFF;", C.setAttribute("step", "0.01"), C.setAttribute("min", "0"), C.setAttribute("max", "1"), C.setAttribute("value", "1"); var y = document.createElement("div"); y.appendChild(m), y.appendChild(C), t.appendChild(y), (f = t.querySelector(".opacityRange")).addEventListener("input", (function () { var A = "#" + ((1 << 24) + (Number(p.value) << 16) + (Number(g.value) << 8) + Number(u.value)).toString(16).slice(1), t = Number(f.value); e.setColor(A, t) })) } return t }, createColorCode: function () { var A = this, e = document.createElement("div"); e.style.cssText += "width:180px;margin-left:10px;"; var t = document.createElement("input"); t.className = "colorCode", t.type = "text", t.style.cssText += "display:block;float:left;width:110px;margin:10px 10px 10px 0;padding-left:3px;", t.value = "#ffffff", e.appendChild(t); var i = document.createElement("span"); return i.className = "colorCodeBtn", i.style.cssText += "display:block;float:left;width:38px;height:21px;border-radius:5px;margin-top:10px;background-color:#FFFFFF;font-size:13px;text-align:center;line-height:21px;cursor:default;", i.innerHTML = "HEX", i.addEventListener("click", (function (e) { var t = e.target.textContent, i = A.element.querySelector(".colorCode").value; if (A.element.querySelector(".opacityRange")) var o = Number(A.element.querySelector(".opacityRange").value); "HEX" === t ? e.target.innerHTML = "RGB" : "RGB" === t && (e.target.innerHTML = "HEX"), A.setColor(i, o) })), e.appendChild(i), e }, colorRgbToHex: function (A) { if (A) { var e = (A = A.toLowerCase()).replace(/rgba?\(/, "").replace(/\)/, "").replace(/[\s+]/g, "").split(","), t = parseFloat(e[3] || 1), i = Math.floor(t * parseInt(e[0], 0) + 255 * (1 - t)), o = Math.floor(t * parseInt(e[1], 0) + 255 * (1 - t)), n = Math.floor(t * parseInt(e[2], 0) + 255 * (1 - t)); return "#" + ("0" + i.toString(16)).slice(-2) + ("0" + o.toString(16)).slice(-2) + ("0" + n.toString(16)).slice(-2) } return A }, colorHexToRgb: function (A, e) { var t = A.toLowerCase(); if (t && /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/.test(t)) { if (4 === t.length) { for (var i = "#", o = 1; 4 > o; o += 1) i += t.slice(o, o + 1).concat(t.slice(o, o + 1)); t = i } for (var n = [], r = 1; 7 > r; r += 2) n.push(parseInt("0x" + t.slice(r, r + 2), 0)); if (!isNaN(e)) { var a = Number(e); return 0 > a || a > 1 ? t : "rgba(" + n.join(",") + "," + a + ")" } return "rgb(" + n.join(",") + ")" } return t }, checkColor: function (A) { var e = {}; if (A) { var t = A.toLowerCase(); t && /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/.test(t) ? (e.color = !0, e.hex = !0, e.rgb = !1, e.hsl = !1, e.hexLength = 4 === t.length ? 3 : 6) : t && /^rgb/.test(t) ? (e.color = !0, e.hex = !1, e.rgb = !0, e.hsl = !1) : t && /^hsl/.test(t) ? (e.color = !0, e.hex = !1, e.rgb = !1, e.hsl = !0) : (e.color = !1, e.hex = !1, e.rgb = !1, e.hsl = !1) } else e.color = !1, e.hex = !1, e.rgb = !1, e.hsl = !1; return e }, setColor: function (A, e) { var t = this.defaultSetting; if (t.picker || t.colorCode) { var i = this.checkColor(A); if (i.color) { var o = "", n = "", r = A.toLowerCase(); if (i.hex) { if (3 === i.hexLength) { for (var a = "#", s = 1; 4 > s; s += 1) a += r.slice(s, s + 1).concat(r.slice(s, s + 1)); r = a } n = r, o = this.colorHexToRgb(A, e) } else i.rgb && (n = this.colorRgbToHex(A), o = r); if (o) { if (t.picker) { xh.css(this.element.querySelector(".colorShow"), { "background-color": o }); var l = this.getRgbNumber(n); 3 === l.length && (this.element.querySelector(".redRange").value = l[0], this.element.querySelector(".greenRange").value = l[1], this.element.querySelector(".blueRange").value = l[2], e && (this.element.querySelector(".opacityRange").value = e)) } if (t.colorCode) { var c = this.element.querySelector(".colorCode"); c.value = n; var h = this.element.querySelector(".colorCodeBtn").textContent; "HEX" === h ? c.value = n : "RGB" === h && (c.value = o) } this.colorInputDom.value = o, xh.simulateEvent(this.colorInputDom, "change") } } } }, getRgbNumber: function (A) { var e = [], t = this.checkColor(A); if (t.color) { var i = A.toLowerCase(); if (t.hex) { if (3 === t.hexLength) { for (var o = "#", n = 1; 4 > n; n += 1) o += i.slice(n, n + 1).concat(i.slice(n, n + 1)); i = o } for (var r = 1; 7 > r; r += 2) e.push(parseInt("0x" + i.slice(r, r + 2), 0)) } } return e } }; var Yh = {}; Yh.fullScreen = function (A) { if (!A) return !1; if (A.requestFullscreen) A.requestFullscreen(); else if (A.mozRequestFullScreen) A.mozRequestFullScreen(); else if (A.webkitRequestFullscreen) A.webkitRequestFullscreen(); else { if (!A.msRequestFullscreen) return !1; A.msRequestFullscreen() } }, Yh.exitFullScreen = function () { document.exitFullscreen ? document.exitFullscreen() : document.mozCancelFullScreen ? document.mozCancelFullScreen() : document.webkitCancelFullScreen ? document.webkitCancelFullScreen() : document.msExitFullscreen && document.msExitFullscreen() }, Yh.onFullScreenChanged = function (A) { var e = function () { A && A() }; document.onfullscreenchange = e, document.onwebkitfullscreenchange = e, document.documentElement.onwebkitfullscreenchange = e, document.onmozfullscreenchange = e, document.onmsfullscreenchange = e }, Yh.inFullScreen = function () { return "webkitIsFullScreen" in document ? Boolean(document.webkitIsFullScreen) : "fullscreenElement" in document ? Boolean(document.fullscreenElement) : "mozFullScreenElement" in document ? Boolean(document.mozFullScreenElement) : "msFullscreenElement" in document ? Boolean(document.msFullscreenElement) : Boolean(document.querySelector(".viewer-fill-browser")) }, Yh.findFullScreenElement = function () { return document.fullscreenElement || document.mozFullScreenElement || document.webkitFullscreenElement || document.msFullscreenElement }, Yh.isFullScreenAvailable = function (A) { return A.requestFullscreen || A.mozRequestFullScreen || A.webkitRequestFullscreen || A.msRequestFullscreen }; var Wh = Yh, Jh = { aliceblue: 15792383, antiquewhite: 16444375, aqua: 65535, aquamarine: 8388564, azure: 15794175, beige: 16119260, bisque: 16770244, black: 0, blanchedalmond: 16772045, blue: 255, blueviolet: 9055202, brown: 10824234, burlywood: 14596231, cadetblue: 6266528, chartreuse: 8388352, chocolate: 13789470, coral: 16744272, cornflowerblue: 6591981, cornsilk: 16775388, crimson: 14423100, cyan: 65535, darkblue: 139, darkcyan: 35723, darkgoldenrod: 12092939, darkgray: 11119017, darkgreen: 25600, darkgrey: 11119017, darkkhaki: 12433259, darkmagenta: 9109643, darkolivegreen: 5597999, darkorange: 16747520, darkorchid: 10040012, darkred: 9109504, darksalmon: 15308410, darkseagreen: 9419919, darkslateblue: 4734347, darkslategray: 3100495, darkslategrey: 3100495, darkturquoise: 52945, darkviolet: 9699539, deeppink: 16716947, deepskyblue: 49151, dimgray: 6908265, dimgrey: 6908265, dodgerblue: 2003199, firebrick: 11674146, floralwhite: 16775920, forestgreen: 2263842, fuchsia: 16711935, gainsboro: 14474460, ghostwhite: 16316671, gold: 16766720, goldenrod: 14329120, gray: 8421504, green: 32768, greenyellow: 11403055, grey: 8421504, honeydew: 15794160, hotpink: 16738740, indianred: 13458524, indigo: 4915330, ivory: 16777200, khaki: 15787660, lavender: 15132410, lavenderblush: 16773365, lawngreen: 8190976, lemonchiffon: 16775885, lightblue: 11393254, lightcoral: 15761536, lightcyan: 14745599, lightgoldenrodyellow: 16448210, lightgray: 13882323, lightgreen: 9498256, lightgrey: 13882323, lightpink: 16758465, lightsalmon: 16752762, lightseagreen: 2142890, lightskyblue: 8900346, lightslategray: 7833753, lightslategrey: 7833753, lightsteelblue: 11584734, lightyellow: 16777184, lime: 65280, limegreen: 3329330, linen: 16445670, magenta: 16711935, maroon: 8388608, mediumaquamarine: 6737322, mediumblue: 205, mediumorchid: 12211667, mediumpurple: 9662683, mediumseagreen: 3978097, mediumslateblue: 8087790, mediumspringgreen: 64154, mediumturquoise: 4772300, mediumvioletred: 13047173, midnightblue: 1644912, mintcream: 16121850, mistyrose: 16770273, moccasin: 16770229, navajowhite: 16768685, navy: 128, oldlace: 16643558, olive: 8421376, olivedrab: 7048739, orange: 16753920, orangered: 16729344, orchid: 14315734, palegoldenrod: 15657130, palegreen: 10025880, paleturquoise: 11529966, palevioletred: 14381203, papayawhip: 16773077, peachpuff: 16767673, peru: 13468991, pink: 16761035, plum: 14524637, powderblue: 11591910, purple: 8388736, rebeccapurple: 6697881, red: 16711680, rosybrown: 12357519, royalblue: 4286945, saddlebrown: 9127187, salmon: 16416882, sandybrown: 16032864, seagreen: 3050327, seashell: 16774638, sienna: 10506797, silver: 12632256, skyblue: 8900331, slateblue: 6970061, slategray: 7372944, slategrey: 7372944, snow: 16775930, springgreen: 65407, steelblue: 4620980, tan: 13808780, teal: 32896, thistle: 14204888, tomato: 16737095, turquoise: 4251856, violet: 15631086, wheat: 16113331, white: 16777215, whitesmoke: 16119285, yellow: 16776960, yellowgreen: 10145074 }; function zh(A, e, t) { return 0 > t && (t += 1), t > 1 && (t -= 1), 1 / 6 > t ? A + 6 * (e - A) * t : .5 > t ? e : 2 / 3 > t ? A + 6 * (e - A) * (2 / 3 - t) : A } var Zh, Xh = function (A, e, t, i) { return void 0 === i && void 0 === t ? this.set(A, e) : this.setRGB(A, e, t, i) }; Object.assign(Xh.prototype, { isColor: !0, r: 1, g: 1, b: 1, a: 1, set: function (A, e) { return "number" == typeof A ? this.setHex(A) : "string" == typeof A && this.setStyle(A), void 0 !== e && this.setAlpha(e), this }, setHex: function (A, e) { return A = Math.floor(A), this.r = (A >> 16 & 255) / 255, this.g = (A >> 8 & 255) / 255, this.b = (255 & A) / 255, this.setAlpha(e), this }, setAlpha: function (A) { return "number" == typeof A ? (A > 1 && (A = 1), 0 > A && (A = 0), this.a = A) : isNaN(parseFloat(A)) ? this.a = 1 : ((A = parseFloat(A)) > 1 && (A = 1), 0 > A && (A = 0), this.a = A), this }, setRGB: function (A, e, t, i) { return this.r = A > 1 ? Math.min(255, parseInt(A, 10)) / 255 : A, this.g = e > 1 ? Math.min(255, parseInt(e, 10)) / 255 : e, this.b = t > 1 ? Math.min(255, parseInt(t, 10)) / 255 : t, this.setAlpha(i), this }, setHSL: function (A, e, t, i) { if (A = Xc.euclideanModulo(A, 1), e = Xc.clamp(e, 0, 1), t = Xc.clamp(t, 0, 1), 0 === e) this.r = this.g = this.b = t; else { var o = t > .5 ? t + e - t * e : t * (1 + e), n = 2 * t - o; this.r = zh(n, o, A + 1 / 3), this.g = zh(n, o, A), this.b = zh(n, o, A - 1 / 3) } return this.a = i, this }, setStyle: function (A) { var e = null; if (e = /^((?:rgb|hsl)a?)\(\s*([^\)]*)\)/.exec(A)) { var t = null, i = e[2]; switch (e[1]) { case "rgb": case "rgba": if (t = /^(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(i)) return this.r = Math.min(255, parseInt(t[1], 10)) / 255, this.g = Math.min(255, parseInt(t[2], 10)) / 255, this.b = Math.min(255, parseInt(t[3], 10)) / 255, this.setAlpha(t[5]), this; if (t = /^(\d+)\%\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(i)) return this.r = Math.min(100, parseInt(t[1], 10)) / 100, this.g = Math.min(100, parseInt(t[2], 10)) / 100, this.b = Math.min(100, parseInt(t[3], 10)) / 100, this.setAlpha(t[5]), this; break; case "hsl": case "hsla": if (t = /^([0-9]*\.?[0-9]+)\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(,\s*([0-9]*\.?[0-9]+)\s*)?$/.exec(i)) { var o = parseFloat(t[1]) / 360, n = parseInt(t[2], 10) / 100, r = parseInt(t[3], 10) / 100; return this.setAlpha(t[5]), this.setHSL(o, n, r) } } } else if (e = /^\#([A-Fa-f0-9]+)$/.exec(A)) { var a, s = (a = e[1]).length; if (3 === s) return this.r = parseInt(a.charAt(0) + a.charAt(0), 16) / 255, this.g = parseInt(a.charAt(1) + a.charAt(1), 16) / 255, this.b = parseInt(a.charAt(2) + a.charAt(2), 16) / 255, this; if (6 === s) return this.r = parseInt(a.charAt(0) + a.charAt(1), 16) / 255, this.g = parseInt(a.charAt(2) + a.charAt(3), 16) / 255, this.b = parseInt(a.charAt(4) + a.charAt(5), 16) / 255, this } A && A.length > 0 && (void 0 !== (a = Jh[A]) ? this.setHex(a) : Bh.warn("Color: Unknown color " + A)); return this }, getHex: function () { return 255 * this.r << 16 ^ 255 * this.g << 8 ^ 255 * this.b << 0 }, getHexString: function () { return ("000000" + this.getHex().toString(16)).slice(-6) }, getHSL: function () { var A = { h: 0, s: 0, l: 0, a: 1 }, e = this.r, t = this.g, i = this.b, o = Math.max(e, t, i), n = Math.min(e, t, i), r = 0, a = 0, s = (n + o) / 2; if (n === o) r = 0, a = 0; else { var l = o - n; switch (a = s > .5 ? l / (2 - o - n) : l / (o + n), o) { case e: r = (t - i) / l + (i > t ? 6 : 0); break; case t: r = (i - e) / l + 2; break; case i: r = (e - t) / l + 4 } r /= 6 } return A.h = r, A.s = a, A.l = s, A.a = this.a, A }, getRGB: function () { return "rgb(" + (255 * this.r | 0) + "," + (255 * this.g | 0) + "," + (255 * this.b | 0) + ")" }, getRGBA: function () { return "rgba(" + (255 * this.r | 0) + "," + (255 * this.g | 0) + "," + (255 * this.b | 0) + "," + this.a + ")" }, getAlpha: function () { return this.a }, getStyle: function () { return "rgb(" + (255 * this.r | 0) + "," + (255 * this.g | 0) + "," + (255 * this.b | 0) + ")" }, offsetHSL: (Zh = {}, function (A, e, t) { return this.getHSL(Zh), Zh.h += A, Zh.s += e, Zh.l += t, this.setHSL(Zh.h, Zh.s, Zh.l), this } ), fromArray: function (A, e) { return void 0 === e && (e = 0), this.r = A[e], this.g = A[e + 1], this.b = A[e + 2], this.a = A[e + 3] || 1, this }, toArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = this.r, A[e + 1] = this.g, A[e + 2] = this.b, A[e + 3] = this.a, A }, toRGBArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = 255 * this.r, A[e + 1] = 255 * this.g, A[e + 2] = 255 * this.b, A[e + 3] = 255 * this.a, A }, toJSON: function () { return this.getHex() } }), Object.defineProperties(Xh.prototype, { red: { get: function () { return this.r }, set: function (A) { this.r = A } }, green: { get: function () { return this.g }, set: function (A) { this.g = A } }, blue: { get: function () { return this.b }, set: function (A) { this.b = A } }, alpha: { get: function () { return this.a }, set: function (A) { this.a = A } }, opacity: { get: function () { return this.a }, set: function (A) { this.a = A } } }); var _h = ["uniform bool receiveShadow;", "uniform vec3 ambientLightColor;", "uniform vec3 lightProbe[ 9 ];", "vec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) {", " float x = normal.x, y = normal.y, z = normal.z;", " vec3 result = shCoefficients[ 0 ] * 0.886227;", " result += shCoefficients[ 1 ] * 2.0 * 0.511664 * y;", " result += shCoefficients[ 2 ] * 2.0 * 0.511664 * z;", " result += shCoefficients[ 3 ] * 2.0 * 0.511664 * x;", " result += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;", " result += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;", " result += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );", " result += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;", " result += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );", " return result;", "}", "vec3 getLightProbeIrradiance( const in vec3 lightProbe[ 9 ], const in GeometricContext geometry ) {", " vec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix );", " vec3 irradiance = shGetIrradianceAt( worldNormal, lightProbe );", " return irradiance;", "}", "vec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {", " vec3 irradiance = ambientLightColor;", " #ifndef PHYSICALLY_CORRECT_LIGHTS", " irradiance *= PI;", " #endif", " return irradiance;", "}", "#if NUM_DIR_LIGHTS > 0", " struct DirectionalLight {", " vec3 direction;", " vec3 color;", " };", " uniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ];", " #if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0", " struct DirectionalLightShadow {", " float shadowBias;", " float shadowRadius;", " vec2 shadowMapSize;", " };", " uniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ];", " #endif", " void getDirectionalDirectLightIrradiance( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight directLight ) {", " directLight.color = directionalLight.color;", " directLight.direction = directionalLight.direction;", " directLight.visible = true;", " }", "#endif", "#if NUM_POINT_LIGHTS > 0", " struct PointLight {", " vec3 position;", " vec3 color;", " float distance;", " float decay;", " };", " uniform PointLight pointLights[ NUM_POINT_LIGHTS ];", " #if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0", " struct PointLightShadow {", " float shadowBias;", " float shadowRadius;", " vec2 shadowMapSize;", " float shadowCameraNear;", " float shadowCameraFar;", " };", " uniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ];", " #endif", " void getPointDirectLightIrradiance( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight directLight ) {", " vec3 lVector = pointLight.position - geometry.position;", " directLight.direction = normalize( lVector );", " float lightDistance = length( lVector );", " directLight.color = pointLight.color;", " directLight.color *= punctualLightIntensityToIrradianceFactor( lightDistance, pointLight.distance, pointLight.decay );", " directLight.visible = ( directLight.color != vec3( 0.0 ) );", " }", "#endif", "#if NUM_SPOT_LIGHTS > 0", " struct SpotLight {", " vec3 position;", " vec3 direction;", " vec3 color;", " float distance;", " float decay;", " float coneCos;", " float penumbraCos;", " };", " uniform SpotLight spotLights[ NUM_SPOT_LIGHTS ];", " #if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0", " struct SpotLightShadow {", " float shadowBias;", " float shadowRadius;", " vec2 shadowMapSize;", " };", " uniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ];", " #endif", " void getSpotDirectLightIrradiance( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight directLight ) {", " vec3 lVector = spotLight.position - geometry.position;", " directLight.direction = normalize( lVector );", " float lightDistance = length( lVector );", " float angleCos = dot( directLight.direction, spotLight.direction );", " if ( angleCos > spotLight.coneCos ) {", " float spotEffect = smoothstep( spotLight.coneCos, spotLight.penumbraCos, angleCos );", " directLight.color = spotLight.color;", " directLight.color *= spotEffect * punctualLightIntensityToIrradianceFactor( lightDistance, spotLight.distance, spotLight.decay );", " directLight.visible = true;", " } else {", " directLight.color = vec3( 0.0 );", " directLight.visible = false;", " }", " }", "#endif", "#if NUM_RECT_AREA_LIGHTS > 0", " struct RectAreaLight {", " vec3 color;", " vec3 position;", " vec3 halfWidth;", " vec3 halfHeight;", " };", " uniform sampler2D ltcMat; uniform sampler2D ltcMag;", " uniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ];", "#endif", "#if NUM_HEMI_LIGHTS > 0", " struct HemisphereLight {", " vec3 direction;", " vec3 skyColor;", " vec3 groundColor;", " };", " uniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ];", " vec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in GeometricContext geometry ) {", " float dotNL = dot( geometry.normal, hemiLight.direction );", " float hemiDiffuseWeight = 0.5 * dotNL + 0.5;", " vec3 irradiance = mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );", " #ifndef PHYSICALLY_CORRECT_LIGHTS", " irradiance *= PI;", " #endif", " return irradiance;", " }", "#endif", "#if defined( USE_ENVMAP ) && defined( PHYSICAL )", " vec3 getLightProbeIndirectIrradiance( const in GeometricContext geometry, const in int maxMIPLevel ) {", " vec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix );", " #ifdef ENVMAP_TYPE_CUBE", " vec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz );", " #ifdef TEXTURE_LOD_EXT", " vec4 envMapColor = textureCubeLodEXT( envMap, queryVec, float( maxMIPLevel ) );", " #else", " vec4 envMapColor = textureCube( envMap, queryVec, float( maxMIPLevel ) );", " #endif", " envMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;", " #elif defined( ENVMAP_TYPE_CUBE_UV )", " vec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz );", " vec4 envMapColor = textureCubeUV( queryVec, 1.0 );", " #else", " vec4 envMapColor = vec4( 0.0 );", " #endif", " return PI * envMapColor.rgb * envMapIntensity;", " }", " float getSpecularMIPLevel( const in float blinnShininessExponent, const in int maxMIPLevel ) {", " float maxMIPLevelScalar = float( maxMIPLevel );", " float desiredMIPLevel = maxMIPLevelScalar - 0.79248 - 0.5 * log2( pow2( blinnShininessExponent ) + 1.0 );", " return clamp( desiredMIPLevel, 0.0, maxMIPLevelScalar );", " }", " vec3 getLightProbeIndirectRadiance( const in GeometricContext geometry, const in float blinnShininessExponent, const in int maxMIPLevel ) {", " #ifdef ENVMAP_MODE_REFLECTION", " vec3 reflectVec = reflect( -geometry.viewDir, geometry.normal );", " #else", " vec3 reflectVec = refract( -geometry.viewDir, geometry.normal, refractionRatio );", " #endif", " reflectVec = inverseTransformDirection( reflectVec, viewMatrix );", " float specularMIPLevel = getSpecularMIPLevel( blinnShininessExponent, maxMIPLevel );", " #ifdef ENVMAP_TYPE_CUBE", " vec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz );", " #ifdef TEXTURE_LOD_EXT", " vec4 envMapColor = textureCubeLodEXT( envMap, queryReflectVec, specularMIPLevel );", " #else", " vec4 envMapColor = textureCube( envMap, queryReflectVec, specularMIPLevel );", " #endif", " envMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;", " #elif defined( ENVMAP_TYPE_CUBE_UV )", " vec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz );", " vec4 envMapColor = textureCubeUV(queryReflectVec, BlinnExponentToGGXRoughness(blinnShininessExponent));", " #elif defined( ENVMAP_TYPE_EQUIREC )", " vec2 sampleUV;", " sampleUV.y = saturate( reflectVec.y * 0.5 + 0.5 );", " sampleUV.x = atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;", " #ifdef TEXTURE_LOD_EXT", " vec4 envMapColor = texture2DLodEXT( envMap, sampleUV, specularMIPLevel );", " #else", " vec4 envMapColor = texture2D( envMap, sampleUV, specularMIPLevel );", " #endif", " envMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;", " #elif defined( ENVMAP_TYPE_SPHERE )", " vec3 reflectView = normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0,0.0,1.0 ) );", " #ifdef TEXTURE_LOD_EXT", " vec4 envMapColor = texture2DLodEXT( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );", " #else", " vec4 envMapColor = texture2D( envMap, reflectView.xy * 0.5 + 0.5, specularMIPLevel );", " #endif", " envMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;", " #endif", " return envMapColor.rgb * envMapIntensity;", " }", "#endif"].join("\n"), $h = ["", "GeometricContext geometry;", "geometry.position = - vViewPosition;", "geometry.normal = normal;", "geometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition );", "#ifdef CLEARCOAT", "geometry.clearcoatNormal = clearcoatNormal;", "#endif", "IncidentLight directLight;", "#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )", "PointLight pointLight;", "#if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0", "PointLightShadow pointLightShadow;", "#endif", "#pragma unroll_loop_start", "for ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {", "pointLight = pointLights[ i ];", "getPointDirectLightIrradiance( pointLight, geometry, directLight );", "#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_POINT_LIGHT_SHADOWS )", "pointLightShadow = pointLightShadows[ i ];", "directLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getPointShadow( pointShadowMap[ i ], pointLightShadow.shadowMapSize, pointLightShadow.shadowBias, pointLightShadow.shadowRadius, vPointShadowCoord[ i ], pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar ) : 1.0;", "#endif", "RE_Direct( directLight, geometry, material, reflectedLight );", "}", "#endif", "#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )", "SpotLight spotLight;", "#if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0", "SpotLightShadow spotLightShadow;", "#endif", "#pragma unroll_loop_start", "for ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {", "spotLight = spotLights[ i ];", "getSpotDirectLightIrradiance( spotLight, geometry, directLight );", "#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_SPOT_LIGHT_SHADOWS )", "spotLightShadow = spotLightShadows[ i ];", "directLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( spotShadowMap[ i ], spotLightShadow.shadowMapSize, spotLightShadow.shadowBias, spotLightShadow.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;", "#endif", "RE_Direct( directLight, geometry, material, reflectedLight );", "}", "#pragma unroll_loop_end", "#endif", "#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )", "DirectionalLight directionalLight;", "#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0", "DirectionalLightShadow directionalLightShadow;", "#endif", "#pragma unroll_loop_start", "for ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {", "directionalLight = directionalLights[ i ];", "getDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );", "#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )", "directionalLightShadow = directionalLightShadows[ i ];", "directLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;", "#endif", "RE_Direct( directLight, geometry, material, reflectedLight );", "}", "#pragma unroll_loop_end", "#endif", "#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )", "RectAreaLight rectAreaLight;", "#pragma unroll_loop_start", "for ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {", "rectAreaLight = rectAreaLights[ i ];", "RE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );", "}", "#pragma unroll_loop_end", "#endif", "#if defined( RE_IndirectDiffuse )", "vec3 iblIrradiance = vec3( 0.0 );", "vec3 irradiance = getAmbientLightIrradiance( ambientLightColor );", "irradiance += getLightProbeIrradiance( lightProbe, geometry );", "#if ( NUM_HEMI_LIGHTS > 0 )", "#pragma unroll_loop_start", "for ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {", "irradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );", "}", "#pragma unroll_loop_end", "#endif", "#endif", "#if defined( RE_IndirectSpecular )", "vec3 radiance = vec3( 0.0 );", "vec3 clearcoatRadiance = vec3( 0.0 );", "#endif"].join("\n"), Ad = ["#ifdef DOUBLE_SIDED", " float flipNormal = ( float( gl_FrontFacing ) * 2.0 - 1.0 );", "#else", " float flipNormal = 1.0;", "#endif\n"].join("\n"), ed = ["#ifdef FLAT_SHADED", " vec3 fdx = vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) );", " vec3 fdy = vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) );", " vec3 normal = normalize( cross( fdx, fdy ) );", "#else", " vec3 normal = normalize( vNormal ) * flipNormal;", "#endif", "#ifdef USE_NORMALMAP", " normal = perturbNormal2Arb( -vViewPosition, normal );", "#elif defined( USE_BUMPMAP )", " normal = perturbNormalArb( -vViewPosition, normal, dHdxy_fwd() );", "#endif", "vec3 geometryNormal = normal;"].join("\n"), td = ["GeometricContext geometry;", "geometry.position = - vViewPosition;", "#if NUM_CLIPPING_PLANES == 1", " if (gl_FrontFacing) geometry.normal = normal;", " else if (fillFaceClipDistance < 0.0) geometry.normal = -clippingPlanes[0].xyz;", " else geometry.normal = -normal;", "#else", " geometry.normal = normal;", "#endif", "geometry.viewDir = normalize( vViewPosition );", "IncidentLight directLight;", "#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )", " PointLight pointLight;", " for ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {", " pointLight = pointLights[ i ];", " getPointDirectLightIrradiance( pointLight, geometry, directLight );", " #ifdef USE_SHADOWMAP", " directLight.color *= all( bvec2( pointLight.shadow, directLight.visible ) ) ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ] ,pointLight.shadowCameraNear, pointLight.shadowCameraFar) : 1.0;", " #endif", " RE_Direct( directLight, geometry, material, reflectedLight );", " }", "#endif", "#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )", " SpotLight spotLight;", " for ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {", " spotLight = spotLights[ i ];", " getSpotDirectLightIrradiance( spotLight, geometry, directLight );", " #ifdef USE_SHADOWMAP", " directLight.color *= all( bvec2( spotLight.shadow, directLight.visible ) ) ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;", " #endif", " RE_Direct( directLight, geometry, material, reflectedLight );", " }", "#endif", "#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )", " DirectionalLight directionalLight;", " for ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {", " directionalLight = directionalLights[ i ];", " getDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );", " #ifdef USE_SHADOWMAP", " directLight.color *= all( bvec2( directionalLight.shadow, directLight.visible ) ) ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;", " #endif", " RE_Direct( directLight, geometry, material, reflectedLight );", " }", "#endif", "#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )", " RectAreaLight rectAreaLight;", " for ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {", " rectAreaLight = rectAreaLights[ i ];", " RE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );", " }", "#endif", "#if defined( RE_IndirectDiffuse )", " vec3 irradiance = getAmbientLightIrradiance( ambientLightColor );", " #ifdef USE_LIGHTMAP", " vec3 lightMapIrradiance = texture2D( lightMap, vUv2 ).xyz * lightMapIntensity;", " #ifndef PHYSICALLY_CORRECT_LIGHTS", " lightMapIrradiance *= PI; // factor of PI should not be present; included here to prevent breakage", " #endif", " irradiance += lightMapIrradiance;", " #endif", " #if ( NUM_HEMI_LIGHTS > 0 )", " for ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {", " irradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );", " }", " #endif", " #if defined( USE_ENVMAP ) && defined( PHYSICAL ) && defined( ENVMAP_TYPE_CUBE_UV )", " irradiance += getLightProbeIndirectIrradiance( /*lightProbe,*/ geometry, 8 );", " #endif", " RE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );", "#endif", "#if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )", " vec3 radiance = getLightProbeIndirectRadiance( /*specularLightProbe,*/ geometry, Material_BlinnShininessExponent( material ), 8 );", " #ifndef STANDARD", " vec3 clearCoatRadiance = getLightProbeIndirectRadiance( /*specularLightProbe,*/ geometry, Material_ClearCoat_BlinnShininessExponent( material ), 8 );", " #else", " vec3 clearCoatRadiance = vec3( 0.0 );", " #endif", " RE_IndirectSpecular( radiance, clearCoatRadiance, geometry, material, reflectedLight );", "#endif"].join("\n"), id = ["#define PHONG", "uniform vec3 diffuse;", "uniform vec3 emissive;", "uniform vec3 specular;", "uniform float shininess;", "uniform float opacity;", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "void main() {", " #include ", " vec4 diffuseColor = vec4( diffuse, opacity );", " ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );", " vec3 totalEmissiveRadiance = emissive;", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", " float fillFaceClipDistance = 0.0;", " #if NUM_CLIPPING_PLANES == 1", " vec4 plane = clippingPlanes[ 0 ];", " fillFaceClipDistance = dot( vViewPosition, plane.xyz ) - plane.w;", " #endif", " #include ", " #include ", " #include ", " vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;", " #include ", " gl_FragColor = vec4( outgoingLight, diffuseColor.a );", " #include ", " #include ", " #include ", " #include ", " #include ", "}"].join("\n"), od = ["#define PHONG", "varying vec3 vViewPosition;", "#ifndef FLAT_SHADED", "varying vec3 vNormal;", "#endif", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "void main() {", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#ifndef FLAT_SHADED", "vNormal = normalize( transformedNormal );", "#endif", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "vViewPosition = - mvPosition.xyz;", "#include ", "#include ", "#include ", "#include ", "}"].join("\n"), nd = ["#define PHYSICAL", "varying vec3 vViewPosition;", "#ifndef FLAT_SHADED", "varying vec3 vNormal;", "#endif", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "void main() {", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#ifndef FLAT_SHADED", "vNormal = normalize( transformedNormal );", "#endif", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "vViewPosition = - mvPosition.xyz;", "#include ", "#include ", "#include ", "}"].join("\n"), rd = ["#define PHYSICAL", "uniform vec3 diffuse;", "uniform vec3 emissive;", "uniform float roughness;", "uniform float metalness;", "uniform float opacity;", "#ifndef STANDARD", "uniform float clearCoat;", "uniform float clearCoatRoughness;", "#endif", "varying vec3 vViewPosition;", "#ifndef FLAT_SHADED", "varying vec3 vNormal;", "#endif", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "void main() {", "#include ", "vec4 diffuseColor = vec4( diffuse, opacity );", "vec3 totalEmissiveRadiance = emissive;", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "const mat4 diffuseMatrix = mat4(-0.07425443828105927, -0.05652861297130585, 0.12247831374406815, 0.2297295778989792,", " -0.05652860924601555, 0.034799136221408844, -0.08437120914459229, -0.13896968960762024,", " 0.12247832119464874, -0.08437121659517288, 0.021763987839221954, 0.12510454654693604,", " 0.2297295778989792, -0.13896968960762024, 0.12510454654693604, 0.6190560460090637);", "const vec3 sunDir = vec3(-0.6632131338119507, 0.5486575961112976, -0.509041428565979);", "vec3 viewDir = normalize( vViewPosition );", "vec4 diffuseDir = diffuseMatrix * vec4(normal, 1.0);", "float diffuseTerm = dot(vec4(normal, 1.0), diffuseDir);", "float nv = max(dot(normal, -viewDir), 0.0);", "float vl = max(dot(viewDir, sunDir), 0.0);", "diffuseTerm = diffuseTerm + (nv * (1.0 - vl)) * 0.8;", "vec3 H = -normalize(sunDir + viewDir);", "float nh = max(dot(normal, H), 0.0);", "float specularTerm = pow(nh, 100.0);", "vec3 color = 1.05 * vec3(0.5, 0.497, 0.49) * (diffuse * diffuseTerm + vec3(specularTerm)) + diffuse * 0.5;", "vec3 outgoingLight = color + totalEmissiveRadiance;", "gl_FragColor = vec4( outgoingLight, diffuseColor.a );", "#include ", "#include ", "#include ", "#include ", "#include ", "}"].join("\n"), ad = ["#define EIMMODELPHYSICAL", "mat3 transpose2( const in mat3 v ) {\n mat3 tmp;\n tmp[0] = vec3(v[0].x, v[1].x, v[2].x);\n tmp[1] = vec3(v[0].y, v[1].y, v[2].y);\n tmp[2] = vec3(v[0].z, v[1].z, v[2].z);\n return tmp;\n}\n", "varying vec3 vViewPosition;", "varying vec3 vWorldPosition;", "#ifndef FLAT_SHADED", " varying vec3 vNormal;", " #ifdef USE_TANGENT", " varying vec3 vTangent;", " varying vec3 vBitangent;", " #endif", "#endif", "#ifdef USE_INSTANCE", " attribute float vState;", " attribute float vState2;", " varying float fState;", " attribute float vMirror;", " attribute vec4 aColor;", " varying vec4 vaColor;", " attribute vec3 mcol0;", " attribute vec3 mcol1;", " attribute vec3 mcol2;", " attribute vec3 mcol3;", "#ifdef INSTANCE_STATE_TERTIARY", " attribute float vState3;", "#endif", "#endif", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "mat3 inverse_mat3(in mat3 m)", "{", " float determinant =", " m[0][0] * (m[1][1] * m[2][2] - m[2][1] * m[1][2])", " - m[1][0] * (m[0][1] * m[2][2] - m[2][1] * m[0][2])", " + m[2][0] * (m[0][1] * m[1][2] - m[1][1] * m[0][2]);", " mat3 inverse;", " inverse[0][0] = + (m[1][1] * m[2][2] - m[2][1] * m[1][2]);", " inverse[1][0] = - (m[1][0] * m[2][2] - m[2][0] * m[1][2]);", " inverse[2][0] = + (m[1][0] * m[2][1] - m[2][0] * m[1][1]);", " inverse[0][1] = - (m[0][1] * m[2][2] - m[2][1] * m[0][2]);", " inverse[1][1] = + (m[0][0] * m[2][2] - m[2][0] * m[0][2]);", " inverse[2][1] = - (m[0][0] * m[2][1] - m[2][0] * m[0][1]);", " inverse[0][2] = + (m[0][1] * m[1][2] - m[1][1] * m[0][2]);", " inverse[1][2] = - (m[0][0] * m[1][2] - m[1][0] * m[0][2]);", " inverse[2][2] = + (m[0][0] * m[1][1] - m[1][0] * m[0][1]);", " inverse /= determinant;", " return inverse;", "}", "void main() {", " #include ", " #ifdef USE_TRANSFORM_AOMAP", " #if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )", " vUv2 = ( uv2Transform * vec3( uv2, 1 ) ).xy;", " #endif", " #endif ", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", "#ifdef USE_INSTANCE", " vaColor = aColor;", " #ifdef INSTANCE_STATE_SECONDARY", " fState = vState2;", " #else", " fState = vState;", " #endif", " #ifdef INSTANCE_STATE_TERTIARY", " fState = vState3;", " #endif", " transformed = vec3(mat4(vec4(mcol0, 0.0),", " vec4(mcol1, 0.0),", " vec4(mcol2, 0.0),", " vec4(mcol3, 1.0)) * vec4(transformed, 1.0));", " #ifdef USE_INSTANCE_NORMAL", " mat3 normalMat = mat3(mcol0, mcol1, mcol2);", " normalMat = inverse_mat3(normalMat);", " normalMat = transpose2(normalMat);", " transformedNormal = normalMat * objectNormal;", " transformedNormal = normalMatrix * transformedNormal;", " #ifdef FLIP_SIDED", " transformedNormal = - transformedNormal;", " #endif", " transformedNormal = normalize( transformedNormal );", " #endif", "#endif", "#ifndef FLAT_SHADED", " vNormal = normalize( transformedNormal );", " #ifdef USE_TANGENT", " vTangent = normalize( transformedTangent );", " vBitangent = normalize( cross( vNormal, vTangent ) * tangent.w );", " #endif", "#endif", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", " vViewPosition = - mvPosition.xyz;", " // 热力图", " #if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP )|| defined(HEATMAPPOINTSCOUNT)", " vec4 worldPosition = vec4( transformed, 1.0 );", " #ifdef USE_INSTANCING", " worldPosition = instanceMatrix * worldPosition;", " #endif", " worldPosition = modelMatrix * worldPosition;", " vWorldPosition = vec3(worldPosition.xyz);", " #endif", " #include ", " #include ", "#ifdef USE_INSTANCE", " if (vMirror <= - 0.01){", " vNormal = vNormal * - 1.0;}", "#endif", "}"].join("\n"), sd = ["#define EIMMODELPHYSICAL", "#ifdef PHYSICAL", " #define REFLECTIVITY", " #define CLEARCOAT", " #define TRANSPARENCY", "#endif", "uniform vec3 diffuse;", "uniform vec3 emissive;", "uniform float roughness;", "uniform float metalness;", "uniform float opacity;", "#ifdef TRANSPARENCY", " uniform float transparency;", "#endif", "#ifdef REFLECTIVITY", " uniform float reflectivity;", "#endif", "#ifdef CLEARCOAT", " uniform float clearcoat;", " uniform float clearcoatRoughness;", "#endif", "#ifdef USE_SHEEN", " uniform vec3 sheen;", "#endif", "uniform float imageFade;", "varying vec3 vViewPosition;", "varying vec3 vWorldPosition;", "#ifndef FLAT_SHADED", " varying vec3 vNormal;", " #ifdef USE_TANGENT", " varying vec3 vTangent;", " varying vec3 vBitangent;", " #endif", "#endif", "#ifdef USE_INSTANCE", " varying vec4 vaColor;", " varying float fState;", "#endif", "uniform float shift;", "uniform float A;", "uniform float B;", "uniform float C;", "uniform float D;", "uniform float E;", "uniform float F;", "uniform float scale;", "uniform vec4 blinkColor;", "uniform float colorState;", "#ifdef HEATMAPPOINTSCOUNT", " uniform float heatmapPoints[HEATMAPPOINTSCOUNT];", " uniform sampler2D heatmapTexture;", "#endif", "vec3 toneMapCanonFilmic(vec3 color)", "{", " color *= (1.0 / shift);", " return (((color * (A * color + C * B)) / (color * (A * color + B) + D * F))) * (1.0 / scale);", "}", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "vec3 hdrDecode(in vec4 rgbm) {", "const float rgbmScale = 2.82842712;", "vec3 r = rgbm.rgb * (rgbmScale * (1.0 - rgbm.a));", "return r * r;", "}", "vec3 linearToGammaUnreal(in vec3 rgb) {", " return rgb / (rgb + 0.187) * 1.035 * (0.5 / shift);", "}", "bool floatEqual(in float x, in float y) {", " return (x >= y - 0.01) && (x <= y + 0.01);", "}", "bool floatNotEqual(in float x, in float y) {", " return (x <= y - 0.01) || (x >= y + 0.01);", "}", "void main() {", " #include ", " vec4 diffuseColor = vec4( diffuse, opacity );", " #ifdef USE_INSTANCE", " if (floatEqual(fState, -1.0)) ", " discard;", " if (floatNotEqual(fState, 0.0)) ", " diffuseColor = vaColor;", " #endif", " vec4 selectedColor = diffuseColor;", " ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );", " vec3 totalEmissiveRadiance = emissive;", " #include ", " #ifdef USE_MAP", " vec4 texelColor = texture2D( map, vUv );", " texelColor = mapTexelToLinear( texelColor );", " diffuseColor = vec4( mix(diffuseColor.rgb , texelColor.rgb, imageFade),opacity);", " #ifdef USE_INSTANCE", " if (floatNotEqual(fState, 0.0)) ", " diffuseColor = vaColor;", " #endif", " #endif", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", "float flipNormal = 1.0;", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", " #include ", "vec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;", "#ifdef USE_COLORWITHOUTLIGHT", " gl_FragColor = diffuseColor;", "#else", " #ifdef TRANSPARENCY", " diffuseColor.a *= saturate( 1. - transparency + linearToRelativeLuminance( reflectedLight.directSpecular + reflectedLight.indirectSpecular ) );", " #endif", " gl_FragColor = vec4( outgoingLight, diffuseColor.a );", "#endif", "#ifdef USE_INSTANCE", " #ifdef NOTAFFECTEDBYLIGHT", " if (floatEqual(fState, 2.0))", " gl_FragColor = selectedColor;", " #endif", " #ifdef USE_MAP", " if (floatEqual(fState, 3.0))", " gl_FragColor = vaColor;", " #endif", "#endif", "#if defined( TONE_MAPPING )", " #if defined(USE_LIGHTMAP)", " gl_FragColor.rgb = linearToGammaUnreal(gl_FragColor.rgb );", " #else", " gl_FragColor.rgb = toneMapCanonFilmic( gl_FragColor.rgb );", " #endif", "#endif", "#ifdef USE_INSTANCE", " if (floatEqual(fState, 5.0) && floatEqual(colorState, 1.0))", " gl_FragColor = blinkColor;", "#else", " if (floatEqual(colorState, 1.0))", " gl_FragColor = blinkColor;", " #ifdef NOTAFFECTEDBYLIGHT", " if (floatEqual(colorState, 2.0))", " gl_FragColor = selectedColor;", " #endif", "#endif", "#include ", "#include ", "#include ", "#include ", "#ifdef HEATMAPPOINTSCOUNT", " float heatvalue = 0.0;", " for ( int i = 0; i < HEATMAPPOINTSCOUNT; i += 5 ) {", " float heatpointX = heatmapPoints[i];", " float heatpointY = heatmapPoints[i + 1];", " float heatpointZ = heatmapPoints[i + 2];", " // heatpointIndex保存的是当前热力点的热力值比上(最大热力和最小热力差)", " // 也就是在热力区间中的百分比位置,为0的时候表示最小热力值,1的时候表示最大热力值", " // 可以理解为就是热力点中心的热力值,只不过范围是0-1", " // 热力最大值和最小值分别是所有热力点中热力最大和最小的值", " float heatpointIndex = heatmapPoints[i + 3];", " float heatpointRadius = heatmapPoints[i + 4];", " float dis = distance(vWorldPosition, vec3(heatpointX, heatpointY, heatpointZ));", " if(dis < heatpointRadius) {", " float step = dis / heatpointRadius;", " // 根据距离计算当前片元在当前热力点下的热力值", " // step表示距离,范围0-1,越小表示距离热力点越近,热力越大,将距离区间0-1和热力区间heatpointIndex-0对应起来", " float currentvalue = (1.0 - step) * heatpointIndex;", " // 这里用到了一个颜色叠加的公式,把每个热点对当前片元产生的热力进行叠加,", " // 没有特殊逻辑,也可以简单相加", " heatvalue = heatvalue + currentvalue - heatvalue * currentvalue;", " if (heatvalue > 1.0) {", " heatvalue = 1.0;", " break;", " }", " }", " }", " if (heatvalue > 0.0) {", " vec4 color = texture2D(heatmapTexture, vec2(heatvalue, 0.5));", " heatvalue = 0.5*heatvalue + 0.5;//使下列因子范围为1-0.5", " color = vec4( mix(gl_FragColor.rgb, color.rgb, heatvalue),gl_FragColor.a);", " gl_FragColor = color;", " }", "#endif", "}"].join("\n"); tt.lights_pars = _h, tt.lights_template = $h, tt.normal_flip = Ad, tt.normal_fragment = ed, tt.meshphong_id_vert = od, tt.lights_fillFace_template = td, tt.fillFaceFragment = id, tt.standardVertex = ad, tt.bos3dStandardFragment = sd, tt.newStyleVertex = nd, tt.newStyleFragment = rd, it.fillFacePhong = { uniforms: Ge.merge([Xe.common, Xe.aomap, Xe.lightmap, Xe.emissivemap, Xe.bumpmap, Xe.normalmap, Xe.displacementmap, Xe.gradientmap, Xe.fog, Xe.lights, { emissive: { value: new LA(0) }, specular: { value: new LA(1118481) }, shininess: { value: 30 } }]), vertexShader: tt.meshphong_id_vert, fragmentShader: tt.fillFaceFragment }, it.newStyle = { vertexShader: tt.newStyleVertex, fragmentShader: tt.newStyleFragment }, it.bos3dStandard = { vertexShader: tt.standardVertex, fragmentShader: tt.bos3dStandardFragment }; var ld = function (A) { yr.call(this), this.type = "bos3dStandard", this.roughness = 1, this.metalness = 0, this.originRoughness = 1, this.originMetalness = 0, this.pureColor = 0, this.textureColor = 0, this.imageFade = 1, this.transparentEx = !1, this.shift = .5, this.A = .64, this.B = .03, this.C = .02, this.D = .54, this.E = 0, this.F = .81, this.scale = .92, this.shininess = 30, this.specular = new LA(0); var e = (new LA).setHex(3330982), t = [e.r, e.g, e.b, 1]; this.colorState = Yc.NONE, this.blinkColor = (new p).fromArray(t), this.uniforms = Ge.merge([Xe.common, Xe.specularmap, Xe.envmap, Xe.aomap, Xe.lightmap, Xe.emissivemap, Xe.bumpmap, Xe.normalmap, Xe.displacementmap, Xe.roughnessmap, Xe.metalnessmap, Xe.fog, Xe.lights, { emissive: { value: new LA(0) }, specular: { value: new LA(0) }, roughness: { value: .5 }, metalness: { value: .5 }, envMapIntensity: { value: 1 } }, { shift: { value: .5 }, A: { value: .64 }, B: { value: .03 }, C: { value: .02 }, D: { value: .54 }, E: { value: 0 }, F: { value: .81 }, scale: { value: .92 }, colorState: { value: 0 }, blinkColor: { value: (new p).fromArray(t) }, imageFade: { value: 1 }, heatmapPoints: { value: [] }, heatmapTexture: { value: null } }]), this.vertexShader = tt.standardVertex, this.fragmentShader = tt.bos3dStandardFragment, this.defaultAttributeValues = { color: [1, 1, 1], uv: [0, 0], uv2: [0, 0] }, void 0 !== A && (void 0 !== A.attributes && Bh.error("IBLMaterial: attributes should now be defined in THREE.BufferGeometry instead."), this.setValues(A)), this.lights && (this.uniforms = Ge.merge([this.uniforms, Xe.lights])), this.refreshUniforms && this.refreshUniforms() }; function cd(A, e) { var t = (65535 & A) + (65535 & e); return (A >> 16) + (e >> 16) + (t >> 16) << 16 | 65535 & t } function hd(A, e, t, i, o, n) { return cd((r = cd(cd(e, A), cd(i, n))) << (a = o) | r >>> 32 - a, t); var r, a } function dd(A, e, t, i, o, n, r) { return hd(e & t | ~e & i, A, e, o, n, r) } function pd(A, e, t, i, o, n, r) { return hd(e & i | t & ~i, A, e, o, n, r) } function gd(A, e, t, i, o, n, r) { return hd(e ^ t ^ i, A, e, o, n, r) } function ud(A, e, t, i, o, n, r) { return hd(t ^ (e | ~i), A, e, o, n, r) } function fd(A, e) { var t, i, o, n, r; A[e >> 5] |= 128 << e % 32, A[14 + (e + 64 >>> 9 << 4)] = e; var a = 1732584193, s = -271733879, l = -1732584194, c = 271733878; for (t = 0; A.length > t; t += 16) i = a, o = s, n = l, r = c, a = dd(a, s, l, c, A[t], 7, -680876936), c = dd(c, a, s, l, A[t + 1], 12, -389564586), l = dd(l, c, a, s, A[t + 2], 17, 606105819), s = dd(s, l, c, a, A[t + 3], 22, -1044525330), a = dd(a, s, l, c, A[t + 4], 7, -176418897), c = dd(c, a, s, l, A[t + 5], 12, 1200080426), l = dd(l, c, a, s, A[t + 6], 17, -1473231341), s = dd(s, l, c, a, A[t + 7], 22, -45705983), a = dd(a, s, l, c, A[t + 8], 7, 1770035416), c = dd(c, a, s, l, A[t + 9], 12, -1958414417), l = dd(l, c, a, s, A[t + 10], 17, -42063), s = dd(s, l, c, a, A[t + 11], 22, -1990404162), a = dd(a, s, l, c, A[t + 12], 7, 1804603682), c = dd(c, a, s, l, A[t + 13], 12, -40341101), l = dd(l, c, a, s, A[t + 14], 17, -1502002290), a = pd(a, s = dd(s, l, c, a, A[t + 15], 22, 1236535329), l, c, A[t + 1], 5, -165796510), c = pd(c, a, s, l, A[t + 6], 9, -1069501632), l = pd(l, c, a, s, A[t + 11], 14, 643717713), s = pd(s, l, c, a, A[t], 20, -373897302), a = pd(a, s, l, c, A[t + 5], 5, -701558691), c = pd(c, a, s, l, A[t + 10], 9, 38016083), l = pd(l, c, a, s, A[t + 15], 14, -660478335), s = pd(s, l, c, a, A[t + 4], 20, -405537848), a = pd(a, s, l, c, A[t + 9], 5, 568446438), c = pd(c, a, s, l, A[t + 14], 9, -1019803690), l = pd(l, c, a, s, A[t + 3], 14, -187363961), s = pd(s, l, c, a, A[t + 8], 20, 1163531501), a = pd(a, s, l, c, A[t + 13], 5, -1444681467), c = pd(c, a, s, l, A[t + 2], 9, -51403784), l = pd(l, c, a, s, A[t + 7], 14, 1735328473), a = gd(a, s = pd(s, l, c, a, A[t + 12], 20, -1926607734), l, c, A[t + 5], 4, -378558), c = gd(c, a, s, l, A[t + 8], 11, -2022574463), l = gd(l, c, a, s, A[t + 11], 16, 1839030562), s = gd(s, l, c, a, A[t + 14], 23, -35309556), a = gd(a, s, l, c, A[t + 1], 4, -1530992060), c = gd(c, a, s, l, A[t + 4], 11, 1272893353), l = gd(l, c, a, s, A[t + 7], 16, -155497632), s = gd(s, l, c, a, A[t + 10], 23, -1094730640), a = gd(a, s, l, c, A[t + 13], 4, 681279174), c = gd(c, a, s, l, A[t], 11, -358537222), l = gd(l, c, a, s, A[t + 3], 16, -722521979), s = gd(s, l, c, a, A[t + 6], 23, 76029189), a = gd(a, s, l, c, A[t + 9], 4, -640364487), c = gd(c, a, s, l, A[t + 12], 11, -421815835), l = gd(l, c, a, s, A[t + 15], 16, 530742520), a = ud(a, s = gd(s, l, c, a, A[t + 2], 23, -995338651), l, c, A[t], 6, -198630844), c = ud(c, a, s, l, A[t + 7], 10, 1126891415), l = ud(l, c, a, s, A[t + 14], 15, -1416354905), s = ud(s, l, c, a, A[t + 5], 21, -57434055), a = ud(a, s, l, c, A[t + 12], 6, 1700485571), c = ud(c, a, s, l, A[t + 3], 10, -1894986606), l = ud(l, c, a, s, A[t + 10], 15, -1051523), s = ud(s, l, c, a, A[t + 1], 21, -2054922799), a = ud(a, s, l, c, A[t + 8], 6, 1873313359), c = ud(c, a, s, l, A[t + 15], 10, -30611744), l = ud(l, c, a, s, A[t + 6], 15, -1560198380), s = ud(s, l, c, a, A[t + 13], 21, 1309151649), a = ud(a, s, l, c, A[t + 4], 6, -145523070), c = ud(c, a, s, l, A[t + 11], 10, -1120210379), l = ud(l, c, a, s, A[t + 2], 15, 718787259), s = ud(s, l, c, a, A[t + 9], 21, -343485551), a = cd(a, i), s = cd(s, o), l = cd(l, n), c = cd(c, r); return [a, s, l, c] } function md(A) { var e, t = "", i = 32 * A.length; for (e = 0; i > e; e += 8) t += String.fromCharCode(A[e >> 5] >>> e % 32 & 255); return t } function Cd(A) { var e, t = []; for (t[(A.length >> 2) - 1] = void 0, e = 0; t.length > e; e += 1) t[e] = 0; var i = 8 * A.length; for (e = 0; i > e; e += 8) t[e >> 5] |= (255 & A.charCodeAt(e / 8)) << e % 32; return t } function yd(A) { var e, t, i = ""; for (t = 0; A.length > t; t += 1) e = A.charCodeAt(t), i += "0123456789abcdef".charAt(e >>> 4 & 15) + "0123456789abcdef".charAt(15 & e); return i } function vd(A) { return unescape(encodeURIComponent(A)) } function Id(A) { return function (A) { return md(fd(Cd(A), 8 * A.length)) }(vd(A)) } function Ed(A, e) { return function (A, e) { var t, i, o = Cd(A), n = [], r = []; for (n[15] = r[15] = void 0, o.length > 16 && (o = fd(o, 8 * A.length)), t = 0; 16 > t; t += 1) n[t] = 909522486 ^ o[t], r[t] = 1549556828 ^ o[t]; return i = fd(n.concat(Cd(e)), 512 + 8 * e.length), md(fd(r.concat(i), 640)) }(vd(A), vd(e)) } function Bd(A, e, t) { return e ? t ? Ed(e, A) : yd(Ed(e, A)) : t ? Id(A) : yd(Id(A)) } (ld.prototype = Object.create(yr.prototype)).constructor = ld, ld.prototype.destroy = function () { yr.prototype.dispose.call(this), this.blinkColor = null, this.uniforms = null, this.defaultAttributeValues = null, this.lights = null }, ld.prototype.copy = function (A) { return yr.prototype.copy.call(this, A), this.shift = A.shift, this.A = A.A, this.B = A.B, this.C = A.C, this.D = A.D, this.E = A.E, this.F = A.F, this.scale = A.scale, this.colorState = A.colorState, this.blinkColor.copy(A.blinkColor), this.imageFade = A.imageFade, Object.assign(this.defines, A.defines), this }, ld.prototype.refreshUniforms = function () { this.uniforms.shift.value = this.shift, this.uniforms.A.value = this.A, this.uniforms.B.value = this.B, this.uniforms.C.value = this.C, this.uniforms.D.value = this.D, this.uniforms.E.value = this.E, this.uniforms.F.value = this.F, this.uniforms.scale.value = this.scale, this.uniforms.blinkColor.value.copy(this.blinkColor), this.uniforms.colorState.value = this.colorState, this.uniforms.imageFade.value = this.imageFade }, ld.prototype.setBlinkColor = function (A) { this.blinkColor.fromArray(A.toArray()), this.uniforms.blinkColor.value.copy(this.blinkColor), this.uniforms.colorState.value = Yc.BLINK }, ld.prototype.updateBlinkUniformValue = function (A, e) { this.uniforms.colorState.value = A, this.uniforms.blinkColor.value.copy(e) }, ld.prototype.resetBlinkUniformValue = function () { this.uniforms.colorState.value = this.colorState, this.uniforms.blinkColor.value.copy(this.blinkColor) }, Object.defineProperties(ld.prototype, { transparent: { set: function (A) { this.transparentEx = A, vc.notDepthWriteByTransparent && (this.depthWrite = !A) }, get: function () { return this.transparentEx } } }); var xd = { REGULAR: 0, FRACTAL: 1, DISORDER: 2 }, Sd = { type: xd.REGULAR, color1: new Xh(0, 0, 0, 1), color2: new Xh(255, 255, 255, 1), size: 10, level: 1, phase: 1, width: 32, height: 32, thresholdLow: 0, thresholdHigh: 1 }; function wd() { this.m = 2147483647, this.a = 16807, this.q = 127773, this.r = 2836, this.seed = 1, this.setSeed = function (A) { A > 0 || (A = -A % (this.m - 1) + 1), A > this.m - 1 && (A = this.m - 1), this.seed = A }, this.nextLong = function () { var A = this.a * (this.seed % this.q) - this.r * Math.floor(this.seed / this.q); return A > 0 || (A += this.m), this.seed = A, A }, this.next = function () { return this.nextLong() / this.m } } function Md(A, e, t) { this.width = A, this.height = e, this.randseed = t, this.gradients = new Array(A * e * 2); var i = new wd; i.setSeed(t); for (var o = 0; this.gradients.length > o; o += 2) { var n, r, a = i.next() * Math.PI * 2; n = Math.sin(a), r = Math.cos(a), this.gradients[o] = n, this.gradients[o + 1] = r } this.dot = function (A, e, t, i) { var o = 2 * (A + e * this.width); return this.gradients[o] * t + this.gradients[o + 1] * i }, this.lerp = function (A, e, t) { return A + t * (e - A) }, this.sCurve = function (A) { return A * A * (3 - 2 * A) }, this.getValue = function (A, e, t, i) { var o = Math.floor(A), n = Math.floor(e), r = A - o, a = e - n, s = o, l = n, c = o === this.width - 1 ? 0 : o + 1, h = n === this.height - 1 ? 0 : n + 1, d = this.dot(s, l, r, a), p = this.dot(c, l, r - 1, a), g = this.dot(s, h, r, a - 1), u = this.dot(c, h, r - 1, a - 1), f = this.lerp(d, p, this.sCurve(r)), m = this.lerp(g, u, this.sCurve(r)); return this.lerp(f, m, this.sCurve(a)) } } var bd, Ud, Fd = function (A) { var e = Object.assign({}, Sd, A); switch (e.type) { case xd.REGULAR: return function (A) { var e = 10 * A.width, t = 10 * A.height; if (!(A.color1 instanceof Xh)) return Bh.warn("color1 不合法"), null; if (!(A.color2 instanceof Xh)) return Bh.warn("color2 不合法"), null; var i = A.color1.toRGBArray(), o = A.color2.toRGBArray(), n = A.thresholdLow, r = A.thresholdHigh, a = 10 * A.size, s = A.phase; 1 === a && (a = 1.1); for (var l = new Array(e * t * 4), c = new Md(Math.ceil(e / a), Math.ceil(t / a), s), h = 0, d = 0, p = 0, g = 0, u = 0, f = 0, m = 0; t > m; m += 1) for (var C = 0; e > C; C += 1) { var y = (c.getValue(C / a, m / a) + 1) / 2; if (y > r) h = o[0], d = o[1], p = o[2]; else if (n > y) h = i[0], d = i[1], p = i[2]; else if (y >= n && r >= y || n === r) { var v = (y - n) / (r - n || 1); g = o[0] * v, u = o[1] * v, f = o[2] * v, h = i[0] * (v = 1 - v) + g, d = i[1] * v + u, p = i[2] * v + f } var I = 4 * (m * e + C); l[I] = h, l[I + 1] = d, l[I + 2] = p, l[I + 3] = 255 } var E = document.createElement("canvas"); E.width = e, E.height = t; for (var B = E.getContext("2d"), x = B.createImageData(e, t), S = 0, w = e * t * 4; w > S; S += 1) x.data[S] = l[S]; return B.putImageData(x, 0, 0), E.toDataURL() }(e); case xd.FRACTAL: return function (A) { var e = 10 * A.width, t = 10 * A.height; if (!(A.color1 instanceof Xh)) return Bh.warn("color1 不合法"), null; if (!(A.color2 instanceof Xh)) return Bh.warn("color2 不合法"), null; var i = A.color1.toRGBArray(), o = A.color2.toRGBArray(), n = A.thresholdLow, r = A.thresholdHigh, a = 10 * A.size, s = A.phase, l = A.level; 1 === a && (a = 1.1); for (var c = new Array(e * t * 4), h = [], d = a, p = 0, g = l; g > p; p += 1) { var u = new Md(Math.ceil(e / d), Math.ceil(t / d), s); d /= 2, h.push(u) } for (var f = 0, m = 0, C = 0, y = 0, v = 0, I = 0, E = 0; t > E; E += 1) for (var B = 0; e > B; B += 1) { for (var x = 0, S = a, w = 0, M = l; M > w; w += 1) x += h[w].getValue(B / S, E / S, s) * (l - w), S /= 2; var b = ((x /= l) + 1) / 2; if (b > r) f = o[0], m = o[1], C = o[2]; else if (n > b) f = i[0], m = i[1], C = i[2]; else if (b >= n && r >= b || n === r) { var U = (b - n) / (r - n || 1); y = o[0] * U, v = o[1] * U, I = o[2] * U, f = i[0] * (U = 1 - U) + y, m = i[1] * U + v, C = i[2] * U + I } var F = 4 * (E * e + B); c[F] = f, c[F + 1] = m, c[F + 2] = C, c[F + 3] = 255 } var K = document.createElement("canvas"); K.width = e, K.height = t; for (var Q = K.getContext("2d"), R = Q.createImageData(e, t), T = 0, k = e * t * 4; k > T; T += 1) R.data[T] = c[T]; return Q.putImageData(R, 0, 0), K.toDataURL() }(e); case xd.DISORDER: return function (A) { var e = 10 * A.width, t = 10 * A.height; if (!(A.color1 instanceof Xh)) return Bh.warn("color1 不合法"), null; if (!(A.color2 instanceof Xh)) return Bh.warn("color2 不合法"), null; var i = A.color1.toRGBArray(), o = A.color2.toRGBArray(), n = A.thresholdLow, r = A.thresholdHigh, a = 10 * A.size, s = A.phase, l = A.level; 1 === a && (a = 1.1); for (var c = new Array(e * t * 4), h = [], d = a, p = 0, g = l; g > p; p += 1) { var u = new Md(Math.ceil(e / d), Math.ceil(t / d), s); d /= 2, h.push(u) } for (var f = 0, m = 0, C = 0, y = 0, v = 0, I = 0, E = 0; t > E; E += 1) for (var B = 0; e > B; B += 1) { for (var x = 0, S = a, w = 0, M = l; M > w; w += 1) x += h[w].getValue(B / S, E / S, s) * (l - w), S /= 2; x /= l; var b = Math.abs(x) + .05; if (b > r) f = o[0], m = o[1], C = o[2]; else if (n > b) f = i[0], m = i[1], C = i[2]; else if (b >= n && r >= b || n === r) { var U = (b - n) / (r - n || 1); y = o[0] * U, v = o[1] * U, I = o[2] * U, f = i[0] * (U = 1 - U) + y, m = i[1] * U + v, C = i[2] * U + I } var F = 4 * (E * e + B); c[F] = f, c[F + 1] = m, c[F + 2] = C, c[F + 3] = 255 } var K = document.createElement("canvas"); K.width = e, K.height = t; for (var Q = K.getContext("2d"), R = Q.createImageData(e, t), T = 0, k = e * t * 4; k > T; T += 1) R.data[T] = c[T]; return Q.putImageData(R, 0, 0), K.toDataURL() }(e); default: return Bh.warn("不支持的噪波类型"), null } }, Kd = { DefaultMaterial: new Ir({ color: 255, side: 2 }), DefaultWireframeColor: { color: new LA(0, 0, 0), opacity: .4 }, getDefaultStandardMaterial: (bd = null, function () { return bd || (bd = new ld({ color: 0, side: 2 })), bd } ), createInstancePhongMaterial: function (A) { return A.clone() }, updateBasicMaterial: function (A, e) { A.needsUpdate = !0 }, setMatrixUniform: function (A) {}, createPhongMaterial: function (A) { var e = new Ir(A); return e.type = "FillFacePhong", e.uniforms = Ge.merge([it.fillFacePhong.uniforms]), e.vertexShader = it.fillFacePhong.vertexShader, e.fragmentShader = it.fillFacePhong.fragmentShader, e.side = 2, e }, createStandardMaterial: function (A) { var e = new ld(A); return vc.EnableTransformAoMap && (e.defines.USE_TRANSFORM_AOMAP = ""), e }, createInstanceMaterial: function (A, e) { var t = Kd.createStandardMaterial(A); return t.defines.USE_INSTANCE = "", e && (t.defines.USE_INSTANCE_NORMAL = ""), t.colorState = Yc.BLINK, vc.InfluencedByLight || (t.defines.NOTAFFECTEDBYLIGHT = ""), t.refreshUniforms(), t }, createMaterialByMaterialBufferAndTexture: function (A, e) { var t, i, o, n, r, a, l, c, h = Kd.createStandardMaterial(); if ((h.name = A.name || A.id, h.key = A.id, A.emissive && h.emissive && (1 === A.emissive[0] && 1 === A.emissive[1] && 1 === A.emissive[2] || h.emissive.setRGB(A.emissive[0], A.emissive[1], A.emissive[2])), A.specular && h.specular && h.specular.setRGB(A.specular[0], A.specular[1], A.specular[2]), A.color ? h.color.setRGB(A.color[0], A.color[1], A.color[2]) : A.emissive && h.emissive ? h.color.setRGB(0, 0, 0) : h.color.setRGB(.72, .72, .72), A.tint && (h.imageFade = void 0 === A.imageFade || 0 > A.imageFade || A.imageFade > 10 ? .5 : A.imageFade, h.color.setRGB(A.tint[0], A.tint[1], A.tint[2])), A.map && vc.EnableTextureLoading) && ("string" == typeof A.map ? void 0 !== A.mapOffsetY && 0 !== A.mapOffsetY || void 0 !== A.mapOffsetX && 0 !== A.mapOfsfetX || void 0 !== A.mapScaleX && 1 !== A.mapScaleX || void 0 !== A.mapScaleY && 1 !== A.mapScaleY || void 0 !== A.mapWAngle && 0 !== A.mapWAngle ? t = A.mapOffsetX + "_" + A.mapOffsetY + "_" + A.mapScaleX + "_" + A.mapScaleY + "_" + A.mapWAngle + "_" + A.map : e[A.map] ? h.map = e[A.map] : Bh.warn(h.name, " 中map贴图未找到:", A.map) : t = Bd(JSON.stringify(A.map)), t)) if (e[t]) h.map = e[t]; else { var p = new d; if (p.wrapS = p.wrapT = 1e3, "string" == typeof A.map) p.image = e[A.map] && e[A.map].image ? e[A.map].image : null; else { var g = A.map, u = document.createElement("img"), f = Fd({ type: Number(g.noise_Type), color1: (new Xh).fromArray(g.noise_Color1), color2: (new Xh).fromArray(g.noise_Color2), size: g.noise_Size, level: g.noise_Levels, phase: g.noise_Phase, width: 32, height: 32, thresholdLow: g.noise_ThresholdLow, thresholdHigh: g.noise_ThresholdHigh }); f && (u.src = f, p.image = u) } p.needsUpdate = !0, p.image && (p.offset.x = A.mapOffsetX ? A.mapOffsetX : 0, p.offset.y = A.mapOffsetY ? A.mapOffsetY : 0, p.repeat.x = A.mapScaleX ? A.mapScaleX : 1, p.repeat.y = A.mapScaleY ? A.mapScaleY : 1, p.rotation = A.mapWAngle ? A.mapWAngle : 0, e[t] = p, h.map = p) } if (A.bumpMap && vc.EnableTextureLoading && ("string" == typeof A.bumpMap ? void 0 !== A.bumpMapOffsetY && 0 !== A.bumpMapOffsetY || void 0 !== A.bumpMapOffsetX && 0 !== A.bumpMapOfsfetX || void 0 !== A.bumpMapScaleX && 1 !== A.bumpMapScaleX || void 0 !== A.bumpMapScaleY && 1 !== A.bumpMapScaleY || void 0 !== A.bumpMapWAngle && 0 !== A.bumpMapWAngle ? i = A.bumpMapOffsetX + "_" + A.bumpMapOffsetY + "_" + A.bumpMapScaleX + "_" + A.bumpMapScaleY + "_" + A.bumpMapWAngle + "_" + A.bumpMap : e[A.bumpMap] ? h.bumpMap = e[A.bumpMap] : Bh.warn(h.name, " 中bumpMap贴图未找到:", A.bumpMap) : i = Bd(JSON.stringify(A.bumpMap)), i)) if (e[i]) h.bumpMap = e[i]; else { var m = new d; if (m.wrapS = m.wrapT = 1e3, "string" == typeof A.bumpMap) m.image = e[A.bumpMap] && e[A.bumpMap].image ? e[A.bumpMap].image : null; else { var C = A.bumpMap, y = document.createElement("img"), v = Fd({ type: Number(C.noise_Type), color1: (new Xh).fromArray(C.noise_Color1), color2: (new Xh).fromArray(C.noise_Color2), size: C.noise_Size, level: C.noise_Levels, phase: C.noise_Phase, width: 32, height: 32, thresholdLow: C.noise_ThresholdLow, thresholdHigh: C.noise_ThresholdHigh }); v && (y.src = v, m.image = y) } m.needsUpdate = !0, m.image && (m.offset.x = A.bumpMapOffsetX ? A.bumpMapOffsetX : 0, m.offset.y = A.bumpMapOffsetY ? A.bumpMapOffsetY : 0, m.repeat.x = A.bumpMapScaleX ? A.bumpMapScaleX : 1, m.repeat.y = A.bumpMapScaleY ? A.bumpMapScaleY : 1, m.rotation = A.bumpMapWAngle ? A.bumpMapWAngle : 0, e[i] = m, h.bumpMap = m) } if ((void 0 !== A.bumpScale && (h.bumpScale = A.bumpScale), A.aoMap && vc.EnableTextureLoading) && ("string" == typeof A.aoMap ? void 0 !== A.aoMapOffsetY && 0 !== A.aoMapOffsetY || void 0 !== A.aoMapOffsetX && 0 !== A.aoMapOfsfetX || void 0 !== A.aoMapScaleX && 1 !== A.aoMapScaleX || void 0 !== A.aoMapScaleY && 1 !== A.aoMapScaleY || void 0 !== A.aoMapWAngle && 0 !== A.aoMapWAngle ? o = A.aoMapOffsetX + "_" + A.aoMapOffsetY + "_" + A.aoMapScaleX + "_" + A.aoMapScaleY + "_" + A.aoMapWAngle + "_" + A.aoMap : e[A.aoMap] ? h.aoMap = e[A.aoMap] : Bh.warn(h.name, " 中aoMap贴图未找到:", A.aoMap) : o = Bd(JSON.stringify(A.aoMap)), o)) if (e[o]) h.aoMap = e[o]; else { var I = new d; if (I.wrapS = I.wrapT = 1e3, "string" == typeof A.aoMap) I.image = e[A.aoMap] && e[A.aoMap].image ? e[A.aoMap].image : null; else { var E = A.aoMap, B = document.createElement("img"), x = Fd({ type: Number(E.noise_Type), color1: (new Xh).fromArray(E.noise_Color1), color2: (new Xh).fromArray(E.noise_Color2), size: E.noise_Size, level: E.noise_Levels, phase: E.noise_Phase, width: 32, height: 32, thresholdLow: E.noise_ThresholdLow, thresholdHigh: E.noise_ThresholdHigh }); x && (B.src = x, I.image = B) } I.needsUpdate = !0, I.image && (I.offset.x = A.aoMapOffsetX ? A.aoMapOffsetX : 0, I.offset.y = A.aoMapOffsetY ? A.aoMapOffsetY : 0, I.repeat.x = A.aoMapScaleX ? A.aoMapScaleX : 1, I.repeat.y = A.aoMapScaleY ? A.aoMapScaleY : 1, I.rotation = A.aoMapWAngle ? A.aoMapWAngle : 0, e[o] = I, h.aoMap = I) } if ((void 0 !== A.aoMapIntensity && (h.aoMapIntensity = A.aoMapIntensity), A.normalMap && vc.EnableTextureLoading) && ("string" == typeof A.normalMap ? void 0 !== A.normalMapOffsetY && 0 !== A.normalMapOffsetY || void 0 !== A.normalMapOffsetX && 0 !== A.normalMapOfsfetX || void 0 !== A.normalMapScaleX && 1 !== A.normalMapScaleX || void 0 !== A.normalMapScaleY && 1 !== A.normalMapScaleY || void 0 !== A.normalMapWAngle && 0 !== A.normalMapWAngle ? n = A.normalMapOffsetX + "_" + A.normalMapOffsetY + "_" + A.normalMapScaleX + "_" + A.normalMapScaleY + "_" + A.normalMapWAngle + "_" + A.normalMap : e[A.normalMap] ? h.normalMap = e[A.normalMap] : Bh.warn(h.name, " 中normalMap贴图未找到:", A.normalMap) : n = Bd(JSON.stringify(A.normalMap)), n)) if (e[n]) h.normalMap = e[n]; else { var S = new d; if (S.wrapS = S.wrapT = 1e3, "string" == typeof A.normalMap) S.image = e[A.normalMap] && e[A.normalMap].image ? e[A.normalMap].image : null; else { var w = A.normalMap, M = document.createElement("img"), b = Fd({ type: Number(w.noise_Type), color1: (new Xh).fromArray(w.noise_Color1), color2: (new Xh).fromArray(w.noise_Color2), size: w.noise_Size, level: w.noise_Levels, phase: w.noise_Phase, width: 32, height: 32, thresholdLow: w.noise_ThresholdLow, thresholdHigh: w.noise_ThresholdHigh }); b && (M.src = b, S.image = M) } S.needsUpdate = !0, S.image && (S.offset.x = A.normalMapOffsetX ? A.normalMapOffsetX : 0, S.offset.y = A.normalMapOffsetY ? A.normalMapOffsetY : 0, S.repeat.x = A.normalMapScaleX ? A.normalMapScaleX : 1, S.repeat.y = A.normalMapScaleY ? A.normalMapScaleY : 1, S.rotation = A.normalMapWAngle ? A.normalMapWAngle : 0, e[n] = S, h.normalMap = S) } if (void 0 !== A.normalScale && (h.normalScale = (new s).fromArray(A.normalScale)), A.alphaMap && vc.EnableTextureLoading) { var U; if ("string" == typeof A.alphaMap ? void 0 !== A.alphaMapOffsetY && 0 !== A.alphaMapOffsetY || void 0 !== A.alphaMapOffsetX && 0 !== A.alphaMapOfsfetX || void 0 !== A.alphaMapScaleX && 1 !== A.alphaMapScaleX || void 0 !== A.alphaMapScaleY && 1 !== A.alphaMapScaleY || void 0 !== A.alphaMapWAngle && 0 !== A.alphaMapWAngle ? U = A.alphaMapOffsetX + "_" + A.alphaMapOffsetY + "_" + A.alphaMapScaleX + "_" + A.alphaMapScaleY + "_" + A.alphaMapWAngle + "_" + A.alphaMap : e[A.alphaMap] ? h.alphaMap = e[A.alphaMap] : Bh.warn(h.name, " 中alphaMap贴图未找到:", A.alphaMap) : U = Bd(JSON.stringify(A.alphaMap)), U) if (e[U]) h.alphaMap = e[U]; else { var F = new d; if (F.wrapS = F.wrapT = 1e3, "string" == typeof A.alphaMap) F.image = e[A.alphaMap] && e[A.alphaMap].image ? e[A.alphaMap].image : null; else { var K = A.alphaMap, Q = document.createElement("img"), R = Fd({ type: Number(K.noise_Type), color1: (new Xh).fromArray(K.noise_Color1), color2: (new Xh).fromArray(K.noise_Color2), size: K.noise_Size, level: K.noise_Levels, phase: K.noise_Phase, width: 32, height: 32, thresholdLow: K.noise_ThresholdLow, thresholdHigh: K.noise_ThresholdHigh }); R && (Q.src = R, F.image = Q) } F.needsUpdate = !0, F.image && (F.offset.x = A.alphaMapOffsetX ? A.alphaMapOffsetX : 0, F.offset.y = A.alphaMapOffsetY ? A.alphaMapOffsetY : 0, F.repeat.x = A.alphaMapScaleX ? A.alphaMapScaleX : 1, F.repeat.y = A.alphaMapScaleY ? A.alphaMapScaleY : 1, F.rotation = A.alphaMapWAngle ? A.alphaMapWAngle : 0, e[U] = F, h.alphaMap = F) } h.transparent = !0, h.alphaTest = Number.isNaN(vc.alphaTest) ? .5 : vc.alphaTest } if (A.envMap && vc.EnableTextureLoading && ("string" == typeof A.envMap ? void 0 !== A.envMapOffsetY && 0 !== A.envMapOffsetY || void 0 !== A.envMapOffsetX && 0 !== A.envMapOfsfetX || void 0 !== A.envMapScaleX && 1 !== A.envMapScaleX || void 0 !== A.envMapScaleY && 1 !== A.envMapScaleY || void 0 !== A.envMapWAngle && 0 !== A.envMapWAngle ? r = A.envMapOffsetX + "_" + A.envMapOffsetY + "_" + A.envMapScaleX + "_" + A.envMapScaleY + "_" + A.envMapWAngle + "_" + A.envMap : e[A.envMap] ? h.envMap = e[A.envMap] : Bh.warn(h.name, " 中envMap贴图未找到:", A.envMap) : r = Bd(JSON.stringify(A.envMap)), r)) if (e[r]) h.envMap = e[r]; else { var T = new d; if (T.wrapS = T.wrapT = 1e3, "string" == typeof A.envMap) T.image = e[A.envMap] && e[A.envMap].image ? e[A.envMap].image : null; else { var k = A.envMap, D = document.createElement("img"), L = Fd({ type: Number(k.noise_Type), color1: (new Xh).fromArray(k.noise_Color1), color2: (new Xh).fromArray(k.noise_Color2), size: k.noise_Size, level: k.noise_Levels, phase: k.noise_Phase, width: 32, height: 32, thresholdLow: k.noise_ThresholdLow, thresholdHigh: k.noise_ThresholdHigh }); L && (D.src = L, T.image = D) } T.needsUpdate = !0, T.image && (T.offset.x = A.envMapOffsetX ? A.envMapOffsetX : 0, T.offset.y = A.envMapOffsetY ? A.envMapOffsetY : 0, T.repeat.x = A.envMapScaleX ? A.envMapScaleX : 1, T.repeat.y = A.envMapScaleY ? A.envMapScaleY : 1, T.rotation = A.envMapWAngle ? A.envMapWAngle : 0, e[r] = T, h.envMap = T) } if (A.lightMap && vc.EnableTextureLoading && ("string" == typeof A.lightMap ? void 0 !== A.lightMapOffsetY && 0 !== A.lightMapOffsetY || void 0 !== A.lightMapOffsetX && 0 !== A.lightMapOfsfetX || void 0 !== A.lightMapScaleX && 1 !== A.lightMapScaleX || void 0 !== A.lightMapScaleY && 1 !== A.lightMapScaleY || void 0 !== A.lightMapWAngle && 0 !== A.lightMapWAngle ? a = A.lightMapOffsetX + "_" + A.lightMapOffsetY + "_" + A.lightMapScaleX + "_" + A.lightMapScaleY + "_" + A.lightMapWAngle + "_" + A.lightMap : e[A.lightMap] ? h.lightMap = e[A.lightMap] : Bh.warn(h.name, " 中lightMap贴图未找到:", A.lightMap) : a = Bd(JSON.stringify(A.lightMap)), a)) if (e[a]) h.lightMap = e[a]; else { var N = new d; if (N.wrapS = N.wrapT = 1e3, "string" == typeof A.lightMap) N.image = e[A.lightMap] && e[A.lightMap].image ? e[A.lightMap].image : null; else { var O = A.lightMap, V = document.createElement("img"), G = Fd({ type: Number(O.noise_Type), color1: (new Xh).fromArray(O.noise_Color1), color2: (new Xh).fromArray(O.noise_Color2), size: O.noise_Size, level: O.noise_Levels, phase: O.noise_Phase, width: 32, height: 32, thresholdLow: O.noise_ThresholdLow, thresholdHigh: O.noise_ThresholdHigh }); G && (V.src = G, N.image = V) } N.needsUpdate = !0, N.image && (N.offset.x = A.lightMapOffsetX ? A.lightMapOffsetX : 0, N.offset.y = A.lightMapOffsetY ? A.lightMapOffsetY : 0, N.repeat.x = A.lightMapScaleX ? A.lightMapScaleX : 1, N.repeat.y = A.lightMapScaleY ? A.lightMapScaleY : 1, N.rotation = A.lightMapWAngle ? A.lightMapWAngle : 0, e[a] = N, h.lightMap = N) } if ((void 0 !== A.lightMapIntensity && (h.lightMapIntensity = A.lightMapIntensity), A.emissiveMap && vc.EnableTextureLoading) && ("string" == typeof A.emissiveMap ? void 0 !== A.emissiveMapOffsetY && 0 !== A.emissiveMapOffsetY || void 0 !== A.emissiveMapOffsetX && 0 !== A.emissiveMapOfsfetX || void 0 !== A.emissiveMapScaleX && 1 !== A.emissiveMapScaleX || void 0 !== A.emissiveMapScaleY && 1 !== A.emissiveMapScaleY || void 0 !== A.emissiveMapWAngle && 0 !== A.emissiveMapWAngle ? l = A.emissiveMapOffsetX + "_" + A.emissiveMapOffsetY + "_" + A.emissiveMapScaleX + "_" + A.emissiveMapScaleY + "_" + A.emissiveMapWAngle + "_" + A.emissiveMap : e[A.emissiveMap] ? h.emissiveMap = e[A.emissiveMap] : Bh.warn(h.name, " 中emissiveMap贴图未找到:", A.emissiveMap) : l = Bd(JSON.stringify(A.emissiveMap)), l)) if (e[l]) h.emissiveMap = e[l]; else { var P = new d; if (P.wrapS = P.wrapT = 1e3, "string" == typeof A.emissiveMap) P.image = e[A.emissiveMap] && e[A.emissiveMap].image ? e[A.emissiveMap].image : null; else { var q = A.emissiveMap, j = document.createElement("img"), H = Fd({ type: Number(q.noise_Type), color1: (new Xh).fromArray(q.noise_Color1), color2: (new Xh).fromArray(q.noise_Color2), size: q.noise_Size, level: q.noise_Levels, phase: q.noise_Phase, width: 32, height: 32, thresholdLow: q.noise_ThresholdLow, thresholdHigh: q.noise_ThresholdHigh }); H && (j.src = H, P.image = j) } P.needsUpdate = !0, P.image && (P.offset.x = A.emissiveMapOffsetX ? A.emissiveMapOffsetX : 0, P.offset.y = A.emissiveMapOffsetY ? A.emissiveMapOffsetY : 0, P.repeat.x = A.emissiveMapScaleX ? A.emissiveMapScaleX : 1, P.repeat.y = A.emissiveMapScaleY ? A.emissiveMapScaleY : 1, P.rotation = A.emissiveMapWAngle ? A.emissiveMapWAngle : 0, e[l] = P, h.emissiveMap = P) } if ((void 0 !== A.emissiveIntensity && (h.emissiveIntensity = A.emissiveIntensity), A.specularMap && vc.EnableTextureLoading) && ("string" == typeof A.specularMap ? void 0 !== A.specularMapOffsetY && 0 !== A.specularMapOffsetY || void 0 !== A.specularMapOffsetX && 0 !== A.specularMapOfsfetX || void 0 !== A.specularMapScaleX && 1 !== A.specularMapScaleX || void 0 !== A.specularMapScaleY && 1 !== A.specularMapScaleY || void 0 !== A.specularMapWAngle && 0 !== A.specularMapWAngle ? c = A.specularMapOffsetX + "_" + A.specularMapOffsetY + "_" + A.specularMapScaleX + "_" + A.specularMapScaleY + "_" + A.specularMapWAngle + "_" + A.specularMap : e[A.specularMap] ? h.specularMap = e[A.specularMap] : Bh.warn(h.name, " 中specularMap贴图未找到:", A.specularMap) : c = Bd(JSON.stringify(A.specularMap)), c)) if (e[c]) h.specularMap = e[c]; else { var Y = new d; if (Y.wrapS = Y.wrapT = 1e3, "string" == typeof A.specularMap) Y.image = e[A.specularMap] && e[A.specularMap].image ? e[A.specularMap].image : null; else { var W = A.specularMap, J = document.createElement("img"), z = Fd({ type: Number(W.noise_Type), color1: (new Xh).fromArray(W.noise_Color1), color2: (new Xh).fromArray(W.noise_Color2), size: W.noise_Size, level: W.noise_Levels, phase: W.noise_Phase, width: 32, height: 32, thresholdLow: W.noise_ThresholdLow, thresholdHigh: W.noise_ThresholdHigh }); z && (J.src = z, Y.image = J) } Y.needsUpdate = !0, Y.image && (Y.offset.x = A.specularMapOffsetX ? A.specularMapOffsetX : 0, Y.offset.y = A.specularMapOffsetY ? A.specularMapOffsetY : 0, Y.repeat.x = A.specularMapScaleX ? A.specularMapScaleX : 1, Y.repeat.y = A.specularMapScaleY ? A.specularMapScaleY : 1, Y.rotation = A.specularMapWAngle ? A.specularMapWAngle : 0, e[c] = Y, h.specularMap = Y) } return void 0 !== A.shininess && (h.shininess = A.shininess), void 0 !== A.opacity && (h.opacity = A.opacity, 1 > A.opacity && (h.transparent = !0), A.opacity > 0 || (h.opacity = .1)), h.side = 2, h.refreshUniforms && h.refreshUniforms(), h }, createNewStyleMaterial: function (A) { var e = new yr(A); return e.type = "NewStyle", e.uniforms = Ge.merge([it.standard.uniforms]), e.vertexShader = it.newStyle.vertexShader, e.fragmentShader = it.newStyle.fragmentShader, e.metalness = 0, e }, createHighlightMaterial: function () { var A = this.createStandardMaterial(vc.SelectionColor); return vc.InfluencedByLight || (A.defines.NOTAFFECTEDBYLIGHT = ""), A }, getBlinkMaterial: function (A, e) { var t = Kd.getMaterialParameters(A), i = Kd.createStandardMaterial(t); return i.blinkColor.copy(e), i.colorState = Yc.BLINK, i.refreshUniforms(), i }, getMaterialParameters: function (A) { var e = {}; return A.hasOwnProperty("color") && (e.color = A.color), e.opacity = 1, e.transparent = !1, A.hasOwnProperty("opacity") && (e.opacity = A.opacity, 1 > A.opacity && (e.transparent = !0)), A.hasOwnProperty("side") && (e.side = A.side), A.hasOwnProperty("name") && (e.name = A.name || ""), A.hasOwnProperty("emissive") && (e.emissive = A.emissive), A.hasOwnProperty("emissiveIntensity") && (e.emissive = A.emissiveIntensity), A.hasOwnProperty("specular") && (e.specular = A.specular), A.hasOwnProperty("shininess") && (e.shininess = A.shininess), A.hasOwnProperty("map") && (e.map = A.map), A.hasOwnProperty("aoMap") && (e.aoMap = A.aoMap), A.hasOwnProperty("aoMapIntensity") && (e.aoMapIntensity = A.aoMapIntensity), A.hasOwnProperty("bumpMap") && (e.bumpMap = A.bumpMap), A.hasOwnProperty("bumpScale") && (e.bumpScale = A.bumpScale), A.hasOwnProperty("normalMap") && (e.normalMap = A.normalMap), A.hasOwnProperty("normalScale") && (e.normalScale = A.normalScale), A.hasOwnProperty("alphaMap") && (e.alphaMap = A.alphaMap), A.hasOwnProperty("alphaTest") && (e.alphaTest = A.alphaTest), A.hasOwnProperty("transparent") && (e.transparent = A.transparent), A.hasOwnProperty("emissiveMap") && (e.emissiveMap = A.emissiveMap), A.hasOwnProperty("envMap") && (e.envMap = A.envMap), A.hasOwnProperty("envMapIntensity") && (e.envMapIntensity = A.envMapIntensity), A.hasOwnProperty("roughness") && (e.roughness = A.roughness), A.hasOwnProperty("metalness") && (e.metalness = A.metalness), A.hasOwnProperty("originRoughness") && (e.originRoughness = A.originRoughness), A.hasOwnProperty("originMetalness") && (e.originMetalness = A.originMetalness), A.hasOwnProperty("iblProbe") && (e.iblProbe = A.iblProbe), A.hasOwnProperty("shift") && (e.shift = A.shift), A.hasOwnProperty("wireframe") && (e.wireframe = A.wireframe), A.hasOwnProperty("pureColor") && (e.pureColor = A.pureColor), A.hasOwnProperty("textureColor") && (e.textureColor = A.textureColor), A.hasOwnProperty("imageFade") && (e.imageFade = A.imageFade), "bos3d" === A.type && A.hasOwnProperty("lights") && (e.lights = A.lights), A.hasOwnProperty("lightMap") && (e.lightMap = A.lightMap), A.hasOwnProperty("lightMapIntensity") && (e.lightMapIntensity = A.lightMapIntensity), A.hasOwnProperty("viewportSize") && (e.viewportSize = A.viewportSize), A.hasOwnProperty("fillMap") && (e.fillMap = A.fillMap), e }, nextHighestPowerOfTwo: function (A) { A -= 1; for (var e = 1; 32 > e; e <<= 1) A |= A >> e; return A + 1 }, ensurePowerOfTwo: function (A) { if (0 === A.width || 0 === A.height) return A; if (!a.isPowerOfTwo(A.width) || !a.isPowerOfTwo(A.height)) { var e = document.createElement("canvas"); return e.width = Kd.nextHighestPowerOfTwo(A.width), e.height = Kd.nextHighestPowerOfTwo(A.height), e.getContext("2d").drawImage(A, 0, 0, A.width, A.height, 0, 0, e.width, e.height), e } return A }, ensureQuadrate: function (A) { var e = A.width, t = A.height; if (0 === e || 0 === t || a.isPowerOfTwo(e) && a.isPowerOfTwo(t) && e === t) return A; a.isPowerOfTwo(e) || (e = Kd.nextHighestPowerOfTwo(e)), a.isPowerOfTwo(t) || (t = Kd.nextHighestPowerOfTwo(t)); var i = 0, o = 0; t > e ? i = .5 * (t - e) : o = .5 * (e - t); var n = document.createElement("canvas"); return n.width = n.height = Math.max(e, t), n.getContext("2d").drawImage(A, 0, 0, A.width, A.height, i, o, e, t), n }, getRGBAFromColorArray: function (A) { var e = A[0], t = A[1], i = A[2], o = A[3]; return void 0 !== o ? "rgba(" + e + "," + t + "," + i + "," + o + ")" : "rgb(" + e + "," + t + "," + i + ")" }, getRGBAFromArray: function (A) { var e = 255 * A[0], t = 255 * A[1], i = 255 * A[2], o = 255 * A[3]; return void 0 !== o ? "rgba(" + e + "," + t + "," + i + "," + o + ")" : "rgb(" + e + "," + t + "," + i + ")" }, getArrayFromRGBA: function (A) { var e = A.split(","), t = parseInt(e[0].split("(")[1], 0) / 255, i = parseInt(e[1], 0) / 255, o = parseInt(e[2].split(")")[0], 0) / 255; return void 0 !== e[3] ? [t, i, o, parseFloat(e[3].split(")")[0])] : [t, i, o] }, getColorArrayFromRGBA: function (A) { var e = A.split(","), t = parseInt(e[0].split("(")[1], 0), i = parseInt(e[1], 0), o = parseInt(e[2].split(")")[0], 0); return void 0 !== e[3] ? [t, i, o, parseFloat(e[3].split(")")[0])] : [t, i, o] }, getHexStringFromRGB: function (A) { return "#" + ("000000" + Kd.getHex(Kd.getArrayFromRGBA(A)).toString(16)).slice(-6) }, getArrayFromColorArray: function (A) { return [A[0] / 255, A[1] / 255, A[2] / 255] }, getHexStringFromColorArray: function (A) { return "#" + ("000000" + Kd.getHex(Kd.getArrayFromColorArray(A)).toString(16)).slice(-6) }, getHexStringFromArray: function (A) { return "#" + ("000000" + Kd.getHex(A).toString(16)).slice(-6) }, getHex: function (A) { return 255 * A[0] << 16 ^ 255 * A[1] << 8 ^ 255 * A[2] << 0 }, getColorParamsByMaterial: function (A) { return { rgbaColor: [A.color.r, A.color.g, A.color.b, A.opacity], transparent: A.transparent, wireframe: A.wireframe } }, getHoverColorByColor: function (A) { var e = {}; return e.r = A.r, e.g = A.g, e.b = A.b, e.a = Kd.getHoverOpacity(A.a), e }, getHoverOpacity: function (A) { return .4 > A ? A + .3 : A - .3 }, cloneMaterialBaseOnColor: function (A, e) { if (!A.color && !A.diffuse) return A; var t = A.clone(); return t.wireframe = e.wireframe, t.opacity = e.opacity, t.transparent = e.transparent, t.color && t.color.isColor && e.color && e.color.isColor && t.color.copy(e.color), t.diffuse && t.diffuse.isColor && e.diffuse && e.diffuse.isColor && t.diffuse.copy(e.diffuse), t } }, Qd = function (A, e, t, i, o, n, r, a) { this.name = A, this.position = e, this.target = t, this.up = i, this.fov = o, this.frustumWidth = r, this.frustumHeight = a, this.version = n }, Rd = { createCameraInfo: function (A) { var e = A.camera, t = new Qd(A.getCameraName(), e.position, e.target, e.up); return JSON.stringify(t) }, transformCamera: function (A, e) { var t = new y, i = function (A) { return [parseFloat(A[0]), parseFloat(A[1]), parseFloat(A[2])] }; t.fromArray(i(A.position.split(","))); var o = new y; o.fromArray(i(A.direction.split(","))); var n = new y; n.fromArray(i(A.up.split(","))); var r = new y; r.addVectors(t, o), t.applyMatrix4(e.rootNode.matrix), r.applyMatrix4(e.rootNode.matrix); var a = new M; return a.makeRotationFromEuler(e.rootNode.rotation), n.applyMatrix4(a), n.normalize(), new Qd(A.name, t, r, n) }, parseCameraInfo: function (A) { if (!A) return null; var e = JSON.parse(A); if (!e.hasOwnProperty("position") || !e.hasOwnProperty("target") || !e.hasOwnProperty("up")) return null; var t = e.name || Ec.PERSPECTIVE, i = new y; i.x = e.position.x, i.y = e.position.y, i.z = e.position.z; var o = new y; o.x = e.target.x, o.y = e.target.y, o.z = e.target.z; var n = new y; return n.x = e.up.x, n.y = e.up.y, n.z = e.up.z, new Qd(t, i, o, n, void 0, void 0 === e.version ? 0 : e.version, e.frustumWidth, e.frustumHeight) }, canvasToNormalized: function (A, e, t) { var i = { x: 0, y: 0, z: 0 }; return i.x = A.x / e * 2 - 1, i.y = -A.y / t * 2 + 1, i.z = A.z || 0, i }, normalizedToCanvas: function (A, e, t) { var i = { x: 0, y: 0, z: 0 }; return i.x = Math.floor(.5 * (A.x + 1) * e + .5), i.y = Math.floor(-.5 * (A.y - 1) * t + .5), i.z = A.z || 0, i }, drawingToCanvas: function (A, e, t, i) { var o = new y(e.x, e.y, e.z); return o.project(A), this.normalizedToCanvas(o, t, i) }, drawingPointsToCanvas: function (A, e, t, i, o) { var n = {}, r = (new M).getInverse(A.matrixWorld), a = new y(e.x, e.y, e.z); a.applyMatrix4(r); var s = new y(t.x, t.y, t.z); if (s.applyMatrix4(r), a.z > 0 && s.z > 0) return null; var l = a.clone().sub(s); if (l.normalize(), a.z > 0) a.sub(l.multiplyScalar((a.z + A.near) / l.z)); else if (s.z > 0) { s.sub(l.multiplyScalar((s.z + A.near) / l.z)) } return a.applyMatrix4(A.projectionMatrix), s.applyMatrix4(A.projectionMatrix), n.start = this.normalizedToCanvas(a, i, o), n.end = this.normalizedToCanvas(s, i, o), n }, lineIntersectWithRect: function (A, e) { if (A && A.start.x === A.end.x && A.start.y === A.end.y) return Bh.log("Invalid line."), null; var t, i = 0; A.start.x !== A.end.x && (i = (A.start.y - A.end.y) / (A.start.x - A.end.x)); var o = [], n = e.min, r = e.max; return n.y > i * n.x + (t = A.start.y - i * A.start.x) || i * n.x + t > r.y || o.push(new s(n.x, i * n.x + t)), n.y > i * r.x + t || i * r.x + t > r.y || o.push(new s(r.x, i * r.x + t)), 0 === i && (o.push(new s(n.x, t)), o.push(new s(r.x, t))), (n.y - t) / i > n.x && r.x > (n.y - t) / i && o.push(new s((n.y - t) / i, n.y)), (r.y - t) / i > n.x && r.x > (r.y - t) / i && o.push(new s((r.y - t) / i, r.y)), o }, canvasToDrawing: function (A, e, t, i) { var o = this.canvasToNormalized(e, t, i), n = new y(o.x, o.y, o.z); return n.unproject(A), { x: n.x, y: n.y, z: n.z } }, intersectBoxByRay: function (A, e) { var t = 0, i = 0, o = 0, n = 0, r = 0, a = 0, s = 1 / A.direction.x, l = 1 / A.direction.y, c = 1 / A.direction.z, h = A.origin; return 0 > s ? (t = (e.max.x - h.x) * s, i = (e.min.x - h.x) * s) : (t = (e.min.x - h.x) * s, i = (e.max.x - h.x) * s), 0 > l ? (o = (e.max.y - h.y) * l, n = (e.min.y - h.y) * l) : (o = (e.min.y - h.y) * l, n = (e.max.y - h.y) * l), t > n || o > i ? null : ((o > t || isNaN(t)) && (t = o), (i > n || isNaN(i)) && (i = n), 0 > c ? (r = (e.max.z - h.z) * c, a = (e.min.z - h.z) * c) : (r = (e.min.z - h.z) * c, a = (e.max.z - h.z) * c), t > a || r > i ? null : ((r > t || isNaN(t)) && (t = r), (i > a || isNaN(i)) && (i = a), 0 > i ? null : 0 > t ? i : t)) }, intersectObject: function (A, e, t, i) { if (A.visible) { A.raycast(e, t); if (!0 === i && A.children) for (var o = A.children, n = 0, r = o.length; r > n; n += 1) Rd.intersectObject(o[n], e, t, !0) } }, intersectObjectWithFrustum: (Ud = new aA, function (A, e) { if (!A.boundingBox || A instanceof Ue) { var t = A.geometry; null === t.boundingBox && t.computeBoundingBox(), Ud.copy(t.boundingBox) } else Ud.copy(A.boundingBox); return Ud.applyMatrix4(A.matrixWorld), e.intersectsBox(Ud) } ) }, Td = function (A, e, t, i) { je.call(this, A, e, t, i), this.projectOnWidth = !1 }; (Td.prototype = Object.create(je.prototype)).constructor = Td, Td.prototype.updateProjectionMatrixByFrustum = function (A, e) { var t = this.near, i = null, o = null, n = null, r = null; this.projectOnWidth ? (o = -.5 * (n = A), i = .5 * (r = this.aspect * n)) : (i = .5 * (r = e), o = -.5 * (n = this.aspect * r)); var a = this.view; if (null !== a) { var s = a.fullWidth, l = a.fullHeight; o += a.offsetX * n / s, i -= a.offsetY * r / l, n *= a.width / s, r *= a.height / l } var c = this.filmOffset; 0 !== c && (o += t * c / this.getFilmWidth()), this.projectionMatrix.makePerspective(o, o + n, i, i - r, t, this.far) }, Td.prototype.setProjectOnWidth = function (A) { this.projectOnWidth = A }; var kd = function (A, e) { qe.call(this), this.target = new y, this.name = A || "", this.fov = e.fov, this.near = e.near, this.far = e.far, A === Ec.PERSPECTIVE ? (this.aspect = e.width / e.height, this.fov = e.fov, this.left = -e.width / 2, this.right = e.width / 2, this.top = e.height / 2, this.bottom = -e.height / 2, this.perspectiveCamera = new Td(this.fov, this.aspect, this.near, this.far), this.orthoCamera = null, this.toPerspective()) : (this.left = e.left, this.right = e.right, this.top = e.top, this.bottom = e.bottom, this.fov = 45, this.aspect = (this.right - this.left) / (this.top - this.bottom), this.orthoCamera = new Ka(this.left, this.right, this.top, this.bottom, this.near, this.far), this.perspectiveCamera = null, this.orthoCamera.updateProjectionMatrix(), this.projectionMatrix = this.orthoCamera.projectionMatrix, this.isPerspective = !1), this.zoom = e.zoom || 1, this.updateProjectionMatrixByFrustum = !1 }; (kd.prototype = Object.create(qe.prototype)).constructor = kd, kd.prototype.toPerspective = function () { null !== this.perspectiveCamera ? this.updateProjectionMatrixByFrustum || (this.perspectiveCamera.aspect = this.aspect, this.perspectiveCamera.near = this.near, this.perspectiveCamera.far = this.far, this.perspectiveCamera.fov = this.fov, this.perspectiveCamera.updateProjectionMatrix(), this.projectionMatrix = this.perspectiveCamera.projectionMatrix, this.projectionMatrixInverse = this.perspectiveCamera.projectionMatrixInverse, this.isPerspective = !0, this.dirty = !0) : Bh.log("Can not convert to perspective camera because the camera original type is orthographic.") }, kd.prototype.toOrthographic = function () { null === this.orthoCamera && (this.orthoCamera = new Ka(this.left, this.right, this.top, this.bottom, this.near, this.far)); var A = this.fov, e = this.target.clone().sub(this.position).length(), t = Math.tan(A * Math.PI / 180 / 2) * e, i = t * this.aspect; t /= this.zoom, this.left = this.orthoCamera.left = -(i /= this.zoom), this.right = this.orthoCamera.right = i, this.top = this.orthoCamera.top = t, this.bottom = this.orthoCamera.bottom = -t, this.orthoCamera.near = this.near, this.orthoCamera.far = this.far, this.orthoCamera.updateProjectionMatrix(), this.projectionMatrix = this.orthoCamera.projectionMatrix, this.projectionMatrixInverse = this.orthoCamera.projectionMatrixInverse, this.isPerspective = !1, this.dirty = !0 }, kd.prototype.setSize = function (A, e) { this.perspectiveCamera.aspect = A / e, this.left = -A / 2, this.right = A / 2, this.top = e / 2, this.bottom = -e / 2, this.aspect = A / e, this.dirty = !0 }, kd.prototype.setSizeByFrustum = function (A, e) { var t = 2 * this.right, i = 2 * this.top; this.aspect = t / i; var o = null; A / e > t / i ? (o = i / t, this.perspectiveCamera.setProjectOnWidth(!0)) : (o = t / i, this.perspectiveCamera.setProjectOnWidth(!1)), this.dirty = !0, this.isPerspective && (this.perspectiveCamera.aspect = o, this.perspectiveCamera.near = this.near, this.perspectiveCamera.far = this.far, this.perspectiveCamera.fov = this.fov, this.perspectiveCamera.updateProjectionMatrixByFrustum(A, e), this.projectionMatrix = this.perspectiveCamera.projectionMatrix, this.isPerspective = !0, this.dirty = !0) }, kd.prototype.setFov = function (A) { this.fov = A, this.dirty = !0, this.updateProjectionMatrix() }, kd.prototype.setNearFar = function (A, e) { this.near = A, this.far = e, this.dirty = !0, this.updateProjectionMatrix() }, kd.prototype.updateProjectionMatrix = function () { this.isPerspective ? this.toPerspective() : this.toOrthographic() }, kd.prototype.setLens = function (A, e) { void 0 === e && (e = 24); var t = 2 * a.radToDeg(Math.atan(e / (2 * A))); return this.setFov(t), this.dirty = !0, t }, kd.prototype.setZoom = function (A) { this.zoom = A, this.dirty = !0, this.updateProjectionMatrix() }, kd.prototype.copy = function (A) { qe.prototype.copy.call(this, A), this.target.copy(A.target), this.aspect = A.aspect, this.fov = A.fov, this.near = A.near, this.far = A.far, this.left = A.left, this.right = A.right, this.top = A.top, this.bottom = A.bottom, this.zoom = A.zoom, this.isPerspective = A.isPerspective, A.orthoCamera && (this.orthoCamera ? this.orthoCamera.copy(A.orthoCamera) : this.orthoCamera = A.orthoCamera.clone()), A.perspectiveCamera && (this.perspectiveCamera ? this.perspectiveCamera.copy(A.perspectiveCamera) : this.perspectiveCamera = A.perspectiveCamera.clone()) }, kd.prototype.isDirty = function () { return this.dirty }, kd.prototype.toFrontView = function () { this.rotation.x = 0, this.rotation.y = 0, this.rotation.z = 0 }, kd.prototype.toBackView = function () { this.rotation.x = 0, this.rotation.y = Math.PI, this.rotation.z = 0 }, kd.prototype.toLeftView = function () { this.rotation.x = 0, this.rotation.y = -Math.PI / 2, this.rotation.z = 0 }, kd.prototype.toRightView = function () { this.rotation.x = 0, this.rotation.y = Math.PI / 2, this.rotation.z = 0 }, kd.prototype.toTopView = function () { this.rotation.x = -Math.PI / 2, this.rotation.y = 0, this.rotation.z = 0 }, kd.prototype.toBottomView = function () { this.rotation.x = Math.PI / 2, this.rotation.y = 0, this.rotation.z = 0 }; var Dd = function (A, e, t, i) { this.ray = new CA(A, e), this.near = t || 0, this.far = i || 1 / 0, this.params = { Sprite: {}, Mesh: {}, Points: { threshold: 1 }, LOD: {}, Line: {} } }; Dd.prototype = { constructor: Dd, precision: 1e-4, linePrecision: 1, descSort: function (A, e) { return A.distance - e.distance }, set: function (A, e) { this.ray.set(A, e) }, setFromCamera: function (A, e) { e instanceof kd ? e.isPerspective ? (this.ray.origin.copy(e.position), this.ray.direction.set(A.x, A.y, .5).unproject(e).sub(e.position).normalize()) : (this.ray.origin.set(A.x, A.y, -1).unproject(e), this.ray.direction.set(0, 0, -1).transformDirection(e.matrixWorld)) : e instanceof je ? (this.ray.origin.copy(e.position), this.ray.direction.set(A.x, A.y, .5).unproject(e).sub(e.position).normalize()) : e instanceof Ka ? (this.ray.origin.set(A.x, A.y, -1).unproject(e), this.ray.direction.set(0, 0, -1).transformDirection(e.matrixWorld)) : Bh.error("Raycaster: Unsupported camera type.") }, intersectObject: function (A, e) { var t = []; return Rd.intersectObject(A, this, t, e), t.sort(this.descSort), t.length > 0 ? t[0] : null }, intersectObjects: function (A, e) { for (var t = [], i = 0, o = A.length; o > i; i += 1) Rd.intersectObject(A[i], this, t, e); return t.sort(this.descSort), t.length > 0 ? t[0] : null }, intersectOctantForNode: function (A, e) { var t = this, i = new aA; ! function A(o) { var n = null, r = null; if (i.set(o.min, o.max), t.ray.intersectBox(i) && (e.push(o), o.childOctants)) for (n = 0, r = o.childOctants.length; r > n; n += 1) A(o.childOctants[n]) }(A) } }, CA.prototype.intersectBoxWithDistance = function (A) { var e = null, t = null, i = null, o = null, n = null, r = null, a = 1 / this.direction.x, s = 1 / this.direction.y, l = 1 / this.direction.z, c = this.origin; if (0 > a ? (t = (A.max.x - c.x) * a, e = (A.min.x - c.x) * a) : (t = (A.min.x - c.x) * a, e = (A.max.x - c.x) * a), 0 > s ? (o = (A.max.y - c.y) * s, i = (A.min.y - c.y) * s) : (o = (A.min.y - c.y) * s, i = (A.max.y - c.y) * s), t > i || o > e) return -1; if ((o > t || isNaN(t)) && (t = o), (e > i || isNaN(e)) && (e = i), 0 > l ? (r = (A.max.z - c.z) * l, n = (A.min.z - c.z) * l) : (r = (A.min.z - c.z) * l, n = (A.max.z - c.z) * l), t > n || r > e) return -1; if ((r > t || isNaN(t)) && (t = r), (e > n || isNaN(e)) && (e = n), 0 > e) return -1; if (0 > t) return 0; var h = new y; this.at(0 > t ? e : t, h); var d = h.x - c.x, p = h.y - c.y, g = h.z - c.z; return Math.sqrt(d * d + p * p + g * g) }; var Ld = function () {}, Nd = function () {}; Nd.prototype = uh.extend(!0, {}, Ld.prototype = { constructor: Ld, apply: function (A) { A.addEventListener = Ld.prototype.addEventListener, A.hasEventListener = Ld.prototype.hasEventListener, A.removeEventListener = Ld.prototype.removeEventListener, A.fireEvent = Ld.prototype.dispatchEvent, A.dispatchEvent = Ld.prototype.dispatchEvent }, addEventListener: function (A, e) { A && (void 0 === this._listeners && (this._listeners = {}), void 0 === this._listeners[A] && (this._listeners[A] = []), this._listeners[A].push(e)) }, hasEventListener: function (A, e) { if (!A) return !1; if (void 0 === this._listeners) return !1; var t = this._listeners; return void 0 !== t[A] && -1 !== t[A].indexOf(e) }, removeEventListener: function (A, e) { if (A && (void 0 === this._listeners && (this._listeners = {}), Array.isArray(this._listeners[A]))) for (var t = this._listeners[A], i = 0, o = t.length; o > i; i += 1) if (t[i] === e) { t.splice(i, 1); break } }, removeAllEventListenerByType: function (A) { A && (void 0 === this._listeners && (this._listeners = {}), Array.isArray(this._listeners[A]) && this._listeners[A] && (this._listeners[A] = void 0)) }, removeAllEventListener: function () { for (var A in void 0 === this._listeners && (this._listeners = {}), this._listeners) if (this._listeners.hasOwnProperty(A)) for (var e = this._listeners[A], t = 0, i = e.length; i > t; t += 1) e.splice(t, 1); this._listeners = {} }, dispatchEvent: function (A) { if (void 0 === this._listeners && (this._listeners = {}), "string" == typeof A && (A = { type: A }), !A.target) try { A.target = this } catch (A) {} if (null == A.type) throw Bh.trace("事件类型未知."), new Error("事件类型未知."); if (Array.isArray(this._listeners[A.type])) for (var e = this._listeners[A.type].slice(), t = 0; e.length > t; t += 1) e[t].call(this, A) }, fireEvent: function (A) { this.dispatchEvent(A) } }, { init: function (A) { this.marks = {}, this.allOids = [], this.components = {}, this.SelectedMark = {}, this.mouse = new s, this.lastX = 0, this.lastY = 0, this.active = !0, this.viewer = A }, addObjectToScene: function (A, e) { A && A.id && e && (this.viewer.addExternalObject(A.id, e), this.components[A.id] = e, this.allOids.push(A.id), this.marks[A.id] = A) }, enabled: function () { this.mousedown = this.viewer.domElement.addEventListener("mousedown", this.onMouseDown.bind(this), !1), this.mouseup = this.viewer.domElement.addEventListener("mouseup", this.onMouseUp.bind(this), !1) }, disabled: function () { this.mousedown = this.viewer.domElement.removeEventListener("mousedown", this.onMouseDown.bind(this), !1), this.mouseup = this.viewer.domElement.removeEventListener("mouseup", this.onMouseUp.bind(this), !1) }, touchEnabled: function () { this.touchstart = document.getElementById(this.viewer.uuid).addEventListener("touchstart", this.onTouchStart.bind(this), !1), this.touchend = document.getElementById(this.viewer.uuid).addEventListener("touchend", this.onTouchEnd.bind(this), !1) }, touchDisabled: function () { this.touchstart = this.viewer.domElement.removeEventListener("touchstart", this.onTouchStart.bind(this), !1), this.touchend = this.viewer.domElement.removeEventListener("touchend", this.onTouchEnd.bind(this), !1) }, onMouseDown: function (A) { this.mouse.x = this.lastX = A.clientX, this.mouse.y = this.lastY = A.clientY }, onMouseUp: function (A) { var e = [A.clientX, A.clientY]; (e[0] > this.lastX ? 5 > e[0] - this.lastX : 5 > this.lastX - e[0]) && (e[1] > this.lastY ? 5 > e[1] - this.lastY : 5 > this.lastY - e[1]) && (this.mouse.x = this.lastX = e[0], this.mouse.y = this.lastY = e[1], this.pick("pick")) }, onTouchStart: function (A) { this.mouse.x = this.lastX = A.changedTouches[0].clientX, this.mouse.y = this.lastY = A.changedTouches[0].clientY }, onTouchEnd: function (A) { (A.changedTouches[0].clientX > this.lastX ? 5 > A.changedTouches[0].clientX - this.lastX : 5 > this.lastX - A.changedTouches[0].clientX) && (A.changedTouches[0].clientY > this.lastY ? 5 > A.changedTouches[0].clientY - this.lastY : 5 > this.lastY - A.changedTouches[0].clientY) && (this.mouse.x = this.lastX = A.changedTouches[0].clientX, this.mouse.y = this.lastY = A.changedTouches[0].clientY, this.pick("pick")) }, pick: function () { var A = this.viewer.cameraControl.getIntersectContext(this.mouse), e = new Dd; e.setFromCamera(A.mouse, A.camera), e.camera = A.camera, e._camera = A.camera, e.viewportSize = A.viewportSize; var t = Object.values(this.components), i = e.intersectObjects(t); i ? this.SelectedMark !== i.object ? (this.SelectedMark = i.object, this.dispatchEvent({ type: "updated", added: { objects: this.SelectedMark } })) : (this.dispatchEvent({ type: "updated", removed: { objects: this.SelectedMark } }), this.SelectedMark = {}) : (this.SelectedMark = {}, this.dispatchEvent({ type: "updated", removed: { objects: this.SelectedMark } })) }, getClickCoordsWithinElement: function (A) { var e = [0, 0]; if (A) { for (var t = A.target, i = 0, o = 0; t.offsetParent;) i += t.offsetLeft, o += t.offsetTop, t = t.offsetParent; e[0] = A.pageX - i, e[1] = A.pageY - o } else A = window.event, e.x = A.x, e.y = A.y; return e }, listentoSelectMarks: function (A) { var e = this; this.addEventListener("updated", (function (t) { t.added && e.SelectedMark !== {} ? A(e.SelectedMark.key, e.SelectedMark) : A(null, null) })) }, hasTheSameId: function (A) { if ("" !== A.id) for (var e = 0; this.allOids.length > e; e += 1) if (A.id === this.allOids[e]) return { data: "标签id重复" } }, findMark: function (A) { return this.components[A] }, idsToArray: function (A) { return null == A ? { data: "未选中mark" } : (Array.isArray(A) || (A = [A]), A) }, removeIdAndInfo: function (A) { var e = this.allOids.indexOf(A); this.allOids.splice(e, 1), delete this.marks[A], delete this.components[A] }, remove: function (A) { if (A = this.idsToArray(A), !Array.isArray(A)) return A; for (var e = 0; A.length > e; e += 1) this.removeIdAndInfo(A[e]), this.viewer.removeExternalObjectByName(A[e]); this.viewer.render() }, hide: function (A) { if (A = this.idsToArray(A), !Array.isArray(A)) return A; for (var e = 0; A.length > e; e += 1) { var t = this.findMark(A[e]); t && (t.visible = !1) } this.viewer.render() }, show: function (A) { var e = null; if (A) { A = this.idsToArray(A); for (var t = 0; A.length > t; t += 1) (e = this.findMark(A[t])) && (e.visible = !0) } else for (var i in this.components) (e = this.components[i]) && (e.visible = !0); this.viewer.render() }, isolation: function (A) { if (this.allOids.length > 0) { A = this.idsToArray(A); this.show(); for (var e = this.allOids.concat(), t = 0; A.length > t; t += 1) { var i = A[t]; if (-1 === this.allOids.indexOf(i)) return { data: "mark不存在" }; for (var o = 0; e.length > o; o += 1) if (i === e[o]) { e.splice(o, 1); break } } var n = null; for (o = 0; e.length > o; o += 1) (n = this.findMark(e[o])) && (n.visible = !1); this.viewer.render() } } }); var Od = function (A) { this.defaultSettings = { id: "", mode: "absolute", startPosition: [0, 0, 0], endPosition: [0, 0], color: [255, 0, 0], colorLine: [0, 0, 0], offset: [0, 0], draggable: !0, componentId: "", domElement: null, title: "标签", showPoint: !0, showLine: !0 }, this.initStartPos = {}; var e = A; "function" == typeof A.getViewerImpl && (e = A.getViewerImpl()), this.dragging = !1, this.init(e), this.markState = {}; var t = this; this.showPoint = !0, this.showLine = !0, e.cameraControl.addEventListener(Rc.ON_CAMERA_CHANGE, (function () { t._update() })) }; Od.prototype = uh.extend(!0, {}, Nd.prototype, { constructor: Od, add: function (A, e) { var t = document.createElement("div"), i = Object.assign({}, this.defaultSettings, A), o = this.hasTheSameId(i); if (o) return o; "" === i.id && (i.id = a.generateUUID()), t.id = "label" + i.id, this.marks[i.id] = Object.assign({}, i); var n = this.viewer.getScreenCoordFromSceneCoord(i.startPosition), r = i.offset, s = i.endPosition.concat(), l = []; ("relativeute" === i.mode ? (s = [n[0] + r[0], n[1] + r[1]], i.endPosition = [0, 0]) : i.offset = [0, 0], Array.isArray(i.colorLine)) && (i.colorLine = "rgb(" + i.colorLine[0] + "," + i.colorLine[1] + "," + i.colorLine[2] + ")"); var c = document.createElement("div"); (c.id = "labelStart" + i.id, c.className = "labelStart", c.style.cssText = "border:2px solid red; border-radius:5px; -moz-border-radius:5px; height: 4px;width: 4px;position: absolute;margin-left: -3px;margin-top: -3px;top:" + n[1] + "px;left:" + n[0] + "px; background-color: red;", t.appendChild(c), this.showPoint && i.showPoint || (c.style.display = "none"), Array.isArray(i.color)) && (i.color = "rgb(" + i.color[0] + "," + i.color[1] + "," + i.color[2] + ")"); var h = document.createElement("div"); h.id = i.id, h.className = "labelingDiv", h.style.cssText = "border:2px solid " + i.colorLine + ";text-align:center;border-radius:5px;-moz-border-radius:5px;min-width: 66px;position: absolute;width:-webkit-fit-content;width: -moz-fit-content;background-color:" + i.color + ";", t.appendChild(h); var d = document.createElement("span"); d.id = "labelTitle" + i.id, d.className = "labelTitle", d.onmouseover = function () { d.style.cursor = "move" }, d.onmouseout = function () { d.style.cursor = "auto" }, d.style.cssText = "display:block;padding:2%;text-align:center;color: #000000;white-space:nowrap", d.innerText = i.title, h.appendChild(d), 0 > s[0] && (s[0] = 5), 0 > s[1] && (s[1] = 5), s[0] > this.viewer.domElement.offsetWidth - h.offsetWidth && (s[0] = this.viewer.domElement.offsetWidth - h.offsetWidth), s[1] > this.viewer.domElement.offsetHeight - h.offsetHeight && (s[1] = this.viewer.domElement.offsetHeight - h.offsetHeight), h.style.cssText += "left:" + s[0] + "px; top:" + s[1] + "px", i.domElement && h.appendChild(i.domElement), s[0] > n[0] ? s[1] > n[1] ? (l[0] = s[0], l[1] = s[1]) : (l[0] = s[0], l[1] = s[1] + h.offsetHeight) : s[1] > n[1] ? (l[0] = s[0] + h.offsetWidth, l[1] = s[1]) : (l[0] = s[0] + h.offsetWidth, l[1] = s[1] + h.offsetHeight); var p = n[0] - l[0], g = n[1] - l[1], u = Math.sqrt(p * p + g * g), f = Math.atan(g / p) / Math.PI * 180; p > 0 || (g > 0 ? f += 180 : f -= 180); var m = document.createElement("div"); m.id = "labelLine" + i.id, m.className = "labelLine", m.style.cssText = " height: 2px;position: absolute;transform-origin: left center;width:" + u + "px;-ms-transform:rotateZ(" + f + "deg);-moz-transform:rotateZ(" + f + "deg);-webkit-transform:rotateZ(" + f + "deg);-o-transform:rotateZ(" + f + "deg);transform:rotateZ(" + f + "deg);left:" + l[0] + "px;top:" + l[1] + "px;background-color:" + i.colorLine + ";", t.appendChild(m), this.showLine && i.showLine || (m.style.display = "none"), this.viewer.domElement.appendChild(t), i.draggable && this._enableDrag(h), this.allOids.push(i.id), this.markState[i.id] = { userHide: !1, outOfBoundary: !1 }, "function" == typeof e && e(i.id) }, enablePoint: function (A) { this.showPoint = A, this._update() }, enableLine: function (A) { this.showLine = A, this._update() }, _update: function () { for (var A in this.marks) { var e = this.viewer.getScreenCoordFromSceneCoord(this.marks[A].startPosition), t = this.marks[A].endPosition.concat(), i = this.marks[A].offset; "relativeute" === this.marks[A].mode && (0 !== t[0] || 0 !== t[1] ? (i = [t[0] - e[0], t[1] - e[1]], this.marks[A].endPosition = [0, 0], this.marks[A].offset = i) : t = [e[0] + i[0], e[1] + i[1]]); var o = [0, 0], n = document.getElementById(A); t[0] > e[0] ? t[1] > e[1] ? (o[0] = t[0], o[1] = t[1]) : (o[0] = t[0], o[1] = t[1] + n.offsetHeight) : t[1] > e[1] ? (o[0] = t[0] + n.offsetWidth, o[1] = t[1]) : (o[0] = t[0] + n.offsetWidth, o[1] = t[1] + n.offsetHeight); var r = e[0] - o[0], a = e[1] - o[1], s = Math.sqrt(r * r + a * a), l = Math.atan(a / r) / Math.PI * 180; r > 0 || (a > 0 ? l += 180 : l -= 180); var c = getComputedStyle(this.viewer.domElement), h = parseInt(c.width, 10), d = parseInt(c.height, 10); 0 > e[1] || e[1] > d || 0 > e[0] || e[0] > h ? (this.markState[A].outOfBoundary = !0, document.getElementById("labelStart" + A).setCss({ display: "none" }), document.getElementById("labelLine" + A).setCss({ display: "none" }), document.getElementById(A).setCss({ display: "none" })) : (this.markState[A].outOfBoundary = !1, this.dragging || "relativeute" !== this.marks[A].mode || (document.getElementById(A).style.left = t[0] + "px", document.getElementById(A).style.top = t[1] + "px"), this.markState[A].userHide || (document.getElementById(A).setCss({ display: "block" }), this.showPoint && this.marks[A].showPoint ? document.getElementById("labelStart" + A).style.cssText += ";display:block;top:" + e[1] + "px; left:" + e[0] + "px" : document.getElementById("labelStart" + A).setCss({ display: "none" }), this.showLine && this.marks[A].showLine ? document.getElementById("labelLine" + A).style.cssText += ";display:block;width:" + s + "px;transform-origin: left center;-ms-transform:rotateZ(" + l + "deg);-moz-transform:rotateZ(" + l + "deg);-webkit-transform:rotateZ(" + l + "deg);-o-transform:rotateZ(" + l + "deg);transform:rotateZ(" + l + "deg);left:" + o[0] + "px; top:" + o[1] + "px" : document.getElementById("labelLine" + A).setCss({ display: "none" }))) } }, _enableDrag: function (A) { var e = this, t = A, i = A.id, o = t.querySelector("#labelTitle" + i), n = this.viewer.domElement, r = n.offsetLeft, a = n.offsetTop, s = this; o.addEventListener("mousedown", (function (e) { e.preventDefault(), s.dragging = !0, t.setAttribute("offset-left", e.offsetX), t.setAttribute("offset-top", e.offsetY), t.setAttribute("allow-drag", "true"), [A.style.left, A.style.top] })), document.addEventListener("mousemove", function (A) { if ("true" === t.getAttribute("allow-drag")) { A.preventDefault(); var e = A.clientX - parseInt(t.getAttribute("offset-left"), 10) - parseInt(t.style.borderWidth, 10) - r, o = A.clientY - parseInt(t.getAttribute("offset-top"), 10) - parseInt(t.style.borderWidth, 10) - a; 0 > o && (o = 5), o > n.offsetHeight - t.offsetHeight && (o = n.offsetHeight - t.offsetHeight), 0 > e && (e = 5), e > n.offsetWidth - t.offsetWidth && (e = n.offsetWidth - t.offsetWidth), t.style.cssText += ";left:" + e + "px;top:" + o + "px", this.marks[i].endPosition = [e, o], this._update() } } .bind(this)), document.addEventListener("mouseup", (function (A) { "true" === t.getAttribute("allow-drag") && (A.preventDefault(), t.setAttribute("allow-drag", "false"), s.dragging = !1) })), o.addEventListener("touchstart", (function (e) { e.preventDefault(); var i = parseInt(t.style.left, 10), o = parseInt(t.style.top, 10), n = e.targetTouches[0].clientY; t.setAttribute("offset-left", e.targetTouches[0].clientX - i), t.setAttribute("offset-top", n - o), t.setAttribute("allow-drag", "true"), [A.style.left, A.style.top] })), document.addEventListener("touchmove", (function (A) { if ("true" === t.getAttribute("allow-drag")) { A.preventDefault(); var o = A.targetTouches[0].clientX - parseInt(t.getAttribute("offset-left"), 10) - parseInt(t.style.borderWidth, 10) - r, n = A.targetTouches[0].clientY - parseInt(t.getAttribute("offset-top"), 10) - parseInt(t.style.borderWidth, 10) - a; 0 > n && (n = 5), n > e.viewer.domElement.offsetHeight - t.offsetHeight && (n = e.viewer.domElement.offsetHeight - t.offsetHeight), 0 > o && (o = 5), o > e.viewer.domElement.offsetWidth - t.offsetWidth && (o = e.viewer.domElement.offsetWidth - t.offsetWidth), t.style.cssText += ";left:" + o + "px;top:" + n + "px", e.marks[i].endPosition = [o, n], e._update() } })), document.addEventListener("touchend", (function (A) { "true" === t.getAttribute("allow-drag") && (A.preventDefault(), t.setAttribute("allow-drag", "false")) })) }, updateMark: function (A, e) { if (!this.marks[A]) return { id: A, data: "该标签不存在" }; var t = Object.assign({}, this.marks[A], e); this.marks[A] = Object.assign({}, t); var i = this.viewer.getScreenCoordFromSceneCoord(t.startPosition), o = t.offset, n = t.endPosition.concat(), r = []; "relativeute" === t.mode ? (n = [i[0] + o[0], i[1] + o[1]], t.endPosition = [0, 0]) : t.offset = [0, 0], Array.isArray(t.colorLine) && (t.colorLine = "rgb(" + t.colorLine[0] + "," + t.colorLine[1] + "," + t.colorLine[2] + ")"); var a = document.getElementById("labelStart" + A); a.style.cssText = "border:2px solid red; border-radius:5px; -moz-border-radius:5px; height: 4px;width: 4px;position: absolute;margin-left: -3px;margin-top: -3px;top:" + i[1] + "px;left:" + i[0] + "px;background-color:" + t.colorLine + ";", this.showPoint && t.showPoint || (a.style.display = "none"), Array.isArray(t.color) && (t.color = "rgb(" + t.color[0] + "," + t.color[1] + "," + t.color[2] + ")"); var s = document.getElementById(A); s.style.cssText = "border:2px solid " + t.colorLine + ";text-align:center;border-radius:5px;-moz-border-radius:5px;min-width: 66px;position: absolute;width:-webkit-fit-content;width: -moz-fit-content;background-color:" + t.color + ";"; var l = document.getElementById("labelTitle" + A); l.innerText = t.title, 0 > n[0] && (n[0] += 5), 0 > n[1] && (n[1] += 5), n[0] > this.viewer.domElement.offsetWidth - s.offsetWidth && (n[0] = this.viewer.domElement.offsetWidth - s.offsetWidth), n[1] > this.viewer.domElement.offsetHeight - s.offsetHeight && (n[1] = this.viewer.domElement.offsetHeight - s.offsetHeight), s.style.cssText += "left:" + n[0] + "px; top:" + n[1] + "px"; var c = l.nextElementSibling || l.nextSibling; c && s.removeChild(c), t.domElement && s.appendChild(t.domElement), t.draggable && this._enableDrag(s), n[0] > i[0] ? n[1] > i[1] ? (r[0] = n[0], r[1] = n[1]) : (r[0] = n[0], r[1] = n[1] + s.offsetHeight) : n[1] > i[1] ? (r[0] = n[0] + s.offsetWidth, r[1] = n[1]) : (r[0] = n[0] + s.offsetWidth, r[1] = n[1] + s.offsetHeight); var h = i[0] - r[0], d = i[1] - r[1], p = Math.sqrt(h * h + d * d), g = Math.atan(d / h) / Math.PI * 180; h > 0 || (d > 0 ? g += 180 : g -= 180); var u = document.getElementById("labelLine" + A); u.style.cssText = "height: 2px;position: absolute;transform-origin: left center;width:" + p + "px;-ms-transform:rotateZ(" + g + "deg);-moz-transform:rotateZ(" + g + "deg);-webkit-transform:rotateZ(" + g + "deg);-o-transform:rotateZ(" + g + "deg);transform:rotateZ(" + g + "deg);left:" + r[0] + "px;top:" + r[1] + "px;background-color:" + t.colorLine + ";", this.showLine && t.showLine || (u.style.display = "none") }, updateColor: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = 0; A.length > t; t += 1) { var i = A[t]; if (!this.marks[i]) return { id: i, data: "该标签不存在" }; Array.isArray(e) ? document.getElementById(i).style.cssText += ";background-color:rgb(" + e[0] + "," + e[1] + "," + e[2] + ")" : document.getElementById(i).style.cssText += ";background-color:" + e, this.marks[i].color = e } }, updateTitle: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = 0; A.length > t; t += 1) { var i = A[t]; if (!this.marks[i]) return { id: i, data: "该标签不存在" }; document.getElementById("labelTitle" + i).innerText = e, this.marks[i].title = e } }, updateDomElement: function (A, e) { if (this.marks[A]) { var t = document.getElementById(A), i = t.querySelector(".labelTitle"), o = i.nextElementSibling || i.nextSibling; return o && t.removeChild(o), e && t.appendChild(e), this.marks[A].domElement = e, !0 } return { id: A, data: "该标签不存在" } }, remove: function (A) { A = this.idsToArray(A); for (var e = 0; A.length > e; e += 1) { var t = A[e]; if (!this.marks[t]) return { id: t, data: "该标签不存在" }; this.viewer.domElement.removeChild(document.getElementById("label" + t)), delete this.marks[t], delete this.markState[t]; var i = this.allOids.indexOf(t); this.allOids.splice(i, 1) } }, hide: function (A) { A = this.idsToArray(A); for (var e = 0; A.length > e; e += 1) { var t = A[e]; if (!this.marks[t]) return { id: t, data: "该标签不存在" }; this.markState[t].userHide = !0, this.markState[t].outOfBoundary || (document.getElementById("labelLine" + t).style.display = "none", document.getElementById("labelStart" + t).style.display = "none", document.getElementById(t).style.display = "none") } }, show: function (A) { if (A) { A = this.idsToArray(A); for (var e = 0; A.length > e; e += 1) { if (!this.marks[o = A[e]]) return { id: o, data: "该标签不存在" }; this.markState[o].userHide = !1, this.markState[o].outOfBoundary || (this.showPoint && this.marks[o].showPoint && (document.getElementById("labelStart" + o).style.display = "block"), this.showLine && this.marks[o].showLine && (document.getElementById("labelLine" + o).style.display = "block"), document.getElementById(o).style.display = "block") } } else for (var t = this.allOids.concat(), i = 0; t.length > i; i += 1) { var o; this.markState[o = t[i]].userHide = !1, this.markState[o].outOfBoundary || (this.showPoint && this.marks[o].showPoint && (document.getElementById("labelStart" + o).style.display = "block"), this.showLine && this.marks[o].showLine && (document.getElementById("labelLine" + o).style.display = "block"), document.getElementById(o).style.display = "block") } }, isolation: function (A) { if (this.allOids.length > 0) { A = this.idsToArray(A), this.show(); for (var e = this.allOids.concat(), t = 0; A.length > t; t += 1) { var i = A[t]; if (!this.marks[i]) return { data: "mark不存在" }; for (var o = 0; e.length > o; o += 1) if (i === e[o]) { e.splice(o, 1); break } } for (var n = 0; e.length > n; n += 1) document.getElementById("labelLine" + e[n]).style.display = "none", document.getElementById("labelStart" + e[n]).style.display = "none", document.getElementById(e[n]).style.display = "none" } }, addEventListener: function (A, e, t) { document.getElementById(A).addEventListener(e, t) }, removeEventListener: function (A, e, t) { document.getElementById(A).removeEventListener(e, t) } }); var Vd = function (A) { this.defaultSettings = { id: "", URL: "", side: 2, scale: 1, width: 1, height: 1, opacity: 1, transparent: !1, alwaysVisible: !1, useImageSize: !0, faceToCamera: !1, color: [1, 1, 1], emissive: [0, 0, 0], position: [0, 0, 0], face: "z", useFaceMatrix: !0, matrix: [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1] }, this.faceMatrix = { x: [0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1], y: [1, 0, 0, 0, 0, 0, 1, 0, 0, -1, 0, 0, 0, 0, 0, 1], z: [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1] }; var e = A; "function" == typeof A.getViewerImpl && (e = A.getViewerImpl()), this.init(e), this.enabled() }; Vd.prototype = uh.extend(!0, {}, Nd.prototype, { constructor: Vd, add: function (A, e) { var t = this, i = gc({}, this.defaultSettings, A), o = this.hasTheSameId(i); if (o) return o; var n = 1, r = 1, a = (new Aa).load(i.URL, (function (A) { t.viewer.render() }), (function () {}), (function (A) { t.dispatchEvent({ type: Tc.LOAD_TEXTURE_ERROR, data: "加载材质出错" }) })); !0 === i.alwaysVisible && (i.transparent = !0); var s = new xr({ color: new LA(i.color[0], i.color[1], i.color[2]), emissive: new LA(i.emissive[0], i.emissive[1], i.emissive[2]), map: a, depthTest: !i.alwaysVisible, side: i.side, opacity: i.opacity, transparent: i.transparent }); n = i.width ? i.width : s.map.image.width, r = i.height ? i.height : s.map.image.height; var l = new Ue(new et(1, 1, 1, 1), s), c = new M; if (i.matrix && (3 === i.matrix.length ? (c.elements[12] = i.matrix[0], c.elements[13] = i.matrix[1], c.elements[14] = i.matrix[2]) : c.fromArray(i.matrix)), l.applyMatrix4(c), i.faceToCamera) { var h = new y, d = new y, p = new f; l.onBeforeRender = function () { t.viewer.camera.matrixWorld.decompose(h, p, d), l.quaternion.copy(p), l.updateMatrixWorld(!0) } } return l.scale.set(i.scale * n, i.scale * r, 1), l.updateMatrixWorld(!0), "" !== i.id ? l.key = i.id : (l.key = l.uuid, i.id = l.uuid), t.addObjectToScene(i, l), "function" == typeof e && e(l.key), l.componentKey = i.componentKey && Array.isArray(i.componentKey) ? i.componentKey : i.componentKey ? [i.componentKey] : [], l }, updateMark: function (A, e) { var t = this, i = this.findMark(A); if (i) { i.applyMatrix4((new M).getInverse(i.matrix)); var o = gc({}, t.marks[A], e), n = new M; if (o.matrix && (3 === o.matrix.length ? (n.elements[12] = o.matrix[0], n.elements[13] = o.matrix[1], n.elements[14] = o.matrix[2]) : n.fromArray(o.matrix)), i.applyMatrix4(n), o.faceToCamera) { var r = new y, a = new y, s = new f; i.onBeforeRender = function () { t.viewer.camera.matrixWorld.decompose(r, s, a), i.quaternion.copy(s), i.updateMatrixWorld(!0) } } else delete i.onBeforeRender; if (i.scale.set(o.scale * o.width, o.scale * o.height, 1), i.updateMatrixWorld(!0), i.componentKey = o.componentKey && Array.isArray(o.componentKey) ? o.componentKey : o.componentKey ? [o.componentKey] : [], t.marks[A] = o, e.URL) (new Aa).load(o.URL, (function (A) { !0 === o.alwaysVisible && (o.transparent = !0); var e = new xr({ color: new LA(o.color[0], o.color[1], o.color[2]), emissive: new LA(o.emissive[0], o.emissive[1], o.emissive[2]), map: A, depthTest: !o.alwaysVisible, side: o.side, opacity: o.opacity, transparent: o.transparent }); i.material = e })); else !0 === o.alwaysVisible && (o.transparent = !0), i.material.depthTest = !o.alwaysVisible, i.material.transparent = o.transparent, i.material.opacity = o.opacity, i.material.side = o.side, i.material.emissive = new LA(o.emissive[0], o.emissive[1], o.emissive[2]) } this.viewer.render() } }); var Gd = function (A) { this.defaultSettings = { id: "", url: "", width: 1, height: 1, scale: 1, alwaysVisible: !1, position: [0, 0, 0], componentId: "", useImageSize: !0 }; var e = A; "function" == typeof A.getViewerImpl && (e = A.getViewerImpl()), this.init(e), this.enabled() }; Gd.prototype = uh.extend(!0, {}, Nd.prototype, { constructor: Gd, add: function (A, e) { var t = this; !A.url && A.URL && (A.url = A.URL); var i = Object.assign({}, this.defaultSettings, A), o = this.hasTheSameId(i); if (o) return o; var n = 1, r = 1; (new Aa).load(i.URL || i.url, (function (A) { var o = new ro({ map: A, color: 16777215, depthTest: !i.alwaysVisible, transparent: i.alwaysVisible }); n = i.useImageSize && o.map && o.map.image && o.map.image.width ? o.map.image.width : i.width, r = i.useImageSize && o.map && o.map.image && o.map.image.width ? o.map.image.height : i.height; var a = new vo(o); a.scale.set(i.scale * n, i.scale * r, 1), i.position.isVector3 ? a.position.copy(i.position) : a.position.set(i.position[0], i.position[1], i.position[2]), a.updateMatrixWorld(!0), "" !== i.id ? a.key = i.id : (a.key = a.uuid, i.id = a.uuid), t.addObjectToScene(i, a), "function" == typeof e && e(a.key) }), (function () {}), (function (A) { t.dispatchEvent({ type: Tc.LOAD_TEXTURE_ERROR, data: "加载材质出错" }) })) }, updateMark: function (A, e, t) { var i = this, o = this.findMark(A); if (o) { var n = Object.assign({}, i.marks[A], e), r = 1, a = 1; (new Aa).load(n.URL || n.url, (function (e) { var s = new ro({ map: e, color: 16777215, depthTest: !n.alwaysVisible }); r = n.useImageSize && s.map && s.map.image && s.map.image.width ? s.map.image.width : n.width, a = n.useImageSize && s.map && s.map.image && s.map.image.width ? s.map.image.height : n.height, o.material = s, o.scale.set(n.scale * r, n.scale * a, 1), n.position.isVector3 ? o.position.copy(n.position) : o.position.set(n.position[0], n.position[1], n.position[2]), o.updateMatrixWorld(), i.viewer.render(), i.marks[A] = n, "function" == typeof t && t(A) }), (function () {}), (function (A) { i.dispatchEvent({ type: Tc.LOAD_TEXTURE_ERROR, data: "加载材质出错" }) })) } }, resize: function (A, e, t) { if (null == A) return { data: "未选中mark" }; if (!e || !t) return { data: "未指定尺寸" }; Array.isArray(A) || (A = [A]); for (var i = null, o = 0; A.length > o; o += 1) (i = this.findMark(A[o])) && (i.scale.set(e, t, 1), i.updateMatrixWorld(), this.viewer.render()) } }); var Pd = { front: "", back: "", left: "", right: "", top: "", bottom: "", add: "", plus: "", E: "", Q: "", downArrow: "", upArrow: "", mouseLeft: "", sxzy: "", wasd: "", fire: "", in: "", info: "", wall: "", window: "", kitchen: "", livingRoom: "", skyBoxLeft: "", skyBoxRight: "", skyBoxBack: "", skyBoxFront: "", skyBoxUp: "", skyBoxDown: "" }, qd = new bh, jd = function () { var A = "Success", e = "", t = "", i = !1, o = 0, n = null; return function (r, a, s) { return 5 === r ? document.querySelector(".loading").classList.add("hide") : A = r, "error" === r && (i = !1), void 0 !== a && (e = a, void 0 !== s && (i = s)), 5e3 > (new Date).getTime() - o ? e !== t && (n = qd.notify(A, { size: "mini", rounded: !0, position: "center top", sound: !1, delay: i, msg: e }), o = (new Date).getTime(), n.$el.childNodes[1].childNodes[0].title = e) : (n = qd.notify(A, { size: "mini", rounded: !0, position: "center top", sound: !1, delay: i, msg: e }), o = (new Date).getTime(), n.$el.childNodes[1].childNodes[0].title = e), t = e, n } }(), Hd = function (A, e) { var t = A.toolId, i = A.Flag, o = A.viewer, n = e.toolbarTop, r = function (A) { var e = o.viewerImpl.getBoundingBoxByIds([A]); return e.max.distanceTo(e.min) / 10 }, a = this; this.deleteListener = null, this.addListener = null, this.updateListener = null, this.imageSize = 100; var s = qd.window({ title: "标签", id: "markWindow" + t, width: 356, height: 848, closeOnEsc: !1, closeButton: !0, afterWindowHide: function () { var A = document.getElementById("mark" + t); i.mark = !1, A && (A.style.backgroundColor = "", A.querySelector(".yj-icon").className = "yj-icon label-icon"), document.getElementById("markColorModal" + t) && (document.getElementById("markColorModal" + t).style.display = "none"), o.viewerImpl.cameraControl.dispatchEvent(Rc.ON_CAMERA_CHANGE) }, content: '
标签类型:
标签样式:
标题:
背景色:
标签位置(点击模型获取):
构件:
备注栏数:
' }); s.$el.addClass("markWindow"); var l = function (A) { if (A.intersectInfo) { var e = "", i = function A(e) { if (e.intersectInfo) { o.viewerImpl.modelManager.removeEventListener(Rc.ON_CLICK_PICK, A); var t = o.viewerImpl.camera, i = e.intersectInfo.point.clone(), n = t.position.clone(), r = i.clone().sub(n), a = r.length(), s = o.viewerImpl.getBoundingBoxByIds([e.intersectInfo.selectedObjectId]), l = new CA(n, i.sub(n).normalize()).intersectBox(s), c = Math.min(s.max.x - l.x, l.x - s.min.x), h = Math.min(s.max.y - l.y, l.y - s.min.y), d = Math.min(s.max.z - l.z, l.z - s.min.z), p = Math.min(c, h, d); return { point: e.intersectInfo.point, distance: a, face: p === c ? "x" : p === h ? "y" : "z", eye: r, box: s } } }(A), n = document.getElementById("updateMark" + t); xh.hasClass(n, "hide") ? (e = s.$el.querySelector(".mark .first-floor select").value, s.$el.querySelector(".mark ." + e + " .startX ").value = A.intersectInfo.point.x, s.$el.querySelector(".mark ." + e + " .startY ").value = A.intersectInfo.point.y, s.$el.querySelector(".mark ." + e + " .startZ ").value = A.intersectInfo.point.z, s.$el.querySelector(".mark ." + e + " .component ").value = A.intersectInfo.selectedObjectId, "plane" === e && (s.$el.querySelector(".mark ." + e + " .face ").value = i.face)) : (e = "block" === n.querySelector(".dom").style.display ? "dom" : "block" === n.querySelector(".sprite").style.display ? "sprite" : "plane", n.querySelector("." + e + " .startX ").value = A.intersectInfo.point.x, n.querySelector("." + e + " .startY ").value = A.intersectInfo.point.y, n.querySelector("." + e + " .startZ ").value = A.intersectInfo.point.z, n.querySelector("." + e + " .component ").value = A.intersectInfo.selectedObjectId, "plane" === e && (n.querySelector("." + e + " .face ").value = i.face)) } }, c = new Od(o.viewerImpl), h = new Gd(o.viewerImpl), d = new Vd(o.viewerImpl), p = s.$el.querySelector(".mark .dom .markColorInput"), g = new Hh(p, { hasOpacity: !1 }); p.value = "rgb(255,0,0)"; var u = g.element; u.id = "markColorModal" + t, u.className = "markColorModal", document.getElementById("mark" + t).parentNode.appendChild(u); var f = qd.prompt({ title: "修改标签", id: "updateMark" + t, width: 356, height: 400, closeOnEsc: !1, closeButton: !1, buttons: { ok: { class: "lobibox-btn lobibox-btn-default", text: "确定", closeOnClick: !0 }, cancel: { class: "lobibox-btn lobibox-btn-cancel", text: "取消", closeOnClick: !0 } }, content: '
标签id:
标题:
背景色:
标签位置(点击模型获取):
构件:
备注栏数:
标签id:
图标选择:
标签大小:
标签位置(点击模型获取):
X:
Y:
Z:
构件:
标签id:
图标选择:
标签大小:
标签位置(点击模型获取):
X:
Y:
Z:
构件:
标签所在面:
' }); f.setPosition({ left: o.viewportDiv.offsetWidth - f.width - 5, top: 60 }), f.promptHide(), f.$el.addClass("updateMark"), u.querySelector(".btn-yes").addEventListener("click", (function () { var A = document.getElementById("updateMark" + t); xh.hasClass(A, "hide") ? s.$el.querySelector(".mark .dom .colorRect").style.backgroundColor = p.value : f.$el.querySelector(".updateMarkPrompt .dom .colorRect").style.backgroundColor = p.value })); var m = qd.confirm({ title: "请再次确认:", id: "confirm-mark" + t, width: 356, height: 87, closeOnEsc: !1, closeButton: !1, iconClass: !1, msg: "是否要删除此标签?" }); m.setPosition({ left: (qd.viewport.offsetWidth - m.$options.width) / 2, top: 5 }), m.confirmHide(), xh.addEventListener(n.querySelector("#mark" + t), "click", (function () { i.mark ? (s.windowHide(), o.viewerImpl.modelManager.removeEventListener(Rc.ON_CLICK_PICK, l), f.promptHide(), u.style.display = "none") : (document.getElementById("mark" + t).querySelector(".yj-icon").className = "yj-icon label-icon active", i.mark = !i.mark, s.windowShow(), o.viewerImpl.modelManager.addEventListener(Rc.ON_CLICK_PICK, l)) })); for (var C = s.$el.querySelectorAll(".lobibox .lobibox-body .showColorModal"), v = 0; C.length > v; v += 1) C[v].addEventListener("click", (function () { u.style.display = "none" === u.style.display ? "block" : "none" })); for (var I = f.$el.querySelectorAll(".lobibox .lobibox-body .showColorModal"), E = 0; I.length > E; E += 1) I[E].addEventListener("click", (function () { u.style.display = "none" === u.style.display ? "block" : "none" })); for (var B = s.$el.querySelectorAll(".lobibox .lobibox-body .picture .chosed-pic"), x = 0; B.length > x; x += 1) B[x].addEventListener("click", (function () { var A = this.parentElement.lastChild; A.style.display = "none" === A.style.display ? "block" : "none" })); for (var S = s.$el.querySelectorAll(".lobibox .lobibox-body .picture .file-choose span"), w = 0; S.length > w; w += 1) S[w].addEventListener("click", (function () { this.parentElement.querySelector("input").click() })); for (var M = s.$el.querySelectorAll(".lobibox .lobibox-body .picture .pic-list li"), b = 0; M.length > b; b += 1) M[b].addEventListener("click", (function () { var A = this.parentElement.parentElement.querySelector(".chosed-pic"), e = this.querySelector("img").getAttribute("src"); A.dataset.chosedUrl = e, A.querySelector("img").setAttribute("src", e), A.parentElement.lastChild.style.display = "none" })); s.$el.querySelector(".mark .first-floor select").addEventListener("change", (function () { for (var A = this.value, e = s.$el.querySelectorAll(".mark .second-floor"), t = 0; e.length > t; t += 1) e[t].style.display = "none"; s.$el.querySelector(".mark ." + A).style.display = "block", u.style.display = "none" })), s.$el.querySelector(".mark .third-floor .showList").addEventListener("click", (function () { var A = s.$el.querySelector(".mark .forth-floor"); "none" === A.style.display ? (A.style.display = "block", this.innerHTML = "隐藏标签列表") : (A.style.display = "none", this.innerHTML = "展示标签列表") })), s.$el.querySelector(".mark .third-floor .addMark").addEventListener("click", (function () { u.style.display = "none"; var A = s.$el.querySelector(".mark .first-floor select").value, e = [], t = null; if ("dom" === A) { var i = s.$el.querySelector(".mark .dom .title ").value; "" === i && (i = "标签"); var n = Kd.getColorArrayFromRGBA(s.$el.querySelector(".mark .dom .colorRect").style.backgroundColor), l = parseInt(s.$el.querySelector(".mark .dom .text-tab ").value, 0), c = null; if (l > 10) return void jd("warning", "备注栏不可超过10个", 5e3); if (l > 0) { c = document.createElement("div"); for (var h = 0; l > h; h += 1) c.innerHTML += '' } var d = s.$el.querySelector(".mark .dom .component ").value; if (e[0] = Number(s.$el.querySelector(".mark .dom .startX ").value), e[1] = Number(s.$el.querySelector(".mark .dom .startY ").value), e[2] = Number(s.$el.querySelector(".mark .dom .startZ ").value), isNaN(e[0]) || isNaN(e[1]) || isNaN(e[2])) return void jd("warning", "标签位置错误,无法新建标签", 5e3); var p = o.getScreenCoordFromSceneCoord(e); t = { title: i, color: n, startPosition: [e[0], e[1], e[2]], endPosition: [p[0] + 100, p[1] - 200], domElement: c, componentId: d } } else if ("sprite" === A) { try { var g = s.$el.querySelector(".mark .sprite .chosed-pic").dataset.chosedUrl } catch (A) { return void jd("warning", "未选择标签图标", 5e3) } var f = Number(s.$el.querySelector(".mark .sprite .size ").value); f && f >= 0 || (f = 1); var m = s.$el.querySelector(".mark .sprite .component ").value; if (m && (a.imageSize = r(m)), e[0] = Number(s.$el.querySelector(".mark .sprite .startX ").value), e[1] = Number(s.$el.querySelector(".mark .sprite .startY ").value), e[2] = Number(s.$el.querySelector(".mark .sprite .startZ ").value), isNaN(e[0]) || isNaN(e[1]) || isNaN(e[2])) return void jd("warning", "标签位置错误,无法新建标签", 5e3); t = { url: g, scale: f, useImageSize: !1, width: a.imageSize, height: a.imageSize, position: e, alwaysVisible: !0, componentId: m } } else { try { g = s.$el.querySelector(".mark .plane .chosed-pic").dataset.chosedUrl } catch (A) { return void a.message("warning", "未选择标签图标", 5e3) } var C = Number(s.$el.querySelector(".mark .plane .size ").value); C && C >= 0 || (C = 1); var y = s.$el.querySelector(".mark .plane .component ").value; if (y && (a.imageSize = r(y)), e[0] = Number(s.$el.querySelector(".mark .plane .startX ").value), e[1] = Number(s.$el.querySelector(".mark .plane .startY ").value), e[2] = Number(s.$el.querySelector(".mark .plane .startZ ").value), isNaN(e[0]) || isNaN(e[1]) || isNaN(e[2])) return void a.message("warning", "标签位置错误,无法新建标签", 5e3); var v = s.$el.querySelector(".mark .plane .face").value; v || (v = "x"), t = { URL: g, scale: C, useImageSize: !1, width: a.imageSize, height: a.imageSize, position: e, alwaysVisible: !0, componentId: y, transparent: !0, face: v, useFaceMatrix: !0 } } "function" == typeof a.addListener ? a.addListener(A, t, (function (e, i) { e && a.add(A, i || t) })) : a.add(A, t) })), s.$el.querySelector(".forth-floor").addEventListener("click", (function (A) { switch (A.target.className) { case "deleteMark": a.markDelete(A); break; case "updateMark": a.markUpdate(A); break; case "info": if ("聚焦" === A.target.innerText) { var e = "", i = xh.closest(A.target, "tr"), n = i.querySelector(".id").innerHTML, r = xh.closest(i, "table").className; if ("dom" === r ? e = c.marks[n].componentId : "sprite" === r ? e = h.marks[n].componentId : "plane" === r && (e = d.marks[n].componentId), !e) return void jd("warning", "该标签没有关联构件!", 5e3); for (var s = document.querySelectorAll("#markWindow" + t + " .forth-floor .info"), l = 0; s.length > l; l += 1) s[l].innerText = "聚焦"; A.target.innerText = "失焦", function (A) { var e = o.viewerImpl.getBoundingBoxByIds([A]); if (e.min.x !== -1 / 0 && e.min.x !== 1 / 0) { var t = e.getCenter(new y), i = o.viewerImpl.camera.getWorldDirection(), n = e.max.distanceTo(e.min), r = new y; r.copy(i), r.setLength(n); var a = new y; a.subVectors(t, r), o.flyTo({ position: a, target: t, up: o.viewerImpl.camera.up }, (function () { o.viewerImpl.cameraControl.dispatchEvent(Rc.ON_CAMERA_CHANGE) })), o.highlightComponentsByKey([A]), o.closeTransparentComponentsByKey([A]), o.transparentOtherComponentsByKey([A]) } else jd("warning", "该构件不存在!", 5e3) }(e) } else A.target.innerText = "聚焦", o.clearTransparentList(), o.clearHighlightList(); break; default: if (xh.hasClass(A.target, "hideOrShow")) { var p = xh.closest(A.target, "tr"), g = p.querySelector(".id").innerHTML, u = xh.closest(p, "table").className, f = null; f = "dom" === u ? c : "sprite" === u ? h : c, xh.hasClass(A.target, "hideMark") ? (f.hide(g), A.target.classList.remove("hideMark"), A.target.classList.add("showMark"), A.target.innerHTML = "显示") : (f.show(g), A.target.classList.remove("showMark"), A.target.classList.add("hideMark"), A.target.innerHTML = "隐藏") } } })), s.setPosition({ left: "", right: 5, top: 60 }), s.windowHide(), this.add = function (A, e) { switch (A) { case "dom": this.addDOMMark(e); break; case "sprite": this.addSpriteMark(e); break; case "plane": this.addPlaneMark(e) } }, this.addDOMMark = function (A) { c.add(A, (function (e) { s.$el.querySelector(".mark .forth-floor .dom tbody").innerHTML += "' + e + '' + A.title + '' })) }, this.addSpriteMark = function (A) { h.add(A, (function (e) { s.$el.querySelector(".mark .forth-floor .sprite tbody").innerHTML += "' + e + '' })) }, this.addPlaneMark = function (A) { d.add(A, (function (e) { s.$el.querySelector(".mark .forth-floor .plane tbody").innerHTML += "' + e + '' })) }, this.markDelete = function (A) { var e = xh.closest(A.target, "tr"), i = e.querySelector(".id").innerHTML, o = xh.closest(e, "table").className; m.confirmShow(); var n = ""; "dom" === o ? n = "文字标签" : "sprite" === o ? n = "精灵标签" : "plane" === o && (n = "平面标签"), document.querySelector("#confirm-mark" + t + " .lobibox-body-text").innerHTML = "是否要删除编号为[" + i + "]的" + n + "?", document.querySelector("#confirm-mark" + t + " .lobibox-btn-yes").onclick = function () { "function" == typeof a.deleteListener ? a.deleteListener(o, i, (function (A) { A && a.delete(o, i) })) : a.delete(o, i), m.confirmHide() }, document.querySelector("#confirm-mark" + t + " .lobibox-btn-no").onclick = function () { m.confirmHide() } }, this.delete = function (A, e) { var t = null; if ("dom" === A) { if (t = c) { t.remove(e); var i = s.$el.querySelector(".mark .forth-floor .dom tbody"), o = document.querySelector("tr[markId='" + e + "']"); i.removeChild(o) } } else if ("sprite" === A) { if (t = h) { t.remove(e); var n = s.$el.querySelector(".mark .forth-floor .sprite tbody"), r = document.querySelector("tr[markId='" + e + "']"); n.removeChild(r) } } else if ("plane" === A && (t = d)) { t.remove(e); var a = s.$el.querySelector(".mark .forth-floor .plane tbody"), l = document.querySelector("tr[markId='" + e + "']"); a.removeChild(l) } }, this.markUpdate = function (A) { var e = xh.closest(A.target, "tr"), i = e.querySelector(".id").innerHTML, o = xh.closest(e, "table").className; f.promptShow(); var n = document.getElementById("updateMark" + t); if (n.style.cssText += "z-index:" + (Number(document.getElementById("markWindow" + t).style.zIndex) + 1), "dom" === o) { for (var l = n.querySelectorAll(".sprite , .plane"), p = 0; l.length > p; p += 1) l[p].style.display = "none"; n.querySelector(".dom ").style.display = "block", n.querySelector(".dom .markId").value = i, n.querySelector(".dom .title").value = c.marks[i].title, n.querySelector(".dom .startX").value = c.marks[i].startPosition[0], n.querySelector(".dom .startY").value = c.marks[i].startPosition[1], n.querySelector(".dom .startZ").value = c.marks[i].startPosition[2], n.querySelector(".dom .component").value = c.marks[i].componentId, c.marks[i].domElement && (n.querySelector(".dom .text-tab").value = c.marks[i].domElement.querySelectorAll("input").length), n.querySelector(".dom .colorRect").style.backgroundColor = Kd.getRGBAFromColorArray(c.marks[i].color), n.querySelector(".lobibox-btn-default").onclick = function () { var A = n.querySelector(".dom .title").value; "" === A && (A = "标签"); var e = Kd.getColorArrayFromRGBA(n.querySelector(".dom .colorRect").style.backgroundColor), t = []; if (t[0] = n.querySelector(".dom .startX").value, t[1] = n.querySelector(".dom .startY").value, t[2] = n.querySelector(".dom .startZ").value, isNaN(t[0]) || isNaN(t[1]) || isNaN(t[2])) jd("warning", "标签位置无效,无法更新标签", 5e3); else { var r = parseInt(n.querySelector(".dom .text-tab ").value, 0), s = null; if (10 < r) jd("warning", "备注栏不可超过10个", 5e3); else { if (r > 0) { s = document.createElement("div"); for (var l = 0; r > l; l += 1) s.innerHTML += '' } var c = { title: A, color: e, startPosition: t, domElement: s, componentId: n.querySelector(".dom .component").value }; "function" == typeof a.updateListener ? a.updateListener(o, i, c, (function (A, e) { A && a.update(o, i, e || c) })) : a.update(o, i, c), f.promptHide(), u.style.display = "none" } } } } else if ("sprite" === o) { for (var g = n.querySelectorAll(".dom , .plane"), m = 0; g.length > m; m += 1) g[m].style.display = "none"; n.querySelector(".sprite ").style.display = "block", n.querySelector(".sprite .markId").value = i, n.querySelector(".sprite .picture .chosed-pic").dataset.chosedUrl = h.marks[i].url, n.querySelector(".sprite .picture .chosed-pic img").setAttribute("src", h.marks[i].url), n.querySelector(".sprite .size").value = h.marks[i].scale, n.querySelector(".sprite .startX").value = h.marks[i].position[0], n.querySelector(".sprite .startY").value = h.marks[i].position[1], n.querySelector(".sprite .startZ").value = h.marks[i].position[2], n.querySelector(".sprite .component").value = h.marks[i].componentId, n.querySelector(".lobibox-btn-default").onclick = function () { try { var A = n.querySelector(".sprite .picture .chosed-pic").dataset.chosedUrl } catch (A) { return void jd("warning", "未选择标签图标", 5e3) } var e = n.querySelector(".sprite .size").value; e && e >= 0 || (e = 1); var t = []; if (t[0] = Number(n.querySelector(".sprite .startX ").value), t[1] = Number(n.querySelector(".sprite .startY ").value), t[2] = Number(n.querySelector(" .sprite .startZ ").value), isNaN(t[0]) || isNaN(t[1]) || isNaN(t[2])) jd("warning", "标签位置无效,无法更新标签", 5e3); else { var s = n.querySelector(".sprite .component").value; s && (a.imageSize = r(s)); var l = { url: A, scale: e, position: t, useImageSize: !1, width: a.imageSize, height: a.imageSize, alwaysVisible: !0, componentId: s }; "function" == typeof a.updateListener ? a.updateListener(o, i, l, (function (A, e) { A && a.update(o, i, e || l) })) : a.update(o, i, l), f.promptHide() } } } else if ("plane" === o) { for (var C = n.querySelectorAll(".dom , .sprite"), y = 0; C.length > y; y += 1) C[y].style.display = "none"; n.querySelector(".plane ").style.display = "block", n.querySelector(".plane .markId").value = i, n.querySelector(".plane .picture .chosed-pic").dataset.chosedUrl = d.marks[i].URL, n.querySelector(".plane .picture .chosed-pic img").setAttribute("src", d.marks[i].URL), n.querySelector(".plane .size").value = d.marks[i].scale, n.querySelector(".plane .startX").value = d.marks[i].position[0], n.querySelector(".plane .startY").value = d.marks[i].position[1], n.querySelector(".plane .startZ").value = d.marks[i].position[2], n.querySelector(".plane .component").value = d.marks[i].componentId, n.querySelector(".plane .face").value = d.marks[i].face, n.querySelector(".lobibox-btn-default").onclick = function () { try { var A = n.querySelector(".plane .picture .chosed-pic").dataset.chosedUrl } catch (A) { return void jd("warning", "未选择标签图标", 5e3) } var e = n.querySelector(".plane .size").value; e && e >= 0 || (e = 1); var t = []; if (t[0] = Number(n.querySelector(".plane .startX ").value), t[1] = Number(n.querySelector(".plane .startY ").value), t[2] = Number(n.querySelector(" .plane .startZ ").value), isNaN(t[0]) || isNaN(t[1]) || isNaN(t[2])) jd("warning", "标签位置无效,无法更新标签", 5e3); else { var l = n.querySelector(".plane .component").value; l && (a.imageSize = r(l)); var c = s.$el.querySelector(".updateMarkPrompt .plane .face").value; c || (c = "x"); var h = { URL: A, scale: e, position: t, useImageSize: !1, width: a.imageSize, height: a.imageSize, alwaysVisible: !0, face: c, componentId: l }; "function" == typeof a.updateListener ? a.updateListener(o, i, h, (function (A, e) { A && a.update(o, i, e || h) })) : a.update(o, i, h), f.promptHide() } } } n.querySelector(".lobibox-btn-cancel").onclick = function () { f.promptHide(), u.style.display = "none" } }, this.update = function (A, e, t) { "dom" === A ? a.updateDOMMark(e, t) : "sprite" === A ? a.updateSpriteMark(e, t) : "plane" === A && a.updatePlaneMark(e, t) }, this.hide = function (A, e) { var t = document.querySelector("tr[markId='" + e + "']"); if (t) { var i = t.querySelector(".hideOrShow"); i.classList.remove("hideMark"), i.classList.add("showMark"), i.innerHTML = "显示" } "dom" === A ? c.hide(e) : "sprite" === A && h.hide(e) }, this.show = function (A, e) { var t = document.querySelector("tr[markId='" + e + "']"); if (t) { var i = t.querySelector(".hideOrShow"); i.classList.remove("showMark"), i.classList.add("hideMark"), i.innerHTML = "显示" } "dom" === A ? c.show(e) : "sprite" === A && h.show(e) }, this.updateDOMMark = function (A, e) { var t = document.querySelector("tr[markId='" + A + "']"); t && (t.querySelector(".markTitle").innerHTML = e.title, t.querySelector(".markTitle").setAttribute("title", e.title)), c.updateMark(A, e) }, this.updateSpriteMark = function (A, e) { var t = document.querySelector("tr[markId='" + A + "']"); t && t.querySelector(".markImg").setAttribute("src", e.url), h.updateMark(A, e) }, this.updatePlaneMark = function (A, e) { var t = document.querySelector("tr[markId='" + A + "']"); t && t.querySelector(".markImg").setAttribute("src", e.URL), d.updateMark(A, e) }, this.getDOMMark = function () { return c }, this.getSpriteMark = function () { return h }, this.getPlaneMark = function () { return d } }, Yd = function (A, e, t, i, o) { var n = A.toolId, r = A.Flag, s = A.viewer; function l(A, e) { A.length > e && s.flyTo(A[e], (function () { l(A, e += 1) })) } o.querySelector("#collision" + n).addEventListener("click", (function (A) { "walk" === s.viewerImpl.controlManager.control.name && (vc.EnableHitDetection = !vc.EnableHitDetection), s.viewerImpl.controlManager.setFocuse() })), o.querySelector("#gravity" + n).addEventListener("click", (function () { "walk" === s.viewerImpl.controlManager.control.name && (vc.WalkingWithGravity = !vc.WalkingWithGravity), s.viewerImpl.controlManager.setFocuse() })); var c = {}, h = [], d = qd.window({ title: "漫游路径", id: "pathRoam" + n, width: 356, height: 848, closeOnEsc: !1, closeButton: !0, afterWindowHide: function () { var A = document.getElementById("roam" + n); r.roam = !1, A && (A.style.backgroundColor = "", A.querySelector(".yj-icon").className = "yj-icon roam-icon") }, content: '
路径列表:
' }); d.$el.addClass("pathRoam"); var p = null; t.addEventListener("click", (function () { if (r.roam) return p && p.destroy(), document.getElementById("instructions" + n) && s.viewerImpl.domElement.removeChild(document.getElementById("instructions" + n)), o.style.display = "none", this.style.backgroundColor = "", this.querySelector(".yj-icon").className = "yj-icon roam-icon", r.roam = !1, s.viewerImpl.controlManager.setControlMode(s.viewerImpl, "pick"), void(d && d.windowHide && d.windowHide()); r.measurement && (document.getElementById("measurement" + n).style.backgroundColor = "", document.getElementById("measurement" + n).querySelector(".yj-icon").className = "yj-icon measurement-icon", jd("info", "漫游模式下将关闭测量功能", 2e3), e.exitMeasure && e.exitMeasure()), r.sectioning && (document.getElementById("sectioning" + n).style.backgroundColor = "", document.getElementById("sectioning" + n).querySelector(".yj-icon").className = "yj-icon sectioning-icon", jd("info", "漫游模式下将关闭剖切功能", 2e3), s.viewerImpl.controlManager.disableTool(Pc.CLIP_BY_BOX), r.sectioning = !1), r.multiple && (document.getElementById("multiple" + n).style.backgroundColor = "", document.getElementById("multiple" + n).querySelector(".yj-icon").className = "yj-icon multiple-icon", jd("info", "漫游模式下将关闭框选功能", 2e3), s.viewerImpl.controlManager.disableTool(Pc.PICK_BY_RECT), r.multiple = !1), s.render(), this.style.backgroundColor = "#1f89de", this.querySelector(".yj-icon").className = "yj-icon roam-icon active", r.roam = !r.roam, p = qd.prompt({ title: "漫游", id: "roamChoose" + n, width: 356, height: 87, closeOnEsc: !1, closeButton: !1, afterWindowHide: function () { var A = document.getElementById("roam" + n); r.roam = !1, A && (A.style.backgroundColor = ""), p.destroy(), p = null }, buttons: { ok: { class: "lobibox-btn lobibox-btn-default", text: "自由漫游", closeOnClick: !0 }, cancel: { class: "lobibox-btn lobibox-btn-cancel", text: "路径漫游", closeOnClick: !0 } } }); var A = document.getElementById("roamChoose" + n); A.querySelector(".lobibox-body").style.display = "none", A.querySelector(".lobibox-btn-default").addEventListener("click", (function () { p.destroy(), p = null; var A = document.createElement("div"); A.id = "instructions" + n, A.style.cssText += "position:absolute;left:0;top:0;width:100%;height:100%;background:rgba(80,80,80,0.3);margin:0;padding:0;", A.innerHTML = '
点击进入沉浸式浏览
移动方向
高度
视角
速度
' + A + '', h = [], d.$el.querySelector(".path-roaming .second-floor .viewList .name").value = "", d.$el.querySelector(".path-roaming .second-floor .viewList table tbody").innerHTML = "" } })), d.$el.querySelector(".path-roaming .second-floor .saveView").addEventListener("click", (function () { var A = {}; A.position = s.viewerImpl.camera.position.clone(), A.target = s.viewerImpl.camera.target.clone(), A.up = { x: 0, y: 0, z: 1 }, h.push(A); var e = h.length; d.$el.querySelector(".path-roaming .second-floor .viewList table tbody").innerHTML += "视角' + e + '' })); var g = qd.confirm({ title: "请再次确认:", id: "confirm-path" + n, width: 356, height: 87, closeOnEsc: !1, closeButton: !1, iconClass: !1, msg: "是否要删除此视角?" }); return g.setPosition({ left: (qd.viewport.offsetWidth - g.$options.width) / 2, top: 5 }), g.confirmHide(), d.$el.addEventListener("click", (function (A) { if ("deleteView" === A.target.className) { var e = (r = xh.closest(A.target, "tr")).dataset.index; g.confirmShow(), document.querySelector("#confirm-path" + n + " .lobibox-body-text").innerHTML = "是否要删除编号为[" + (Number(e) + 1) + "]的视角?", document.querySelector("#confirm-path" + n + " .lobibox-btn-yes").onclick = function () { h.splice(e, 1), d.$el.querySelector(".path-roaming .second-floor .viewList tbody").removeChild(r); for (var A = d.$el.querySelectorAll(".path-roaming .second-floor .viewList tbody tr"), t = 0; A.length > t; t += 1) A[t].dataset.index = t, A[t].querySelector(".name").innerHTML = "视角" + (t + 1); g.confirmHide() }, document.querySelector("#confirm-path" + n + " .lobibox-btn-no").onclick = function () { g.confirmHide() } } else if ("updateView" === A.target.className) { var t = xh.closest(A.target, "tr").dataset.index; g.confirmShow(), document.querySelector("#confirm-path" + n + " .lobibox-body-text").innerHTML = "是否要修改编号为[" + (Number(t) + 1) + "]的视角为当前视角?", document.querySelector("#confirm-path" + n + " .lobibox-btn-yes").onclick = function () { var A = {}; A.position = s.viewerImpl.camera.position.clone(), A.target = s.viewerImpl.camera.target.clone(), A.up = { x: 0, y: 0, z: 1 }, h[t] = A, g.confirmHide() }, document.querySelector("#confirm-path" + n + " .lobibox-btn-no").onclick = function () { g.confirmHide() } } else if ("checkView" === A.target.className) { var i = xh.closest(A.target, "tr").dataset.index; s.flyTo(h[i]) } else if ("roamPath" === A.target.className) { var o = xh.closest(A.target, "tr").dataset.key; l(c[o].camera, 0) } else if ("deletePath" === A.target.className) { var r, a = (r = xh.closest(A.target, "tr")).dataset.key; g.confirmShow(), document.querySelector("#confirm-path" + n + " .lobibox-body-text").innerHTML = "是否要删除名称为[" + c[a].name + "]的路径?", document.querySelector("#confirm-path" + n + " .lobibox-btn-yes").onclick = function () { d.$el.querySelector(".path-roaming .pathList tbody").removeChild(r), delete c[a], g.confirmHide() }, document.querySelector("#confirm-path" + n + " .lobibox-btn-no").onclick = function () { g.confirmHide() } } })), d }, Wd = function (A, e, t) { var i = this; this.lobibox = new bh, A ? (this.element = document.getElementById(A), this.lobibox.viewport = document.querySelector("#" + A)) : this.element = document, this.change = !1; var o = function () { this.storage = null }; o.prototype = { init: function () { this.storage = function () { var A = !1; return "object" === lc(window.localStorage) ? A = localStorage : "object" === lc(window.globalStorage) && (A = window.globalStorage), A }() }, getStorage: function () { return this.storage }, save: function (A, e) { var t = this.storage, i = !1; return !1 !== t && (i = t.setItem(A, e)), i }, load: function (A) { var e = this.storage, t = !1; return !1 !== e && (t = e.getItem(A)), t } }, i.model = i.model || {}, i.model.StorageModel = o; ! function () { var A, e, t, o, n, r, a; (n = function () { this.name = "Mouse", this.option = {}, this.mouseShape = null, this.init = function (A, e) { this.setOption({ lineWidth: 1, strokeStyle: A.strokeStyle, radius: Math.ceil(A.lineWidth / 2), opacity: 100 }), this.setPoints(e), this.setMouseShape(new i.model.shapeModel.CircleStroke), this.initMouseShape(), this.setImage() }, this.paint = function (A) { this.getMouseShape().paint(A) } }).prototype = { getName: function () { return this.name }, setOption: function (A) { return "object" === lc(A) ? (uh.extend(!0, this.option, A), this.getOption()) : null }, getOption: function () { return uh.extend(!0, {}, this.option) }, getMouseShape: function () { return this.mouseShape }, setMouseShape: function (A) { return this.mouseShape = A, A }, setPoints: function (A) { this.setOption(A) }, initMouseShape: function () { this.getMouseShape().init(this.getOption()) }, setImage: function () { var A = this.getName(); return [].map.call(document.querySelectorAll("#canvas-mouse"), (function (e, t) { e.setAttribute("data-mouse", A) })), !0 } }, (A = function () { this.name = "Cross", this.init = function (A, e) { var t = this.getName(); this.setOption({ length: 10, lineHeight: 1, opacity: 100, strokeStyle: A.strokeStyle, lineJoin: A.lineJoin, lineCap: A.lineCap, shadowOffsetX: A.shadowOffsetX, shadowOffsetY: A.shadowOffsetY, shadowBlur: A.shadowBlur, shadowColor: A.shadowColor }), this.setPoints(e), this.setMouseShape(new i.model.shapeModel[t]), this.initMouseShape(), this.setImage() }, this.paint = function (A) { this.getMouseShape().paint(A) } }).prototype = new n, (r = function () { this.name = "Pen" }).prototype = new n, (e = function () { this.name = "Eraser", this.init = function (A, e) { this.setOption({ strokeStyle: "#000", opacity: A.opacity, radius: Math.ceil(A.lineWidth / 2, 10), lineJoin: A.lineJoin, lineCap: A.lineCap, shadowOffsetX: A.shadowOffsetX, shadowOffsetY: A.shadowOffsetY, shadowBlur: A.shadowBlur, shadowColor: A.shadowColor }), this.setPoints(e), this.setMouseShape(new i.model.shapeModel.CircleStroke), this.initMouseShape(), this.setImage() }, this.paint = function (A) { this.getMouseShape().paint(A) } }).prototype = new n, (a = function () { this.name = "Text", this.init = function (A, e) { this.setImage() }, this.paint = function (A) {} }).prototype = new n, (o = function () { this.name = "FloodFill", this.init = function (A, e) { this.setOption({ strokeStyle: "#000", opacity: 90, radius: Math.ceil(A.lineWidth / 2, 10) }), this.setPoints(e), this.setMouseShape(new i.model.shapeModel.CircleStroke), this.initMouseShape(), this.setImage() }, this.paint = function (A) { this.getMouseShape().paint(A) } }).prototype = new n, (t = function () { this.name = "EyeDropper", this.init = function (A, e) { this.setOption({ strokeStyle: "#000", opacity: 90, radius: Math.ceil(A.lineWidth / 2, 10) }), this.setPoints(e), this.setMouseShape(new i.model.shapeModel.CircleStroke), this.initMouseShape(), this.setImage() }, this.paint = function (A) { this.getMouseShape().paint(A) } }).prototype = new n, i.model = i.model || {}, i.model.mouseModel = i.model.mouseModel || {}, i.model.mouseModel.Mouse = n, i.model.mouseModel.Cross = A, i.model.mouseModel.Pen = r, i.model.mouseModel.Eraser = e, i.model.mouseModel.Text = a, i.model.mouseModel.FloodFill = o, i.model.mouseModel.EyeDropper = t }(); var n = { list: [], add: function (A) { return this.list.push({ x: Math.round(A.x), y: Math.round(A.y) }), this.list }, getStart: function () { return this.list[0] }, getEnd: function () { return this.list[this.list.length - 1] }, getList: function () { return this.list }, init: function () { return this.list = [], this.list } }; i.model = i.model || {}, i.model.PointList = n; (function () { var A, e, t, o, n, r, a, s, l, c, h, d, p, g, u, f, m, C, y, v; function I(A, e, t, i, o) { var n = i / .75 / 2, r = o / 2; return A.beginPath(), A.moveTo(e, t - r), A.bezierCurveTo(e + n, t - r, e + n, t + r, e, t + r), A.bezierCurveTo(e - n, t + r, e - n, t - r, e, t - r), A.closePath(), A } (m = function () { this.name = "Shape", this.option = {} }).prototype = { init: function (A) { this.initOption(A) }, getName: function () { return this.name }, initOption: function (A) { this.option = {}, this.setOption(A) }, setOption: function (A) { return uh.extend(!0, this.option, A), this.option }, getOption: function () { return this.option }, repaint: function (A) { this.paint(A) }, setAttributes: function (A) {} }, (c = function () { this.name = "FillStroke", this.setAttributes = function (A) { var e = this.getOption(); A.strokeStyle = e.strokeStyle, A.fillStyle = e.fillStyle, A.lineWidth = e.lineWidth, A.globalAlpha = e.opacity / 100, A.lineJoin = e.lineJoin, A.lineCap = e.lineCap, A.shadowOffsetX = e.shadowOffsetX, A.shadowOffsetY = e.shadowOffsetY, A.shadowBlur = e.shadowBlur, A.shadowColor = e.shadowColor } }).prototype = new m, (p = function () { this.name = "Line", this.paint = function (A) { var e = this.getOption(); A.save(), this.setAttributes(A), A.beginPath(), A.moveTo(e.startX, e.startY), A.lineTo(e.endX, e.endY), A.closePath(), A.stroke(), A.restore() } }).prototype = new c, (o = function () { this.name = "CurveClosed", this.paint = function (A) { var e = this.getOption().list, t = e[0], i = e.length, o = 0; for (A.save(), this.setAttributes(A), A.beginPath(), A.moveTo(t.x, t.y); i > o; o += 1) A.lineTo(e[o].x, e[o].y); A.closePath(), A.fill(), A.stroke(), A.restore() } }).prototype = new c, (u = function () { this.name = "Rect", this.paint = function (A) { var e = this.getOption(); A.save(), this.setAttributes(A), A.fillRect(e.left, e.top, e.width, e.height), A.strokeRect(e.left, e.top, e.width, e.height), A.restore() } }).prototype = new c, (A = function () { this.name = "Circle", this.paint = function (A) { var e = this.getOption(); A.save(), this.setAttributes(A), A.beginPath(), A.arc(e.x, e.y, e.radius, 0, 2 * Math.PI, !0), A.closePath(), A.fill(), A.stroke(), A.restore() } }).prototype = new c, (r = function () { this.name = "Ellipes", this.paint = function (A) { var e = this.getOption(), t = e.x, i = e.y, o = e.width, n = e.height; A.save(), this.setAttributes(A), I(A, t, i, o, n), A.fill(), A.stroke(), A.restore() } }).prototype = new c, (C = function () { this.name = "Stroke", this.setAttributes = function (A) { var e = this.getOption(); A.strokeStyle = e.strokeStyle, A.lineWidth = e.lineWidth, A.globalAlpha = e.opacity / 100, A.lineJoin = e.lineJoin, A.lineCap = e.lineCap, A.shadowOffsetX = e.shadowOffsetX, A.shadowOffsetY = e.shadowOffsetY, A.shadowBlur = e.shadowBlur, A.shadowColor = e.shadowColor } }).prototype = new m, (g = function () { this.name = "Pen", this.paint = function (A) { var e = this.getOption().list, t = e[0], i = e.length, o = 0; for (A.save(), this.setAttributes(A), A.beginPath(), A.moveTo(t.x, t.y); i > o; o += 1) A.lineTo(e[o].x, e[o].y); A.stroke(), A.restore() } }).prototype = new C, (n = function () { this.name = "CurveClosedStroke", this.paint = function (A) { var e = this.getOption().list, t = e[0], i = e.length, o = 0; for (A.save(), this.setAttributes(A), A.beginPath(), A.moveTo(t.x, t.y); i > o; o += 1) A.lineTo(e[o].x, e[o].y); A.closePath(), A.stroke(), A.restore() } }).prototype = new C, (f = function () { this.name = "RectStroke", this.paint = function (A) { var e = this.getOption(); A.save(), this.setAttributes(A), A.strokeRect(e.left, e.top, e.width, e.height), A.restore() } }).prototype = new C, (e = function () { this.name = "CircleStroke", this.paint = function (A) { var e = this.getOption(); A.save(), this.setAttributes(A), A.beginPath(), A.arc(e.x, e.y, e.radius, 0, 2 * Math.PI, !0), A.closePath(), A.stroke(), A.restore() } }).prototype = new C, (a = function () { this.name = "EllipesStroke", this.paint = function (A) { var e = this.getOption(), t = e.x, i = e.y, o = e.width, n = e.height; A.save(), this.setAttributes(A), I(A, t, i, o, n), A.stroke(), A.restore() } }).prototype = new C, (s = function () { this.name = "Eraser", this.paint = function (A) { var e = this.getOption(), t = e.list, i = t[0], o = t.length, n = 0; for (A.save(), A.strokeStyle = e.color, A.lineWidth = e.lineWidth, A.shadowOffsetX = e.shadowOffsetX, A.shadowOffsetY = e.shadowOffsetY, A.shadowBlur = e.shadowBlur, A.shadowColor = e.shadowColor, A.lineJoin = e.lineJoin, A.lineCap = e.lineCap, A.globalAlpha = e.opacity / 100, A.beginPath(), A.moveTo(i.x, i.y); o > n; n += 1) A.lineTo(t[n].x, t[n].y); A.stroke(), A.restore() } }).prototype = new m, (h = function () { this.name = "FloodFill", this.paint = function (A) { var e = this.getOption(), t = e.allowance, i = e.fillStyle ? e.fillStyle : "rgba(0,0,0,1)", o = i.indexOf("(") + 1, n = i.slice(o, -1).split(","), r = { r: parseInt(n[0], 10), g: parseInt(n[1], 10), b: parseInt(n[2], 10), a: Math.ceil(255 * (n[3] || 1)) }, a = e.x, s = e.y, l = e.width, c = e.height, h = A.getImageData(0, 0, l, c), d = h.data, p = 4 * (l * s + a), g = d[p], u = d[p + 1], f = d[p + 2], m = d[p + 3] / 255, C = [{ x: a, y: s }]; try { ! function (A, e) { var o = null, n = null, r = null, h = null, p = null, y = null, v = {}; for (Bh.time("floodFill"); 0 !== C.length;) y = C.pop(), v[o = 4 * (l * y.y + y.x)] = !0, r = d[o + 1], h = d[o + 2], p = d[o + 3] / 255, ((n = d[o]) !== e.r || r !== e.g || h !== e.b || 255 * p !== e.a) && Math.abs(n - g) < t && Math.abs(r - u) < t && Math.abs(h - f) < t && Math.abs(p - m) < t / 256 && (d[o] = e.r, d[o + 1] = e.g, d[o + 2] = e.b, d[o + 3] = e.a, !v[o - 4] && a > 0 && C.push({ x: y.x - 1, y: y.y }), !v[o + 4] && l > a && C.push({ x: y.x + 1, y: y.y }), !v[o - 4 * l] && s > 0 && C.push({ x: y.x, y: y.y - 1 }), !v[o + 4 * l] && c > s && C.push({ x: y.x, y: y.y + 1 })); Bh.timeEnd("floodFill"), y = null, o = null, n = null, r = null, h = null, p = null, i = null }(0, r) } catch (A) { window.console.log(A.message) } d = null, A.save(), A.putImageData(h, 0, 0), A.restore() } }).prototype = new m, (l = function () { this.name = "EyeDropper", this.paint = function (A) { var e = this.getOption(), t = document.querySelector("#tool-wrap .tool .color"), i = A.getImageData(e.x, e.y, 1, 1).data, o = "rgba(".concat(i[0], ",", i[1], ",", i[2], ",", i[3] / 255, ")"); t.value = o, xh.css(document.querySelector("#tool-wrap #colorOperatorDiv"), { "background-color": o }) }, this.repaint = function () {} }).prototype = new m, (t = function () { this.name = "Cross", this.paint = function (A) { var e = this.getOption(), t = e.x, i = e.y, o = e.length, n = t - o, r = i, a = t + o, s = i, l = t, c = i - o, h = t, d = i + o; A.save(), A.strokeStyle = e.strokeStyle, A.lineWidth = e.lineWidth, A.shadowOffsetX = e.shadowOffsetX, A.shadowOffsetY = e.shadowOffsetY, A.shadowBlur = e.shadowBlur, A.shadowColor = e.shadowColor, A.lineJoin = e.lineJoin, A.lineCap = e.lineCap, A.globalAlpha = e.opacity / 100, A.beginPath(), A.moveTo(n, r), A.lineTo(a, s), A.moveTo(l, c), A.lineTo(h, d), A.closePath(), A.stroke(), A.restore() } }).prototype = new m, (y = function () { this.name = "Text", this.setAttributes = function (A) { var e = this.getOption(); A.shadowOffsetX = e.shadowOffsetX, A.shadowOffsetY = e.shadowOffsetY, A.shadowBlur = e.shadowBlur, A.shadowColor = e.shadowColor, A.strokeStyle = e.strokeStyle, A.fillStyle = e.fillStyle, A.globalAlpha = e.opacity / 100, A.font = e.italic + " " + e.bold + " " + e.size + "px " + e.family, A.lineWidth = e.border, A.textAlign = e.textAlign }, this.paint = function (A) { var e = this.getOption(), t = e.x, i = e.y, o = e.text; A.save(), this.setAttributes(A), "string" == typeof o && (o = o.match(/[\n\r]/) ? o.split(/\r\n|\r|\n/g) : [o]); for (var n = 0; o.length > n; n += 1) A.fillText(o[n], t, i + e.size * n), A.strokeText(o[n], t, i + e.size * n); A.restore() } }).prototype = new m, (v = function () { this.name = "TextStroke", this.paint = function (A) { var e = this.getOption(), t = e.x, i = e.y, o = e.text; A.save(), this.setAttributes(A), A.strokeText(o, t, i), A.restore() } }).prototype = new y, (d = function () { this.name = "ImageShape", this.paint = function (A) { var e = this.getOption(), t = e.x, i = e.y, o = e.src, n = e.width, r = e.height, a = new Image, s = this; a.src = o, a.onload = function () { A.save(), s.setAttributes(A), A.drawImage(a, t, i, n, r), A.restore() } } }).prototype = new m, (i = i || {}).model = i.model || {}, i.model.shapeModel = i.model.shapeModel || {}, i.model.shapeModel.Line = p, i.model.shapeModel.CurveClosed = o, i.model.shapeModel.Rect = u, i.model.shapeModel.Circle = A, i.model.shapeModel.Pen = g, i.model.shapeModel.CurveClosedStroke = n, i.model.shapeModel.RectStroke = f, i.model.shapeModel.CircleStroke = e, i.model.shapeModel.Eraser = s, i.model.shapeModel.FloodFill = h, i.model.shapeModel.EyeDropper = l, i.model.shapeModel.Cross = t, i.model.shapeModel.Ellipes = r, i.model.shapeModel.EllipesStroke = a, i.model.shapeModel.Text = y, i.model.shapeModel.TextStroke = v, i.model.shapeModel.ImageShape = d })(), function () { var A, e, t, o, n, r, a, s, l, c, h, d, p, g, u, f, m, C, y; (y = function (A) { this.name = "Tool", this.className = "shape", this.mouse = "Mouse", this.option = { strokeStyle: "#000", fillStyle: "#000", lineWidth: 1 }, void 0 !== A && uh.extend(!0, this.option, A) }).prototype = { getClassName: function () { return this.className }, getName: function () { return this.name }, setOption: function (A) { return "object" === lc(A) ? (uh.extend(!0, this.option, A), this.getOption()) : null }, getOption: function () { return uh.extend(!0, {}, this.option) }, getMouse: function () { return this.mouse } }, (u = function () { this.name = "Shape", this.mouse = "Cross", this.initAttributes = function () { for (var A = document.querySelector("#tool-shape-attribute-panel"), e = A.querySelector(".width").value, t = A.querySelector(".opacity").value, i = document.querySelector("#tool-wrap .tool .color").value, o = A.querySelector(".shadow-offsetx").value, n = A.querySelector(".shadow-offsety").value, r = A.querySelector(".shadow-blur").value, a = A.querySelector(".shadow-color").value, s = A.getElementsByTagName("radio"), l = void 0, c = void 0, h = 0; s.length > h; h += 1) "line-join" === s[h].name && (l = s[h].value), "line-cap" === s[h].name && (c = s[h].value); return this.setOption({ lineWidth: e, opacity: t, strokeStyle: i, fillStyle: i, lineJoin: l, lineCap: c, shadowOffsetX: o, shadowOffsetY: n, shadowBlur: r, shadowColor: a }) } }).prototype = new y, (h = function () { this.name = "Line", this.init = function () { this.initAttributes() }, this.setPoint = function (A) { var e = A.getStart(), t = A.getEnd(); return this.setOption({ startX: e.x, startY: e.y, endX: t.x, endY: t.y }) } }).prototype = new u, (o = function () { this.name = "CurveClosed", this.init = function () { this.initAttributes() }, this.setPoint = function (A) { var e = A.getList(); return this.option.list = [], this.setOption({ list: e }) } }).prototype = new u, (p = function () { this.name = "Rect", this.init = function () { this.initAttributes() }, this.setPoint = function (A) { var e = A.getStart(), t = A.getEnd(), i = e.x, o = e.y; return this.setOption({ left: i, top: o, width: t.x - i, height: t.y - o }) } }).prototype = new u, (A = function () { this.name = "Circle", this.init = function () { this.initAttributes() }, this.setPoint = function (A) { var e = A.getStart(), t = A.getEnd(), i = (e.x + t.x) / 2, o = (e.y + t.y) / 2, n = Math.abs(Math.sqrt(Math.pow(e.x, 2) + Math.pow(e.y, 2)) - Math.sqrt(Math.pow(t.x, 2) + Math.pow(t.y, 2))) / 2; return this.setOption({ x: i, y: o, radius: n }) } }).prototype = new u, (r = function () { this.name = "Ellipes", this.init = function () { this.initAttributes() }, this.setPoint = function (A) { var e = A.getStart(), t = A.getEnd(), i = (e.x + t.x) / 2, o = (e.y + t.y) / 2, n = Math.abs(e.x - t.x), r = Math.abs(e.y - t.y); return this.setOption({ x: i, y: o, width: n, height: r }) } }).prototype = new u, (f = function () { this.name = "Stroke", this.mouse = "Cross", this.initAttributes = function () { for (var A = document.querySelector("#tool-stroke-attribute-panel"), e = A.querySelector(".width").value, t = A.querySelector(".opacity").value, i = document.querySelector("#tool-wrap .tool .color").value, o = A.querySelector(".shadow-offsetx").value, n = A.querySelector(".shadow-offsety").value, r = A.querySelector(".shadow-blur").value, a = A.querySelector(".shadow-color").value, s = A.getElementsByTagName("radio"), l = void 0, c = void 0, h = 0; s.length > h; h += 1) "line-join" === s[h].name && (l = s[h].value), "line-cap" === s[h].name && (c = s[h].value); return this.setOption({ lineWidth: e, opacity: t, strokeStyle: i, lineJoin: l, lineCap: c, shadowOffsetX: o, shadowOffsetY: n, shadowBlur: r, shadowColor: a }) } }).prototype = new y, (d = function () { this.name = "Pen", this.mouse = "Pen", this.init = function () { this.initAttributes() }, this.setPoint = function (A) { var e = A.getList(); return this.option.list = [], this.setOption({ list: e }) } }).prototype = new f, (n = function () { this.name = "CurveClosedStroke", this.mouse = "Cross" }).prototype = new d, (g = function () { this.name = "RectStroke", this.init = function () { this.initAttributes() }, this.setPoint = function (A) { var e = A.getStart(), t = A.getEnd(), i = e.x, o = e.y; return this.setOption({ left: i, top: o, width: t.x - i, height: t.y - o }) } }).prototype = new f, (e = function () { this.name = "CircleStroke", this.init = function () { this.initAttributes() }, this.setPoint = function (A) { var e = A.getStart(), t = A.getEnd(), i = (e.x + t.x) / 2, o = (e.y + t.y) / 2, n = Math.abs(Math.sqrt(Math.pow(e.x, 2) + Math.pow(e.y, 2)) - Math.sqrt(Math.pow(t.x, 2) + Math.pow(t.y, 2))) / 2; return this.setOption({ x: i, y: o, radius: n }) } }).prototype = new f, (a = function () { this.name = "EllipesStroke", this.init = function () { this.initAttributes() }, this.setPoint = function (A) { var e = A.getStart(), t = A.getEnd(), i = (e.x + t.x) / 2, o = (e.y + t.y) / 2, n = Math.abs(e.x - t.x), r = Math.abs(e.y - t.y); return this.setOption({ x: i, y: o, width: n, height: r }) } }).prototype = new f, (s = function () { this.name = "Eraser", this.mouse = "Eraser", this.init = function () { for (var A = document.querySelector("#tool-eraser-attribute-panel"), e = A.querySelector(".size") ? A.querySelector(".size").value : void 0, t = A.querySelector(".opacity") ? A.querySelector(".opacity").value : void 0, i = A.querySelector(".shadow-offsetx") ? A.querySelector(".shadow-offsetx").value : void 0, o = A.querySelector(".shadow-offsety") ? A.querySelector(".shadow-offsety").value : void 0, n = A.querySelector(".shadow-blur") ? A.querySelector(".shadow-blur").value : void 0, r = A.querySelector(".shadow-color") ? A.querySelector(".shadow-color").value : void 0, a = A.getElementsByTagName("radio"), s = void 0, l = void 0, c = 0; a.length > c; c += 1) "line-join" === a[c].name && (s = a[c].value), "line-cap" === a[c].name && (l = a[c].value); return this.setOption({ opacity: t, lineWidth: e, color: "#fff", shadowOffsetX: i, shadowOffsetY: o, shadowBlur: n, shadowColor: r, lineJoin: s, lineCap: l }) }, this.setPoint = function (A) { var e = A.getList(); return this.option.list = [], this.setOption({ list: e }) } }).prototype = new y, (c = function () { this.name = "FloodFill", this.mouse = "FloodFill", this.init = function () { var A = document.querySelector("#tool-flood-fill-attribute-panel"), e = document.querySelector("#tool-wrap .tool .color").value, t = parseInt(A.querySelector(".allowance").value, 10), o = i.canvas.currentCanvasContainer.getCanvas(), n = o.getWidth(), r = o.getHeight(); return this.setOption({ fillStyle: e, width: n, height: r, allowance: t }) }, this.setPoint = function (A) { var e = A.getEnd(); return this.setOption({ x: e.x, y: e.y }) } }).prototype = new y, (l = function () { this.name = "EyeDropper", this.mouse = "EyeDropper", this.init = function () { return this.setOption({}) }, this.setPoint = function (A) { var e = A.getEnd(); return this.setOption({ x: e.x, y: e.y }) } }).prototype = new y, (t = function () { this.name = "Cross", this.init = function () { return this.setOption({ lineWidth: 1, strokeStyle: "#000000", length: 10 }) }, this.setPoint = function (A) { var e = A.getEnd(); return this.setOption({ x: e.x, y: e.y }) } }).prototype = new y, (m = function () { this.name = "Text", this.mouse = "Text", this.init = function () { this.initAttributes() }, this.initAttributes = function () { var A = document.querySelector("#tool-text-attribute-panel"), e = A.querySelector(".opacity").value, t = A.querySelector(".text").value, i = A.querySelector(".size").value, o = A.querySelector(".border").value, n = A.querySelector(".font").value, r = document.querySelector("#tool-wrap .tool .color").value, a = A.querySelector(".shadow-offsetx").value, s = A.querySelector(".shadow-offsety").value, l = A.querySelector(".shadow-blur").value, c = A.querySelector(".shadow-color").value, h = "checked" === A.querySelector(".bold").getAttribute("checked") ? "bold" : "", d = "checked" === A.querySelector(".italic").getAttribute("checked") ? "italic" : ""; return this.setOption({ strokeStyle: r, opacity: e, fillStyle: r, text: t, size: i, border: o, family: n, bold: h, italic: d, shadowOffsetX: a, shadowOffsetY: s, shadowBlur: l, shadowColor: c }) }, this.setPoint = function (A) { var e = A.getStart(), t = A.getEnd(), i = e.x; return this.setOption({ x: i, y: e.y, textAlign: i > t.x ? "right" : "left" }) } }).prototype = new y, (C = function () { this.name = "TextStroke" }).prototype = new m, (i = i || {}).model = i.model || {}, i.model.toolModel = i.model.toolModel || {}, i.model.toolModel.Line = h, i.model.toolModel.CurveClosed = o, i.model.toolModel.Rect = p, i.model.toolModel.Circle = A, i.model.toolModel.Pen = d, i.model.toolModel.CurveClosedStroke = n, i.model.toolModel.RectStroke = g, i.model.toolModel.CircleStroke = e, i.model.toolModel.Eraser = s, i.model.toolModel.FloodFill = c, i.model.toolModel.EyeDropper = l, i.model.toolModel.Cross = t, i.model.toolModel.Ellipes = r, i.model.toolModel.EllipesStroke = a, i.model.toolModel.Text = m, i.model.toolModel.TextStroke = C }(); this.init = function () { i.initImgDiv(), i.initCanvas(), i.initTitleDiv(), i.initTool(), i.initTopTool(), i.Index.init(), i.Nav.init(), i.Tool.init(), i.Canvas.init() }, this.initTool = function () { xh.append(i.element, '
\n
\n
\n
\n \n \n \n \n \n \n
\n
\n
\n 属性\n \n \n
\n
\n 阴影\n \n \n \n \n
\n
\n
\n
\n
\n \n \n \n \n \n \n
\n
\n
\n 属性\n \n \n
\n
\n 阴影\n \n \n \n \n
\n
\n
\n
\n
\n
\n
\n
\n 属性\n \n \n
\n
\n
\n
\n
\n
\n
\n
\n 属性\n \n
\n
\n
\n
\n
\n \n \n
\n
\n \n
\n 属性\n \n \n \n \n \n \n
\n
\n 阴影\n \n \n \n \n
\n
\n
\n
\n
\n
\n
\n \n \n \n \n
\n
\n \n
\n
\n
\n
\n \n \n \n
\n
\n \n
\n
\n
') }, this.initCanvas = function () { xh.append(i.element, '
\n \n \n \n \n
') }, this.initTopTool = function () { xh.append(i.element, '
\n
\n \n \n \n \n
\n
'), xh.addEventListener(document.querySelectorAll("#edit-exit"), "click", i.exit) }, this.initTitleDiv = function () { xh.append(i.element, '
\n
文件编号-文件名-版本
\n
') }, this.initImgDiv = function () { xh.append(i.element, ' '); var A = document.querySelector("#myModal"); xh.addEventListener(A.querySelector(".close"), "click", (function () { xh.addClass(A, "hide"), xh.remove(document.querySelector(".modal-backdrop")) })), xh.addEventListener(A.querySelector(".btn"), "click", (function () { xh.addClass(A, "hide"), xh.remove(document.querySelector(".modal-backdrop")) })); xh.append(i.element, ' '); var e = document.querySelector("#image-modal"); xh.addEventListener(e.querySelector(".close"), "click", (function () { xh.addClass(e, "hide"), xh.remove(document.querySelector(".modal-backdrop")) })), xh.addEventListener(e.querySelector(".but-cancel"), "click", (function () { xh.addClass(e, "hide"), xh.remove(document.querySelector(".modal-backdrop")) })), xh.addEventListener(e.querySelector(".btn-primary"), "click", (function () { xh.addClass(e, "hide"), xh.remove(document.querySelector(".modal-backdrop")) })) }, this.setTitle = function (A) { [].map.call(document.querySelectorAll(".titleText"), (function (e, t) { e.textContent = A })) }, this.getTitle = function () { return document.querySelector(".titleText").textContent }, this.exit = function () { i.hide(), e.postilExit() }, this.hide = function () { i.element.style.display = "none" }, this.show = function () { i.element.style.display = "block" }, this.clear = function () { i.canvas.mouseCanvasContainer.getCanvas().clear(), i.canvas.bufferCanvasContainer.getCanvas().clear(), i.canvas.currentCanvasContainer.getCanvas().clear(), i.canvas.negativeCanvasContainer.getCanvas().clear(), i.change = !1 }, this.updateSize = function (A, e) { i.canvas.currentCanvasContainer.getCanvas().updateSize(A, e), i.canvas.bufferCanvasContainer.getCanvas().updateSize(A, e), i.canvas.mouseCanvasContainer.getCanvas().updateSize(A, e), i.canvas.negativeCanvasContainer.getCanvas().updateSize(A, e) }, this.bindEvent = function () {}, this.getCoordsWithinElement = function (A) { var e = [0, 0]; if (A) { for (var t = A.target, i = 0, o = 0; t.offsetParent;) i += t.offsetLeft - t.scrollLeft, o += t.offsetTop - t.scrollTop, t = t.offsetParent; e[0] = Math.round(A.pageX - i), e[1] = Math.round(A.pageY - o) } else A = window.event, e[0] = Math.round(A.x), e[0] = Math.round(A.y); return e }, this.Index = { init: function () { this.bindEvent() }, bindEvent: function () { var A = i.element, e = null, t = null; xh.bind(A, "keydown", (function (A) { A.ctrlKey && 90 === A.keyCode && (xh.simulateEvent(document.querySelector("#nav-edit-undo"), "click"), A.preventDefault()) })), xh.bind(A, "keydown", (function (A) { A.ctrlKey && 83 === A.keyCode && (xh.simulateEvent(document.querySelector("#nav-file-save"), "click"), A.preventDefault()) })), xh.bind(A, "keydown", (function (A) { A.ctrlKey && 68 === A.keyCode && (xh.simulateEvent(document.querySelector("#nav-edit-clear"), "click"), A.preventDefault()) })), xh.bind(A, "keydown", (function (A) { A.ctrlKey && 69 === A.keyCode && (xh.simulateEvent(document.querySelector("#nav-file-export"), "click"), A.preventDefault()) })), xh.bind(document, "resize", (function (A) { var e = i.canvas, t = e.currentCanvasContainer.getCanvas(), o = e.bufferCanvasContainer.getCanvas(), n = e.mouseCanvasContainer.getCanvas(), r = i.canvas.negativeCanvasContainer.getCanvas(); t.updateSize(), o.updateSize(), n.updateSize(), r.updateSize() })), xh.delegate(i.element, "#negative-modal-file", "change", (function (A) { var t = A.target.files, i = new FileReader; i.readAsDataURL(t[0]), i.onload = function () { var A = document.querySelector("#negative-modal").querySelector("#negative-modal-view"); e = i.result, A.setAttribute("src", i.result), xh.bind(A, "load", (function () { var A = document.querySelector("#negative-modal"), e = A.querySelector("#negative-modal-width"), t = A.querySelector("#negative-modal-height"); e.value = parseInt(xh.getStyleValue(this, "width"), 0), t.value = parseInt(xh.getStyleValue(this, "height"), 0) })) } })), xh.delegate(i.element, "#negative-modal-ok", "click", (function (A) { var t = i.canvas.negativeCanvasContainer.getCanvas(), o = new i.model.shapeModel.ImageShape, n = document.querySelector("#negative-modal"), r = n.querySelector("#negative-modal-x").value, a = n.querySelector("#negative-modal-y").value, s = parseInt(n.querySelector("#negative-modal-width").value, 0), l = parseInt(n.querySelector("#negative-modal-height").value, 0); o.init({ x: r, y: a, width: s, height: l, src: e }), t.paint(o) })), xh.delegate(i.element, "#image-modal-file", "change", (function (A) { var e = A.target.files, i = new FileReader; i.readAsDataURL(e[0]), i.onload = function () { var A = document.querySelector("#image-modal").querySelector("#image-modal-view"); t = i.result, A.setAttribute("src", i.result), xh.bind(A, "load", (function () { var A = document.querySelector("#image-modal"), e = A.querySelector("#image-modal-width"), t = A.querySelector("#image-modal-height"); e.value = parseInt(xh.getStyleValue(this, "width"), 0), t.value = parseInt(xh.getStyleValue(this, "height"), 0) })) } })), xh.delegate(i.element, "#image-modal-ok", "click", (function (A) { var e = i.canvas.currentCanvasContainer.getCanvas(), o = new i.model.shapeModel.ImageShape, n = document.querySelector("#image-modal"), r = n.querySelector("#image-modal-x").value, a = n.querySelector("#image-modal-y").value, s = parseInt(n.querySelector("#image-modal-width").value, 0), l = parseInt(n.querySelector("#image-modal-height").value, 0); o.init({ x: r, y: a, width: s, height: l, src: t }), e.paint(o) })) } }, this.Canvas = { clickStatus: !1, pointList: Object.create(n), getPointList: function () { return this.pointList }, getClickStatus: function () { return this.clickStatus }, setClickStatus: function (A) { return this.clickStatus = A = A || !1, A }, init: function () { var A = document.querySelectorAll(".canvas-negative")[0], e = new s, t = Object.create(a), o = document.querySelectorAll(".canvas-layer")[0], n = new s, r = Object.create(a), l = document.querySelectorAll(".canvas-buffer")[0], c = new s, h = Object.create(a), d = document.querySelectorAll(".canvas-mouse")[0], p = new s, g = Object.create(a); e.init(A, "negativeCanvas"), t.init(e), i.canvas = i.canvas || {}, i.canvas.negativeCanvasContainer = t, n.init(o, "currentCanvas"), r.init(n), i.canvas = i.canvas || {}, i.canvas.currentCanvasContainer = r, c.init(l, "bufferCanvas"), h.init(c), i.canvas = i.canvas || {}, i.canvas.bufferCanvasContainer = h, p.init(d, "mouseCanvas"), g.init(p), i.canvas = i.canvas || {}, i.canvas.mouseCanvasContainer = g, this.bindEvent() }, bindEvent: function () { var A = i.element, e = i.canvas.mouseCanvasContainer.getCanvas(), t = i.canvas.bufferCanvasContainer.getCanvas(), o = i.canvas.currentCanvasContainer.getCanvas(), n = e.getLeft(), r = e.getTop(), a = this, s = i.tool.currentToolContainer.getTool(); xh.delegate(A, "#canvas-mouse", "mousemove", (function (A) { var o = i.getCoordsWithinElement(A), n = null, r = null, l = "", c = null, h = null, d = a.getClickStatus(), p = "", g = null, u = null; "shape" === s.getClassName() && (n = { x: o[0], y: o[1] }, p = s.getMouse(), g = s.getOption(), (u = new i.model.mouseModel[p]).init(g, n), e.clear(), e.paint(u), d && (l = s.getName(), (r = a.getPointList()).add(n), h = s.setPoint(r), "FloodFill" !== (c = new i.model.shapeModel[l]).getName() && (c.init(h), t.clear(), t.paint(c)))) })), xh.delegate(A, "#canvas-mouse", "mousedown", (function (A) { var e = i.getCoordsWithinElement(A), t = { x: e[0], y: e[1] }; a.getPointList(); a.getPointList().init(), a.getPointList().add(t), a.setClickStatus(!0) })), xh.delegate(A, "#canvas-mouse", "mouseup", (function (A) { var e = i.getCoordsWithinElement(A), n = { x: e[0], y: e[1] }, r = a.getPointList(), l = s.getName(), c = null, h = null; "shape" === s.getClassName() && (a.getPointList().add(n), a.setClickStatus(!1), c = new i.model.shapeModel[l], h = s.setPoint(r), c.init(h), o.paint(c), t.clear()) })), xh.delegate(A, "#canvas-mouse", "mouseleave", (function (A) { e.clear() })), xh.delegate(A, "#canvas-mouse", "mouseenter", (function (A) { e.clear(), s = i.tool.currentToolContainer.getTool() })), document.getElementById("canvas-mouse").addEventListener("touchmove", (function (A) { var o = null, l = null, c = "", h = null, d = null, p = a.getClickStatus(), g = "", u = null, f = null, m = s.getClassName(), C = A.changedTouches[0]; A.preventDefault(), "shape" === m && (o = { x: C.pageX - n, y: C.pageY - r }, g = s.getMouse(), u = s.getOption(), (f = new i.model.mouseModel[g]).init(u, o), e.clear(), e.paint(f), p && (c = s.getName(), (l = a.getPointList()).add(o), d = s.setPoint(l), (h = new i.model.shapeModel[c]).init(d), t.clear(), t.paint(h))) }), !1), document.getElementById("canvas-mouse").addEventListener("touchstart", (function (A) { var e = A.touches[0], t = { x: e.pageX - n, y: e.pageY - r }; a.getPointList(); A.preventDefault(), a.getPointList().init(), a.getPointList().add(t), a.setClickStatus(!0) }), !1), document.getElementById("canvas-mouse").addEventListener("touchend", (function (A) { var e = A.changedTouches[0], l = { x: e.pageX - n, y: e.pageY - r }, c = a.getPointList(), h = s.getName(), d = null, p = null, g = s.getClassName(); A.preventDefault(), "shape" === g && (a.getPointList().add(l), a.setClickStatus(!1), d = new i.model.shapeModel[h], p = s.setPoint(c), d.init(p), o.paint(d), t.clear()) }), !1) } }, this.Nav = { init: function () { this.bindEvent() }, bindEvent: function () { var A = i.element; xh.delegate(A, "#nav-file-export", "click", (function (e) { var t = i.canvas.currentCanvasContainer.getCanvas(), o = i.canvas.negativeCanvasContainer.getCanvas(), n = document.createElement("canvas"); n.width = t.width, n.height = t.height; var r = n.getContext("2d"); r.drawImage(o.getCanvas(), 0, 0), r.drawImage(t.getCanvas(), 0, 0), document.querySelectorAll("#save-image")[0].src = n.toDataURL(), xh.append(A, ""), [].map.call(document.querySelectorAll("#myModal"), (function (A, e) { xh.removeClass(A, "hide") })) })), xh.delegate(A, "#nav-file-saveAs", "click", (function (e) { var t = i.canvas.currentCanvasContainer.getCanvas(), o = i.canvas.negativeCanvasContainer.getCanvas(), n = document.createElement("canvas"); n.width = t.width, n.height = t.height; var r = n.getContext("2d"); r.drawImage(o.getCanvas(), 0, 0), r.drawImage(t.getCanvas(), 0, 0), document.querySelectorAll("#save-image")[0].src = n.toDataURL(), xh.append(A, ""), [].map.call(document.querySelectorAll("#myModal"), (function (A, e) { xh.removeClass(A, "hide") })) })), xh.delegate(A, "#nav-file-save", "click", (function (A) { var t = i.canvas.currentCanvasContainer.getCanvas(), o = i.canvas.negativeCanvasContainer.getCanvas(); t.save(), o.save(); var n = i.lobibox.alert("success", { msg: "保存成功", title: "保存", backdrop: !0, buttons: { yes: { closeOnClick: !1, text: "关闭" } }, callback: function (A, t) { A.destroy(), e.postilSave() } }), r = (new Date).getTime() - i.lobibox.alert.startTime; n.$el.style.zIndex = r + 2 })), xh.delegate(A, "#nav-file-open", "click", (function (e) { xh.append(A, ""), [].map.call(document.querySelectorAll("#image-modal"), (function (A, e) { xh.removeClass(A, "hide") })) })), xh.delegate(A, "#nav-file-import-img", "click", (function (e) { xh.append(A, ""), [].map.call(document.querySelectorAll("#image-modal"), (function (A, e) { xh.removeClass(A, "hide") })) })), xh.delegate(A, "#nav-edit-undo", "click", (function (A) { i.canvas.currentCanvasContainer.getCanvas().undo(), e.undo() })), xh.delegate(A, "#nav-edit-clear", "click", (function (A) { i.canvas.currentCanvasContainer.getCanvas().clear() })), xh.delegate(A, "#nav-edit-clear-negative", "click", (function (A) { i.canvas.negativeCanvasContainer.getCanvas().clear() })), xh.delegate(A, "#nav-edit-convert", "click", (function (A) { i.canvas.currentCanvasContainer.getCanvas().convert() })), xh.delegate(A, "#nav-edit-flipx", "click", (function (A) { i.canvas.currentCanvasContainer.getCanvas().flipX() })), xh.delegate(A, "#nav-edit-flipy", "click", (function (A) { i.canvas.currentCanvasContainer.getCanvas().flipY() })) } }; var r; (r = function () { this.currentOpenAttributePanel = null, this.colorPicker = void 0, this.attributePanelWindow = void 0 }).prototype = { init: function () { this.bindEvent(), this.initAttributePanel(), this.initColor(), i.tool = i.tool || {}, i.tool.currentToolContainer = Object.create(i.model.ToolContainerModel), i.tool.currentToolContainer.init(new i.model.toolModel.Line) }, initAttributePanel: function () { document.querySelector("#tool-wrap"); var A = document.querySelector("#tool-shape-attribute-panel"), e = document.createElement("div"); e.className = "tool-attribute-panel-content", this.attributePanelWindow = i.lobibox.window({ title: "属性面板", width: 334, height: 415, closeOnEsc: !1, closeButton: !0, afterWindowHide: function (A) {}, content: e }), this.attributePanelWindow.setPosition({ left: "", right: 35, bottom: 120 }), this.attributePanelWindow.windowHide(); var t = document.querySelectorAll(".tool-attribute-panel"); [].map.call(t, (function (A, t) { A.style.display = "none", e.appendChild(A) })), this.setCurrentAttributePanel(A), this.openAttributePanel(A) }, initColor: function () { var A = document.querySelector("#tool-wrap .tool .color"); this.colorPicker = new Hh(A), A.style.display = "none"; var e = A.parentNode; xh.append(e, '
'); var t = e.querySelector("#colorOperatorDiv"), i = this.colorPicker.element; i.id = "toolColorModal", i.className = "colorModal", i.style.cssText += "margin-left:" + t.offsetLeft + "px;bottom:50px", t.addEventListener("click", (function (A) { i.focus(), i.style.display = "block" === i.style.display ? "none" : "block", A.stopPropagation ? A.stopPropagation() : A.cancelBubble = !0 })), document.addEventListener("click", (function (A) {})), xh.addEventListener(A, "change", (function (e) { xh.css(t, { "background-color": A.value }) })), A.parentNode.parentNode.appendChild(i) }, openAttributePanel: function (A) { document.querySelector("#tool-wrap"), document.querySelector(".tool-attribute-panel-content"); var e = document.querySelectorAll(".tool-attribute-panel"), t = A || this.getCurrentAttributePanel(); t && ([].map.call(e, (function (A, e) { A.style.display = A.id == t.id ? "block" : "none" })), this.attributePanelWindow.windowShow()) }, getCurrentAttributePanel: function () { return this.currentOpenAttributePanel }, setCurrentAttributePanel: function (A) { return void 0 !== A && (this.currentOpenAttributePanel = A, !0) }, bindEvent: function () { var A = document.querySelector("#tool-wrap"), e = this; xh.delegate(A.querySelector(".tool"), "button", "click", (function (A) { if ("nav-file-import-img" === this.id) e.attributePanelWindow.$el.style.zIndex = 888; else { var t = document.querySelector("#tool-wrap"), o = this.getAttribute("data-tool-panel"), n = t.querySelector(".tool-panel ." + o), r = t.querySelectorAll(".tool-panel .wrap"), a = document.querySelector("#tool-" + o + "-attribute-panel"), s = this.getAttribute("data-current-tool"); [].map.call(t.querySelectorAll(".tool button.active"), (function (A, e) { xh.removeClass(A, "active") })), xh.addClass(this, "active"); for (var l = 0; r.length > l; l += 1) r[l].style.display = "none"; if (n && (n.style.display = "block"), a) { var c = a.getAttribute("title") ? a.getAttribute("title") : "属性面板"; i.Tool.attributePanelWindow.setTitle(c) } if (e.setCurrentAttributePanel(a), e.openAttributePanel(a), !s) return; - 1 === s.indexOf("Arrow") ? i.tool.currentToolContainer.init(new i.model.toolModel[s]) : console.log("currentTool: 箭头没有原型类实现") } })), xh.delegate(A.querySelectorAll(".tool-panel .wrap"), "button", "click", (function (A) { var e = this.getAttribute("data-tool"), t = this.getAttribute("data-tool-class"), i = document.querySelector("#tool-wrap .tool button[data-tool-panel='" + e + "']"); i.setAttribute("data-current-tool", t), xh.simulateEvent(i, "click") })), xh.delegate(A, ".color", "change", (function (A) { var e = this.value; i.tool.currentToolContainer.getTool().setOption({ fillStyle: e, strokeStyle: e }) })), xh.delegate(document.querySelectorAll(".tool-attribute-panel"), "select", "change", (function (A) { var e = A.target, t = e.getAttribute("data-attr"), o = e.value, n = i.tool.currentToolContainer.getTool(), r = {}; r[t] = o, n.setOption(r) })), [].map.call(i.element.querySelectorAll("input"), (function (A, e) { var t = A.getAttribute("type"); "checkbox" !== t && "radio" !== t && xh.addEventListener(A, "change", (function (A) { var e = A.target, t = e.getAttribute("data-attr"), o = e.value, n = i.tool.currentToolContainer.getTool(), r = {}, a = e.parentNode.querySelector("span"); a && (a.textContent = o), r[t] = o, n.setOption(r) })) })), [].map.call(i.element.querySelectorAll(".tool-attribute-panel input"), (function (A, e) { "checkbox" === A.getAttribute("type") && xh.addEventListener(A, "change", (function (A) { var e = A.target, t = e.getAttribute("data-attr"), o = e.value, n = e.getAttribute("checked"), r = i.tool.currentToolContainer.getTool(), a = {}; a[t] = !0 === n ? o : "", r.setOption(a), window.console.log(n) })) })), [].map.call(i.element.querySelectorAll(".tool-attribute-panel input"), (function (A, e) { "radio" === A.getAttribute("type") && xh.addEventListener(A, "change", (function (A) { var e = A.target, t = e.attr("data-attr"), o = e.val(), n = i.tool.currentToolContainer.getTool(), r = {}; r[t] = o, n.setOption(r) })) })) } }, this.Tool = new r; var a = { canvas: null, init: function (A) { this.setCanvas(A) }, setCanvas: function (A) { return this.canvas = A, !0 }, getCanvas: function () { return this.canvas } }; i.model = i.model || {}, i.model.CanvasContainerModel = a; var s = function () { this.canvas = null, this.documentName = "", this.pictureName = "", this.name = "Canvas", this.shapeList = [], this.convertStatus = "source-over", this.flipXStatus = !1, this.flipYStatus = !1, this.width = 1e3, this.height = 400, this.context2D = null, this.top = 0, this.left = 0 }; s.prototype = { init: function (A, e) { this.initCanvas(A), this.initHeight(), this.initWidth(), this.initLeft(), this.initTop(), this.initContext2D(), this.initName(e), this.load() }, initName: function (A) { this.setName(A) }, setName: function (A) { this.name = A }, setDocumentName: function (A) { this.documentName = A }, setPictureName: function (A) { this.pictureName = A }, getDocumentName: function () { return this.documentName }, getPictureName: function () { return this.pictureName }, getName: function () { return this.name }, initCanvas: function (A) { this.setCanvas(A) }, setCanvas: function (A) { return null != A && (this.canvas = A, !0) }, getCanvas: function () { return this.canvas }, initContext2D: function () { this.setContext2D() }, getContext2D: function () { return this.context2D }, setContext2D: function (A) { A = A || this.getCanvas().getContext("2d"), this.context2D = A }, clearContext: function () { var A = this.getHeight(), e = this.getWidth(), t = this.getContext2D(); return t.clearRect(0, 0, e, A), t }, initLeft: function () { this.updateLeft() }, updateLeft: function () { var A; return A = function (A) { for (var e = A.offsetLeft, t = A.offsetParent; null !== t;) e += t.offsetLeft, t = t.offsetParent; return e }(this.getCanvas()), this.left = A, A }, getLeft: function () { return this.left }, initTop: function () { this.updateTop() }, updateTop: function () { var A; return A = function (A) { for (var e = A.offsetTop, t = A.offsetParent; null !== t;) e += t.offsetTop, t = t.offsetParent; return e }(this.getCanvas()), this.top = A, A }, getTop: function () { return this.top }, updateSize: function (A, e) { this.updateHeight(e), this.updateWidth(A), this.repaint() }, initHeight: function () { this.updateHeight() }, updateHeight: function (A) { var e = this.getCanvas(), t = parseInt(xh.getStyleValue(e.parentNode, "height")); return A && (t = A), e.setAttribute("height", t), this.setHeight(t) }, setHeight: function (A) { return this.height = A = A || 600, A }, getHeight: function () { return this.height }, initWidth: function () { this.updateWidth() }, updateWidth: function (A) { var e = this.getCanvas(), t = parseInt(xh.getStyleValue(e.parentNode, "width")); return A && (t = A), e.setAttribute("width", t), this.setWidth(t) }, setWidth: function (A) { return this.width = A = A || 600, this.width }, getWidth: function () { return this.width }, initShapeList: function () { this.clearShapeList() }, getShapeList: function () { return uh.extend(!0, [], this.shapeList) }, setShapeList: function (A) { return this.clearShapeList(), uh.extend(!0, this.shapeList, A), A }, addShape: function (A) { this.shapeList.push(A) }, deleteShape: function () { this.shapeList.pop() }, clearShapeList: function () { this.shapeList = [] }, paint: function (A) { this.addShape(A), A.paint(this.getContext2D()), "negativeCanvas" != this.name && "currentCanvas" != this.name || (i.change = !0) }, repaint: function () { var A, e = this.shapeList, t = e.length, o = 0; for (A = this.clearContext(); t > o; o += 1) e[o].paint(A); t > 0 && ("negativeCanvas" != this.name && "currentCanvas" != this.name || (i.change = !0)) }, undo: function () { this.deleteShape(), this.repaint() }, clear: function () { this.clearContext(), this.clearShapeList() }, convert: function () { var A = this.getContext2D(), e = A.globalCompositeOperation, t = "source-over" === this.convertStatus ? "destination-over" : "source-over"; this.convertStatus = t, A.globalCompositeOperation = t, this.repaint(), A.globalCompositeOperation = e }, save: function (A) { var e = new i.model.StorageModel, t = [], o = this.shapeList, n = o.length, r = 0, a = this.getName(), s = ""; if (a = a + "-" + this.getDocumentName() + "-" + this.getPictureName(), null != A && (a = A), e.init(), !1 !== e.getStorage()) { for (; n > r; r += 1) t[r] = { name: o[r].getName(), option: o[r].getOption() }; s = window.JSON.stringify(t), e.save(a, s) } }, load: function (A) { var e, t, o = new i.model.StorageModel, n = [], r = 0, a = this.getName(), s = this.getDocumentName(), l = this.getPictureName(), c = this.shapeList; if (a = a + "-" + s + "-" + l, null != A && (a = A), o.init(), !1 !== o.getStorage()) { for (t = o.load(a) || "[]", e = (n = window.JSON.parse(t)).length; e > r; r += 1) c[r] = new i.model.shapeModel[n[r].name], c[r].init(n[r].option); this.repaint() } }, autoSave: function (A) { var e = this; window.setInterval((function () { e.save() }), A) }, flipX: function () { var A = this.getContext2D(), e = this.getWidth(); A.save(), this.flipXStatus ? this.flipXStatus = !1 : (this.flipXStatus = !0, A.translate(e, 0), A.scale(-1, 1)), this.repaint(), A.restore() }, flipY: function () { var A = this.getContext2D(), e = this.getHeight(); A.save(), this.flipYStatus ? this.flipYStatus = !1 : (this.flipYStatus = !0, A.translate(0, e), A.scale(1, -1)), this.repaint(), A.restore() } }, i.model = i.model || {}, i.model.CanvasModel = s; (i = i || {}).model = i.model || {}, i.model.ToolContainerModel = { tool: null, init: function (A) { A.init(), this.setTool(A) }, setTool: function (A) { return this.tool = A, !0 }, getTool: function () { return this.tool } } }, Jd = function (A, e) { var t = A.toolId, i = A.Flag, o = A.viewer, n = e.toolbarTop, r = this; r.viewer = o, r.postilInfo = {}, this.editingPostilObj = void 0, this.editingNodeDom = void 0, this.postilDelConf = !0, this.eventDispatcher = new Ld; var a = 0; this.deleteListener = null, this.addListener = null, this.renameListener = null, this.updateListener = null, this.exitListener = null, this.saveListener = null, this.openListener = null, this.restoreToPostilListener = null; var s = document.createElement("div"); s.className = "postil-content", xh.append(s, '
'), r.postilWindow = qd.window({ title: "批注", width: 334, height: 688, closeOnEsc: !1, closeButton: !0, afterWindowHide: function () { var A = document.getElementById("postil" + t); i.postil = !1, A && (A.style.backgroundColor = "", A.querySelector(".yj-icon").className = "yj-icon postil-icon") }, content: s }), r.postilWindow.setPosition({ left: "", right: 5, top: 60 }), r.postilWindow.windowHide(), xh.addEventListener(n.querySelector("#postil" + t), "click", (function (A) { if (i.postil) A.target.parentNode.style.backgroundColor = "", A.target.className = "yj-icon postil-icon active", r.postilWindow.windowHide(); else { r.load([]), i.postil = !i.postil, r.postilWindow.windowShow(); var e = o.viewerImpl.modelManager.sceneState; A.target.parentNode.style.backgroundColor = "#1f89de", A.target.className = "yj-icon postil-icon active", e.getSelection() } })), xh.append(document.querySelector("body"), '
'), document.querySelector("#postilEdit" + t).style.display = "none", this.edit = new Wd("postilEdit" + t, this, o, t), r.edit.init(), xh.addEventListener(r.postilWindow.$el.querySelector(".postil-body"), "click", (function (A) { switch (A.target.className) { case "postil-node-delete": r.postilDelete(A); break; case "postil-node-img": r.postilflyto(A); break; case "postil-node-button-update": r.postilUpdate(A); break; case "postil-node-button-edit": r.postilEdit(A) } })), xh.addEventListener(r.postilWindow.$el.querySelector(".postil-body"), "dblclick", (function (A) { switch (A.target.className) { case "postil-node-name": r.postilRename(A) } })), this.makePostils = function () { var A, e, t, i, n, r = o.viewerImpl.modelManager.getModelSnapshotPhoto(); A = r.imgURL; var s = r.width, l = r.height, c = o.viewerImpl.getSceneState(); e = c.camera, t = c.state, i = c.selection.concat(), n = c.modelSelection.concat(); var h = a; return a += 1, { cameraState: e, componentState: t, highlightComponentsKeys: i, highlightModelsKeys: n, imageURL: A, width: s, height: l, num: h, code: (new Date).getTime().toString(), name: "批注" + h } }, this.clear = function () { [].map.call(r.postilWindow.$el.querySelectorAll(".postil .postil-body"), (function (A, e) { A.innerHTML = "" })), r.postilInfo = {}, r.postilDelConf = !0 }, this.load = function (A) { Array.isArray(A) && A.forEach((function (A) { r.add(A) })) }, xh.addEventListener(r.postilWindow.$el.querySelector("#postilAdd" + t), "click", (function (A) { var e = r.makePostils(); "function" == typeof r.addListener ? r.addListener(e, (function (A, t) { A && r.add(t || e) })) : r.add(e) })), this.add = function (A) { var e = A.imageURL, t = A.width, i = A.height, o = A.code, n = A.name, a = A.num; if (A.cameraState && A.componentState && e && o && t && i) { for (var s = r.postilWindow.$el.querySelectorAll(".postil-node"), l = 0; s.length > l; l += 1) xh.css(s[l], { border: "2px" }); var c = '
' + n + '×
'; [].map.call(r.postilWindow.$el.querySelectorAll(".postil-body"), (function (A, e) { xh.append(A, c) })), r.postilInfo[o] = A } }, this.postilEdit = function (A) { var e = document.querySelector("#postilEdit" + t); e.style.display = "block", e.style.height = r.viewer.viewerImpl.getDomElement().style.height, e.style.width = r.viewer.viewerImpl.getDomElement().style.width; var i = A.target.parentNode.parentNode.parentNode.getAttribute("imgid"); "function" == typeof r.openListener ? r.openListener(i, (function (A) { A && r.open(i) })) : r.open(i) }, this.open = function (A) { document.querySelector("#postilEdit" + t).style.display = "block"; var e = r.postilWindow.$el.querySelector("div[imgid='" + A + "']"); if (e) { this.editingNodeDom = e; var i = e.querySelector(".postil-node-name").textContent; r.editingPostilObj = r.postilInfo[A], r.edit.setTitle(i), xh.showOrHideElement(o.viewport, !1), r.edit.canvas.currentCanvasContainer.getCanvas().setDocumentName(A), r.edit.canvas.currentCanvasContainer.getCanvas().setPictureName(A), r.edit.canvas.negativeCanvasContainer.getCanvas().setDocumentName(A), r.edit.canvas.negativeCanvasContainer.getCanvas().setPictureName(A); var n = r.edit.canvas.negativeCanvasContainer.getCanvas(), a = new r.edit.model.shapeModel.ImageShape, s = e.children[1].children[0].naturalWidth, l = e.children[1].children[0].naturalHeight; a.init({ x: 0, y: 0, width: s, height: l, src: e.children[1].children[0].src }), r.edit.clear(), n.paint(a), r.edit.updateSize(s, l) } }, this.postilUpdate = function (A) { var e = A.target.parentNode.parentNode.parentNode.getAttribute("imgid"), t = r.makePostils(); "function" == typeof r.updateListener ? r.updateListener(e, t, (function (A, i, o) { A && r.update(i || e, o || t) })) : r.update(e, t) }, this.update = function (A, e) { var t = r.postilInfo[A]; t && (t.cameraState = e.cameraState, t.componentState = e.componentState, t.highlightComponentsKeys = e.highlightComponentsKeys, t.highlightModelsKeys = e.highlightModelsKeys, t.imageURL = e.imageURL); var i = r.postilWindow.$el.querySelector("div[imgid='" + A + "']"); if (i) { var o = i.querySelector(".postil-node-img"); o && (o.src = e.imageURL) } }, this.postilDelete = function (A) { var e = A.target.parentNode.parentNode.getAttribute("imgid"); if (r.postilDelConf) { var t = qd.alert("info", { msg: "删除不可恢复,确认删除?", title: "删除确认", backdrop: !0, buttons: { yes: { closeOnClick: !1, text: "删除并不再提示" }, no: { closeOnClick: !1, text: "删除" } }, callback: function (A, t) { "no" !== t && "yes" !== t || ("yes" === t && (r.postilDelConf = !1), "function" == typeof r.deleteListener ? r.deleteListener(e, (function (A) { A && r.delete(e) })) : r.delete(e)), A.destroy() } }), i = (new Date).getTime() - qd.window.startTime; [].map.call(r.postilWindow.$el.querySelectorAll(".lobibox-backdrop"), (function (A, e) { xh.css(A, { "z-index": i }) })), t.$el.style.zIndex = i + 2 } else "function" == typeof r.deleteListener ? r.deleteListener(e, (function (A) { A && r.delete(e) })) : r.delete(e) }, this.delete = function (A) { var e = r.postilWindow.$el.querySelector("div[imgid='" + A + "']"); e && e.remove(), delete r.postilInfo[A] }, this.postilRename = function (A) { o.viewerImpl.cameraControl.enabled = !1; var e = A.target, t = e.parentNode.parentNode.getAttribute("imgid"), i = e.innerText, n = document.createElement("input"); n.type = "text", n.value = i, e.innerText = "", xh.append(e, n), n.focus(), n.select(), n.addEventListener("blur", (function (A) { var e = A.target; e.removeEventListener("blur", (function () {})), e.value !== i && "" !== xh.trim(e.value) ? "function" == typeof r.renameListener ? r.renameListener(t, e.value, (function (A, o) { A ? r.rename(t, o || e.value) : e.parentNode.innerText = i })) : r.rename(t, e.value) : e.parentNode.innerText = i, n.remove(), o.viewerImpl.cameraControl.enabled = !0 })) }, this.rename = function (A, e) { var t = r.postilWindow.$el.querySelector("div[imgid='" + A + "']"); if (t) { var i = t.querySelector(".postil-node-name"); i && (i.innerText = e) } r.postilInfo[A].name = e }, this.postilflyto = function (A) { for (var e = r.postilWindow.$el.querySelectorAll(".postil-node"), t = 0; e.length > t; t += 1) xh.css(e[t], { border: "2px" }); var i = A.target.parentNode.parentNode.getAttribute("code"); "function" == typeof r.restoreToPostilListener ? r.restoreToPostilListener(i, (function (A) { r.restoreToPostil(i) })) : r.restoreToPostil(i) }, this.restoreToPostil = function (A) { var e = r.postilInfo[A]; if (e) { o.viewerImpl.setSceneState({ camera: e.cameraState, state: e.componentState, selection: e.highlightComponentsKeys, modelSelection: e.highlightModelsKeys }); var t = r.postilWindow.$el.querySelector("div[imgid='" + A + "']"); t && xh.css(t, { border: "2px solid #002553" }) } }, this.postilSave = function () { "function" == typeof r.saveListener ? r.saveListener(this.editingPostilObj.code, (function (A) { A && r.save() })) : r.save() }, this.save = function () { r.edit.canvas.currentCanvasContainer.getCanvas().save(), r.edit.canvas.negativeCanvasContainer.getCanvas().save(); var A = r.edit.canvas.currentCanvasContainer.getCanvas(), e = r.edit.canvas.negativeCanvasContainer.getCanvas(), t = document.createElement("canvas"); t.width = A.width, t.height = A.height; var i = t.getContext("2d"); i.drawImage(e.getCanvas(), 0, 0), i.drawImage(A.getCanvas(), 0, 0); var o = t.toDataURL(); r.editingPostilObj.imageURL = o, this.editingNodeDom.children[1].children[0].setAttribute("src", o), r.eventDispatcher.dispatchEvent({ type: "POSTIL-EDIT-SAVE", event: event, data: r.editingPostilObj }) }, this.undo = function () { r.eventDispatcher.dispatchEvent({ type: "POSTIL-EDIT-UNDO", event: event }) }, this.postilExit = function () { "function" == typeof r.exitListener ? r.exitListener(this.editingPostilObj.code, (function (A) { A && r.exit() })) : r.exit() }, this.exit = function () { r.edit.canvas.currentCanvasContainer.getCanvas().clear(), r.edit.canvas.negativeCanvasContainer.getCanvas().clear(), r.edit.canvas.currentCanvasContainer.getCanvas().setDocumentName(""), r.edit.canvas.currentCanvasContainer.getCanvas().setPictureName(""), r.edit.canvas.negativeCanvasContainer.getCanvas().setDocumentName(""), r.edit.canvas.negativeCanvasContainer.getCanvas().setPictureName(""), r.clearPostilStorage(), r.edit.hide(), r.editingPostilObj = void 0, document.querySelector("#" + o.viewport).style.display = "block", r.eventDispatcher.dispatchEvent({ type: "POSTIL-EDIT-CLOSE" }) }, this.clearPostilStorage = function () { for (var A = localStorage.length, e = [], t = 0; A > t; t += 1) { var i = localStorage.key(t); - 1 === i.indexOf("currentCanvas-") && -1 === i.indexOf("negativeCanvas-") || e.push(i) } e.map((function (A, e) { return localStorage.removeItem(A) })) }, this.clearPostilStorage(), this.getPostilByKey = function (A) { return r.postilInfo ? r.postilInfo[A] : null }, this.getAllPostil = function () { return r.postilInfo ? r.postilInfo : null } }, zd = function (A, e) { var t = document.getElementById("svgBar" + e), i = this; if (!t) { this.svg = document.createElementNS("http://www.w3.org/2000/svg", "svg"), this.svg.setAttribute("id", "svgBar" + e), this.svg.setAttribute("style", "width: 100%; height: 10px; position:absolute; left: 0; top:0;"), A.appendChild(this.svg); var o = Number(2).toString(), n = A.clientWidth.toString(), r = (A.clientWidth - 2).toString(); this.backBar = document.createElementNS("http://www.w3.org/2000/svg", "line"), this.backBar.setAttribute("id", "backBar" + e), this.backBar.setAttribute("class", "progressBar"), this.backBar.setAttribute("x1", o), this.backBar.setAttribute("y1", "1"), this.backBar.setAttribute("x2", n), this.backBar.setAttribute("y2", "1"), this.backBar.setAttribute("stroke", "#CFF9FE"), this.backBar.setAttribute("stroke-width", "7"), this.backBar.setAttribute("stroke-linecap", "round"), this.frontBar = document.createElementNS("http://www.w3.org/2000/svg", "line"), this.frontBar.setAttribute("id", "frontBar" + e), this.frontBar.setAttribute("class", "progressBar"), this.frontBar.setAttribute("x1", o), this.frontBar.setAttribute("y1", "1"), this.frontBar.setAttribute("x2", n), this.frontBar.setAttribute("y2", "1"), this.frontBar.setAttribute("stroke", "#58BDFD"), this.frontBar.setAttribute("stroke-dasharray", r), this.frontBar.setAttribute("stroke-dashoffset", r), this.frontBar.setAttribute("stroke-width", "7"), this.frontBar.setAttribute("stroke-linecap", "round"), this.svg.appendChild(this.backBar), this.svg.appendChild(this.frontBar) } this.setProgressBar = function (A, e) { var t = A / e, o = r - r * t; i.svg.style.display = "", i.frontBar.setAttribute("stroke-dashoffset", o.toString()), 1 > t || setTimeout((function () { i.deleteProgressBar() }), 500) }, this.deleteProgressBar = function () { document.getElementsByClassName("progressBar"); i.svg.style.display = "none" } }, Zd = function (A, e) { var t = A.toolId, i = A.Flag, o = A.viewer, n = e.toolbarTop, r = this, a = 0; this.snapshotInfo = {}, this.snapshotDelConf = !0, this.deleteListener = null, this.addListener = null, this.renameListener = null, this.updateListener = null, this.annotationListener = null, this.restoreToSnapshotListener = null; var s = document.createElement("div"); s.className = "snapshot-content", xh.append(s, '
'), this.snapshotWindow = qd.window({ title: "快照", width: 334, height: 688, closeOnEsc: !1, closeButton: !0, afterWindowHide: function () { var A = document.getElementById("snapshot" + t); i.snapshot = !1, A && (A.style.backgroundColor = "", A.querySelector(".yj-icon").className = "yj-icon snapshot-icon") }, content: s }), r.snapshotWindow.setPosition({ left: "", right: 5, top: 60 }), r.snapshotWindow.windowHide(), xh.addEventListener(n.querySelector("#snapshot" + t), "click", (function (A) { if (i.snapshot) r.snapshotInfo = void 0, A.target.parentNode.style.backgroundColor = "", A.target.className = "yj-icon snapshot-icon", r.snapshotWindow.windowHide(); else { r.load([]), i.snapshot = !i.snapshot, r.snapshotWindow.windowShow(); var e = o.viewerImpl.modelManager.sceneState; A.target.parentNode.style.backgroundColor = "#1f89de", A.target.className = "yj-icon snapshot-icon active", e.getSelection() } })), xh.addEventListener(r.snapshotWindow.$el.querySelector("#add" + t), "click", (function (A) { var e = r.makeSnapshots(); "function" == typeof r.addListener ? r.addListener(e, (function (A, t) { A && r.add(t || e) })) : r.add(e) })), this.clear = function () { [].map.call(r.snapshotWindow.$el.querySelectorAll(".snapshot .snapshot-body"), (function (A, e) { A.innerHTML = "" })), r.snapshotInfo = {}, r.snapshotDelConf = !0 }, this.load = function (A) { Array.isArray(A) && A.forEach((function (A) { r.add(A) })) }, this.makeSnapshots = function () { var A, e, t, i, n, r = o.viewerImpl.modelManager.getModelSnapshotPhoto(); A = r.imgURL; var s = r.width, l = r.height, c = o.viewerImpl.getSceneState(); e = c.camera, t = c.state, i = c.selection.concat(), n = c.modelSelection.concat(); var h = a; return a += 1, { cameraState: e, componentState: t, highlightComponentsKeys: i, highlightModelsKeys: n, imageURL: A, width: s, height: l, num: h, code: (new Date).getTime().toString(), name: "快照" + h, description: "无注释" } }, xh.addEventListener(r.snapshotWindow.$el.querySelector(".snapshot-body"), "click", (function (A) { switch (A.target.className) { case "snapshot-node-delete": r.snapshotsDelete(A); break; case "snapshot-node-img": r.snapshotsflyto(A); break; case "snapshot-node-annotation": r.snapshotsAnnotation(A); break; case "snapshot-node-button-update": r.snapshotUpdate(A) } })), xh.addEventListener(r.snapshotWindow.$el.querySelector(".snapshot-body"), "dblclick", (function (A) { switch (A.target.className) { case "snapshot-node-name": r.snapshotsRename(A) } })), this.add = function (A) { var e = A.imageURL, t = A.width, i = A.height, o = A.code, n = A.name, a = A.num, s = A.description; if (A.cameraState && A.componentState && e && o && t && i) { for (var l = r.snapshotWindow.$el.querySelectorAll(".snapshot-node"), c = 0; l.length > c; c += 1) xh.css(l[c], { border: "2px" }); var h = '
' + n + '×
'; [].map.call(r.snapshotWindow.$el.querySelectorAll(".snapshot-body"), (function (A, e) { xh.append(A, h) })), r.snapshotInfo[o] = A } }, this.snapshotsflyto = function (A) { for (var e = r.snapshotWindow.$el.querySelectorAll(".snapshot-node"), t = 0; e.length > t; t += 1) xh.css(e[t], { border: "2px" }); var i = A.target.parentNode.parentNode.getAttribute("code"); "function" == typeof r.restoreToSnapshotListener ? r.restoreToSnapshotListener(i, (function (A) { r.restoreToSnapshot(i) })) : r.restoreToSnapshot(i) }, this.restoreToSnapshot = function (A) { var e = r.snapshotInfo[A]; if (e) { o.viewerImpl.setSceneState({ camera: e.cameraState, state: e.componentState, selection: e.highlightComponentsKeys, modelSelection: e.highlightModelsKeys }); var t = r.snapshotWindow.$el.querySelector("div[imgid='" + A + "']"); t && xh.css(t, { border: "2px solid #002553" }) } }, this.snapshotsPlay = function () { var A = null; function e(t) { var i = r.snapshotWindow.$el.querySelectorAll(".snapshot-node"); if (0 !== i.length) { var n, a = i[t].getAttribute("imgid"); if (void 0 === r.snapshotInfo[a]) i.length > t && e(t + 1); else { for (var s = 0; i.length > s; s += 1) xh.css(i[s], { border: "2px" }); xh.css(i[t], { border: "2px solid #002553" }), o.viewerImpl.setSceneState({ camera: r.snapshotInfo[a].cameraState, state: r.snapshotInfo[a].componentState, selection: r.snapshotInfo[a].highlightComponentsKeys, modelSelection: r.snapshotInfo[a].highlightModelsKeys }), i.length - 1 > t ? A = setTimeout((n = t + 1, function () { e(n) } ), 1e3) : [].map.call(r.snapshotWindow.$el.querySelectorAll(".snapshot-play"), (function (A, e) { A.innerHTML = "播放模型快照" })) } i.length > t || [].map.call(r.snapshotWindow.$el.querySelectorAll(".snapshot-play"), (function (A, e) { A.innerText = "播放模型快照" })) } else [].map.call(r.snapshotWindow.$el.querySelectorAll(".snapshot-play"), (function (A, e) { A.innerText = "播放模型快照" })) } return function (t) { if ("播放模型快照" === t.target.innerText) { t.target.innerText = "停止播放"; e(0) } else "停止播放" === t.target.innerText && (t.target.innerText = "播放模型快照", A && clearTimeout(A)) } }(), xh.addEventListener(r.snapshotWindow.$el.querySelector(".snapshot-play"), "click", (function (A) { r.snapshotsPlay(A) })), this.snapshotsDelete = function (A) { var e = A.target.parentNode.parentNode.getAttribute("imgid"); if (r.snapshotDelConf) { var t = qd.alert("info", { msg: "删除不可恢复,确认删除?", title: "删除确认", backdrop: !0, buttons: { yes: { closeOnClick: !1, text: "删除并不再提示" }, no: { closeOnClick: !1, text: "删除" } }, callback: function (A, t) { "no" !== t && "yes" !== t || ("yes" === t && (r.snapshotDelConf = !1), "function" == typeof r.deleteListener ? r.deleteListener(e, (function (A) { A && r.delete(e) })) : r.delete(e)), A.destroy() } }), i = (new Date).getTime() - qd.window.startTime; [].map.call(r.snapshotWindow.$el.querySelectorAll(".lobibox-backdrop"), (function (A, e) { xh.css(A, { "z-index": i }) })), t.$el.style.zIndex = i + 2 } else "function" == typeof r.deleteListener ? r.deleteListener(e, (function (A) { A && r.delete(e) })) : r.delete(e) }, this.delete = function (A) { var e = r.snapshotWindow.$el.querySelector("div[imgid='" + A + "']"); e && e.remove(), delete r.snapshotInfo[A] }, this.snapshotsRename = function (A) { o.viewerImpl.cameraControl.enabled = !1; var e = A.target, t = e.parentNode.parentNode.getAttribute("imgid"), i = e.innerText, n = document.createElement("input"); n.type = "text", n.value = i, e.innerText = "", xh.append(e, n), n.focus(), n.select(), n.addEventListener("blur", (function (A) { var e = A.target; e.removeEventListener("blur", (function () {})), e.value !== i && "" !== xh.trim(e.value) ? "function" == typeof r.renameListener ? r.renameListener(t, e.value, (function (A, o) { A ? r.rename(t, o || e.value) : e.parentNode.innerText = i })) : r.rename(t, e.value) : e.parentNode.innerText = i, n.remove(), o.viewerImpl.cameraControl.enabled = !0 })) }, this.rename = function (A, e) { var t = r.snapshotWindow.$el.querySelector("div[imgid='" + A + "']"); if (t) { var i = t.querySelector(".snapshot-node-name"); i && (i.innerText = e) } r.snapshotInfo[A].name = e }, this.snapshotUpdate = function (A) { var e = A.target.parentNode.parentNode.getAttribute("imgid"), t = r.makeSnapshots(); "function" == typeof r.updateListener ? r.updateListener(e, t, (function (A, i, o) { A && r.update(i || e, o || t) })) : r.update(e, t) }, this.update = function (A, e) { var t = r.snapshotInfo[A]; t && (t.cameraState = e.cameraState, t.componentState = e.componentState, t.highlightComponentsKeys = e.highlightComponentsKeys, t.highlightModelsKeys = e.highlightModelsKeys, t.imageURL = e.imageURL); var i = r.snapshotWindow.$el.querySelector("div[imgid='" + A + "']"); if (i) { var o = i.querySelector(".snapshot-node-img"); o && (o.src = e.imageURL) } }, this.snapshotsAnnotation = function (A) { var e = A.target, t = e.parentNode.parentNode.getAttribute("imgid"), i = e.innerHTML, o = qd.prompt("text", { title: "添加/修改-注释/说明", value: e.innerHTML, multiline: !0, modal: !0, backdrop: !0, lines: 6, attrs: { placeholder: "无注释" }, buttons: { ok: { class: "btn btn-info", closeOnClick: !1, text: "确定" }, cancel: { class: "btn btn-danger", closeOnClick: !1, text: "取消" } }, callback: function (A, n) { if ("ok" === n) { var a = o.getValue(); a !== i && "" !== xh.trim(a) ? "function" == typeof r.annotationListener ? r.annotationListener(t, a, (function (A, e, i) { A && r.annotation(e || t, i || a) })) : r.annotation(t, a) : e.innerHTML = i, A.destroy() } else "cancel" === n && A.destroy() } }), n = (new Date).getTime() - qd.window.startTime; [].map.call(r.snapshotWindow.$el.querySelectorAll(".lobibox-backdrop"), (function (A, e) { xh.css(A, { "z-index": n }) })), o.$el.style.zIndex = n + 2 }, this.annotation = function (A, e) { var t = r.snapshotWindow.$el.querySelector("div[imgid='" + A + "']"); if (t) { var i = t.querySelector(".snapshot-node-annotation"); i && (i.innerText = e) } r.snapshotInfo[A].description = e }, this.getSnapshotByKey = function (A) { return r.snapshotInfo ? r.snapshotInfo[A] : null }, this.getAllSnapshot = function () { return r.snapshotInfo ? r.snapshotInfo : null } }, Xd = function (A, e) { var t = this; qd.viewport = document.querySelector("#" + A.viewport), A.getViewerImpl().getModelManager().addEventListener(Rc.ON_LOAD_ERROR, (function (A) { jd("error", A.message || "加载出现错误", !1) })), A.getViewerImpl().getModelManager().addEventListener(Rc.ON_LOAD_INVALID_SCENE, (function (A) { jd("error", "key为 " + A.modelKey + " 的模型信息不合法", !1) })), A.getViewerImpl().getModelManager().addEventListener(Rc.ON_NETWORK_ERROR, (function (A) { jd("error", A.message || "网络连接错误", !1) })), A.getViewerImpl().getModelManager().addEventListener(Rc.NO_PERMISSION, (function (A) { jd("error", A.message || "权限不足", !1) })), A.getViewerImpl().getModelManager().addEventListener(Rc.ACCOUNT_NO_EXIST, (function (A) { jd("error", A.message || "无法获取账户", !1) })), A.getViewerImpl().getModelManager().addEventListener(Rc.ON_LOAD_EMPTY_SCENE, (function (A) { jd("error", "key为 " + A.modelKey + " 的模型场景为空,请生成场景", !1) })), A.getViewerImpl().getModelManager().addEventListener(Tc.PARSEFAILE, (function (A) { jd("error", "key为 " + A.modelKey + " 的模型解析失败", !1) })), A.getViewerImpl().getModelManager().addEventListener(Tc.PARSING, (function (A) { jd("error", "key为 " + A.modelKey + " 的模型解析中", !1) })), A.getViewerImpl().getModelManager().addEventListener(Tc.SCENE_NOTHING_TO_LOAD, (function (A) { jd("error", "key为 " + A.modelKey + " 的模型没有可加载的内容", !1) })); var i = A.viewerImpl.uuid, o = { roam: !1, sectioning: !1, multiple: !1, fullScreen: !1, attribute: !1, search: !1, measurement: !1, modelTree: !1, treeDataLoad: !1, snapshot: !1, postil: !1, mark: !1 }, n = { home: !0, fit: !0, restore: !0, roam: !0, multiple: !0, transparent: !1, hide: !0, isolation: !0, sectioning: !0, modelPartition: !0, wireframe: !0, color: !0, setting: !0, modelTree: !1, attribute: !0, search: !1, measurement: !0, snapshot: !0, postil: !0, mark: !0 }, r = { Flag: o, lobibox: qd, toolId: i, viewer: A }; this.progressBar = new zd(A.viewerImpl.domElement, i); var a = {}; A.getViewerImpl().modelManager.addEventListener(Rc.ON_LOAD_PROGRESS, (function (A) { a[A.progress.modelKey] = [A.progress.total, A.progress.loaded]; var e = 0, i = 0; for (var o in a) if (a.hasOwnProperty(o)) { var n = a[o]; e += n[0], i += n[1] } t.progressBar.setProgressBar(i, e) })), A.getViewerImpl().modelManager.addEventListener(Rc.ON_LOAD_COMPLETE, (function (A) { delete a[A.modelKey], 0 === Object.keys(a).length && t.progressBar.setProgressBar(1, 1) })); A.viewerImpl.getScene(); this.undoList = [], this.redoList = [], this.maxUndoListLength = 10; var s, l, c, h, d = 0; function p(e) { var i = t.undoList[e - 1]; if (i) switch (i.type) { case "隐藏": A.showComponentsByKey(i.data); break; case "隔离": A.closeIsolateComponentsByKey(i.data); break; case "修改颜色": A.closeColorfulComponentsByKey(i.data.key); break; case "框选添加": A.closeHighlightComponentsByKey(i.data); break; case "框选移除": A.highlightComponentsByKey(i.data); break; case "修改线框": A.closeWireFrameComponentsByKey(i.data) } } function g(e) { var i = t.redoList[e]; if (i) switch (i.type) { case "隐藏": A.hideComponentsByKey(i.data); break; case "隔离": A.isolateComponentsByKey(i.data); break; case "修改颜色": A.colorfulComponentsByKey(i.data.key, i.data.color, i.data.opacity); break; case "框选添加": A.highlightComponentsByKey(i.data); break; case "框选移除": A.closeHighlightComponentsByKey(i.data); break; case "修改线框": A.wireFrameComponentsByKey(i.data) } } function u(A) { if (void 0 !== A.target.undoNum) { var e = Number(A.target.undoNum); 1 === e && jd("info", "无法再撤销、重做。请使用ctrl+z或ctrl+shift+z", 3e3), isNaN(e) || t.undoOrRedo(e) } } this.className = "Tool", this.getToolId = function () { return i }, this.getFlag = function () { return o }, this.createTool = function (e) { t.options = uh.extend(!0, {}, n, e); var a = document.createElement("div"); a.id = "my-tool" + i, a.className = "yj-tool", A.viewerImpl.domElement.appendChild(a), this.toolbarTop = a, t.toolbar = a; var s = document.createElement("div"); s.className = "yj-group", a.appendChild(s); var l = document.createElement("div"); l.className = "homeViewer-div", l.id = "homeViewerDiv" + i, l.style.display = "flex"; var c = document.createElement("button"); c.className = "yj-but", c.title = "视图操作", c.id = "homeViewer" + i; var h = document.createElement("div"); h.classList.add("yj-icon"), h.classList.add("homeViewer-icon"), c.appendChild(h); var p = document.createElement("div"); p.className = "viewerModal", p.id = "viewerModal" + i, l.appendChild(c), l.appendChild(p), t.options.home && s.appendChild(l), c.addEventListener("click", (function (A) { "" === p.style.display || "none" === p.style.display ? (DA(), p.style.display = "flex") : p.style.display = "none" })); var g = document.createElement("button"); g.className = "yj-but", g.title = "初始化", g.id = "home" + i; var u = document.createElement("div"); u.classList.add("yj-icon"), u.classList.add("home-icon"), g.appendChild(u), t.options.home && p.appendChild(g); var f = document.createElement("button"); f.className = "yj-but", f.title = "聚焦", f.id = "fit" + i; var m = document.createElement("div"); m.classList.add("yj-icon"), m.classList.add("fit-icon"), f.appendChild(m), t.options.fit && p.appendChild(f); var C = document.createElement("button"); C.className = "yj-but", C.title = "复位", C.id = "restore" + i; var y = document.createElement("div"); y.classList.add("yj-icon"), y.classList.add("restore-icon"), C.appendChild(y); var v = document.createElement("ul"); v.className = "restoreModal", v.style.cssText += "display: none;", v.id = "restoreModal" + i; for (var I = 0; 6 > I; I += 1) { var E = document.createElement("li"); E.className = "input-group-addon", v.appendChild(E); var B = document.createElement("input"); B.type = "checkbox", B.className = 5 === I ? "checkAll" : "check", E.appendChild(B); var x = document.createElement("label"); switch (E.appendChild(x), I) { case 0: B.id = "showSet" + i, x.setAttribute("for", "showSet" + i), x.innerHTML = "复位构件可见设置"; break; case 1: B.id = "highlightSet" + i, x.setAttribute("for", "highlightSet" + i), x.innerHTML = "复位构件高亮设置"; break; case 2: B.id = "viewSet" + i, x.setAttribute("for", "viewSet" + i), x.innerHTML = "复位模型视角设置"; break; case 3: B.id = "wireframeSet" + i, x.setAttribute("for", "wireframeSet" + i), x.innerHTML = "复位构件线框设置"; break; case 4: B.id = "colorSet" + i, x.setAttribute("for", "colorSet" + i), x.innerHTML = "复位构件颜色设置"; break; case 5: B.id = "checkAll" + i, x.setAttribute("for", "checkAll" + i), x.innerHTML = "全选"; var S = document.createElement("input"); S.type = "button", S.id = "reset" + i, S.className = "reset", S.value = "复位选中项", E.appendChild(S) } } var w = document.createElement("ul"); w.className = "history", w.id = "history" + i, w.style.cssText += "display: none;"; var M = document.createElement("span"); M.innerText = "历史记录", M.style.cssText += "color:white", w.appendChild(M), t.options.restore && (s.appendChild(C), s.appendChild(v), s.appendChild(w), v.style.cssText += "margin-left:" + C.style.left - v.style.width / 2 + "px"); var b = document.createElement("button"); b.className = "yj-but", b.title = "漫游", b.id = "roam" + i; var U = document.createElement("div"); U.classList.add("yj-icon"), U.classList.add("roam-icon"), b.appendChild(U); var F = document.createElement("div"); F.classList.add("roamModal"), F.classList.add("clearfix"), F.id = "roamModal" + i, F.innerHTML = '
提示信息
-
+
提示信息
-
+
'; var K = document.createElement("div"); K.className = "roamOnOff", K.innerHTML = '
碰撞:
重力:
', t.options.roam && (s.appendChild(b), s.appendChild(F), s.appendChild(K), F.style.cssText += "margin-left:" + b.style.left - F.style.width / 2 + "px"); var Q = document.createElement("div"); Q.className = "yj-group", a.appendChild(Q); var R = null; t.options.multiple && (R = function (A, e) { var t = A.toolId, i = A.Flag, o = A.viewer, n = document.createElement("button"); n.className = "yj-but", n.title = "框选", n.id = "multiple" + t; var r = document.createElement("div"); r.classList.add("yj-icon"), r.classList.add("multiple-icon"), n.appendChild(r); var a = null; return n.addEventListener("click", (function () { if (i.multiple) return this.style.backgroundColor = "", this.querySelector(".yj-icon").className = "yj-icon multiple-icon", i.multiple = !1, a && a.remove(), a = null, void o.viewerImpl.controlManager.disableTool(Pc.PICK_BY_RECT); i.roam && (document.getElementById("roam" + t).style.backgroundColor = "", document.getElementById("roam" + t).querySelector(".yj-icon").className = "yj-icon roam-icon", jd("info", "框选模式下将关闭漫游功能", 2e3), e.exitRoam()), i.measurement && (document.getElementById("measurement" + t).style.backgroundColor = "", document.getElementById("measurement" + t).querySelector(".yj-icon").className = "yj-icon measurement-icon", jd("info", "框选模式下将关闭测量功能", 2e3), e.exitMeasure && e.exitMeasure()), i.sectioning && (document.getElementById("sectioning" + t).style.backgroundColor = "", document.getElementById("sectioning" + t).querySelector(".yj-icon").className = "yj-icon sectioning-icon", jd("info", "框选模式下将关闭剖切功能", 2e3), o.viewerImpl.controlManager.disableTool(Pc.CLIP_BY_BOX), i.sectioning = !1), o.render(), a = jd("info", "按住'Ctrl'键,框选模式为增选;按住'Alt'键,框选模式为减选", 5e3), this.style.backgroundColor = "#1f89de", this.querySelector(".yj-icon").className = "yj-icon multiple-icon active", i.multiple = !i.multiple, o.viewerImpl.controlManager.enableTool(o.viewerImpl, Pc.PICK_BY_RECT) })), n }(r, this), Q.appendChild(R)); var T = document.createElement("button"); T.className = "yj-but", T.title = "构件透明化", T.id = "transparent" + i; var k = document.createElement("div"); k.classList.add("yj-icon"), k.classList.add("transparent-icon"), T.appendChild(k); var D = document.createElement("div"); D.classList.add("transparentModal"), D.classList.add("clearfix"), D.id = "transparentModal" + i; var L = document.createElement("div"); D.appendChild(L); var N = document.createElement("span"); N.innerHTML = "提示信息", N.className = "transparent-info", L.appendChild(N), (uA = document.createElement("div")).className = "subtract", uA.innerHTML = "-", D.appendChild(uA); var O = document.createElement("div"); O.className = "transparentRangeParent", D.appendChild(O); var V = document.createElement("input"); V.type = "range", V.className = "transparentRange", V.setAttribute("step", "0.01"), V.setAttribute("min", "0"), V.setAttribute("max", "1"), O.appendChild(V), (CA = document.createElement("div")).className = "add", CA.innerHTML = "+", D.appendChild(CA), t.options.transparent && (Q.appendChild(T), Q.appendChild(D), D.style.cssText += "margin-left:" + T.style.left - D.style.width / 2 + "px"); var G = document.createElement("div"); G.className = "toolComponentDiv", G.id = "toolComponentDiv" + i, G.style.display = "flex"; var P = document.createElement("button"); P.className = "yj-but", P.title = "构件操作", P.id = "toolComponent" + i; var q = document.createElement("div"); q.classList.add("yj-icon"), q.classList.add("toolComponent-icon"), P.appendChild(q); var j = document.createElement("div"); j.className = "toolComponentModal", j.id = "toolComponentModal" + i, G.appendChild(P), G.appendChild(j), Q.appendChild(G), P.addEventListener("click", (function (A) { "" === j.style.display || "none" === j.style.display ? (DA(), j.style.display = "flex") : j.style.display = "none" })); var H = document.createElement("button"); H.className = "yj-but", H.title = "构件隐藏", H.id = "hide" + i; var Y = document.createElement("div"); Y.classList.add("yj-icon"), Y.classList.add("hide-icon"), H.appendChild(Y), t.options.hide && j.appendChild(H); var W = document.createElement("button"); W.className = "yj-but", W.title = "构件隔离", W.id = "insulate" + i; var J = document.createElement("div"); J.classList.add("yj-icon"), J.classList.add("insulate-icon"), W.appendChild(J), t.options.isolation && j.appendChild(W); var z = document.createElement("button"); z.className = "yj-but", z.title = "构件属性", z.id = "attribute" + i; var Z = document.createElement("div"); Z.classList.add("yj-icon"), Z.classList.add("attribute-icon"), z.appendChild(Z), t.options.attribute && (j.appendChild(z), this.attributeWindow = function (A) { var e = A.lobibox, t = A.toolId, i = A.Flag, o = document.createElement("div"); o.className = "tab-body", o.id = "tab-properties" + t; var n = document.createElement("table"); n.classList.add("sx-table"), n.classList.add("table-no-top"), o.appendChild(n); var r = document.createElement("thead"); n.appendChild(r); var a = document.createElement("tbody"); n.appendChild(a); var s = document.createElement("tr"); s.className = "noprop", a.appendChild(s); var l = document.createElement("td"); return l.innerText = "尚未选择构件", s.appendChild(l), e.window({ title: "属性", width: 334, height: 688, closeOnEsc: !1, closeButton: !0, afterWindowHide: function () { var A = document.getElementById("attribute" + t); i.attribute = !1, A && (A.style.backgroundColor = "", A.querySelector(".yj-icon").className = "yj-icon attribute-icon") }, content: o }) }(r), t.attributeWindow.setPosition({ left: "", right: 5, top: 60 }), t.attributeWindow.windowHide(), z.addEventListener("click", (function () { if (o.attribute) this.style.backgroundColor = "", t.attributeWindow.windowHide(); else { o.attribute = !o.attribute, this.style.backgroundColor = "#1f89de", this.querySelector(".yj-icon").className = "yj-icon attribute-icon active", t.attributeWindow.windowShow(); var e = A.viewerImpl.modelManager.sceneState; e.getSelection() && t.showComponentAttribute(e.getSelection()[0]) } }))); var X = document.createElement("button"); X.className = "yj-but", X.title = "构件线框化", X.id = "wireframe" + i; var _ = document.createElement("div"); _.classList.add("yj-icon"), _.classList.add("wireframe-icon"), X.appendChild(_), t.options.wireframe && j.appendChild(X); var $ = document.createElement("button"); $.className = "yj-but", $.title = "构件变色", $.id = "color" + i, $.style.borderRadius = "0 6px 6px 0"; var AA = document.createElement("div"); AA.classList.add("yj-icon"), AA.classList.add("color-icon"), $.appendChild(AA); var eA = document.createElement("input"); eA.style.cssText += "display:none;", eA.className = "toolColorInput", $.appendChild(eA); var tA = new Hh(eA, { hasOpacity: !0 }).element; tA.id = "colorModal" + i, tA.className = "colorModal", t.options.color && (j.appendChild($), Q.appendChild(tA), tA.style.cssText += "margin-left:" + $.offsetLeft + "px"), tA.querySelector(".btn-yes").addEventListener("click", (function () { var e = A.getHighlightComponentsKey(), i = Kd.getHexStringFromRGB(eA.value), o = Kd.getColorArrayFromRGBA(eA.value)[3]; t.push({ type: "修改颜色", data: { key: e, color: i, opacity: o } }), A.colorfulComponentsByKey(e, i, o) })); var iA = document.createElement("button"); iA.className = "yj-but", iA.title = "模型测量", iA.id = "measurement" + i; var oA = document.createElement("div"); oA.classList.add("yj-icon"), oA.classList.add("measurement-icon"), iA.appendChild(oA), t.options.measurement && (Q.appendChild(iA), iA.addEventListener("click", (function (e) { o.measurement ? (o.measurement = !1, this.style.backgroundColor = "", this.querySelector(".yj-icon").className = "yj-icon measurement-icon", A.viewerImpl.controlManager.disableTool(Pc.PICK_BY_MEASURE)) : (o.measurement = !0, this.style.backgroundColor = "#1f89de", this.querySelector(".yj-icon").className = "yj-icon measurement-icon active", A.viewerImpl.controlManager.enableTool(A.viewerImpl, Pc.PICK_BY_MEASURE)) }))); var nA = document.createElement("div"); nA.className = "toolModelDiv", nA.id = "toolModelDiv" + i, nA.style.display = "flex"; var rA = document.createElement("button"); rA.className = "yj-but", rA.title = "模型操作", rA.id = "toolModel" + i; var aA = document.createElement("div"); aA.classList.add("yj-icon"), aA.classList.add("toolModel-icon"), rA.appendChild(aA); var sA = document.createElement("div"); sA.className = "toolModelModal", sA.id = "toolModelModal" + i, nA.appendChild(rA), nA.appendChild(sA), Q.appendChild(nA), rA.addEventListener("click", (function (A) { "" === sA.style.display || "none" === sA.style.display ? (DA(), sA.style.display = "flex") : sA.style.display = "none" })); var lA = document.createElement("button"); lA.className = "yj-but", lA.title = "模型剖切", lA.id = "sectioning" + i; var cA = document.createElement("div"); cA.classList.add("yj-icon"), cA.classList.add("sectioning-icon"), lA.appendChild(cA), t.options.sectioning && sA.appendChild(lA); var hA = document.createElement("button"); hA.className = "yj-but", hA.title = "模型分解", hA.id = "modelPartition" + i; var dA = document.createElement("div"); dA.classList.add("yj-icon"), dA.classList.add("modelPartition-icon"), hA.appendChild(dA); var pA = document.createElement("div"); pA.classList.add("modelPartitionModal"), pA.id = "modelPartitionModal" + i, pA.style.cssText += "display: none;"; var gA = document.createElement("div"); pA.appendChild(gA); var uA, fA = document.createElement("span"); fA.innerHTML = "提示信息", fA.className = "modelPartition-info", gA.appendChild(fA), (uA = document.createElement("div")).className = "subtract", uA.innerHTML = "-", pA.appendChild(uA); var mA = document.createElement("div"); mA.className = "modelPartitionRangeParent", pA.appendChild(mA); var CA, yA = document.createElement("input"); yA.type = "range", yA.className = "modelPartitionRange", yA.setAttribute("value", "1"), yA.setAttribute("name", "points"), yA.setAttribute("step", "0.01"), yA.setAttribute("min", "1"), yA.setAttribute("max", "3"), mA.appendChild(yA), (CA = document.createElement("div")).className = "add", CA.innerHTML = "+", pA.appendChild(CA), t.options.modelPartition && (sA.appendChild(hA), Q.appendChild(pA), D.style.cssText += "margin-left:" + hA.style.left - pA.style.width / 2 + "px"); var vA = document.createElement("div"); vA.className = "toolPostilDiv", vA.id = "toolPostilDiv" + i, vA.style.display = "flex", (wA = document.createElement("button")).className = "yj-but", wA.title = "批注操作", wA.id = "toolPostil" + i; var IA = document.createElement("div"); IA.classList.add("yj-icon"), IA.classList.add("toolPostil-icon"), wA.appendChild(IA); var EA = document.createElement("div"); EA.className = "toolPostilModal", EA.id = "toolPostilModal" + i, vA.appendChild(wA), vA.appendChild(EA), Q.appendChild(vA), wA.addEventListener("click", (function (A) { "" === EA.style.display || "none" === EA.style.display ? (DA(), EA.style.display = "flex") : EA.style.display = "none" })); var BA = document.createElement("button"); BA.className = "yj-but", BA.title = "添加标签", BA.id = "mark" + i; var xA = document.createElement("div"); if (xA.classList.add("yj-icon"), xA.classList.add("label-icon"), BA.appendChild(xA), t.options.mark && (EA.appendChild(BA), t.mark = new Hd(r, this)), t.options.snapshot) { xh.append(EA, ''); var SA = document.getElementById("snapshot" + i); SA.addEventListener("mouseover", (function (A) { this.style.backgroundColor = "#1f89de" })), SA.addEventListener("mouseout", (function (A) { o[this.id.split(i)[0]] || (this.style.backgroundColor = "") })), t.snapshot = new Zd(r, this) } if (t.options.postil) { var wA; xh.append(EA, wA = ''); var MA = document.getElementById("postil" + i); MA.addEventListener("mouseover", (function (A) { this.style.backgroundColor = "#1f89de" })), MA.addEventListener("mouseout", (function (A) { o[this.id.split(i)[0]] || (this.style.backgroundColor = "") })), t.postil = new Jd(r, this) } var bA = document.createElement("div"); bA.className = "yj-group", bA.style.display = "flex", bA.style.width = "160px", a.appendChild(bA); var UA = document.createElement("button"); UA.className = "yj-but", UA.title = "设置", UA.id = "set" + i, UA.style.borderRadius = "6px"; var FA = document.createElement("div"); FA.classList.add("yj-icon"), FA.classList.add("set-icon"), UA.appendChild(FA); var KA = document.createElement("div"); KA.className = "setModal", KA.id = "setModal" + i; var QA = document.createElement("div"); QA.className = "sceneColorDiv", QA.title = "选择背景颜色", KA.appendChild(QA); var RA = document.createElement("button"); RA.id = "sceneColorSet" + i, RA.classList.add("yj-icon"), RA.classList.add("sceneColorSet"), QA.appendChild(RA); var TA = document.createElement("input"); TA.style.cssText += "display:none;", TA.className = "sceneColorInput", QA.appendChild(TA); var kA = new Hh(TA, { hasOpacity: !0 }).element; function DA() { v && (v.style.display = "none"), D && (D.style.display = "none"), pA && (pA.style.display = "none"), tA && (tA.style.display = "none"), p && (p.style.display = "none"), j && (j.style.display = "none"), sA && (sA.style.display = "none"), EA && (EA.style.display = "none"), KA && (KA.style.display = "none"), w && (w.style.display = "none") } kA.id = "sceneColorModal" + i, kA.className = "sceneColorModal", kA.querySelector(".btn-yes").addEventListener("click", (function () { DA(); var e = Kd.getHexStringFromRGB(TA.value), t = Kd.getColorArrayFromRGBA(TA.value)[3]; A.setSceneBackGroundColor(e, t) })), kA.querySelector(".btn-no").addEventListener("click", (function () { DA() })); var LA = document.createElement("div"); LA.className = "fullScreenDiv", LA.title = "全屏显示", KA.appendChild(LA); var NA = document.createElement("button"); function OA(A) { A.stopPropagation ? A.stopPropagation() : A.cancelBubble = !0 } NA.classList.add("yj-icon"), NA.classList.add("fullScreen"), NA.id = "Fullscreen" + i, LA.appendChild(NA), t.options.setting && (bA.appendChild(UA), bA.appendChild(KA), KA.appendChild(kA), kA.style.cssText += "margin-left:" + (UA.offsetWidth + 5) + "px;"), document.addEventListener("click", (function (A) {})), document.addEventListener("keydown", (function (A) { 27 === (A.keyCode ? A.keyCode : A.which) && (o.roam && b.click(), o.measurement && document.querySelector("#measurement" + i).click(), o.multiple && R && R.click(), o.sectioning && lA.click()), (A.keyCode ? A.keyCode : A.which) === Oh && (!0 === A.ctrlKey && !0 === A.shiftKey && t.undoOrRedo(d + 1), !0 === A.ctrlKey && !1 === A.shiftKey && t.undoOrRedo(d - 1)) })), g.addEventListener("click", (function () { t.clearUndoList(), A.resetScene() })), f.addEventListener("click", (function () { A.adaptiveSize() })), C.addEventListener("click", (function (A) { "none" === v.style.display && DA(), v.addEventListener("click", (function (A) { OA(A) })), w.addEventListener("click", (function (A) { OA(A) })), v.style.display = "none" === v.style.display ? "block" : "none", w.style.display = "none" === w.style.display ? "block" : "none", OA(A) })), document.getElementById("reset" + i).addEventListener("click", (function () { var e = document.getElementById("showSet" + i).checked, t = document.getElementById("highlightSet" + i).checked, o = document.getElementById("viewSet" + i).checked, n = document.getElementById("wireframeSet" + i).checked, r = document.getElementById("colorSet" + i).checked, a = {}; a.visible = e, a.selected = t, a.wireframed = n, a.colorfully = r, a.view = o, A.resetScene(a) })); var VA = document.querySelectorAll("input[type=checkbox].check"); document.querySelector("input[type=checkbox].checkAll").addEventListener("click", (function () { for (var A = 0; VA.length > A; A += 1) VA[A].checked = this.checked })); for (var GA = 0; VA.length > GA; GA += 1) VA[GA].addEventListener("click", (function () { document.querySelector("input[type=checkbox].checkAll").checked = VA.length === document.querySelectorAll("input[type=checkbox].check:checked").length })); this.pathRoam = Yd(r, this, b, 0, K), t.pathRoam.setPosition({ left: "", right: 5, top: 60 }), t.pathRoam.windowHide(); var PA = D.querySelector(".subtract"), qA = D.querySelector(".add"), jA = D.querySelector(".transparentRange"); T.addEventListener("click", (function (e) { if ("none" === D.style.display && DA(), D.addEventListener("click", (function (A) { OA(A) })), D.style.display = "none" === D.style.display ? "block" : "none", 1 > A.getHighlightComponentsKey().length) jd("warning", "未选中构件", 2e3), D.style.display = "none"; else { jA.value = 1, document.querySelector(".transparent-info").innerText = "透明度: " + 100..toFixed(0) + "%" } OA(e) })); var HA = mh.isIE11(); jA.addEventListener(HA ? "change" : "input", (function (e) { var t = A.getHighlightComponentsKey(); document.querySelector(".transparent-info").innerHTML = "透明度: " + (100 * Number(jA.value)).toFixed(0) + "%", A.transparentComponentsByKey(t, Number(jA.value), !1) })), PA.addEventListener("click", (function () { var e = Number(jA.value), t = Number(jA.getAttribute("step")); jA.value = e - t; var i = A.getHighlightComponentsKey(); document.querySelector(".transparent-info").innerHTML = "透明度: " + (100 * Number(jA.value)).toFixed(0) + "%", A.transparentComponentsByKey(i, Number(jA.value), !1) })), qA.addEventListener("click", (function () { var e = Number(jA.value), t = Number(jA.getAttribute("step")); jA.value = e + t; var i = A.getHighlightComponentsKey(); document.querySelector(".transparent-info").innerHTML = "透明度: " + (100 * Number(jA.value)).toFixed(0) + "%", A.transparentComponentsByKey(i, Number(jA.value), !1) })), H.addEventListener("click", (function () { var e = A.getHighlightComponentsKey(); 1 > e.length ? jd("warning", "未选中构件", 2e3) : (t.push({ type: "隐藏", data: e }), A.hideComponentsByKey(e)) })), W.addEventListener("click", (function () { var e = A.getHighlightComponentsKey(); 1 > e.length ? jd("warning", "未选中构件", 2e3) : (t.push({ type: "隔离", data: e }), A.isolateComponentsByKey(e)) })); var YA = document.createElement("div"); YA.className = "section-body"; var WA = document.createElement("div"); WA.style.cssText += "color: #ff6700;top: 10px;height: 60px;text-align: center;font-size: 16px;", YA.appendChild(WA); var JA = document.createElement("span"); JA.innerHTML = "是否显示剖切框", WA.appendChild(JA); var zA = document.createElement("input"); zA.type = "radio", zA.name = "UIControl", zA.value = 1, zA.checked = "checked", WA.appendChild(zA); var ZA = document.createElement("span"); ZA.innerHTML = "显示", WA.appendChild(ZA); var XA = document.createElement("input"); XA.type = "radio", XA.name = "UIControl", XA.value = 0, XA.checked = "", WA.appendChild(XA); var _A = document.createElement("span"); _A.innerHTML = "不显示", WA.appendChild(_A); var $A = document.createElement("button"); $A.innerHTML = "确定", $A.type = "button", $A.style.cssText += "width:80px;height:30px;border-radius:10px;display:block;margin:0 auto;", YA.appendChild($A), this.sectionWindow = qd.window({ title: "剖切", id: "sectionWindow", width: 334, height: 405, closeOnEsc: !1, closeButton: !0, afterWindowHide: function () { o.sectioning = !1, document.getElementById("sectioning" + i).style.backgroundColor = "", zA.checked = "checked", XA.checked = "", A.viewerImpl.controlManager.disableTool(Pc.CLIP_BY_BOX), A.render() }, content: YA }), t.sectionWindow.setPosition({ left: "", right: 5, top: 60 }), t.sectionWindow.windowHide(), lA.addEventListener("click", (function () { if (o.sectioning) return this.style.backgroundColor = "", this.querySelector(".yj-icon").className = "yj-icon sectioning-icon", t.sectionWindow.windowHide(), o.sectioning = !1, void A.disableSectionBox(); o.multiple && (document.getElementById("multiple" + i).style.backgroundColor = "", document.getElementById("multiple" + i).querySelector(".yj-icon").className = "yj-icon multiple-icon", jd("info", "剖切模式下将关闭框选功能", 2e3), A.viewerImpl.controlManager.disableTool(Pc.PICK_BY_RECT), o.multiple = !1), o.roam && (document.getElementById("roam" + i).style.backgroundColor = "", document.getElementById("roam" + i).querySelector(".yj-icon").className = "yj-icon roam-icon", jd("info", "剖切模式下将关闭漫游功能", 2e3), t.exitRoam()), o.measurement && (document.getElementById("measurement" + i).style.backgroundColor = "", document.getElementById("measurement" + i).querySelector(".yj-icon").className = "yj-icon measurement-icon", jd("info", "剖切模式下将关闭测量功能", 2e3), t.exitMeasure && t.exitMeasure()), A.render(), this.style.backgroundColor = "#1f89de", this.querySelector(".yj-icon").className = "yj-icon sectioning-icon active", t.sectionWindow.windowShow(), o.sectioning = !o.sectioning, A.enableSectionBox(), $A.addEventListener("click", (function () { document.querySelector("#sectionWindow input[type=radio]:checked").value > 0 ? A.showSectionBox() : A.hideSectionBox() })) })); var Ae = pA.querySelector(".subtract"), ee = pA.querySelector(".add"), te = pA.querySelector(".modelPartitionRange"); hA.addEventListener("click", (function (e) { o.roam && (document.getElementById("roam" + i).style.backgroundColor = "", jd("info", "模型分解模式下将关闭漫游功能", 2e3), t.exitRoam()), A.render(), pA.addEventListener("click", (function (A) { OA(A) })), "none" === pA.style.display ? (DA(), pA.style.display = "block") : pA.style.display = "none", fA.innerText = "离散系数: " + te.value, OA(e) })), te.addEventListener("change", (function (e) { document.querySelector(".modelPartition-info").innerText = "离散系数: " + te.value; var t = A.getViewerImpl().modelManager.getModelKeys(), i = Number(te.value); isNaN(i) || A.modelsExplosion({ modelKey: t, coefficientX: i, coefficientY: i, coefficientZ: i }) })), Ae.addEventListener("click", (function () { var e = te.value, t = Number(te.getAttribute("step")); te.value = Number(e) - t, document.querySelector(".modelPartition-info").innerText = "离散系数: " + te.value; var i = A.getViewerImpl().modelManager.getModelKeys(), o = Number(te.value); isNaN(o) || A.modelsExplosion({ modelKey: i, coefficientX: o, coefficientY: o, coefficientZ: o }) })), ee.addEventListener("click", (function () { var e = te.value, t = Number(te.getAttribute("step")); te.value = Number(e) + t, document.querySelector(".modelPartition-info").innerText = "离散系数: " + te.value; var i = A.getViewerImpl().modelManager.getModelKeys(), o = Number(te.value); isNaN(o) || A.modelsExplosion({ modelKey: i, coefficientX: o, coefficientY: o, coefficientZ: o }) })), X.addEventListener("click", (function () { var e = A.getHighlightComponentsKey(); 1 > e.length ? jd("warning", "未选中构件", 2e3) : (t.push({ type: "修改线框", data: e }), A.wireFrameComponentsByKey(e, !0)) })), $.addEventListener("click", (function (e) { "none" === tA.style.display && DA(), tA.addEventListener("click", (function (A) { OA(A) })), tA.style.display = "none" === tA.style.display ? "block" : "none", 1 > A.getHighlightComponentsKey().length && (jd("warning", "未选中构件", 2e3), tA.style.display = "none"), OA(e) })), UA.addEventListener("click", (function (A) { KA.addEventListener("click", (function (A) { OA(A) })), "" === KA.style.display || "none" === KA.style.display ? (DA(), KA.style.display = "flex") : KA.style.display = "none", kA.style.display = "none", OA(A) })), RA.addEventListener("click", (function (A) { kA.addEventListener("click", (function (A) { OA(A) })), kA.style.display = "none" === kA.style.display ? "block" : "none", OA(A) })), NA.addEventListener("click", (function (e) { DA(); var t = document.getElementById("Fullscreen" + i); o.fullScreen ? (o.fullScreen = !1, Wh.exitFullScreen(), t.className = "fullScreen", t.title = "全屏显示") : (o.fullScreen = !0, Wh.fullScreen(A.viewportDiv), t.className = "cancelFullScreen", t.title = "取消全屏") })), A.viewportDiv.focus() }, this.createTool2 = function () { var e = document.createElement("div"); e.id = "my-tool2" + i, e.className = "yj-tool2", A.viewerImpl.domElement.appendChild(e), this.toolbarTop = e; var n = document.createElement("div"); n.className = "yj-group", e.appendChild(n); var a = document.createElement("button"); a.className = "yj-but", a.title = "模型树", a.id = "modelTree" + i; var s = document.createElement("div"); s.classList.add("yj-icon"), s.classList.add("modelTree-icon"), a.appendChild(s), t.options.modelTree && n.appendChild(a); var l = document.createElement("button"); l.className = "yj-but", l.title = "查询", l.id = "search" + i; var c = document.createElement("div"); c.classList.add("yj-icon"), c.classList.add("search-icon"), l.appendChild(c); var h = document.createElement("div"); h.className = "yj-group", e.appendChild(h); var d = document.createElement("button"); d.className = "yj-but", d.title = "添加标签", d.id = "mark" + i; var p = document.createElement("div"); p.classList.add("yj-icon"), p.classList.add("label-icon"), d.appendChild(p), t.options.mark && (h.appendChild(d), t.mark = new Hd(r, this)); for (var g = document.querySelectorAll("button"), u = 0; g.length > u; u += 1) g[u].addEventListener("mouseover", (function (A) { this.style.backgroundColor = "#1f89de" })), g[u].addEventListener("mouseout", (function (A) { this.id.split(i).length > 1 && (o[this.id.split(i)[0]] || (this.style.backgroundColor = "")) })); if (A.viewerImpl.modelManager.addEventListener(Rc.ON_CLICK_PICK, (function (e) { o.attribute && (e.intersectInfo ? t.showComponentAttribute(A.viewerImpl.modelManager.sceneState.getSelection()[0]) : t.showComponentAttribute()) })), t.options.snapshot) { xh.append(h, ''); var f = document.getElementById("snapshot" + i); f.addEventListener("mouseover", (function (A) { this.style.backgroundColor = "#1f89de" })), f.addEventListener("mouseout", (function (A) { o[this.id.split(i)[0]] || (this.style.backgroundColor = "") })), t.snapshot = new Zd(r, this) } if (t.options.postil) { xh.append(h, ''); var m = document.getElementById("postil" + i); m.addEventListener("mouseover", (function (A) { this.style.backgroundColor = "#1f89de" })), m.addEventListener("mouseout", (function (A) { o[this.id.split(i)[0]] || (this.style.backgroundColor = "") })), t.postil = new Jd(r, this) } A.viewportDiv.focus() }, this.showComponentAttribute = (s = "", l = document.getElementById("tab-properties" + i), c = function (A, e, t) { var i = document.createElement("tr"); t.parentNode.appendChild(i), i.appendChild(document.createElement("td")), i.querySelector("td").innerHTML = A; var o = document.createElement("td"), n = null === e ? "" : e, r = document.createElement("span"); r.classList.add("value"), r.classList.add("nonEditable"), r.innerHTML = n, o.appendChild(r), i.appendChild(o) }, h = function (A, e) { var t = document.createElement("tr"); t.className = "sx-active", l.querySelector("table tbody").appendChild(t); var i = document.createElement("td"); for (var o in i.colSpan = 2, i.style.fontSize = "14px", t.appendChild(i), i.appendChild(document.createElement("b")), i.firstElementChild.innerHTML = A, e) c(o, e[o], t) }, function (e) { if (l = document.querySelector("#tab-properties" + i), e !== s) { if (void 0 === e) { var o = l.querySelectorAll("table tbody tr"); l.querySelector("table tbody").removeChild(o[0]), l.querySelector("table tbody").innerHTML = ""; var n = document.createElement("tr"); n.className = "noprop"; var r = document.createElement("td"); return r.setAttribute("colspan", "2"), r.innerHTML = "未选中构件", n.appendChild(r), l.querySelector("table tbody").appendChild(n), void(s = e) } s = e, l.querySelector("table tbody").innerHTML = ""; var a = A.viewerImpl.getModelByComponentKey(s), d = ""; a && (d = a.projectKey), t.getComponentAttribute({ key: s, projectKey: d }, (function (A) { if (l.querySelector("table tbody").innerHTML = "", null === A) { var e = document.createElement("tr"); e.className = "noprop"; var t = document.createElement("td"); return t.innerHTML = "没有属性", e.appendChild(t), void l.querySelector("table tbody").appendChild(e) } if (void 0 === A) { var i = document.createElement("tr"); i.className = "noprop"; var o = document.createElement("td"); return o.innerHTML = "属性加载失败", i.appendChild(o), void l.querySelector("table tbody").appendChild(i) } var n = document.createElement("tr"); n.className = "noprop"; var r = document.createElement("th"); n.appendChild(r); var a = document.createElement("span"); a.classList.add("value"), a.classList.add("nonEditable"), a.innerHTML = "名称", r.appendChild(a); var s = document.createElement("th"); n.appendChild(s); var d = document.createElement("span"); d.classList.add("value"), d.classList.add("nonEditable"), d.innerHTML = "值", s.appendChild(d), l.querySelector("table tbody").appendChild(n); var p = A; for (var g in p) "object" === lc(p[g]) ? h(g, p[g]) : "string" == typeof p[g] && c(g, p[g], n) })) } } ), this.undoOrRedo = function (A) { t.maxUndoListLength > A || (A = t.maxUndoListLength), 0 > A && (A = 0); var e = document.querySelectorAll(".history_li"); if (d > A) for (var i = d; i >= A; i -= 1) { p(i + 1); var o = e[i]; o && (o.classList.remove("history_redo"), o.classList.add("history_undo")) } if (A > d) for (var n = d; A > n; n += 1) { g(n); var r = e[n]; r && (r.classList.remove("history_undo"), r.classList.add("history_redo")) } d = A }, this.clearUndoList = function () { d = 0, t.undoList = [], t.redoList = []; var A = document.querySelector(".history"); if (A) { A.innerHTML = ""; var e = document.createElement("span"); e.innerText = "历史记录", e.style.cssText += "color:white", A.appendChild(e) } }, this.push = function (A) { if (t.undoList.length > d && (t.undoList.splice(d, t.maxUndoListLength), t.redoList.splice(d, t.maxUndoListLength)), t.maxUndoListLength > t.undoList.length || (t.undoList.shift(), t.redoList.shift(), d -= 1), t.maxUndoListLength - (d += 1), t.undoList.push(A), t.redoList.push(A), t.options.restore) { var e = document.querySelector(".history"); if (e) { e.innerHTML = ""; var i = document.createElement("span"); i.innerText = "历史记录", i.style.cssText += "color:white", e.appendChild(i); for (var o = 0; d > o; o += 1) { var n = document.createElement("li"); n.innerHTML = t.undoList[o].type, n.undoNum = o + 1, n.title = "点击执行撤销或重做", n.className = "history_li history_redo", n.addEventListener("click", u), e.appendChild(n) } } } }, A.getViewerImpl().getModelManager().addEventListener(Rc.ON_RECTPICK_ADD, (function (A) { A.list && t.push({ type: "框选添加", data: A.list }) })), A.getViewerImpl().getModelManager().addEventListener(Rc.ON_RECTPICK_REMOVE, (function (A) { A.list && t.push({ type: "框选移除", data: A.list }) })), this.getComponentAttribute = function (e, t) { A.getComponentsAttributeByKey(e.key, (function (A) { A && t(A.attribute) })) }, this.exitMeasure = function () { if (o.measurement) { var A = document.getElementById("measurement" + i); A && xh.fireEvent(A, "click") } }, this.exitRoam = function () { if (o.roam) { var A = document.getElementById("roam" + i); A && (xh.fireEvent(A, "click"), o.roam = !1) } } }, _d = function (A) { return new Promise((function (e, t) { var i = Object.assign({ type: "get", cache: !0, headers: { "Content-type": "application/x-www-form-urlencoded" }, data: null, async: !0, success: null, error: null, beforeSend: null, requestQueue: void 0 }, A), o = null; for (var n in (o = window.XMLHttpRequest ? new XMLHttpRequest : new ActiveXObject("Microsoft.XMLHTTP")).onreadystatechange = function () { if (4 === o.readyState || "4" === o.readyState) { var A = o.status; A >= 200 && 300 > A || 0 === A ? (i.success && i.success(o.response || o.responseText, "" === o.responseType || "document" === o.responseType && o.responseXML), e(o.response || o.responseText, "" === o.responseType || "document" === o.responseType && o.responseXML)) : (i.error && i.error(A, o.response || o.responseText, "" === o.responseType || "document" === o.responseType && o.responseXML), t(A, o.response || o.responseText, "" === o.responseType || "document" === o.responseType && o.responseXML)) } }, o.open(i.type, i.url, i.async), i.headers) o.setRequestHeader(n, i.headers[n]); i.responseType && (o.responseType = i.responseType), i.requestQueue ? i.requestQueue.addRequest(o, i.data) : i.beforeSend ? i.beforeSend(o, (function () { o.send(i.data) })) : o.send(i.data) })) }, $d = function () { var A = 0, e = document.createElement("div"); function t(A) { return e.appendChild(A.dom), A } function i(t) { for (var i = 0; e.children.length > i; i++) e.children[i].style.display = i === t ? "block" : "none"; A = t } e.style.cssText = "position:fixed;top:0;left:0;cursor:pointer;opacity:0.9;z-index:10000", e.addEventListener("click", (function (t) { t.preventDefault(), i(++A % e.children.length) }), !1); var o = (performance || Date).now(), n = o, r = 0, a = t(new $d.Panel("FPS", "#0ff", "#002")), s = t(new $d.Panel("MS", "#0f0", "#020")); if (self.performance && self.performance.memory) var l = t(new $d.Panel("MB", "#f08", "#201")); return i(0), { REVISION: 16, dom: e, addPanel: t, showPanel: i, begin: function () { o = (performance || Date).now() }, end: function () { r++; var A = (performance || Date).now(); if (s.update(A - o, 200), A >= n + 1e3 && (a.update(1e3 * r / (A - n), 100), n = A, r = 0, l)) { var e = performance.memory; l.update(e.usedJSHeapSize / 1048576, e.jsHeapSizeLimit / 1048576) } return A }, update: function () { o = this.end() }, domElement: e, setMode: i } }; $d.Panel = function (A, e, t) { var i = 1 / 0, o = 0, n = Math.round, r = n(window.devicePixelRatio || 1), a = 80 * r, s = 48 * r, l = 3 * r, c = 2 * r, h = 3 * r, d = 15 * r, p = 74 * r, g = 30 * r, u = document.createElement("canvas"); u.width = a, u.height = s, u.style.cssText = "width:80px;height:48px"; var f = u.getContext("2d"); return f.font = "bold " + 9 * r + "px Helvetica,Arial,sans-serif", f.textBaseline = "top", f.fillStyle = t, f.fillRect(0, 0, a, s), f.fillStyle = e, f.fillText(A, l, c), f.fillRect(h, d, p, g), f.fillStyle = t, f.globalAlpha = .9, f.fillRect(h, d, p, g), { dom: u, update: function (s, m) { i = Math.min(i, s), o = Math.max(o, s), f.fillStyle = t, f.globalAlpha = 1, f.fillRect(0, 0, a, d), f.fillStyle = e, f.fillText(n(s) + " " + A + " (" + n(i) + "-" + n(o) + ")", l, c), f.drawImage(u, h + r, d, p - r, g, h, d, p - r, g), f.fillRect(h + p - r, d, r, g), f.fillStyle = t, f.globalAlpha = .9, f.fillRect(h + p - r, d, r, n((1 - s / m) * g)) } } }; var Ap = function (A) { this.viewer = A }; Ap.prototype = { construtor: Ap, destroy: function () { this.viewer = null }, update: function (A) { var e = this.getControl(); e && (e.update(A), this.viewer.render()) }, getControl: function () { for (var A = this.viewer.controlManager.tools, e = 0; A.length > e; e += 1) if (A[e].getName() === Pc.CLIP_BY_BOX) return A[e]; return null }, setSectionBox: function (A, e) { this.getControl().setSectionBox(A, e) }, toggle: function (A, e) { this.getControl().toggle(A, e) }, setVisible: function (A) { this.getControl().visible(A) }, setRotatable: function (A) { this.getControl().rotatable(A) }, enablePick: function (A) { this.getControl().enablePick = A }, saveState: function () { return this.getControl().store() }, loadState: function (A) { this.getControl().restore(A) }, reset: function () { this.viewer.getScene().resetClipPlanes() }, recalculate: function () { return this.viewer.getFilter().getVisibleComponentsBbox() }, setProcess: function (A, e) { this.getControl().setProcess(A, e) }, getProcess: function (A) { return this.getControl().getProcess(A) } }; var ep = function (A, e) { H.call(this); var t = { priority: 5, pickableType: Qc.UnPickable, globalSpace: !1, hoverEnabled: !1 }; this.name = A; var i = uh.extend({}, t, e); this.priority = i.priority, this.pickableType = i.pickableType, this.globalSpace = i.globalSpace, this.boundingBox = null, this.hoverEnabled = i.hoverEnabled }; (ep.prototype = Object.create(H.prototype)).constructor = ep, Object.assign(ep, Ld), ep.prototype.removeByName = function (A) { for (var e = this.children, t = 0, i = e.length; i > t; t += 1) if (e[t].name === A) { e.splice(t, 1); break } }, ep.prototype.clear = function () { this.children.length = 0 }, ep.prototype.isGlobalSpace = function () { return this.globalSpace }, ep.prototype.hasChild = function (A) { for (var e = 0, t = this.children.length; t > e; e += 1) if (this.children[e].name === A) return !0; return !1 }, ep.prototype.isPickable = function () { return this.pickableType !== Qc.UnPickable }; var tp = function (A) { this.viewer = A, this.viewportDIV = A.viewerImpl.getRenderer().domElement.parentElement, this.creatSVG = function () { document.getElementById("svgid" + this.viewer.getViewerImpl().uuid) || (this.svg = document.createElementNS("http://www.w3.org/2000/svg", "svg"), this.svg.setAttribute("id", "svgid" + this.viewer.getViewerImpl().uuid), this.svg.setAttribute("style", "width: 100%; height: 100%; position:absolute; left: 0; top:0;"), this.viewportDIV.appendChild(this.svg)) }, this.creatRect = function (A) { var e = A.data.left, t = A.data.top, i = A.data.width, o = A.data.height, n = A.data.visible; this.deleteRect(), n && (this.rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"), this.rect.setAttribute("id", "rectid" + this.viewer.getViewerImpl().uuid), this.rect.setAttribute("x", e), this.rect.setAttribute("y", t), this.rect.setAttribute("width", i), this.rect.setAttribute("height", o), this.rect.setAttribute("style", "fill:#0DFFB2;stroke-width:2;stroke:rgb(0,255,0);fill-opacity:0.1;stroke-opacity:0.9"), this.svg.appendChild(this.rect)) }, this.deleteRect = function () { var A = document.getElementById("rectid" + this.viewer.getViewerImpl().uuid); A && this.svg.removeChild(A) }, this.deleteSVG = function () { if (this.svg) { var A = document.getElementById("rectid" + this.viewer.getViewerImpl().uuid); A && this.svg.removeChild(A), this.viewportDIV.removeChild(this.svg) } }, this.creatMoveCircle = function (A) { var e = A.x, t = A.y; this.circleMov = document.createElementNS("http://www.w3.org/2000/svg", "circle"), this.circleMov.setAttribute("id", "circleMove" + this.viewer.getViewerImpl().uuid), this.circleMov.setAttribute("cx", e), this.circleMov.setAttribute("cy", t), this.circleMov.setAttribute("r", "5"), this.circleMov.setAttribute("style", "fill:#500A11;stroke-width:2;stroke:rgb(0,255,0);fill-opacity:0.9;stroke-opacity:0.9"), this.svg.appendChild(this.circleMov) }, this.changeMoveCircleStyle = function (A) { var e = document.getElementById("circleMove" + this.viewer.getViewerImpl().uuid); e.setAttribute("cx", A[0]), e.setAttribute("cy", A[1]), e.setAttribute("style", "fill:#00ff00;stroke-width:1;stroke:rgb(60,240,240);fill-opacity:0.9;stroke-opacity:0.9") }, this.deleteCircle = function () { var A = document.getElementById("circleMove" + this.viewer.getViewerImpl().uuid); A && this.svg.removeChild(A) }, this.createMoveLine = function (A, e) { var t = A.x, i = A.y, o = e.x, n = e.y; this.deleteMoveLine(), this.moveline = document.createElementNS("http://www.w3.org/2000/svg", "line"), this.moveline.setAttribute("id", "moveLine" + this.viewer.getViewerImpl().uuid), this.moveline.setAttribute("class", "moveLine"), this.moveline.setAttribute("x1", t), this.moveline.setAttribute("y1", i), this.moveline.setAttribute("x2", o), this.moveline.setAttribute("y2", n), this.moveline.setAttribute("stroke", "#0AEA06"), this.moveline.setAttribute("stroke-width", "2"), this.svg.appendChild(this.moveline) }, this.deleteMoveLine = function () { var A = document.getElementById("moveLine" + this.viewer.getViewerImpl().uuid); A && this.svg.removeChild(A) }, this.creatPickCircle = function (A, e) { var t = A.x, i = A.y; this.circlePic = document.createElementNS("http://www.w3.org/2000/svg", "circle"), this.circlePic.setAttribute("id", "circlePick" + this.viewer.getViewerImpl().uuid + e), this.circlePic.setAttribute("class", "circlePick"), this.circlePic.setAttribute("cx", t), this.circlePic.setAttribute("cy", i), this.circlePic.setAttribute("r", "5"), this.circlePic.setAttribute("style", "fill:#00ff00;stroke-width:1;stroke:rgb(60,240,240);fill-opacity:0.9;stroke-opacity:0.9"), this.svg.appendChild(this.circlePic) }, this.creatLine = function (A, e, t, i) { var o = A.x, n = A.y, r = e.x, a = e.y; this.line = document.createElementNS("http://www.w3.org/2000/svg", "line"), this.line.setAttribute("id", "pickline" + this.viewer.getViewerImpl().uuid + i), this.line.setAttribute("class", "pickline"), this.line.setAttribute("x1", o), this.line.setAttribute("y1", n), this.line.setAttribute("x2", r), this.line.setAttribute("y2", a), this.line.setAttribute("stroke", t), this.line.setAttribute("stroke-width", "2"), this.svg.appendChild(this.line) }, this.deleteLineAndCircle = function () { for (var A = this.svg.getElementsByClassName("pickline"), e = this.svg.getElementsByClassName("circlePick"); A.length;) this.svg.removeChild(A[A.length - 1]); for (; e.length;) this.svg.removeChild(e[e.length - 1]) } }; function ip(A, e) { var t = A || 0, i = e || 0; return t === i ? 0 : t > i ? 1 : -1 } function op(A, e) { var t = A.split(".").map((function (A) { return Number(A) || 0 })), i = e.split(".").map((function (A) { return Number(A) || 0 })); return 0 === (ip(t[0], i[0]) || ip(t[1], i[1]) || ip(t[2], i[2])) } function np(A, e) { var t = A.split(".").map((function (A) { return Number(A) || 0 })), i = e.split(".").map((function (A) { return Number(A) || 0 })); return (ip(t[0], i[0]) || ip(t[1], i[1]) || ip(t[2], i[2])) >= 0 } function rp(A, e) { var t = A.split(".").map((function (A) { return Number(A) || 0 })), i = e.split(".").map((function (A) { return Number(A) || 0 })); return (ip(t[0], i[0]) || ip(t[1], i[1]) || ip(t[2], i[2])) > 0 } function ap(A, e) { return !np(A, e) } function sp(A, e) { return !rp(A, e) } var lp = function (A, e) { var i = this; this.viewer = A, this.preRotationHandle = e, this.mouseButtons = { LEFT: t.LEFT, RIGHT: t.RIGHT }, this.visible = !0, this.isAnimationFinish = !0, this.pickedColor = 16763094, this.width = 0, this.height = 0, this.isDisable = !1; var o = null, n = null, r = 0, a = 1, l = 2, c = 220, h = 150, d = 80, p = 1, g = 2, u = 5, f = 6, m = 3, C = 4, v = "Home", I = "Bottom", E = "Top", B = "Left", x = "Right", S = "Front", w = "Back", M = "Bottom_Front", b = "Bottom_Back", U = "Bottom_Right", F = "Bottom_Left", K = "Top_Front", Q = "Top_Back", R = "Top_Right", T = "Top_Left", k = "LeftFront", D = "LeftBack", L = "RightFront", N = "RightBack", O = "Bottom_FrontRight", V = "Bottom_FrontLeft", G = "Bottom_BackLeft", P = "Bottom_BackRight", q = "Top_FrontRight", j = "Top_FrontLeft", H = "Top_BackLeft", W = "Top_BackRight", J = new Y, z = new Ka(-h / 2, h / 2, h / 2, -h / 2, -h / 2, h / 2), Z = new Dd, X = new Xi, _ = new Xi, $ = new Xi; X.add(_), X.add($), this._cube = X; var AA = !1, eA = !1, tA = new s, iA = new s, oA = new s, nA = new s, rA = !1, aA = "", sA = null, lA = -1, cA = !1; this.uninit = function () { this.removeDomEventListeners(), o && (o.removeChild(n.domElement), o = null) }, this.enable = function () { o && n && !n.domElement.parentNode && (o.appendChild(n.domElement), this.addDomEventListeners()) }, this.disable = function () { o && n && n.domElement.parentNode && (this.removeDomEventListeners(), o.removeChild(n.domElement)) }; ! function () { var A = new ko({ color: 0, side: 1 }), e = new De; e.vertices.push(new y(-40, 40, 40), new y(40, 40, 40)); var t = new Go(e, A); $.add(t); var i = new De; i.vertices.push(new y(40, 40, 40), new y(40, 40, -40)); var o = new Go(i, A); $.add(o); var n = new De; n.vertices.push(new y(40, 40, -40), new y(-40, 40, -40)); var r = new Go(n, A); $.add(r); var a = new De; a.vertices.push(new y(-40, 40, -40), new y(-40, 40, 40)); var s = new Go(a, A); $.add(s); var l = new De; l.vertices.push(new y(-40, 40, -40), new y(-40, -40, -40)); var c = new Go(l, A); $.add(c); var h = new De; h.vertices.push(new y(40, 40, -40), new y(40, -40, -40)); var d = new Go(h, A); $.add(d); var p = new De; p.vertices.push(new y(40, 40, 40), new y(40, -40, 40)); var g = new Go(p, A); $.add(g); var u = new De; u.vertices.push(new y(-40, 40, 40), new y(-40, -40, 40)); var f = new Go(u, A); $.add(f); var m = new De; m.vertices.push(new y(-40, -40, 40), new y(40, -40, 40)); var C = new Go(m, A); $.add(C); var v = new De; v.vertices.push(new y(40, -40, 40), new y(40, -40, -40)); var I = new Go(v, A); $.add(I); var E = new De; E.vertices.push(new y(40, -40, -40), new y(-40, -40, -40)); var B = new Go(E, A); $.add(B); var x = new De; x.vertices.push(new y(-40, -40, -40), new y(-40, -40, 40)); var S = new Go(x, A); $.add(S); var w = new Aa; w.load(Pd.back, (function (A) { var e = new Ue(new et(60, 60), new jA({ map: A, color: 16777215, side: 2 })); e.position.set(0, 40, 0), e.rotation.x = .5 * Math.PI, e.name = "Back", _.add(e) })), w.load(Pd.front, (function (A) { var e = new Ue(new et(60, 60), new jA({ map: A, color: 16777215, side: 2 })); e.position.set(0, -40, 0), e.rotation.x = .5 * Math.PI, e.name = "Front", _.add(e) })), w.load(Pd.left, (function (A) { var e = new Ue(new et(60, 60), new jA({ map: A, color: 16777215, side: 2 })); e.position.set(-40, 0, 0), e.rotation.y = .5 * Math.PI, e.rotation.x = .5 * Math.PI, e.name = "Left", _.add(e) })), w.load(Pd.right, (function (A) { var e = new Ue(new et(60, 60), new jA({ map: A, color: 16777215, side: 2 })); e.position.set(40, 0, 0), e.rotation.y = .5 * Math.PI, e.rotation.x = .5 * Math.PI, e.name = "Right", _.add(e) })), w.load(Pd.top, (function (A) { var e = new Ue(new et(60, 60), new jA({ map: A, color: 16777215, side: 2 })); e.position.set(0, 0, 40), e.name = "Top", _.add(e) })), w.load(Pd.bottom, (function (A) { var e = new Ue(new et(60, 60), new jA({ map: A, color: 16777215, side: 2 })); e.position.set(0, 0, -40), e.name = "Bottom", _.add(e) })); var M = new Ne(10, 60, 10), b = new Ue(M, new jA({ color: 16777215 })); b.position.set(35, 0, 35), b.name = "Top_Front", _.add(b); var U = new Ue(M, new jA({ color: 16777215 })); U.position.set(35, 0, -35), U.name = "Bottom_Front", _.add(U); var F = new Ue(M, new jA({ color: 16777215 })); F.position.set(-35, 0, 35), F.name = "Top_Back", _.add(F); var K = new Ue(M, new jA({ color: 16777215 })); K.position.set(-35, 0, -35), K.name = "Bottom_Back", _.add(K); var Q = new Ne(60, 10, 10), R = new Ue(Q, new jA({ color: 16777215 })); R.position.set(0, -35, 35), R.name = "Top_Left", _.add(R); var T = new Ue(Q, new jA({ color: 16777215 })); T.position.set(0, -35, -35), T.name = "Bottom_Left", _.add(T); var k = new Ue(Q, new jA({ color: 16777215 })); k.position.set(0, 35, 35), k.name = "Top_Right", _.add(k); var D = new Ue(Q, new jA({ color: 16777215 })); D.position.set(0, 35, -35), D.name = "Bottom_Right", _.add(D); var L = new Ne(10, 10, 60), N = new Ue(L, new jA({ color: 16777215 })); N.position.set(35, -35, 0), N.name = "LeftFront", _.add(N); var O = new Ue(L, new jA({ color: 16777215 })); O.position.set(35, 35, 0), O.name = "RightFront", _.add(O); var V = new Ue(L, new jA({ color: 16777215 })); V.position.set(-35, -35, 0), V.name = "LeftBack", _.add(V); var G = new Ue(L, new jA({ color: 16777215 })); G.position.set(-35, 35, 0), G.name = "RightBack", _.add(G); var P = new Ne(10, 10, 10), q = new Ue(P, new jA({ color: 16777215 })); q.position.set(35, -35, 35), q.name = "Top_FrontLeft", _.add(q); var j = new Ue(P, new jA({ color: 16777215 })); j.position.set(35, -35, -35), j.name = "Bottom_FrontLeft", _.add(j); var H = new Ue(P, new jA({ color: 16777215 })); H.position.set(35, 35, 35), H.name = "Top_FrontRight", _.add(H); var Y = new Ue(P, new jA({ color: 16777215 })); Y.position.set(35, 35, -35), Y.name = "Bottom_FrontRight", _.add(Y); var W = new Ue(P, new jA({ color: 16777215 })); W.position.set(-35, -35, 35), W.name = "Top_BackLeft", _.add(W); var J = new Ue(P, new jA({ color: 16777215 })); J.position.set(-35, -35, -35), J.name = "Bottom_BackLeft", _.add(J); var z = new Ue(P, new jA({ color: 16777215 })); z.position.set(-35, 35, 35), z.name = "Top_BackRight", _.add(z); var Z = new Ue(P, new jA({ color: 16777215 })); Z.name = "Bottom_BackRight", Z.position.set(-35, 35, -35), _.add(Z) }(), J.add(X); var hA = function (A) { eA = A; for (var e = A ? .8 : 1, t = X.children, i = 0; t.length > i; i += 1) for (var o = t[i].children, n = 0; o.length > n; n += 1) o[n].material.transparent = A, o[n].material.opacity = e }; hA(!1); var dA = function () { sA && sA.material.color.set(sA.currentColor), sA = null }, pA = function (A) { if (void 0 !== o) { var e = xh.getDomOffsetToClient(o), t = new s; if (t.x = A.x - e.left, t.y = A.y - e.top, t.x > 0 && i.width > t.x && t.y > 0 && i.height > t.y) return nA.x = t.x / i.width * 2 - 1, nA.y = -t.y / i.height * 2 + 1, !0 } return !1 }, gA = function () { var A = new y(nA.x, nA.y, .5); Z.setFromCamera(A, z); var e, t = Z.intersectObjects(X.children[0].children); t ? sA !== (e = t.object) && (sA && sA.material.color.set(sA.currentColor), (sA = e).currentColor = sA.material.color.clone(), "" !== sA.name && sA.material.color.set(i.pickedColor)) : dA() }; this.mouseUp = function (A) { A.stopPropagation(); var t = new s(A.clientX, A.clientY), o = pA(t); return AA ? (AA = !1, iA.set(t.x, t.y), oA.subVectors(iA, tA), this.preRotationHandle && !this.preRotationHandle() || (this.viewer.viewerImpl.rotateCamera(oA), tA.copy(iA))) : o && A.button === i.mouseButtons.LEFT && sA && (lA = -1, function (A) { var e = -1; switch (A) { case v: e = Uc.Home; break; case E: e = Uc.Top; break; case I: e = Uc.Bottom; break; case M: e = Uc.BottomFront; break; case b: e = Uc.BottomBack; break; case U: e = Uc.BottomRight; break; case F: e = Uc.BottomLeft; break; case O: e = Uc.BottomFrontRight; break; case V: e = Uc.BottomFrontLeft; break; case G: e = Uc.BottomBackLeft; break; case P: e = Uc.BottomBackRight; break; case K: e = Uc.TopFront; break; case Q: e = Uc.TopBack; break; case R: e = Uc.TopRight; break; case T: e = Uc.TopLeft; break; case q: e = Uc.TopFrontRight; break; case j: e = Uc.TopFrontLeft; break; case H: e = Uc.TopBackLeft; break; case W: e = Uc.TopBackRight; break; case S: e = Uc.Front; break; case w: e = Uc.Back; break; case B: e = Uc.Left; break; case x: e = Uc.Right; break; case k: e = Uc.FrontLeft; break; case D: e = Uc.BackLeft; break; case L: e = Uc.FrontRight; break; case N: e = Uc.BackRight } lA = e }(sA.name), -1 !== lA && (e(lA), null != lA && i.viewer.viewerImpl.rotateCameraByViewCubeSide(lA))), o }, this.mouseMove = function (A) { A.stopPropagation(); var e = !1, t = new s(A.clientX, A.clientY), i = pA(t); if (AA) iA.set(t.x, t.y), oA.subVectors(iA, tA), this.preRotationHandle && !this.preRotationHandle() || (this.viewer.viewerImpl.rotateCamera(oA), tA.copy(iA)); else if (i) { if (eA && (hA(!1), e = !0), gA(), sA) { if ("" !== sA.name) { var o = sA.name; aA !== o && (aA = o, rA = !0, e = !0) } } else "" !== aA && (aA = "", rA = !1, e = !0); e && this.render(), cA = !0 } else cA && (cA = !1, rA && (dA(), rA = !1, e = !0), e && this.render()); return i }, this.mouseDown = function (A) { A.preventDefault(), A.stopPropagation(); var e = new s(A.clientX, A.clientY), t = pA(e); return t && A.button === i.mouseButtons.LEFT && (AA = !1), t }, this.onMouseDownBinded = this.mouseDown.bind(this), this.onMouseMoveBinded = this.mouseMove.bind(this), this.onMouseUpBinded = this.mouseUp.bind(this), this.addDomEventListeners = function () { o && (o.addEventListener("contextmenu", (function (A) { A.preventDefault() }), !1), o.addEventListener("mousedown", this.onMouseDownBinded, !1), window.addEventListener("mousemove", this.onMouseMoveBinded, !1), o.addEventListener("mouseup", this.onMouseUpBinded, !1)) }, this.removeDomEventListeners = function () { o && (o.removeEventListener("contextmenu", (function (A) { A.preventDefault() }), !1), o.removeEventListener("mousedown", this.onMouseDownBinded, !1), window.removeEventListener("mousemove", this.onMouseMoveBinded, !1), window.removeEventListener("mouseup", this.onMouseUpBinded, !1)) }; var uA = function (A) { switch (A) { case r: i.width = c, i.height = c; break; case a: i.width = h, i.height = h; break; case l: default: i.width = d, i.height = d } o.style.width = i.width + "px", o.style.height = i.height + "px" }; this.resize = function (A, e, t) { uA(200 > A || t ? l : a), n.setSize(this.width, this.height) }; this.init = function (A) { (function (A) { A.style.position = "absolute", A.style.display = "block", A.style.outline = "0", A.style.right = "52px", A.style.top = "0px", A.style.opacity = ".6", A.style.display = "flex", A.style.webkitTransition = "opacity .2s ease", A.style.mozTransition = "opacity .2s ease", A.style.msTransform = "opacity .2s ease", A.style.oTransform = "opacity .2s ease", A.style.transition = "opacity .2s ease" })(o = document.createElement("div")), A.appendChild(o), n = new $i({ antialias: !0, alpha: !0, preserveDrawingBuffer: !0 }), o.appendChild(n.domElement), this.resize(A.offsetWidth, A.offsetHeight, this.viewer.viewerImpl.isMobile), this.addDomEventListeners() }; var fA = function (A, e, t) { return A > e ? t >= A - e : t >= e - A }; this.render = function () { if (this.visible && !this.isDisable && n) { var A = this.viewer.viewerImpl.getActiveCameraInfo(), e = A.quaternion.clone().inverse(); this._cube.quaternion.copy(e), -1 === lA && (lA = function (A, e) { var t = A.clone(); t.normalize(); var i = e.clone(); if (i.normalize(), fA(t.x, 0, 1e-4) && fA(t.y, -1, 1e-4) && fA(t.z, 0, 1e-4) && fA(i.x, 0, 1e-4) && fA(i.y, 0, 1e-4) && fA(i.z, -1, 1e-4)) return p; if (fA(t.x, 0, 1e-4) && fA(t.y, 1, 1e-4) && fA(t.z, 0, 1e-4)) { if (fA(i.x, 0, 1e-4) && fA(i.y, 0, 1e-4) && fA(i.z, 1, 1e-4)) return g; if (fA(i.x, 1, 1e-4) && fA(i.y, 0, 1e-4) && fA(i.z, 0, 1e-4)) return g } return fA(t.x, 0, 1e-4) && fA(t.y, 0, 1e-4) && fA(t.z, -1, 1e-4) && fA(i.x, 0, 1e-4) && fA(i.y, 1, 1e-4) && fA(i.z, 0, 1e-4) ? u : fA(t.x, 0, 1e-4) && fA(t.y, 0, 1e-4) && fA(t.z, 1, 1e-4) && fA(i.x, 0, 1e-4) && fA(i.y, 1, 1e-4) && fA(i.z, 0, 1e-4) ? f : fA(t.x, -1, 1e-4) && fA(t.y, 0, 1e-4) && fA(t.z, 0, 1e-4) && fA(i.x, 0, 1e-4) && fA(i.y, 1, 1e-4) && fA(i.z, 0, 1e-4) ? m : fA(t.x, 1, 1e-4) && fA(t.y, 0, 1e-4) && fA(t.z, 0, 1e-4) && fA(i.x, 0, 1e-4) && fA(i.y, 1, 1e-4) && fA(i.z, 0, 1e-4) ? C : -1 }(A.dir, z.up)), n.autoClear = !0, n.render(J, z) } }, this.destroy = function () { n.dispose(), this.disable() } }, cp = function (A, e, t, i, o) { kd.call(this, Ec.PERSPECTIVE, { width: e, height: t, fov: A, near: i, far: o }), this.realUp = this.up.clone(), this.target = new y, this.dirty = !1, this.orthoScale = 1, this.positionPlane = new EA, this.projScreenMatrix = new M, this.viewProjInverse = new M, this.tempVector3 = new y, this.frustum = new Ze }; (cp.prototype = Object.create(kd.prototype)).constructor = cp, cp.prototype._updatePositionPlane = function () { this.positionPlane.setFromNormalAndCoplanarPoint(this.getWorldDirection(new y), this.position) }, cp.prototype._updateFrustum = function () { this.frustum.setFromProjectionMatrix(this.projScreenMatrix) }, cp.prototype.updateMVP = function () { this.dirty && (null === this.parent && this.updateMatrixWorld(), this.matrixWorldInverse.getInverse(this.matrixWorld), this.projScreenMatrix.multiplyMatrices(this.projectionMatrix, this.matrixWorldInverse), this.viewProjInverse.getInverse(this.projScreenMatrix), this._updateFrustum(), this._updatePositionPlane(), this.dirty = !1) }, cp.prototype.getFrustum = function () { return this.dirty && this.updateMVP(), this.frustum }, cp.prototype.lookAtEx = function (A, e, t, i) { var o = new y; o.copy(e), void 0 !== i && "number" == typeof i && o.setLength(i), this.position.subVectors(A, o), this.up.copy(t), this.lookAt(A), this.realUp.copy(t), this.target.copy(A), this.dirty = !0 }, cp.prototype.lookAtEXForTargetPositionUp = function (A, e, t) { this.position.copy(e), this.up = t, this.lookAt(A), this.realUp = t.clone(), this.target = A.clone(), this.dirty = !0 }, cp.prototype.clone = function () { var A = new cp(2 * this.right, 2 * this.top, this.fov, this.near, this.far); return A.position.copy(this.position), A.quaternion.copy(this.quaternion), A.scale.copy(this.scale), A.up.copy(this.up), A.realUp.copy(this.realUp), A.target.copy(this.target), A.aspect = this.aspect, A.fov = this.fov, A.near = this.near, A.far = this.far, A.left = this.left, A.right = this.right, A.top = this.top, A.bottom = this.bottom, A.zoom = this.zoom, A.isPerspective = this.isPerspective, A.updateProjectionMatrix(), A.updateMVP(), A }, cp.prototype.copy = function (A) { return kd.prototype.copy.call(this, A), this.realUp.copy(A.realUp), this.orthoScale = A.orthoScale, this.dirty = A.dirty, this.updateProjectionMatrix(), this.updateMVP(), this }, cp.prototype.setStandardView = function (A, e) { var t = null, i = null; e ? (t = e.getCenter(new y), i = e.getSize(new y)) : t = new y(0, 0, 0); var o = vc.SceneSize, n = o / 2; switch (i || (i = n), A) { case Uc.ISO: var r = new y(-o, o, o), a = new y, s = new y(0, 0, 0); a.subVectors(s, r), this.lookAtEx(t, a, H.DefaultUp); break; case Uc.Top: this.lookAtEx(t, new y(0, 0, -1), new y(0, 1, 0), i ? i.x : n); break; case Uc.Bottom: this.lookAtEx(t, new y(0, 0, 1), new y(0, 1, 0), i ? i.x : n); break; case Uc.Front: this.lookAtEx(t, new y(0, 1, 0), new y(0, 0, 1), i ? i.z : n); break; case Uc.Back: this.lookAtEx(t, new y(0, -1, 0), new y(0, 0, 1), i ? i.z : n); break; case Uc.Right: this.lookAtEx(t, new y(-1, 0, 0), new y(0, 0, 1), i ? i.y : n); break; case Uc.Left: this.lookAtEx(t, new y(1, 0, 0), new y(0, 0, 1), i ? i.y : n); break; case Uc.FrontRight: this.lookAtEx(t, new y(-1, 1, 0), new y(0, 0, 1), i ? i.x + i.y : n); break; case Uc.FrontLeft: this.lookAtEx(t, new y(1, 1, 0), new y(0, 0, 1), i ? i.x + i.y : n); break; case Uc.BackLeft: this.lookAtEx(t, new y(1, -1, 0), new y(0, 0, 1), i ? i.x + i.y : n); break; case Uc.BackRight: this.lookAtEx(t, new y(-1, -1, 0), new y(0, 0, 1), i ? i.x + i.y : n); break; case Uc.BottomFront: this.lookAtEx(t, new y(0, 1, 1), new y(0, 0, 1), i ? i.x + i.z : n); break; case Uc.BottomBack: this.lookAtEx(t, new y(0, -1, 1), new y(0, 0, 1), i ? i.x + i.z : n); break; case Uc.BottomRight: this.lookAtEx(t, new y(-1, 0, 1), new y(0, 0, 1), i ? i.y + i.z : n); break; case Uc.BottomLeft: this.lookAtEx(t, new y(1, 0, 1), new y(0, 0, 1), i ? i.y + i.z : n); break; case Uc.BottomFrontRight: this.lookAtEx(t, new y(-1, 1, 1), new y(0, 0, 1), i ? i.x + i.y + i.z : n); break; case Uc.BottomFrontLeft: this.lookAtEx(t, new y(1, 1, 1), new y(0, 0, 1), i ? i.x + i.y + i.z : n); break; case Uc.BottomBackLeft: this.lookAtEx(t, new y(1, -1, 1), new y(0, 0, 1), i ? i.x + i.y + i.z : n); break; case Uc.BottomBackRight: this.lookAtEx(t, new y(-1, -1, 1), new y(0, 0, 1), i ? i.x + i.y + i.z : n); break; case Uc.TopFront: this.lookAtEx(t, new y(0, 1, -1), new y(0, 0, 1), i ? i.x + i.z : n); break; case Uc.TopBack: this.lookAtEx(t, new y(0, -1, -1), new y(0, 0, 1), i ? i.x + i.z : n); break; case Uc.TopRight: this.lookAtEx(t, new y(-1, 0, -1), new y(0, 0, 1), i ? i.y + i.z : n); break; case Uc.TopLeft: this.lookAtEx(t, new y(1, 0, -1), new y(0, 0, 1), i ? i.y + i.z : n); break; case Uc.TopFrontRight: this.lookAtEx(t, new y(-1, 1, -1), new y(0, 0, 1), i ? i.x + i.y + i.z : n); break; case Uc.TopFrontLeft: this.lookAtEx(t, new y(1, 1, -1), new y(0, 0, 1), i ? i.x + i.y + i.z : n); break; case Uc.TopBackLeft: this.lookAtEx(t, new y(1, -1, -1), new y(0, 0, 1), i ? i.x + i.y + i.z : n); break; case Uc.TopBackRight: this.lookAtEx(t, new y(-1, -1, -1), new y(0, 0, 1), i ? i.x + i.y + i.z : n); break; case Uc.TopToRight: this.lookAtEx(t, new y(0, 1, 0), new y(-1, 0, 0), n); break; case Uc.TopToBack: this.lookAtEx(t, new y(0, 1, 0), new y(0, 0, 1), n); break; case Uc.TopToLeft: this.lookAtEx(t, new y(0, 1, 0), new y(1, 0, 0), n); break; case Uc.TopToFront: this.lookAtEx(t, new y(0, 1, 0), new y(0, 0, -1), n); break; case Uc.BottomToRight: this.lookAtEx(t, new y(0, -1, 0), new y(-1, 0, 0), n); break; case Uc.BottomToBack: this.lookAtEx(t, new y(0, -1, 0), new y(0, 0, -1), n); break; case Uc.BottomToFront: this.lookAtEx(t, new y(0, -1, 0), new y(0, 0, 1), n); break; case Uc.BottomToLeft: this.lookAtEx(t, new y(0, -1, 0), new y(1, 0, 0), n); break; case Uc.FrontToTop: this.lookAtEx(t, new y(0, 0, -1), new y(0, -1, 0), n); break; case Uc.FrontToBottom: this.lookAtEx(t, new y(0, 0, -1), new y(0, 1, 0), n); break; case Uc.FrontToLeft: this.lookAtEx(t, new y(0, 0, -1), new y(1, 0, 0), n); break; case Uc.FrontToRight: this.lookAtEx(t, new y(0, 0, -1), new y(-1, 0, 0), n); break; case Uc.RightToTop: this.lookAtEx(t, new y(-1, 0, 0), new y(0, -1, 0), n); break; case Uc.RightToBottom: this.lookAtEx(t, new y(-1, 0, 0), new y(0, 1, 0), n); break; case Uc.RightToFront: this.lookAtEx(t, new y(-1, 0, 0), new y(0, 0, -1), n); break; case Uc.RightToBack: this.lookAtEx(t, new y(-1, 0, 0), new y(0, 0, 1), n); break; case Uc.BackToTop: this.lookAtEx(t, new y(0, 0, 1), new y(0, -1, 0), n); break; case Uc.BackToBottom: this.lookAtEx(t, new y(0, 0, 1), new y(0, 1, 0), n); break; case Uc.BackToLeft: this.lookAtEx(t, new y(0, 0, 1), new y(-1, 0, 0), n); break; case Uc.BackToRight: this.lookAtEx(t, new y(0, 0, 1), new y(1, 0, 0), n); break; case Uc.LeftToTop: this.lookAtEx(t, new y(1, 0, 0), new y(0, 0, -1), n); break; case Uc.LeftTopBottom: this.lookAtEx(t, new y(1, 0, 0), new y(0, 1, 0), n); break; case Uc.LeftTopBack: this.lookAtEx(t, new y(1, 0, 0), new y(0, 0, 1), n); break; case Uc.LeftTopFront: this.lookAtEx(t, new y(1, 0, 0), new y(0, 0, -1), n); break; case Uc.Keep: break; default: this.lookAtEx(t, new y(-1, -1, -1), new y(0, 0, 1), n) } return this.updateProjectionMatrix(), t }, cp.prototype.zoomToBox = function (A, e, t, i) { t = t || 1, e = -1 > (e = e || 0) ? -1 : e; var o = new aA; if (o.copy(A), 0 !== e) { var n = .5 * A.getSize(new y).length(), r = new y; r.subVectors(o.max, o.min).normalize(), r.multiplyScalar(n * e), o.expandByVector(r) } var s = i || this.getWorldDirection(new y), l = this.up, c = this.aspect, h = a.degToRad(.5 * this.fov), d = o.getSize(new y), p = o.getCenter(new y), g = .5 * d.length() / Math.sin(h) * t, u = new y; u.copy(s), u.setLength(g); var f = new y; f.subVectors(p, u); var m = new y; m.crossVectors(s, l), m.normalize(); var C = new y; C.crossVectors(s, m), C.normalize(); var v = new EA; v.setFromNormalAndCoplanarPoint(m, f); var I = new EA; I.setFromNormalAndCoplanarPoint(C, f); var E = 0, B = 0, x = 0, S = 0, w = 0, M = [new y, new y, new y, new y, new y, new y, new y, new y]; M[0].set(o.min.x, o.min.y, o.min.z), M[1].set(o.min.x, o.min.y, o.max.z), M[2].set(o.min.x, o.max.y, o.min.z), M[3].set(o.min.x, o.max.y, o.max.z), M[4].set(o.max.x, o.min.y, o.min.z), M[5].set(o.max.x, o.min.y, o.max.z), M[6].set(o.max.x, o.max.y, o.min.z), M[7].set(o.max.x, o.max.y, o.max.z); for (var b = 0; 8 > b; b += 1) { var U = new y; U.subVectors(M[b], f); var F = Math.abs(U.dot(s)), K = Math.abs(I.distanceToPoint(M[b])), Q = K * c, R = Math.abs(v.distanceToPoint(M[b])), T = Math.max(K, R / c), k = Math.max(Q, R); T > E && (E = T), B && x && B * F / x >= T || (B = T, x = F), S && w && S * F / w >= k || (S = k, w = F) } var D = S / Math.tan(h) + (g - w), L = B / Math.tan(h) + (g - x), N = 0; if (N = 1 > c ? Math.max(D, L) : Math.min(D, L), this.near > N) { this.near = (N * N + .001 * N) / 16777.216 } if (u.copy(s).normalize().setLength(N), f.subVectors(p, u), this.position.copy(f), this.lookAt(p), this.target.copy(p), !this.isPerspective) { var O = Math.tan(this.fov * Math.PI / 180 / 2) * N; this.orthoScale = O / E, this.zoom = this.orthoScale } return this.updateProjectionMatrix(), this.dirty = !0, p }, cp.prototype.computeRay = function (A, e, t) { var i = new s; if (void 0 === t) i.x = window.innerWidth, i.y = window.innerHeight; else { var o = t === document ? t.body : t; i.x = o.offsetWidth, i.y = o.offsetHeight } var n = new s; n.x = A / i.x * 2 - 1, n.y = -e / i.y * 2 + 1; var r = new CA; return this.isPerspective ? (r.origin.copy(this.position), r.direction.set(n.x, n.y, .5).unproject(this).sub(this.position).normalize()) : (r.origin.set(n.x, n.y, -1).unproject(this), r.direction.set(0, 0, -1).transformDirection(this.matrixWorld)), r }, cp.prototype.screenToWorld = function (A, e, t, i) { var o = this.computeRay(A, e, t), n = this.getWorldDirection(new y).normalize(), r = new EA(n); return r.setFromNormalAndCoplanarPoint(n, i), o.intersectPlane(r, i) }, cp.prototype.getWorldFrustum = function (A) { var e = new M, t = new Ze, i = this.clone(), o = this.target, n = o.clone().sub(this.position).length(), r = new M; r.getInverse(A); var a = new M; a.extractRotation(A); var s = new f; s.setFromRotationMatrix(a), s.inverse(), i.position.applyMatrix4(r); var l = o.clone(); l.applyMatrix4(r); var c = l.clone().sub(i.position), h = c.length(); return c.normalize(), i.far = this.far * (h / n), i.up.applyQuaternion(s).normalize(), i.realUp.applyQuaternion(s).normalize(), i.updateProjectionMatrix(), i.updateMatrixWorld(), e.getInverse(i.matrixWorld), t.setFromMatrix((new M).multiplyMatrices(i.projectionMatrix, e)), i = null, t }, cp.prototype.distanceFromWorldToDrawing = function (A, e) { var t = this.position.clone(), i = this.target.clone(); i.subVectors(this.target, this.position), i.normalize(); var o = new M; return o.getInverse(A), i.add(t).applyMatrix4(o), t.applyMatrix4(o), i.sub(t), i.normalize().multiplyScalar(e), i.add(t).applyMatrix4(A), i.sub(this.position), i.length() }, cp.drawingToWorld = function (A, e) { var t = A.position.clone(), i = A.target.clone(), o = A.up.clone(), n = new M; return n.getInverse(e), o.add(t), o.applyMatrix4(n), t.applyMatrix4(n), i.applyMatrix4(n), o.sub(t), o.normalize(), { position: t, target: i, up: o } }, cp.worldToDrawing = function (A, e) { var t = A.position.clone(), i = A.target.clone(), o = A.up.clone(); return o.add(t), o.applyMatrix4(e), t.applyMatrix4(e), i.applyMatrix4(e), o.sub(t), o.normalize(), { position: t, target: i, up: o } }; var hp = function () { var A = this, e = null, t = {}, i = {}, o = 1e3, n = null, r = null, a = null, s = !1, l = null, c = null, h = null; this.from = function (A) { for (var i in e = A) e.hasOwnProperty(i) && (t[i] = e[i]); return this }, this.to = function (A, e) { return void 0 !== e && (o = e), i = A, this }, this.onStart = function (A) { return l = A, this }, this.onUpdate = function (A) { return c = A, this }, this.onComplete = function (A) { return h = A, this }, this.start = function (A, d) { s = !1, r && cancelAnimationFrame(r), n = Date.now(), a = d ? this.linearInterpolateForTargetPostionUp : this.interpolate, r = requestAnimationFrame((function d() { var p = t, g = i, u = Date.now(); !1 === s && (null !== l && l(e), s = !0); var f = (u - n) / o; e = a(p, g, f = f > 1 ? 1 : f), 1 === f ? (cancelAnimationFrame(r), null !== h && h(e)) : (r = requestAnimationFrame(d, A), null !== c && c(e, f)) }), A) }, this.isAngleGreaterThanPi = function (A, e, t) { var i = new y; return i.crossVectors(A, e), 0 > i.dot(t) }, this.conicInterpolate = function (A, e, t, i) { var o = -e.angleTo(A) * i, n = new y; n.crossVectors(e, A).normalize(); var r = new f; r.setFromAxisAngle(n, o), t.copy(A), t.applyQuaternion(r) }, this.quaternionInterpolate = function (A, e, t, i, o) { var n = new f(A.x, A.y, A.z, 1).normalize(), r = new f(e.x, e.y, e.z, 1).normalize(), a = new f(0, 0, 0, 1), s = new f(0, 0, 0, 1), l = new y; l.crossVectors(A, t).normalize(), a.set(l.x, l.y, l.z, 1).normalize(); .5 > o ? (f.slerp(n, a, s, 2 * o), i.set(s.x, s.y, s.z)) : (f.slerp(a, r, s, 2 * (o - .5)), i.set(s.x, s.y, s.z)) }, this.slerpInterpolate = function (A, e, t, i, o, n) { var r = A.dot(e); r > n ? i.copy(e) : n < Math.abs(r) ? this.quaternionInterpolate(A, e, t, i, o) : this.conicInterpolate(A, e, i, o), i.normalize() }, this.linearInterpolate = function (A, e, t, i, o) { if (A.equals(e)) t.copy(e); else { var n = new y(1, 0, 0), r = new y(0, 0, 1), a = new y, s = A.dot(e); s > o ? t.copy(e) : -s > o ? (o > Math.abs(A.dot(r)) ? a.crossVectors(A, r).normalize() : a.crossVectors(A, n).normalize(), .5 > i ? t.lerpVectors(A, a, 2 * i) : t.lerpVectors(a, e, 2 * (i - .5))) : t.lerpVectors(A, e, i), t.normalize() } }, this.linearInterpolatePosition = function (A, e, t, i) { t.lerpVectors(A, e, i) }, this.sphericalInterpolate = function (A, e, t, i, o, n) { var r = A.clone().sub(e), a = t.clone().sub(i), s = new Os; s.setFromVector3(r); var l = new Os; l.setFromVector3(a); var c = s.theta + (l.theta - s.theta) * n, h = s.phi + (l.phi - s.phi) * n, d = r.length(), p = new Os; p.set(d, h, c); var g = new y; g.setFromSpherical(p), o.copy(g).multiplyScalar(-1) }, this.interpolate = function (e, t, i) { var o = new y, n = new y, r = new y, a = new y, s = e.animTarget, l = e.animUp, c = e.animFocal, h = t.animTarget, d = t.animUp, p = t.animFocal; return A.sphericalInterpolate(e.animPos, s, t.animPos, h, o, i), A.linearInterpolate(l, d, n, i, .9995), A.linearInterpolatePosition(s, h, r, i), A.linearInterpolatePosition(c, p, a, i), { animDir: o, animUp: n, animFocal: a, animTarget: r } }, this.linearInterpolateForTargetPostionUp = function (e, t, i) { var o = new y, n = new y, r = new y, a = e.animTarget, s = e.animPosition, l = t.animTarget, c = t.animPosition; return A.linearInterpolate(e.animUp, t.animUp, n, i, .9995), A.linearInterpolatePosition(a, l, r, i), A.linearInterpolatePosition(s, c, o, i), { animPosition: o, animUp: n, animTarget: r } } }, dp = function () { var A = 800, e = 14, t = new hp; this.setDuration = function (e) { A = e }, this.getDuration = function () { return A }, this.setFrameTime = function (A) { e = A }, this.setStandardView = function (i, o, n, r, a, s) { var l = o.camera, c = l.position.clone(), h = l.target.clone(), d = l.getWorldDirection(new y); d.normalize(); var p = new y; p.copy(l.realUp || l.up), p.normalize(); var g = new y(l.position.clone().sub(h).length(), 0, 0), u = l.setStandardView(i, n); u = o.camera.zoomToBox(n, r); var f = l.position.clone(), m = l.getWorldDirection(new y); m.normalize(); var C = new y; C.copy(l.realUp || l.up), C.normalize(); var v = new y(l.position.clone().sub(u).length(), 0, 0); d.equals(m) && p.equals(C) && h.equals(u) && g.equals(v) ? s && s() : (o.getControlManager().setInteractiveState(!1), t.from({ animPos: c, animDir: d, animUp: p, animTarget: h, animFocal: g }).to({ animPos: f, animDir: m, animUp: C, animTarget: u, animFocal: v }, A).onUpdate((function (A) { o.camera.lookAtEx(A.animTarget, A.animDir, A.animUp, A.animFocal.x), o.cameraControl.update(!0, !0), o.controlManager.dispatchEvent({ type: Rc.ON_CAMERA_ANIMATION_UPDATE }), a && a() })).onComplete((function () { o.camera.lookAtEx(u, m, C, v.x), o.cameraControl.update(!0, !0), s && s(), o.getControlManager().setInteractiveState(!0) })).start(e)) }, this.active = function (i, o, n, r, a) { var s = n.camera, l = new y(i.position.x, i.position.y, i.position.z), c = new y(i.target.x, i.target.y, i.target.z), h = new y(c.distanceTo(l), 0, 0), d = c.clone().sub(l).normalize(), p = new y(i.up.x, i.up.y, i.up.z); p.normalize(); var g = new y(o.position.x, o.position.y, o.position.z), u = new y(o.target.x, o.target.y, o.target.z), f = new y(u.distanceTo(g), 0, 0), m = u.clone().sub(g).normalize(), C = new y(o.up.x, o.up.y, o.up.z); C.normalize(), d.equals(m) && p.equals(C) && c.equals(u) && h.equals(f) ? a && a() : (n.getControlManager().setInteractiveState(!1), t.from({ animPos: l, animDir: d, animUp: p, animTarget: c, animFocal: h }).to({ animPos: g, animDir: m, animUp: C, animTarget: u, animFocal: f }, A).onUpdate((function (A) { var e = A.animTarget; s.lookAtEx(e, A.animDir, A.animUp, A.animFocal.x), r && r(e) })).onComplete((function () { s.lookAtEx(u, m, C, f.x), r && r(u), a && a(), n.getControlManager().setInteractiveState(!0) })).start(e)) }, this.slerpFlyTo = function (i, o, n, r) { var a = o.camera, s = a.position.clone(), l = a.getWorldDirection(new y), c = new y; c.copy(a.realUp || a.up), c.normalize(); var h = a.target.clone(), d = new y(a.position.clone().sub(h).length(), 0, 0), p = (new y).set(i.position.x, i.position.y, i.position.z), g = (new y).set(i.target.x, i.target.y, i.target.z), u = (new y).set(i.up.x, i.up.y, i.up.z), f = g.clone().sub(p), m = new y(f.length(), 0, 0); f.normalize(); var C = u.normalize(); l.equals(f) && c.equals(C) && h.equals(g) && d.equals(m) ? r && r() : t.from({ animPos: s, animDir: l, animUp: c, animTarget: h, animFocal: d }).to({ animPos: p, animDir: f, animUp: C, animTarget: g, animFocal: m }, A).onUpdate((function (A) { var e = A.animTarget; a.lookAtEx(e, A.animDir, A.animUp, A.animFocal.x), n && n(e) })).onComplete((function () { a.lookAtEx(g, f, C, m.x), n && n(g), r && r(), o.getControlManager().setInteractiveState(!0) })).start(e) }, this.flyTo = this.slerpFlyTo, this.linearFlyTo = function (i, o, n, r) { var a = o.camera, s = new y; s.copy(a.realUp || a.up), s.normalize(); var l = a.target.clone(), c = a.position.clone(), h = (new y).set(i.position.x, i.position.y, i.position.z), d = (new y).set(i.target.x, i.target.y, i.target.z), p = (new y).set(i.up.x, i.up.y, i.up.z).normalize(); c.equals(h) && s.equals(p) && l.equals(d) ? r && r() : t.from({ animPosition: c, animUp: s, animTarget: l }).to({ animPosition: h, animUp: p, animTarget: d }, A).onUpdate((function (A) { var e = A.animTarget; a.lookAtEXForTargetPositionUp(e, A.animPosition, A.animUp), n && n(e) })).onComplete((function () { a.lookAtEXForTargetPositionUp(d, h, p), n && n(d), r && r(), o.getControlManager().setInteractiveState(!0) })).start(e, !0) }, this.linearActive = function (i, o, n, r, a) { var s = n.camera, l = (new y).set(i.position.x, i.position.y, i.position.z), c = (new y).set(i.target.x, i.target.y, i.target.z), h = (new y).set(i.up.x, i.up.y, i.up.z); h.normalize(); var d = (new y).set(o.position.x, o.position.y, o.position.z), p = (new y).set(o.target.x, o.target.y, o.target.z), g = (new y).set(o.up.x, o.up.y, o.up.z).normalize(); l.equals(d) && h.equals(g) && c.equals(p) ? a && a() : t.from({ animPosition: l, animUp: h, animTarget: c }).to({ animPosition: d, animUp: g, animTarget: p }, A).onUpdate((function (A) { var e = A.animTarget; s.lookAtEXForTargetPositionUp(e, A.animPosition, A.animUp), r && r(e) })).onComplete((function () { s.lookAtEXForTargetPositionUp(p, d, g), r && r(p), a && a(), n.getControlManager().setInteractiveState(!0) })).start(e, !0) } }, pp = function () { this.condition = [{ type: "IfcWall" }, { type: "IfcRoof" }, { type: "IfcWallStandardCase" }, { type: "IfcDoor" }, { type: "墙" }, { type: "门" }], this.distance = 150, this.factor = 1 }; pp.prototype.setCondition = function (A) { Array.isArray(A) && (this.condition = A) }, pp.prototype.getCondition = function () { return this.condition }, pp.prototype.getDistance = function () { return this.distance }, pp.prototype.getFactor = function () { return this.factor }, pp.prototype.setDistance = function (A) { "number" == typeof A && (this.distance = A) }, pp.prototype.setFactor = function (A) { "number" == typeof A && (this.factor = A) }, pp.prototype.matchConditions = function (A) { var e = this.condition; if (0 === e.length) return !1; for (var t = !0, i = 0, o = e.length; o > i; i += 1) { var n = e[i]; for (var r in n) if (!A.hasOwnProperty(r) || A[r] !== n[r]) { t = !1; break } if (!0 === t) break; e.length - 1 > i && (t = !0) } return t }, pp.prototype.hasCollision = function (A, e) { return !!A && (this.matchConditions(A) && this.distance * this.factor >= e) }; var gp = { MODEL: "Model", GEOMETRY: "Geometry", LINESEGMENTS: "LineSegments", INSTANCEGEOMETRY: "InstanceGeometry", INSTANCEWIREFRAMEGEOMETRY: "InstanceWireframeGeometry", WIREFRAME: "Wireframe", MARKER3D: "Marker3D", CLIPPLANE: "ClipPlane", FILLCLIPPLANE: "FillClipPlane", IBLCUBE: "IBLCube", CUSTOMPLANE: "CustomPlane", PIVOTBALL: "PivotBall", MEASUREPICKPOINT: "MeasurePickPoint", MEASUREPICKLINE: "MeasurePickLine", MEASUREPLANE: "MeasurePlane", MEASURELINE: "MeasureLine", OCTREENODE: "OctreeNode", AREANODE: "AreaNode", AXISNET: "AxisNet", AXISGRIDMANAGER: "AxisGridManager", EXTRUDEBODYMANAGER: "ExtrudeBodyManager", EXTERNALSCENEMANAGER: "ExternalSceneManager", EXTERNALCOMPONENTMANAGER: "ExternalComponentManager", TRANSFORM: "TRANSFORM", RECEIVESHADOWPLANE: "ReceiveShadowPlane" }, up = function () { this.scene = null, this.camera = null, this.octreeRoots = null, this.octantMap = null, this.mouse = new s }, fp = function (A) { this.raycaster = new Dd, this.viewer = A, this.filter = A.getFilter(), this.recursive = !0, this.lastIntersect = null, this.highPriorities = [gp.EXTRUDEBODYMANAGER] }; fp.prototype.destroy = function () { this.viewer = null, this.filter = null, this.raycaster = null, this.lastIntersect = null, this.highPriorities = null }, fp.prototype.intersectExternalComponent = function (A, e, t, i, o) { if (A.visible || o) { for (var n = this.raycaster, r = this.filter, a = function A(e) { var t = e, i = []; if (t.isGroup) for (var o = 0, a = t.children.length; a > o; o += 1) { var s = A(t.children[o]); i = i.concat(s) } else r._isPickable({ userId: t.key }) && t.raycast(n, i); return i }, s = {}, l = 0, c = A.children.length; c > l; l += 1) { var h = A.children[l], d = a(h); if (d.length > 0) { d.sort((function (A, e) { return A.distance - e.distance })), d[0].userId = h.key; var p = s[h.key]; p ? p.distance > d[0].distance && (s[h.key] = d[0]) : s[h.key] = d[0] } } var g = [], u = Object.values(s); if (u.length > 0) for (var f = 0; u.length > f; f += 1) u[f].distance > t.far || t.near > u[f].distance || this.viewer.clipPoint(u[f].point) || g.push(u[f]); return i ? g : (g.sort((function (A, e) { return A.distance - e.distance })), g.length > 0 ? g[0] : null) } }, fp.prototype.defaultIntersect = function (A, e, t, i, o) { if (A.visible || o) { var n = [], r = this.raycaster; ! function A(e) { for (var t = 0, i = e.children.length; i > t; t += 1) { var o = e.children[t]; o.isGroup ? A(o) : o.raycast(r, n) } }(A); var a = []; if (n.length > 0) for (var s = 0; n.length > s; s += 1) n[s].distance > t.far || t.near > n[s].distance || this.viewer.clipPoint(n[s].point) || a.push(n[s]); return i ? a : (a.sort((function (A, e) { return A.distance - e.distance })), a.length > 0 ? a[0] : null) } }, fp.prototype.intersectMeshesWithDistance = function (A, e, t, i, o, n, r, a) { if (!e || !e.mesh) return null; var s = 0, l = uh.MinusEpsilon, c = this.raycaster, h = [], d = this.filter, p = d._hasVisibleFilter(), g = d._hasPickableFilter(), u = this.viewer.modelManager, f = function (A, e) { var t = u.isHiddenSourceObjectUserId(A.userId); if (e) { if (p && !d._isVisible(A) || g && !d._isPickable(A) || t) return !0 } else if (p && !d._isVisible(A) || t) return !0; return !1 }; !0 === this.byGravity ? i.near = 0 : i.near += l; var m = e.info, C = e.mesh, y = []; if (Bh.time("kdNode Pick"), o && n && !n.explosioning) { var v = [], I = new M; I.getInverse(n.getModelMatrix()); var E = c.ray.clone().applyMatrix4(I); if (Array.isArray(o)) for (var B = new M, x = 0; o.length > x; x += 1) { var S = o[x], w = S.modelKey, b = E; if (w) B.getInverse(n.subModel[w]), b = E.clone().applyMatrix4(B); S.intersect(b, v) } else o.intersect(E, v); y = uh.unique(v) } else y = n.getComponentlist(); Bh.timeEnd("kdNode Pick"); var U = Object.keys(n.manager.explosionList); if (n && n.manager && U.length > 0 && (y = y.concat(U), y = uh.unique(y)), Object.keys(u.transformComponent).length > 0) { for (var F in u.transformComponent) y.push(F); y = uh.unique(y) } var K = this.viewer.modelManager.getMatrixWorldGlobal(); Bh.time("Box Pick"); for (var Q = 0, R = y.length; R > Q; Q += 1) { var T = m[y[Q]]; if (T) { var k = T[0]; if (k) { var D = k.boundingBox.clone(); if (D.applyMatrix4(n.getModelMatrix()).applyMatrix4(K), (s = c.ray.intersectBoxWithDistance(D)) >= i.near && i.far >= s) for (var L = 0, N = T.length; N > L; L += 1) { var O = T[L]; if (!f(O, t)) { var V = C[this.viewer.modelManager.getMeshIdFromOctantMap(O)]; if (V) for (var G = 0, P = V.length; P > G; G += 1) h.push({ object: V[G], distance: s, nodeInfo: O }) } } } } } Bh.timeEnd("Box Pick"), Bh.time("Ending Pick"), h.sort((function (A, e) { return A.distance - e.distance })); for (var q = [], j = 0; h.length > j; j += 1) h[j].distance > i.far || i.near > h[j].distance || h[j].object.raycast(c, h[j].nodeInfo, i, this.viewer, q, a); return q.sort((function (A, e) { return A.distance - e.distance })), a ? q : (Bh.timeEnd("Ending Pick"), q.length > 0 ? q[0] : null) }, fp.prototype.intersect = function (A, e, t, i) { var o = this.raycaster; null === e ? o.setFromCamera(A.mouse, A.camera) : o.set(e.origin, e.direction); Bh.time("intersect time"), o.camera = A.camera, o._camera = A.camera, o.viewportSize = A.viewportSize; var n = new y; A.camera.getWorldDirection(n); for (var r = n.dot(o.ray.direction), a = { near: A.camera.near / Math.abs(r), far: A.camera.far / Math.abs(r) }, s = null, l = [], c = A.scene.getGroups(), h = 0; c.length > h; h += 1) if (c[h].isPickable() && 0 !== c[h].children.length) { var d = A.scene.getGroupType(c[h].name), p = d.groupType, g = d.modelKey; if (-1 < this.highPriorities.indexOf(d.groupType)) (s = this.defaultIntersect(c[h], t, a, void 0, !0)) && (s.objectType = c[h].pickableType, s.hoverEnabled = c[h].hoverEnabled, l.push(s)); else if (this.filter._isModelPickable(g)) { switch (p) { case gp.MODEL: var u = this.viewer.modelManager.getModel(g); s = u && u.isDataReady() && u.isVisible() ? this.intersectMeshesWithDistance([], A.octantMap[g], t, a, u.kdTreeNode, u) : null; break; case gp.GEOMETRY: s = vc.MergeComponent ? null : this.intersectMeshesWithDistance(A.octantMap[g], A.octantMap, t, a); break; case gp.EXTERNALCOMPONENTMANAGER: s = this.intersectExternalComponent(c[h], t, a); break; default: s = this.defaultIntersect(c[h], t, a) } s && (s.objectType = c[h].pickableType, s.hoverEnabled = c[h].hoverEnabled, l.push(s)) } } l.sort((function (A, e) { return A.distance - e.distance })), Bh.timeEnd("intersect time"); var f = l.length; if (f > 0) { l.sort((function (A, e) { return A.distance - e.distance })); for (var m = 0; f > m; m += 1) { var C = (s = l[m]).object; if (C.geometry) return s.userId = s.userId || C.key, s.modelKey = C.modelKey, this.lastIntersect = s, s } } return this.lastIntersect = { intersect: s, pickable: t }, null }, fp.prototype.getObjectsByClientCoordinates = function (A) { var e = this.viewer.cameraControl.getIntersectContext(A), t = this.raycaster; return t.setFromCamera(e.mouse, e.camera), t.camera = e.camera, t.viewportSize = e.viewportSize, this.getObjectsByRaycaster(e, t) }, fp.prototype.getObjectsByRaycaster = function (A, e, t) { this.raycaster = e; for (var i = { near: t ? 0 : A.camera.near, far: t ? 1 / 0 : A.camera.far }, o = [], n = A.scene.getGroups(), r = 0; n.length > r; r += 1) if (n[r].isPickable() && 0 !== n[r].children.length) { var a = [], s = A.scene.getGroupType(n[r].name); switch (s.groupType) { case gp.MODEL: var l = s.modelKey, c = this.viewer.modelManager.getModel(l); c && c.isDataReady() && c.isVisible() && (a = this.intersectMeshesWithDistance([], A.octantMap[l], !1, i, c.kdTreeNode, c), o = o.concat(a)); break; case gp.GEOMETRY: break; default: a = this.defaultIntersect(n[r], !1, i, !0), o = o.concat(a) } } return o.sort((function (A, e) { return A.distance - e.distance })), o }, fp.prototype.hitTest = function (A) { var e = this.intersect(A, null, !1); return null !== e ? e.point : null }, fp.prototype.pick = function (A, e) { var t = this.intersect(A, null, !0); return e && e(t), t }, fp.prototype.getIntersectByRay = function (A, e) { return this.intersect(A, e, !0) }; var mp = function (A, e, t, i) { this.viewer = A, this.camera = e, this.domElement = t, this.scene = A.getScene(), this.intersector = new fp(A), this.enabled = !0, this.tempVector3 = new y, this.pivot = null, this.movementSpeed = 8e-4 * vc.SceneSize, this.defaultMovementSpeed = this.movementSpeed, this.minMovementSpeed = .01, this.noZoom = !1, this.minDistance = .1, this.maxDistance = e.far - 2 * vc.SceneSize, this.defaultThroughOutDistance = .1, this.noRotate = !1, this.rotateSpeed = 1, this.noPan = !1, this.keyPanSpeed = 2, this.defaultKeyPanSpeed = this.keyPanSpeed, this.minKeyPanSpeed = .01, this.autoRotate = !0, this.autoRotateSpeed = 2, this.minDistance = 0, this.maxDistance = 1 / 0, this.minZoom = 0, this.maxZoom = 1 / 0, this.enablePolar = !1, this.minPolarAngle = 0, this.maxPolarAngle = Math.PI, this.minAzimuthAngle = -1 / 0, this.maxAzimuthAngle = 1 / 0, this.enableDamping = !1, this.dampingFactor = .25, this.enableZoom = !0, this.zoomSpeed = 1, this.enableRotate = !0, this.rotateSpeed = 1, this.enablePan = !0, this.enablePassThrough = !0, this.isDisableRotate = !1, this.noKeys = !1, this._realManHeight = 1650; var o, n, r, l, c, h, d, p = this, g = 1e-6, u = new y(0, 0, 1), m = new y, C = new f, v = null, I = !1; function E(A, e, t) { if (null == t) return !0; var i = t[0], o = t[1]; if (i >= o) return !1; var n = p.camera, r = n.position; e || (e = r.clone()); var a = n.getWorldDirection(new y), s = n.realUp || n.up, l = a.clone().cross(s).normalize(), c = (new f).setFromAxisAngle(l, A); r.clone().sub(e).normalize(); var h = a.clone().negate(), d = Math.PI - h.angleTo(u.clone()), g = h.clone().projectOnPlane(u.clone()), m = g.angleTo(u.clone()); 0 > g.x && (m = 2 * Math.PI - m), a.applyQuaternion(c).normalize(); var C = a.clone().negate(), v = Math.PI - C.angleTo(u.clone()), I = C.clone().projectOnPlane(u.clone()), E = I.angleTo(u.clone()); if (0 > I.x && (E = 2 * Math.PI - E), Math.abs(E - m) > .001) return !1; if (d > i && o > d) { if (v > o || i > v) return !1 } else if ((d > o ? v - d : d - v) > 0) return !1; return !0 } function B() { var A = p.viewer.modelManager.sceneState; if (A.hasSelection()) { var e = p.viewer.getFilter(), t = p.viewer, i = e.getVisibleComponentSet(A.getSelectionSet()), o = t.getBoundingBoxByIds(i); if (o && !o.isEmpty()) return o.getCenter() } return p.pivot ? p.pivot : p.scene.getBoundingBox().getCenter(new y) } function x(A, e, t, i) { var o = new M; o.getInverse(e); var n = new y(A.position.x, A.position.y, A.position.z), r = n.clone(); r.applyMatrix4(o); var a = new y(t.x, t.y, t.z); return a.add(n), a.applyMatrix4(o), a.sub(r).normalize().multiplyScalar(i), a.add(r), a.applyMatrix4(e), a.sub(n), a } this.collisionManager = new pp, this.pivotBallGroup = null, this.minDollyDistance = 10, this.gravity = 0, this.farFactor = 11.4514, this.sceneLengthUnitFactor = 1, this.destroy = function () { this.viewer = null, this.camera = null, this.domElement = null, this.scene = null, this.intersector.destroy(), this.intersector = null, this.collisionManager = null, this.pivotBallGroup = null }, this.isCameraChanging = function () { return I }, this.setCameraChanging = function (A) { I = A }, this.setCamera = function (A) { this.camera = A }, this.getCamera = function () { return this.camera.updateMVP(), this.camera }, this.dirtyCamera = function (A) { this.camera.dirty = A }, this.getFrustum = function () { return this.camera.getFrustum() }, this.lockAxisZ = function (A) { jh.LockAxisZ = A }, this.isLockedAxisZ = function () { return jh.LockAxisZ }, this.setLockAxisZRange = function (A) { jh.LockAxisZRange = A }, this.getLockAxisZRange = function () { return jh.LockAxisZRange }, this.getClientSize = function () { var A = p.domElement === document ? p.domElement.body : p.domElement; return new s(A.clientWidth, A.clientHeight) }, this.delayHandle = function () { this.timeoutId && clearTimeout(this.timeoutId), this.timeoutId = setTimeout((function () { p.update(!0, !0) }), 200), this.needUpdateRenderList(!1) }, this.processRotate = function (A, e) { var t = this.getClientSize(), i = -2 * Math.PI * A.x / t.x, o = -2 * Math.PI * A.y / t.y; p.handleRotation(i, o, e) }, this.handleRotation = function (A, e, t) { var i = this.camera, o = i.position, n = i.target.clone(), r = i.getWorldDirection(n), a = n.clone().sub(o).length(), s = null, l = function (A) { var e = null, n = null, s = null, l = new y; t ? (n = (e = o.clone().sub(t)).length(), e.normalize(), s = e.clone().applyQuaternion(A).normalize(), i.position.copy(t).add(s.multiplyScalar(n)), r.applyQuaternion(A).normalize(), l.copy(o).add(r.multiplyScalar(a)), i.target.copy(l)) : (r.applyQuaternion(A).normalize(), l.copy(o).add(r.multiplyScalar(a)), i.target.copy(l)) }, c = i.realUp || i.up, h = r.clone().cross(c).normalize().clone().cross(r).normalize(); i.realUp.copy(h); var d = null; if (jh.LockAxisZ) { if (Math.abs(A) > Math.abs(e)) d = u, l(s = (new f).setFromAxisAngle(d, A)), i.realUp.applyQuaternion(s).normalize(); else if (null != jh.LockAxisZRange && Math.abs(e) > 1e-4) { E(e, t, jh.LockAxisZRange) && (d = r.clone().cross(c).normalize(), l(s = (new f).setFromAxisAngle(d, e)), i.realUp.applyQuaternion(s).normalize(), this.adjustCameraUp()) } } else Math.abs(A) < Math.abs(e) ? Math.abs(e) > 1e-4 && (d = r.clone().cross(c).normalize(), l(s = (new f).setFromAxisAngle(d, e)), i.realUp.applyQuaternion(s).normalize(), this.adjustCameraUp()) : (d = i.up.clone().normalize(), l(s = (new f).setFromAxisAngle(d, A)), i.realUp.applyQuaternion(s).normalize()); this.dirtyCamera(!0), this.setCameraChanging(!0) }, this.enabledPolar = function (A) { jh.LockAxisZ = A }, this.setMinPolarAngle = function (A) { "number" == typeof A && (Array.isArray(jh.LockAxisZRange) || (jh.LockAxisZRange = []), jh.LockAxisZRange[0] = A) }, this.setMaxPolarAngle = function (A) { "number" == typeof A && (Array.isArray(jh.LockAxisZRange) || (jh.LockAxisZRange = []), jh.LockAxisZRange[1] = A) }, this.getMinPolarAngle = function () { return jh.LockAxisZRange ? jh.LockAxisZRange[0] : null }, this.getMaxPolarAngle = function () { return jh.LockAxisZRange ? jh.LockAxisZRange[1] : null }, this.adjustCameraForPan = function (A) { var e = this.camera; e.target.add(A), e.position.add(A), this.dirtyCamera(!0), this.setCameraChanging(!0) }, this.updateCamera = function () { var A = this.camera; A.dirty && (A.lookAt(A.target), A.updateMVP(), this.adjustCameraUp(), this.dispatchEvent({ type: Rc.ON_CAMERA_CHANGE, camera: this.camera })) }, this.update = function (A, e) { this.updateCamera(), this.dispatchEvent({ type: Rc.ON_CAMERA_CHANGE, camera: this.camera }); var t = this.camera; A ? (void 0 !== e && this.needUpdateRenderList(e), i(), m.copy(t.position), C.copy(t.quaternion)) : (m.distanceToSquared(t.position) > g || 8 * (1 - C.dot(t.quaternion)) > g) && (i(), m.copy(t.position), C.copy(t.quaternion)) }, this.updateView = function (A) { void 0 !== A && this.needUpdateRenderList(A), this.dispatchEvent({ type: Rc.ON_CAMERA_CHANGE, camera: this.camera }), i() }, this.updateHighlight = function () { this.dispatchEvent({ type: Rc.ON_CAMERA_CHANGE, camera: this.camera }), i(!0) }, this.needUpdateRenderList = function (A) { this.viewer.controlManager.isUpdateRenderList = A }, this.pan = function (A, e) { var t = p.domElement === document ? p.domElement.body : p.domElement, i = new y; function o(A) { var e = p.camera.matrix.elements; i.set(e[0], e[1], e[2]), i.multiplyScalar(-A), p.camera.target.add(i), p.camera.position.add(i) } function n(A) { var e = p.camera.matrix.elements; i.set(e[4], e[5], e[6]), i.multiplyScalar(A), p.camera.target.add(i), p.camera.position.add(i) } if (p.camera.isPerspective) { var r = p.camera.position.clone().sub(p.camera.target).length(); o(2 * A * (r *= Math.tan(p.camera.fov / 2 * Math.PI / 180)) / t.clientHeight), n(2 * e * r / t.clientHeight) } else void 0 !== p.camera.top ? (o(A * (p.camera.right - p.camera.left) / t.clientWidth), n(e * (p.camera.top - p.camera.bottom) / t.clientHeight)) : Bh.warn("WARNING: CloudPickEditor.js encountered an unknown camera type - pan disabled."); this.dirtyCamera(!0), this.setCameraChanging(!0) }, this.panOnWorld = (o = new y, n = new y, r = new y, function (A, e, t, i) { var a = p.getContainerDimensions(), s = A.x - a.left, l = A.y - a.top; o.x = s / a.width, o.y = l / a.height, l = e.y - a.top, n.x = (s = e.x - a.left) / a.width, n.y = l / a.height, r.subVectors(n, o); var c = -r.x * i.x, h = r.y * i.y, d = p.getWorldRight().multiplyScalar(c), g = p.getWorldUp().multiplyScalar(h); t.addVectors(d, g), p.dirtyCamera(!0), p.setCameraChanging(!0) } ), this.adjustCameraForDolly = function (A, e) { var t = A - 1; if (t *= this.zoomSpeed, Math.abs(t) < g) return !1; var i = this.camera, o = i.position, n = this.getWorldEye(), r = new y; e ? r.subVectors(e, o) : r.copy(n), r.multiplyScalar(t); var a = r.length(); i.isPerspective ? this.minDollyDistance > a && r.normalize().multiplyScalar(this.minDollyDistance) : (i.orthoScale *= A, i.setZoom(i.orthoScale)); var s = new y; s.addVectors(o, r), this._goingToDolly(i, s, t) ? (i.position.copy(s), i.target.copy(n.add(s)), this.dirtyCamera(!0), this.setCameraChanging(!0)) : this.resetCameraToMaximumRange() }, this._goingToDolly = function (A, e, t) { if (!A.isPerspective || !vc.ConstraintZoom) return !0; var i = this.scene.getBoundingBox(); if (t > 0) return !!A.getFrustum().intersectsBox(i); var o = i.getSize(this.tempVector3).length(), n = i.getCenter(this.tempVector3), r = .5 * o / Math.tan(a.degToRad(.5 * A.fov)) * this.farFactor; return e.distanceTo(n) < r }, this.dolly = function (A, e, t) { var i = new s(A, e), o = this.getIntersectContext(i), n = this.intersector.hitTest(o); this.adjustCameraForDolly(t, null !== n ? n : null) }, this.dollyByPoint = function (A, e, t) { var i = this.getTrackingPoint(A, e); this.adjustCameraForDolly(t, i) }, this.endOperation = function () { this.intersector.lastIntersect = null }, this.zoom = function (A, e, t) { var i; i = 1 + A, void 0 === e || void 0 === t ? this.adjustCameraForDolly(i, null) : this.dollyByPoint(e, t, i), this.update() }, this.getContainerDimensions = function () { return xh.getDomOffsetToClient(this.domElement) }, this.computeFrustum = (l = new M, c = new M, function (A, e, t, i, o, n) { var r = this.camera, s = r.near * Math.tan(a.degToRad(.5 * r.fov)), h = s * r.aspect; l.makePerspective(((A - n.left) / n.width * 2 - 1) * h, ((e - n.left) / n.width * 2 - 1) * h, (-(t - n.top) / n.height * 2 + 1) * s, (-(i - n.top) / n.height * 2 + 1) * s, r.near, r.far), r.updateMatrixWorld(), r.matrixWorldInverse.getInverse(r.matrixWorld), c.multiplyMatrices(l, r.matrixWorldInverse), o.setFromProjectionMatrix(c) } ), this.screenToCanvas = function (A, e) { var t = this.getContainerDimensions(); return { x: A - t.left, y: e - t.top } }, this.mapScreenToLocal = function (A, e, t) { var i = this.getContainerDimensions(); t.set(A - i.left, i.height - (e - i.top)) }, this.mapWindowToViewport = function (A, e, t) { var i = this.getContainerDimensions(), o = t || new s; return o.x = (A - i.left) / i.width * 2 - 1, o.y = -(e - i.top) / i.height * 2 + 1, o }, this.getCameraName = function () { return this.camera === this.viewer.defaultCamera ? this.camera.isPerspective ? Ec.PERSPECTIVE : Ec.ORTHOGRAPHIC : this.camera.name }, this.getCameraInfo = function () { var A = new Qd(this.getCameraName(), this.camera.position, this.camera.target, this.camera.up); return JSON.stringify(A) }, this.isKeepZoom = function (A, e, t) { this.dirtyCamera(!0), this.setCameraChanging(!0), void 0 === e && (e = this.minDistance), void 0 === t && (t = this.maxDistance); var i = this.camera.position, o = this.camera.target, n = new y; n.copy(i).sub(o); var r = n.length() * (2 - A); return !(e > r || r > t) }, this.computeRotation = function () { var A = new M; A.lookAt(this.camera.position, this.camera.target, this.camera.up); var e = new f; e.setFromRotationMatrix(A); var t = new F; return t.setFromQuaternion(e, void 0, !1), t }, this.adjustCameraUp = function () { this.camera.realUp.z > 0 ? this.camera.up = new y(0, 0, 1) : 0 > this.camera.realUp.z ? this.camera.up = new y(0, 0, -1) : this.camera.realUp.x > 0 ? this.camera.up = new y(1, 0, 0) : 0 > this.camera.realUp.x ? this.camera.up = new y(-1, 0, 0) : this.camera.realUp.y > 0 ? this.camera.up = new y(0, 1, 0) : 0 > this.camera.realUp.y && (this.camera.up = new y(0, -1, 0)) }, this.getWorldEye = function () { return this.camera.target.clone().sub(this.camera.position) }, this.getWorldRight = function () { var A = new y, e = this.camera.up, t = this.getWorldEye(); return A.crossVectors(t, e), 0 === A.lengthSq() && (e.z > e.y ? t.y -= 1e-4 : t.z += 1e-4, A.crossVectors(t, e)), A.normalize() }, this.getWorldRightByRealUp = function () { var A = new y, e = this.camera.realUp, t = this.getWorldEye(); return A.crossVectors(t, e), 0 === A.lengthSq() && (e.z > e.y ? t.y -= 1e-4 : t.z += 1e-4, A.crossVectors(t, e)), A.normalize() }, this.getWorldUp = function () { var A = this.getWorldRight(), e = this.getWorldEye(); return A.cross(e).normalize() }, this.getWorldDimension = function (A, e) { var t = this.camera.position, i = this.getWorldEye().normalize(), o = this.getTrackingPoint(A, e).clone().sub(t), n = Math.abs(i.dot(o)), r = this.getContainerDimensions(), l = r.width / r.height, c = 2 * n * Math.tan(a.degToRad(.5 * this.camera.fov)); return new s(c * l, c) }, this.getWorldPointFromNearPlane = function (A, e) { var t = new y(A, e, 0); return t.unproject(this.camera), t }, this.getTrackingPoint = function (A, e) { var t = new s(A, e), i = this.getIntersectContext(t), o = this.intersector.hitTest(i), n = this.camera.position; if (!o) { var r = i.mouse, a = this.getWorldEye(), l = a.clone().normalize(), c = this.getWorldPointFromNearPlane(r.x, r.y), h = new CA; if (this.camera.isPerspective) h.origin.copy(n), h.direction.copy(c.clone().sub(n).normalize()); else { var d = c.clone(); d.sub(a), h.origin.copy(d), h.direction.copy(l) } if (v) { var p = new EA; if (p.setFromNormalAndCoplanarPoint(l, v), o = h.intersectPlane(p, new y)) { var u = o.distanceTo(n); g > u && (o = this.getTrackingPointFromBoundingBox(l, h)) } else o = this.getTrackingPointFromBoundingBox(l, h) } else o = this.getTrackingPointFromBoundingBox(l, h); o || (Bh.log("tracking point is default!"), o = c) } return n.equals(o) && (o = null), v = o && o.clone(), o }, this.getTrackingPointFromBoundingBox = function (A, e) { return this.viewer.getScene().getTrackingPointFromBoundingBox(A, e) }, this.setCameraPosition = function (A) { var e = this.camera, t = this.getWorldEye(), i = t.length(), o = t.clone(); o.normalize(), o.setLength(i), e.position.copy(A), e.target.addVectors(e.position, o), this.dirtyCamera(!0), this.setCameraChanging(!0) }, this.moveStraight = function (A, e) { var t = this.camera.position, i = this.camera.target; if (e) { var o = new y(i.x - t.x, 0, i.z - t.z), n = A / o.length(), r = new y(o.x * n, 0, o.z * n); t.add(r), i.add(r) } else { var a = i.clone().sub(t); this.camera.translateZ(-A), i.addVectors(t, a) } this.dirtyCamera(!0), this.setCameraChanging(!0) }, this.getIntersectContext = function (A) { var e = new up; return e.scene = p.viewer.getScene(), e.camera = this.camera, null !== A && this.mapWindowToViewport(A.x, A.y, e.mouse), e.viewportSize = p.viewer.getRenderer().getSize(new s), e.octantMap = p.viewer.modelManager.octantToObjectMap, e }, this.getLastIntersect = function () { return this.intersector.lastIntersect }, this.calculatePivot = function (A, e) { var t = this, i = this.viewer, o = i.getFilter(), n = i.getScene(), r = null; function a(A) { var e = t.getIntersectContext(A), i = t.intersector.hitTest(e); if (i) return i; var o = n.getBoundingBox(); if (n.hasClipPlanes() && n.getClipPlanes().isEnabled()) { var r = n.getClipPlanes().getClipBoundingBox(); o.intersect(r) } else if (n.hasFillClipPlanes() && n.getFillClipPlane().isEnabled()) { var a = n.getFillClipPlane().getFillClipBoundingBox(); o.intersect(a) } return o.getCenter(new y) } var s = null, l = null; switch (A) { case kc.SELECTION: if (n.hasClipPlanes() && n.getClipPlanes().isEnabled() && (s = n.getClipPlanes().getClipBoundingBox()) && !s.isEmpty() && n.getClipPlanes().isVisible()) { r = s.getCenter(); break } n.hasFillClipPlanes() && n.getFillClipPlane().isEnabled() && (l = n.getFillClipPlane().getFillClipBoundingBox()); var c = o.getVisibleComponentSet(i.modelManager.sceneState.getSelectionSet(), i), h = i.getBoundingBoxByIds(c); mh.isMobileDevice() || !h || h.isEmpty() ? r = a(e) : (s ? h.intersect(s) : l && h.intersect(l), r = h.getCenter(new y)); break; case kc.CENTER: r = n.getBoundingBoxWorld().getCenter(new y); break; case kc.CAMERA: r = null; break; default: r = a(e) } return this.dirtyCamera(!0), this.setCameraChanging(!0), this.pivot = r, r }, this.touchUpdateRotationInPersonView = function (A, e) { this.dirtyCamera(!0), this.setCameraChanging(!0); var t = this, i = this.camera.position, o = this.camera.target.clone().sub(i).length(), n = this.camera.getWorldDirection(new y), r = this.camera.realUp || this.camera.up, a = n.clone().cross(r).normalize(), s = a.clone().cross(n).normalize(); this.camera.realUp.copy(s); var l = jh.LockAxisZRange, c = null, h = null; if (Math.abs(A) > Math.abs(e)) c = u, h = A; else { if (jh.LockAxisZ && !E(e, this.camera.target, l)) return; c = a; var d = new y(0, 0, 1).clone().cross(r), p = d.dot(a), m = Math.asin(d.length()); 0 > p && (m = -m), m + e > Math.PI / 4 - g ? e = Math.PI / 4 - g - m : m + e < -Math.PI / 4 + g && (e = -Math.PI / 4 + g - m), h = e } var C, v, I = (new f).setFromAxisAngle(c, h); C = I, v = new y, n.applyQuaternion(C).normalize(), v.copy(i).add(n.multiplyScalar(o)), t.camera.target.copy(v), this.camera.realUp.applyQuaternion(I).normalize() }, this.touchUpdateRotationInModelView = function (A, e, t) { this.dirtyCamera(!0), this.setCameraChanging(!0); var i = t || this.scene.getBoundingBox().getCenter(new y), o = this.camera.position, n = this.camera.target.clone().sub(o).length(), r = o.clone().sub(i), a = r.length(), s = null, l = this.camera.getWorldDirection(new y); r.normalize(); var c = function (A) { var e = new y, t = r.clone().applyQuaternion(A).normalize(); o.copy(i).add(t.multiplyScalar(a)), l.applyQuaternion(A).normalize(), e.copy(o).add(l.multiplyScalar(n)), p.camera.target.copy(e) }, h = this.camera.realUp || this.camera.up, d = l.clone().cross(h).normalize(), m = d.clone().cross(l).normalize(); this.camera.realUp.copy(m); var C = null; if (jh.LockAxisZ) { if (Math.abs(A) > Math.abs(e)) C = u, c(s = (new f).setFromAxisAngle(C, A)), this.camera.realUp.applyQuaternion(s).normalize(); else if (null != jh.LockAxisZRange && Math.abs(e) > 1e-4) { E(e, i, jh.LockAxisZRange) && (C = l.clone().cross(h).normalize(), c(s = (new f).setFromAxisAngle(C, e)), this.camera.realUp.applyQuaternion(s).normalize(), this.adjustCameraUp()) } } else if (Math.abs(A) > Math.abs(e)) C = this.camera.up.clone().normalize(), c(s = (new f).setFromAxisAngle(C, A)), this.camera.realUp.applyQuaternion(s).normalize(); else if (Math.abs(e) > .01) { C = l.clone().cross(h).normalize(); var v = new y(0, 1, 0).clone().cross(h), I = v.dot(d), x = Math.asin(v.length()); 0 > I && (x = -x), x + e > Math.PI / 2 - g ? e = Math.PI / 2 - g - x : x + e < -Math.PI / 2 + g && (e = -Math.PI / 2 + g - x), c(s = (new f).setFromAxisAngle(C, e)), this.camera.realUp.applyQuaternion(s).normalize(), this.adjustCameraUp() } this.pivotBallGroup || function () { p.pivotBallGroup = p.scene.getOrCreateGroup(gp.PIVOTBALL, { priority: 10, globalSpace: !1 }); var A = new er(15, 64, 64), e = new Ue(A, new Ir({ color: 16777215, depthTest: !1, opacity: .5, transparent: !0, side: 2 })), t = new Ue(A = new er(1, 64, 64), new Ir({ color: 16711680, depthTest: !1, opacity: .5, transparent: !0, side: 2 })); p.pivotBallGroup.add(e), p.pivotBallGroup.add(t) }(), this.pivotBallGroup.visible = !0; for (var S = function () { var A = p.camera, e = A.position, t = p.camera.target.clone().sub(e); t.normalize(); var i = new EA; i.setFromNormalAndCoplanarPoint(t.clone().negate(), B()), i.normalize(); var o = i.distanceToPoint(e) * Math.tan(.5 * A.fov), n = p.getContainerDimensions(); return 2 * o / (n.height - n.top) }(), w = B(), M = 0; this.pivotBallGroup.children.length > M; M += 1) { var b = this.pivotBallGroup.children[M]; b.position.copy(w), b.scale.set(S, S, S), b.updateMatrixWorld() } }, this.touchUpdateRotation = function (A, e) { var t = this.camera.position; this.scene.getBoundingBox().containsPoint(t) ? this.touchUpdateRotationInPersonView(A, e) : this.touchUpdateRotationInModelView(A, e, B()) }, this.clearTouchRotateState = function () { this.pivotBallGroup && (this.pivotBallGroup.visible = !1) }, this.touchEndHandler = function () { this.viewer.controlManager.cameraChange = !1, this.clearTouchRotateState(), this.touchUpdate() }, this._adjustCameraForDolly = function (A, e) { var t = e - 1; if (Math.abs(t) < g) return !1; var i = this.camera, o = i.position, n = this.getWorldEye(), r = new y; A ? r.subVectors(A, o) : r.copy(n), r.multiplyScalar(t); var a = r.length(); i.isPerspective && this.minDollyDistance > a && r.normalize().multiplyScalar(this.minDollyDistance); var s = new y; return s.addVectors(o, r), i.isPerspective || (i.orthoScale *= e, i.setZoom(i.orthoScale)), i.position.copy(s), i.target.copy(n.add(s)), this.dirtyCamera(!0), this.setCameraChanging(!0), !0 }, this.touchDolly = function (A, e, t) { var i = new s(A, e), o = this.getIntersectContext(i), n = this.intersector.hitTest(o); this._adjustCameraForDolly(null !== n ? n : null, t) }, this.touchUpdate = (h = new y, d = new f, function () { var A = new y; A.copy(p.camera.up), p.camera.up.copy(p.camera.realUp), p.camera.lookAt(p.camera.target), p.camera.up.copy(A), p.camera.updateMVP(), (h.distanceToSquared(p.camera.position) > g || 8 * (1 - d.dot(this.camera.quaternion)) > g) && (this.dispatchEvent({ type: Rc.ON_CAMERA_CHANGE, camera: this.camera }), i(), p.dirtyCamera(!1), h.copy(p.camera.position), d.copy(p.camera.quaternion)) } ), this.goTurnForWalk = function (A) { var e = this.getCamera(), t = e.position, i = e.target, o = new y(i.x - t.x, i.y - t.y, 0), n = Math.cos(A), r = Math.sin(A), a = new y(o.x * n - o.y * r, o.x * r + o.y * n, 0); i.x = t.x + a.x, i.y = t.y + a.y, this.dirtyCamera(!0), this.setCameraChanging(!0) }, this.goPitchForWalk = function (A) { var e = this.getCamera(), t = e.position, i = e.target, o = i.x - t.x, n = i.y - t.y, r = new y(Math.sqrt(o * o + n * n), 0, i.z - t.z), a = Math.cos(A), s = Math.sin(A), l = new y(r.x * a - r.z * s, 0, r.x * s + r.z * a); i.z = t.z + l.z, this.dirtyCamera(!0), this.setCameraChanging(!0) }, this.goUpDownForWalk = function (A) { var e = this.getCamera(), t = e.position, i = e.target, o = new y(0, 0, 1), n = x(e, this.scene.getMatrixGlobal(), o, A); t.z += n.z, i.z += n.z, this.dirtyCamera(!0), this.setCameraChanging(!0) }, this.stepCameraForWalk = function (A, e) { var t = this.getCamera(), i = t.position, o = t.target, n = new y(o.x - i.x, o.y - i.y, 0).normalize(), r = new y(0, 0, 1), a = n.clone().cross(r), s = this.scene.getMatrixGlobal(), l = null; switch (A) { case qc.FORWARD: (l = x(t, s, n, e)).z = 0; break; case qc.BACK: n.multiplyScalar(-1), (l = x(t, s, n, e)).z = 0; break; case qc.LEFT: a.multiplyScalar(-1), (l = x(t, s, a, e)).z = 0; break; case qc.RIGHT: (l = x(t, s, a, e)).z = 0 } i.add(l), o.add(l), this.dirtyCamera(!0), this.setCameraChanging(!0) }, this.hitTestWithGround = function () { var A = this.getCamera(), e = A.up.clone().multiplyScalar(-1), t = new CA(A.position.clone(), e), i = this.getIntersectContext(null), o = this.intersector.byGravity; this.intersector.byGravity = !0; var n = this.intersector.intersect(i, t, !1); return this.intersector.byGravity = o, n }, this.projectPositionToBottom = function (A) { var e = void 0; if (A instanceof Array) e = new y(A[0], A[1], A[2]); else { if (!(A instanceof y)) return; e = A } this.getCamera(); var t = new CA(e, new y(0, 0, -e.z).normalize()), i = this.getIntersectContext(null), o = this.intersector.byGravity; this.intersector.byGravity = !0; var n = this.intersector.intersect(i, t, !1); if (this.intersector.byGravity = o, n) return n.point }, this.hitTestForward = function (A) { var e = this.getCamera(), t = this.getWorldEye(); t.normalize(), t = t.multiplyScalar(A); var i = new CA(e.position.clone(), t), o = this.getIntersectContext(null); return o.camera.near = -1, this.intersector.intersect(o, i, !1) }, this.hitTestRight = function (A) { var e = this.getCamera(), t = this.getWorldEye(); t.normalize(); var i = t.cross(e.up).normalize(); i = i.multiplyScalar(A); var o = new CA(e.position.clone(), i), n = this.getIntersectContext(null); return n.camera.near = -1, this.intersector.intersect(n, o, !1) }, this.computeGravity = function () { this.gravity = 0; var A = this.hitTestWithGround(); if (null === A) { var e = this.scene.getMatrixGlobal(), t = new M; t.getInverse(e); var i = this.camera.position.clone(); i.applyMatrix4(t), i.z = this.scene.getBoundingBoxWorld().min.z || 0, i.applyMatrix4(e), this.distanceToGround = Math.abs(this.camera.position.z - i.z) } if (void 0 === this.manHeight) this.computeManHeight(); else { var o = A ? A.distance - this.manHeight : this.distanceToGround - this.manHeight; if (o /= this.scene.getGlobalScaleFactor(), .1 > Math.abs(o)) return 0; this.gravity = o } }, this.computeManHeight = function () { if (!this.manHeight) { var A = this.hitTestWithGround(), e = this.scene.getMatrixGlobal(), t = new M; if (t.getInverse(e), null != A) { var i = A.point.clone(); i.applyMatrix4(t), i.z += this._realManHeight * this.sceneLengthUnitFactor, i.applyMatrix4(e), this.manHeight = Math.abs(A.point.z - i.z) } else { var o = this.camera.position.clone(); o.applyMatrix4(t), o.z = 0; var n = o.clone(); n.z += this._realManHeight * this.sceneLengthUnitFactor, o.applyMatrix4(e), n.applyMatrix4(e), this.manHeight = Math.abs(n.z - o.z) } } }, this.setRealManHeight = function (A) { A !== this._realManHeight && (this._realManHeight = A, this.manHeight = void 0) }, this.getRealManHeight = function () { return this._realManHeight }, this.walkWithParallelEye = function () { var A = this.camera, e = this.getWorldEye().length(), t = this.scene.getBoundingBox().getCenter(new y), i = new y; i.subVectors(t, A.position); var o = i.length(); i.z = 0, i.normalize(), i.multiplyScalar(o), A.position.subVectors(t, i), A.target.addVectors(A.position, i.normalize().multiplyScalar(e)); var n = new y(0, 0, 1); A.up.copy(n), A.realUp.copy(n), this.dirtyCamera(!0), this.setCameraChanging(!0), this.update(!0) }, this.updateFlyMove = function (A, e) { var t = this.camera; this.dirtyCamera(!0), this.setCameraChanging(!0); var i = qc; A & i.FORWARD && t.translateZ(-e), A & i.BACK && t.translateZ(e), A & i.LEFT && t.translateX(-e), A & i.RIGHT && t.translateX(e), A & i.UP && t.translateY(e), A & i.DOWN && t.translateY(-e), this.flyOnWorld() }, this.flyOnWorld = function () { var A = this.camera, e = A.up.clone(); A.realUp && A.up.copy(A.realUp), A.lookAt(A.target), A.realUp && A.up.copy(e), this.updateCamera(), this.adjustCameraUp(), i(), this.dirtyCamera(!1), m.copy(A.position), C.copy(A.quaternion) }, this.rotateForFly = function (A, e, t, i) { var o = this.camera, n = o.position, r = o.target, a = r.clone().sub(n), s = new y(0, 1, 0), l = o.realUp || o.up, c = a.clone().cross(l).normalize(); if (this.dirtyCamera(!0), this.setCameraChanging(!0), jh.LockAxisZ && (e = 0), 0 !== e) { var h = (new f).setFromAxisAngle(c, -e), d = a.clone(); d.applyQuaternion(h); var p = d.angleTo(s); t > (p -= .5 * Math.PI) || p > i || a.applyQuaternion(h) } if (0 !== A) { var g = (new f).setFromAxisAngle(s, -A); a.applyQuaternion(g) } r.addVectors(n, a), this.flyOnWorld() }, this.fitAndRotateBySelection = function () { var A = this.viewer; A.setPointRotateMode(kc.SELECTION), A.zoomToSelection() }, this.flyToPointWithParallelEye = function (A) { var e = this.getWorldEye(), t = e.length(), i = e.clone(); i.y = 0, i.normalize(), i.setLength(t); var o = new y(0, 0, 1); this.camera.up = o, this.camera.realUp = o.clone(), this.camera.position.copy(A), this.camera.target.addVectors(this.camera.position, i), this.update(!0) }, this.flyToPoint = function (A) { var e = this.getWorldEye(); this.camera.position.copy(A), this.camera.target.addVectors(this.camera.position, e), this.update(!0) }, this.setRoamingWalkAbsoluteHeight = function (A) {}, this.setCameraHeight = function (A, e) { this.cameraAbsoluteHeightEnabled = !1, this.cameraRelativeHeight = e, void 0 === this.cameraConstraintHeights ? this.cameraConstraintHeights = [] : this.cameraConstraintHeights.length = 0; for (var t = 0, i = A.length; i > t; t += 1) this.cameraConstraintHeights[t] = A[t] }, this.setCameraAbsoluteHeight = function (A) { this.cameraAbsoluteHeightEnabled = !0, this.cameraAbsoluteHeight = A }, this.updateCameraHeight = function () { var A = this.scene, e = this.getCamera(), t = A.drawingToWorld(e.position), i = t.z, o = null, n = null; if (this.cameraAbsoluteHeightEnabled) void 0 === this.cameraAbsoluteHeight && (this.cameraAbsoluteHeight = i), o = this.cameraAbsoluteHeight; else if (void 0 === this.cameraConstraintHeights) o = i; else { var r = uh.findRange(this.cameraConstraintHeights, i); if (o = this.cameraConstraintHeights[r], o += this.cameraRelativeHeight, this.cameraConstraintHeights.length - 1 > r) { var a = this.cameraConstraintHeights[r + 1]; o > a && (o = a) } } o !== i && (n = A.worldToDrawing({ x: t.x, y: t.y, z: o }), this.setCameraPosition(n)) }, this.getRaycaster = function (A, e) { var t = new Dd, i = new s; return this.mapWindowToViewport(A, e, i), t.setFromCamera(i, this.camera), t }, this.translateCameraForWalk = function (A, e) { var t = this.collisionManager; if (0 !== A.x) if (!1 === vc.EnableHitDetection) this.stepCameraForWalk(qc.RIGHT, A.x * e); else { var i = 1; 0 > A.x && (i = -1); var o = this.hitTestRight(i); if (o) { var n = this.viewer.modelManager.getNodeInfosByUserId(o.userId); if (!t.hasCollision({ type: n ? n[0].type : null }, o.distance)) { var r = e; Math.abs(e) > o.distance && (r = e > 0 ? o.distance - t.distance * t.factor - .1 * this.sceneLengthUnitFactor : t.distance * t.factor - o.distance + .1 * this.sceneLengthUnitFactor), this.stepCameraForWalk(qc.RIGHT, A.x * r) } } else this.stepCameraForWalk(qc.RIGHT, A.x * e) } if (0 !== A.y) if (!1 === vc.EnableHitDetection) this.stepCameraForWalk(qc.BACK, A.y * e); else { var a = 1; A.y > 0 && (a = -1); var s = this.hitTestForward(a); if (s) { var l = this.viewer.modelManager.getNodeInfosByUserId(s.userId); if (!t.hasCollision({ type: l ? l[0].type : null }, s.distance)) { var c = e; Math.abs(e) > s.distance && (c = e > 0 ? s.distance - t.distance * t.factor - .1 * this.sceneLengthUnitFactor : t.distance * t.factor - s.distance + .1 * this.sceneLengthUnitFactor), this.stepCameraForWalk(qc.BACK, A.y * c) } } else this.stepCameraForWalk(qc.BACK, A.y * e) } if (0 !== A.z) this.goUpDownForWalk(A.z * e * .5); else { var h = e; if (0 !== this.gravity) { var d = Math.abs(this.gravity); h = d > h ? .2 * d : d } this.gravity > 0 ? this.goUpDownForWalk(-h) : 0 > this.gravity && this.goUpDownForWalk(h) } }, this.rotateCameraForWalk = function (A, e) { 0 !== A.x && (this.goPitchForWalk(A.x * Math.PI), A.x = 0), 0 !== A.z && (this.goTurnForWalk(-A.z * Math.PI * e), A.z = 0) }, this.zoomCameraForWalk = function (A) { this.adjustCameraForDolly(A, null) }, this.movePlane = function (A, e, t, i, o) { if (void 0 === o) { var n = new EA; n.setComponents(A.x, A.y, A.z, A.w), o = new y, n.coplanarPoint(o) } var r = new y(A.x, A.y, A.z), a = this.camera.getWorldDirection(new y), s = new EA; s.setFromNormalAndCoplanarPoint(a, o); var l = this.getRaycaster(e.clientX, e.clientY), c = new y, h = this.getRaycaster(t.x, t.y), d = new y; if (l.ray.intersectPlane(s, c) && h.ray.intersectPlane(s, d)) { c.subVectors(c, d), c.projectOnVector(r); var p = c.length(); if (0 > c.dot(r) && (p = -p), 0 !== p) return i && (r.multiplyScalar(p), p = r.x + r.y + r.z), p } return null }, this.getZenith = function () { var A = this.camera.position, e = p.viewer.getBoundingBox().getCenter(); return A.clone().sub(e.clone()).clone().angleTo(u.clone()) }, this.getAzimuth = function () { var A = this.camera.position, e = p.viewer.getBoundingBox().getCenter(), t = A.clone().sub(e.clone()).clone().projectOnPlane(u.clone()), i = t.angleTo(u.clone()); return 0 > t.x && (i = 360 - i), i }, this.getCurrentRangeofCamera = function () { var A = this.camera, e = this.viewer.getBoundingBox(), t = e.getCenter(), i = A.position, o = .5 * e.getSize().length() / Math.tan(a.degToRad(.5 * A.fov)); return t.distanceTo(i) / o }, this.setMaximalRangeofCamera = function (A) { this.farFactor = A || 2 }, this.getMaximalRangeofCamera = function () { return this.farFactor }, this.cameraWithinMaximumRange = function (A) { var e = A || this.farFactor; return this.getCurrentRangeofCamera() <= e }, this.resetCameraToMaximumRange = function (A) { var e = this.camera, t = this.viewer.getBoundingBox(), i = t.getCenter(), o = e.position, n = this.farFactor; "number" == typeof A && (n = A); var r = (new y).subVectors(i, o), s = .5 * t.getSize().length() / Math.tan(a.degToRad(.5 * e.fov)); r.setLength(n * s); var l = i.clone().sub(r), c = this.getWorldEye(); this.camera.position.copy(l), this.camera.target.copy(c.add(l)), this.updateView(!0) }, this.setZoomSpeed = function (A) { "number" == typeof A && A > 0 && (this.zoomSpeed = A) }, this.getZoomSpeed = function () { return this.zoomSpeed }, this.setZoomOutLimitRate = function (A) { "number" == typeof A && A > 0 && (this.farFactor = A) }, this.getZoomOutLimitRate = function () { return this.farFactor }, this.setSceneUnit = function (A) { var e = 1; switch (A) { case "m": e = .001; break; case "mm": e = 1; break; case "km": e = 1e-6; break; default: e = 1 } this.collisionManager.setFactor(e), this.sceneLengthUnitFactor = e } }; Object.assign(mp.prototype, Ld.prototype); var Cp = function () { this.duration = 500, this._state = null }; Cp.prototype.rotateCameraByViewCubeSide = function (A, e, t, i) { var o = A.target.clone(), n = e.getCenter(new y), r = A.quaternion.clone(), a = A.position.clone(), s = this._calculateDistanceAndEuler(t, e), l = (new f).setFromEuler(s.euler).inverse(), c = new M; c.makeRotationFromQuaternion(l); var h = c.elements, d = new y(-h[8], -h[9], -h[10]).normalize(); d.setLength(s.distance); var p = n.clone().sub(d); if (!a.equals(p) || !r.equals(l)) { var g = this._calculatePositionRotateInfo(r, l, a, p); this._state && this._state.timerID && (cancelAnimationFrame(this._state.timerID), this._state.timerID = void 0), this._state = { startTime: Date.now(), startQuaternion: r, endQuaternion: l, startPosition: a, endPosition: p, startTarget: o, endTarget: n, positionRotateInfo: g, onUpdate: i }, this._state.timerID = requestAnimationFrame(this._animate.bind(this)) } }, Cp.prototype.cancelAnimation = function () { this._state && this._state.timerID && (cancelAnimationFrame(this._state.timerID), this._state = void 0) }, Cp.prototype._animate = function () { if (this._state) { var A = Date.now(), e = this._state, t = e.startTarget, i = e.endTarget, o = e.startQuaternion, n = e.endQuaternion, r = e.startPosition, a = e.endPosition, s = e.positionRotateInfo, l = Math.min((A - e.startTime) / this.duration, 1); l = this._easyOut(l); var c = n.clone(); o.equals(n) || f.slerp(o, n, c, l); var h = a; r.equals(a) || (h = s ? this._rotatePositionAroundCenter(s, r, a, l) : r.clone().lerp(a, l)); var d = i.clone(); t.equals(i) || (d = d.lerpVectors(t, i, l)), "function" == typeof this._state.onUpdate && this._state.onUpdate(l, c, h, d), 1 === l ? (cancelAnimationFrame(this._state.timerID), this._state = null) : this._state.timerID = requestAnimationFrame(this._animate.bind(this)) } }, Cp.prototype._calculateDistanceAndEuler = function (A, e) { var t = -45, i = 0, o = -135, n = 0, r = e ? e.getSize(new y) : { x: 0, y: 0, z: 0 }; switch (A) { case Uc.Home: break; case Uc.Front: t = -90, i = 0, o = 0; break; case Uc.Right: t = -90, i = 0, o = -90; break; case Uc.Back: t = -90, i = 0, o = -180; break; case Uc.Left: t = -90, i = 0, o = -270; break; case Uc.Top: t = 0, i = 0, o = 0; break; case Uc.Bottom: t = -180, i = 0, o = -180; break; case Uc.TopFront: t = -45, i = 0, o = -90; break; case Uc.TopRight: t = -45, i = 0, o = -180; break; case Uc.TopBack: t = -45, i = 0, o = 90; break; case Uc.TopLeft: t = -45, i = 0, o = 0; break; case Uc.BottomFront: t = -135, i = 0, o = 270; break; case Uc.BottomRight: t = -135, i = 0, o = -180; break; case Uc.BottomBack: t = -135, i = 0, o = 90; break; case Uc.BottomLeft: t = -135, i = 0, o = 0; break; case Uc.FrontRight: t = -90, i = 0, o = -135; break; case Uc.BackRight: t = -90, i = 0, o = -225; break; case Uc.BackLeft: t = -90, i = 0, o = 45; break; case Uc.FrontLeft: t = -90, i = 0, o = -45; break; case Uc.TopFrontRight: t = -45, i = -0, o = -135; break; case Uc.TopBackRight: t = -45, i = 0, o = -225; break; case Uc.TopBackLeft: t = -45, i = 0, o = -315; break; case Uc.TopFrontLeft: t = -45, i = 0, o = -45; break; case Uc.BottomFrontRight: t = -135, i = 0, o = -135; break; case Uc.BottomBackRight: t = -135, i = 0, o = -225; break; case Uc.BottomBackLeft: t = -135, i = 0, o = 45; break; case Uc.BottomFrontLeft: t = -135, i = 0, o = -45 } var a = Math.PI / 180, s = new F(t * a, i * a, o * a); return 0 === (n = r.x + r.y + r.z) && (n = vc.SceneSize / 2), { euler: s, distance: n } }, Cp.prototype._easyOut = function (A) { return A * (2 - A) }, Cp.prototype._calculatePositionRotateInfo = function (A, e, t, i) { var o = (new f).multiplyQuaternions(e, A.clone().inverse()); o.normalize(); var n = new y(o.x, o.y, o.z).normalize(), r = 2 * Math.acos(o.w); if (0 !== r) { var a = null; if (r === Math.PI) a = (new y).addVectors(t, i).divideScalar(2); else { var s = (new y).addVectors(t, i), l = (new y).subVectors(i, t), c = n.clone().cross(l).normalize(), h = .5 * l.length() / Math.tan(r / 2); c.setLength(h), a = (new y).addVectors(s.multiplyScalar(.5), c) } var d = null, p = null, g = (new y).subVectors(t, a), u = g.length(), m = (new y).subVectors(i, t); if (r === Math.PI) p = -1, d = (new y).crossVectors(m, n); else { var C = (new y).subVectors(i, a); p = Math.cos(r), p = Math.max(-1, Math.min(1, p)), d = C.clone().sub(g.clone().multiplyScalar(p)) } return { center: a, dot: p, vec: d, start: g, radiusLength: u } } }, Cp.prototype._rotatePositionAroundCenter = function (A, e, t, i) { if (0 === i) return e; if (i >= 1) return t; var o = Math.acos(A.dot) * i, n = A.start.clone(), r = A.vec.clone().normalize(), a = n.multiplyScalar(Math.cos(o)), s = r.multiplyScalar(Math.sin(o) * A.radiusLength), l = a.add(s); return l.add(A.center), l }; var yp = function (A) { this.name = A, this._mousePressed = !1 }; yp.prototype.getName = function () { return this.name }, yp.prototype.onExit = function () {}, yp.prototype.destroy = function () {}, yp.prototype.processMouseDown = function (A) { return !1 }, yp.prototype.processMouseMove = function (A) { return !1 }, yp.prototype.processMouseUp = function (A) { return !1 }, yp.prototype.processMouseWheel = function (A) { return !1 }, yp.prototype.processMouseDoubleClick = function (A) { return !1 }, yp.prototype.processKeyDown = function (A) { return !1 }, yp.prototype.processKeyUp = function (A) { switch (A.keyCode) { case qh: this._mousePressed = !1 } return !1 }, yp.prototype.processTouchstart = function (A) { return !1 }, yp.prototype.processTouchmove = function (A) { return !1 }, yp.prototype.processTouchend = function (A) { return !1 }, yp.prototype.processHover = function (A) { return !1 }, yp.prototype.onEvent = function (A) { var e = !1; switch (A.type) { case "touchmove": e = this.processTouchmove(A); break; case "touchstart": e = this.processTouchstart(A); break; case "touchend": e = this.processTouchend(A); break; case "keydown": e = this.processKeyDown(A); break; case "keyup": e = this.processKeyUp(A); break; case "mousewheel": case "DOMMouseScroll": e = this.processMouseWheel(A); break; case "mousedown": this._mousePressed = !0, e = this.processMouseDown(A); break; case "mousemove": e = this._mousePressed ? this.processMouseMove(A) : this.processHover(A); break; case "mouseup": this._mousePressed = !1, e = this.processMouseUp(A); break; case "dblclick": e = this.processMouseDoubleClick(A) } return e }; var vp = function (A) { yp.call(this, Pc.CLIP_BY_BOX), this.viewer = A, this.scene = A.getScene(), this.enablePick = !1, this.cameraControl = A.cameraControl, this.clipStartPoint = new y, this.startPt = new s, this.onClipBox = !1, this.mapLockedBoxFaces = {}, this.mapBoxFaceIndex = { 0: "right", 1: "left", 2: "top", 3: "bottom", 4: "front", 5: "back" }; for (var e = [], t = 0; 6 > t; t += 1) e.push(new EA); var i = this.scene.getClipPlanes(!0); i.updateClippingParams = function (t) { if (0 === t.iClipPlane.value) A.getRenderer().clippingPlanes = Object.freeze([]); else { for (var i = 0, o = t.iClipPlane.value; o > i; i += 1) { var n = t.vClipPlane.value[i], r = e[i]; r.setComponents(-n.x, -n.y, -n.z, -n.w), r.normalize() } A.getRenderer().clippingPlanes = e, this.calculateClipBoundingBox(e) } }, i.init(), this.selectIndex = null, this.planeDistance = 0, this.offsetSpeed = .02, this.toggle = function (A, e) { i.enable(A, e) }, this.visible = function (A) { i.visible = A }, this.rotatable = function (A) { i.rotatable = A }, this.store = function () { return i.store() }, this.restore = function (A) { i.restore(A) }, this.reset = function () { i.reset() }, this.pointToScreen = function (A) { var e = this.cameraControl.camera, t = new M; t.multiplyMatrices(e.projectionMatrix, e.matrixWorldInverse); var i = new p(A.x, A.y, A.z, 1); i.applyMatrix4(t); var o = new s; o.x = (i.x / i.w + 1) / 2, o.y = 1 - (i.y / i.w + 1) / 2; var n = this.cameraControl.getContainerDimensions(); return o.x = o.x * n.width + n.left, o.y = o.y * n.height + n.top, o }, this.getPlaneDistanceInScreen = function () { if (null === this.selectIndex) return null; if (2 > this.selectIndex) { var A = i.center.clone(), e = i.center.clone(); A.x -= i.cubeSize.x, e.x += i.cubeSize.x; var t = this.pointToScreen(A), o = this.pointToScreen(e); return t.x - o.x } var n = i.center.clone(), r = i.center.clone(); r.y -= i.cubeSize.y, n.y += i.cubeSize.y; var a = this.pointToScreen(r), s = this.pointToScreen(n); return a.y - s.y }, this.getPickPoint = function (A, e) { var t = this.cameraControl.camera, i = this.cameraControl.getContainerDimensions(), o = (A - i.left) / i.width * 2 - 1, n = (i.height - (e - i.top)) / i.height * 2 - 1, r = new Dd; return r.setFromCamera(new s(o, n), t), r.ray.intersectPlane(this.plane) }, this.getSelectIndex = function () { return i.selectIndex }, this._isVisible = function () { return i.visible }, this.isRotate = function () { return i.rotatable }, this.offset = function (A) { var e = Math.floor(this.selectIndex / 2); i.offset(this.selectIndex, this.selectIndex > 3 ? this.selectIndex % 2 == 1 ? -A * i.cubeSize.getComponent(e) * 2 : A * i.cubeSize.getComponent(e) * 2 : -A * i.cubeSize.getComponent(e) * 2) }, this.setSectionBox = function (A, e) { var t = new aA(new y(A.x, A.y, A.z), new y(e.x, e.y, e.z)); t.applyMatrix4(this.scene.getMatrixGlobal()), i.setSectionBox(t.min, t.max) }, this.calculateOffsetByBox = function (A, e) { var t = new aA(new y(A.x, A.y, A.z), new y(e.x, e.y, e.z)); t.applyMatrix4(this.scene.getMatrixGlobal()), t.setFromCenterAndSize(t.getCenter(), t.getSize().multiplyScalar(this.scene.getExpandScalar())), i.calculateOffsetByBox(t.min, t.max) }, this.moveSectionPlane = function (A, e) { i.moveSectionPlane(A, e) }, this.rotateSectionBox = function (A, e) { i.rotateSectionBox(A, e) }, this.rotate = function (A, e) { 2 === this.selectIndex || 3 === this.selectIndex ? i.rotX(e / 180 * Math.PI * .1) : i.rotY(A / 180 * Math.PI * .1) }, this.update = function (A) { i.update(A) }, this.cancelHighLight = function () { i.cancelHighLight() }, this.highLight = function () { i.highLight() }, this.lockBoxFaces = function (A) { var e = !0; try { for (var t, i = A[Symbol.iterator](); !(e = (t = i.next()).done); e = !0) { this.mapLockedBoxFaces[t.value] = !0 } } catch (A) {} finally { try { !e && i.return && i.return() } catch (A) {} } }, this.unlockBox = function () { this.mapLockedBoxFaces = {} }, this.setProcess = function (A, e) { this.mapLockedBoxFaces[A] || i.setProcess(A, e) }, this.getProcess = function (A) { return i.getProcess(A) } }; (vp.prototype = Object.create(yp.prototype)).constructor = vp, vp.prototype.destroy = function () { this.cameraControl = null, this.intersectPoint = null, this.selectIndex = null, this.normal = null, this.plane = null, this.pickHelper = null, this.scene = null, this.viewer = null }, vp.prototype.onExit = function () { this.toggle(!1, !1) }, vp.prototype.processMouseDown = function (A) { if (this.startPt.set(A.clientX, A.clientY), !this.enablePick && A.button === t.LEFT) { var e = this.cameraControl.getRaycaster(A.clientX, A.clientY), i = this.scene.getClipPlanes().hitTest(e), o = this.cameraControl.getIntersectContext(new s(A.clientX, A.clientY)), n = this.cameraControl.intersector.intersect(o, null, !0); if (null !== n && i.distance >= n.distance) return yp.prototype.processMouseDown(this, A); if (this.selectIndex = this.getSelectIndex(), this.planeDistance = this.getPlaneDistanceInScreen(), null !== this.selectIndex) return this.highLight(), this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0), this.enablePick = !0, this.clipStartPoint = e.ray.at(i.distance, this.clipStartPoint), !0 } return yp.prototype.processMouseDown(this, A) }, vp.prototype.processHover = function (A) { if (!this.enablePick) { var e = !1, t = this.cameraControl.getRaycaster(A.clientX, A.clientY), i = this.scene.getClipPlanes(), o = this.getSelectIndex(); null !== o && this.cancelHighLight(); i.hitTest(t); if (this.selectIndex = this.getSelectIndex(), null !== this.selectIndex) { if (this.highLight(), !this.onClipBox) this.onClipBox = !0, this.cameraControl.viewer.modelManager.dispatchEvent({ type: Rc.ON_CLIP_HOVER, onClipBox: !0, event: A }); e = !0 } else if (this.onClipBox) { this.onClipBox = !1, this.cameraControl.viewer.modelManager.dispatchEvent({ type: Rc.ON_CLIP_HOVER, onClipBox: !1, event: A }) } return this.selectIndex !== o && (this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0)), e } return yp.prototype.processHover(this, A) }, vp.prototype.processMouseUp = function (A) { if (A.button === t.LEFT) { var e = this.cameraControl.getRaycaster(A.clientX, A.clientY), i = this.scene.getClipPlanes(); null !== this.getSelectIndex() && (this.cancelHighLight(), this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0)); i.hitTest(e); if (this.selectIndex = this.getSelectIndex(), vc.ClippingCaps = !0, null !== this.selectIndex) { if (this.highLight(), this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0), !this.onClipBox) this.onClipBox = !0, this.cameraControl.viewer.modelManager.dispatchEvent({ type: Rc.ON_CLIP_HOVER, onClipBox: !0, event: A }) } else if (this.onClipBox) { this.onClipBox = !1, this.cameraControl.viewer.modelManager.dispatchEvent({ type: Rc.ON_CLIP_HOVER, onClipBox: !1, event: A }) } if (this.enablePick) return this.planeDistance = 0, this.enablePick = !1, !0 } return yp.prototype.processMouseUp(this, A) }, vp.prototype.processMouseMove = function (A) { if (this.enablePick) { if (this.isRotate()) this.rotate(A.clientX - this.startPt.x, A.clientY - this.startPt.y), this.startPt.set(A.clientX, A.clientY); else { var e = this.mapBoxFaceIndex[this.selectIndex]; if (this.mapLockedBoxFaces[e]) return !0; if (!(A.clientX === this.startPt.x && A.clientY === this.startPt.y)) { vc.ClippingCaps = !1; var t = this.scene.getClipPlanes(), i = this.cameraControl.movePlane(t.clipplanes[this.selectIndex], A, this.startPt, !0, this.clipStartPoint); null !== i && t.offset(this.selectIndex, i), this.startPt.set(A.clientX, A.clientY) } this.cameraControl.viewer.modelManager.dispatchEvent({ type: Rc.ON_CLIP_MOUSE_MOVE, draggedFaceName: e }) } return this.cameraControl.update(!0), !0 } return yp.prototype.processMouseMove(this, A) }, vp.prototype.processTouchstart = function (A) { if (this.startPt.set(A.touches[0].clientX, A.touches[0].clientY), this.enablePick) return yp.prototype.processTouchstart(this, A); var e = this.cameraControl.getRaycaster(A.touches[0].clientX, A.touches[0].clientY); return this.scene.getClipPlanes().hitTest(e), this.selectIndex = this.getSelectIndex(), this.planeDistance = this.getPlaneDistanceInScreen(), null !== this.selectIndex ? (this.highLight(), this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0), this.update(), !0) : void 0 }, vp.prototype.processTouchmove = function (A) { if (null !== this.selectIndex) { if (this.isRotate()) this.rotate(A.touches[0].clientX - this.startPt.x, A.touches[0].clientY - this.startPt.y), this.startPt.set(A.touches[0].clientX, A.touches[0].clientY); else { this.offset((2 > this.selectIndex ? A.touches[0].clientX - this.startPt.x : A.touches[0].clientY - this.startPt.y) / this.planeDistance), this.startPt.set(A.touches[0].clientX, A.touches[0].clientY) } return this.cameraControl.update(!0), this.update(), !0 } return yp.prototype.processTouchmove(this, A) }, vp.prototype.processTouchend = function (A) { return this.selectIndex = null, this.planeDistance = 0, this.enablePick && (this.onUpdateUI({ visible: !1 }), this.startPt.x === A.touches[0].clientX && this.startPt.y === A.touches[0].clientY && this.pickHelper.click(A)), this.cameraControl.needUpdateRenderList(!0), this.cancelHighLight(), this.cameraControl.update(!0), this.update(), yp.prototype.processTouchend(this, A) }; var Ip = function (A, e, t) { yp.call(this, Pc.COMPONENT_TRANSFORM), this._callbackWrapper = void 0, this._objectCallbackWrapper = void 0, this._cancelCallback = void 0, this.transformControl = new Ep(A, e, t), this.bindingComponentKey = void 0 }; (Ip.prototype = Object.create(yp.prototype)).constructor = Ip, Ip.prototype.destroy = function () { this.transformControl.destory() }, Ip.prototype.update = function () { this.transformControl.updateMatrixWorld() }, Ip.prototype.transformComponent = function (A, e, t, i, o) { if (A) { var n = this.transformControl; n.object && A !== n.object && this.cancelTransformComponent(!1), this._callbackWrapper && (this.transformControl.removeEventListener("change", this._callbackWrapper), this._callbackWrapper = void 0), this._objectCallbackWrapper && (this.transformControl.removeEventListener("objectChange", this._objectCallbackWrapper), this._objectCallbackWrapper = void 0), this._cancelCallback && (this._cancelCallback = void 0), this._pauseCallbackWrapper && (this.transformControl.removeEventListener("mouseUp", this._pauseCallbackWrapper), this._pauseCallbackWrapper = void 0), e && (this._callbackWrapper = function (A) { e(A) }, this.transformControl.addEventListener("change", this._callbackWrapper)), t && (this._objectCallbackWrapper = function (A) { t(A) }, this.transformControl.addEventListener("objectChange", this._objectCallbackWrapper)), i && (this._cancelCallback = i), o && (this._pauseCallbackWrapper = function (A) { o(A) }, this.transformControl.addEventListener("mouseUp", this._pauseCallbackWrapper)), this._saveComponentOriginalTransformState(A), !0 !== n.showX && (n.showX = !0), !0 !== n.showY && (n.showY = !0), !0 !== n.showZ && (n.showZ = !0), !0 !== n.enabled && (n.enabled = !0), n.attach(A) } }, Ip.prototype.cancelTransformComponent = function () { var A = this.transformControl.object; if (A) return this.transformControl.detach(), this._callbackWrapper && (this.transformControl.removeEventListener("change", this._callbackWrapper), this._callbackWrapper = void 0), this._objectCallbackWrapper && (this.transformControl.removeEventListener("objectChange", this._objectCallbackWrapper), this._objectCallbackWrapper = void 0), this._cancelCallback && (this._cancelCallback(), this._cancelCallback = void 0), this.bindingComponentKey = void 0, A }, Ip.prototype.switchToTranslateMode = function () { this.transformControl.setMode("translate") }, Ip.prototype.switchToRotateMode = function () { this.transformControl.setMode("rotate") }, Ip.prototype.switchToScaleMode = function () { this.transformControl.setMode("scale") }, Ip.prototype._saveComponentOriginalTransformState = function (A) { var e; if (A instanceof Array) e = A; else { if (!(A instanceof H)) return; e = [A] } for (var t = 0, i = e.length; i > t; t += 1) { var o = e[t]; if (!o.userData._originalTransformState) { var n = o.position.clone(), r = o.quaternion.clone(), a = o.scale.clone(), s = o.matrix.clone(), l = o.matrixWorld.clone(); o.userData._originalTransformState = { position: n, quaternion: r, scale: a, matrix: s, matrixWorld: l } } } }, Ip.prototype.restoreComponentOriginalTransformState = function () { if (!this.transformControl.object) return !1; var A, e = this.transformControl.object; if (e instanceof Array) A = e; else { if (!(e instanceof H)) return !1; A = [e] } for (var t = !1, i = 0, o = A.length; o > i; i += 1) { var n = A[i], r = n.userData._originalTransformState; r && (n.position.copy(r.position), n.quaternion.copy(r.quaternion), n.scale.copy(r.scale), n.matrix.copy(r.matrix), n.matrixWorld.copy(r.matrixWorld), this.transformControl.updateMatrixWorld(), this.transformControl.dispatchEvent({ type: "objectChange" }), t = !0) } return t }, Ip.prototype.increaseTransformControlSize = function () { var A = this.transformControl; if (A.object && A.visible) { var e = A.size; if (3 > e) return A.setSize(e + .1), !0 } return !1 }, Ip.prototype.decreaseTransformControlSize = function () { var A = this.transformControl; if (A.object && A.visible) { var e = A.size; if (e > .5) return A.setSize(e - .1), !0 } return !1 }, Ip.prototype.setTransformSpaceToLocalSpace = function () { console.log("不再支持") }, Ip.prototype.setTransformSpaceToWorldSpace = function () { console.log("不再支持") }, Ip.prototype.switchTransformSpace = function () { console.log("不再支持") }, Ip.prototype.showTransformOnAxis = function (A) { var e = this.transformControl; if (e.object && e.visible) { var t = !1; switch (A) { case "x": case "X": !0 !== e.showX && (t = !0, e.showX = !0); break; case "y": case "Y": !0 !== e.showY && (t = !0, e.showY = !0); break; case "z": case "Z": !0 !== e.showZ && (t = !0, e.showZ = !0) } return t } return !1 }, Ip.prototype.hideTransformOnAxis = function (A) { var e = this.transformControl; if (e.object && e.visible) { var t = !1; switch (A) { case "x": case "X": !1 !== e.showX && (t = !0, e.showX = !1); break; case "y": case "Y": !1 !== e.showY && (t = !0, e.showY = !1); break; case "z": case "Z": !1 !== e.showZ && (t = !0, e.showZ = !1) } return t } return !1 }, Ip.prototype.disableTransform = function () { var A = this.transformControl; return !(!A.object || !A.visible || !1 === A.enabled) && (A.enabled = !1, !0) }, Ip.prototype.enableTransform = function () { var A = this.transformControl; return !(!A.object || !A.visible || !0 === A.enabled) && (A.enabled = !0, !0) }, Ip.prototype.processMouseDown = function (A) { return !!this.transformControl.enabled && (!!this.transformControl.mouseHover(A) && this.transformControl.mouseDown(A)) }, Ip.prototype.processMouseMove = function (A) { return !!this.transformControl.enabled && this.transformControl.mouseMove(A) }, Ip.prototype.processMouseUp = function (A) { return !!this.transformControl.enabled && this.transformControl.mouseUp(A) }, Ip.prototype.processHover = function (A) { return !!this.transformControl.enabled && this.transformControl.mouseHover(A) }, Ip.onExit = function () { this.destroy() }; var Ep = function (A, e, t) { H.call(this), t = void 0 !== t ? t : document, this.scene = A, this.visible = !1; var i = new Bp; this.add(i); var o = new xp; this.add(o); var n = this; N("camera", e), N("object", void 0), N("enabled", !0), N("axis", null), N("mode", "translate"), N("translationSnap", null), N("rotationSnap", null), N("space", "world"), N("size", 1), N("dragging", !1), N("showX", !0), N("showY", !0), N("showZ", !0); var r = { type: "change" }, a = { type: "mouseDown" }, s = { type: "mouseUp", mode: n.mode }, l = { type: "objectChange" }, c = new Dd, h = new y, d = new y, p = new f, g = { X: new y(1, 0, 0), Y: new y(0, 1, 0), Z: new y(0, 0, 1) }, u = new y, m = new y, C = new y, v = new y, I = new y, E = new y, B = 0, x = new y, S = new f, w = new y, b = new y, U = new f, F = new f, K = new y(1, 1, 1), Q = new y, R = new y, T = new f, k = new f, D = new y, L = new y; function N(A, e) { var t = e; Object.defineProperty(n, A, { get: function () { return void 0 !== t ? t : e }, set: function (e) { t !== e && (t = e, o[A] = e, i[A] = e, n.dispatchEvent({ type: A + "-changed", value: e }), n.dispatchEvent(r)) } }), n[A] = e, o[A] = e, i[A] = e } function O(A) { var e = A.changedTouches ? A.changedTouches[0] : A, i = t.getBoundingClientRect(); return { x: (e.clientX - i.left) / i.width * 2 - 1, y: -(e.clientY - i.top) / i.height * 2 + 1, button: A.button } } N("worldPosition", R), N("worldPositionStart", Q), N("worldQuaternion", T), N("cameraPosition", x), N("cameraQuaternion", S), N("pointStart", u), N("pointEnd", m), N("rotationAxis", v), N("rotationAngle", B), N("eye", L), this.attach = function (e) { e && (this.object !== e && (this.scene.add(this), A.componentTransformControl = this, this.object = e, r.object = e, l.object = e, this.updateMatrixWorld()), this.visible = !0) }, this.detach = function () { this.object && (this.object = void 0, r.object = void 0), this.parent && this.parent.remove(this), this.scene.componentTransformControl = void 0 }, this.destory = function () { this.scene.componentTransformControl = void 0, this.scene = void 0, this.axis = void 0, this.camera = void 0 }, this.updateMatrixWorld = function () { if (void 0 !== this.object) { var A, e = new aA; if (this.object instanceof Array) A = this.object; else { if (!(this.object instanceof H)) return; A = [this.object] } for (var t = 0, i = A.length; i > t; t += 1) { var o = A[t]; if (o.geometry) e.expandByObject(A[t]); else { var n = new y; o.getWorldPosition(n), e.expandByPoint(n) } } A[0].parent && A[0].parent.matrixWorld.decompose(b, U, K), A[0].matrixWorld.decompose(R, T, D), e.getCenter(R), F.copy(U).inverse(), k.copy(T).inverse() } this.camera.updateMatrixWorld(), this.camera.matrixWorld.decompose(x, S, w), this.camera instanceof je ? L.copy(x).sub(R).normalize() : this.camera instanceof Ka ? L.copy(x).normalize() : this.camera instanceof kd && (this.camera.isPerspective ? L.copy(x).sub(R).normalize() : L.copy(x).normalize()), H.prototype.updateMatrixWorld.call(this) }, this.mouseHover = function (A) { var e = O(A); if (void 0 === this.object || !0 === this.dragging || void 0 !== e.button && 0 !== e.button) return !1; c.setFromCamera(e, this.camera); var t, o = c.intersectObjects(i.picker[this.mode].children, !0) || !1; return o ? (this.axis = o.object.name, t = !0) : (this.axis = null, t = !1), this.updateMatrixWorld(), t }, this.mouseDown = function (A) { var e = O(A); if (void 0 === this.object || !0 === this.dragging || void 0 !== e.button && 0 !== e.button) return !1; if ((0 === e.button || void 0 === e.button) && null !== this.axis) { c.setFromCamera(e, this.camera); var t = c.intersectObjects([o], !0) || !1; return !1 !== t && (t && (Q.copy(R), u.copy(t.point).sub(Q)), this.dragging = !0, a.mode = this.mode, this.dispatchEvent(a), !0) } }, this.mouseMove = function (A) { var e = O(A), t = this.axis, i = this.mode, n = void 0; if (void 0 === this.object || null === t || !1 === this.dragging || void 0 !== e.button && 0 !== e.button) return !1; c.setFromCamera(e, this.camera); var a = c.intersectObjects([o], !0) || !1; if (!1 === a) return !1; if (m.copy(a.point).sub(Q), "translate" === i) C.copy(m).sub(u), -1 === t.indexOf("X") && (C.x = 0), -1 === t.indexOf("Y") && (C.y = 0), -1 === t.indexOf("Z") && (C.z = 0), C.applyQuaternion(F).divide(K), 0 === C.x && 0 === C.y && 0 === C.z || (n = this._translateCurrentObject(C)); else if ("scale" === i) { if (-1 !== t.search("XYZ")) { var s = m.length() / u.length(); 0 > m.dot(u) && (s *= -1), d.set(s, s, s) } else h.copy(u), d.copy(m), h.applyQuaternion(k), d.applyQuaternion(k), d.divide(h), -1 === t.search("X") && (d.x = 1), -1 === t.search("Y") && (d.y = 1), -1 === t.search("Z") && (d.z = 1); 1 === d.x && 1 === d.y && 1 === d.z || (n = this._scaleCurrentObject(d)) } else if ("rotate" === i) { C.copy(m).sub(u); var y = 20 / R.distanceTo(h.setFromMatrixPosition(this.camera.matrixWorld)); if ("E" === t ? (v.copy(L), B = m.angleTo(u), I.copy(u).normalize(), E.copy(m).normalize(), B *= 0 > E.cross(I).dot(L) ? 1 : -1) : "XYZE" === t ? (v.copy(C).cross(L).normalize(), B = C.dot(h.copy(v).cross(this.eye)) * y) : "X" !== t && "Y" !== t && "Z" !== t || (v.copy(g[t]), h.copy(g[t]), B = C.dot(h.cross(L).normalize()) * y), this.rotationAngle = B, 0 !== B) { var x = new f; v.applyQuaternion(F), x.copy(p.setFromAxisAngle(v, B)), x.normalize(), n = this._rotateCurrentObject(x) } } return n ? (this.updateMatrixWorld(), this.dispatchEvent(r), l.matrix = n.clone(), this.dispatchEvent(l), u.copy(m), !0) : void 0 }, this.mouseUp = function (A) { var e = O(A); return (void 0 === e.button || 0 === e.button) && (this.dragging && null !== this.axis && (s.mode = this.mode, this.dispatchEvent(s)), this.dragging = !1, void 0 === e.button && (this.axis = null), !0) }, this.getMode = function () { return n.mode }, this.setMode = function (A) { n.mode = A, this.updateMatrixWorld() }, this.setTranslationSnap = function (A) { n.translationSnap = A }, this.setRotationSnap = function (A) { n.rotationSnap = A }, this.setSize = function (A) { n.size = A }, this.setSpace = function (A) { n.space = A }, this.getBoundingBox = function () { return i.getBoundingBox() }, this._scaleCurrentObject = function () { var A = new M, e = new M, t = new M, i = new M, o = new y; return function (n) { var r; if (this.object instanceof Array) r = this.object; else { if (!(this.object instanceof H)) return; r = [this.object] } for (var a = 0, s = r.length; s > a; a += 1) { var l = r[a]; l.geometry ? (l.geometry.boundingBox || l.geometry.computeBoundingBox(), l.geometry.boundingBox.getCenter(o), o.applyMatrix4(l.matrix)) : o.copy(l.position), e.makeTranslation(-o.x, -o.y, -o.z), t.makeScale(n.x, n.y, n.z), i.makeTranslation(o.x, o.y, o.z), A.identity(), A.multiply(i), A.multiply(t), A.multiply(e); var c = l.matrixAutoUpdate; l.matrixAutoUpdate = !1, l.applyMatrix4(A), l.updateMatrixWorld(!0), l.matrixAutoUpdate = c } return A } }(), this._rotateCurrentObject = function () { var A = new M, e = new M, t = new M, i = new M, o = new y; return function (n) { var r; if (this.object instanceof Array) r = this.object; else { if (!(this.object instanceof H)) return; r = [this.object] } for (var a = 0, s = r.length; s > a; a += 1) { var l = r[a]; l.geometry ? (l.geometry.boundingBox || l.geometry.computeBoundingBox(), l.geometry.boundingBox.getCenter(o), o.applyMatrix4(l.matrix)) : o.copy(l.position), A.makeTranslation(-o.x, -o.y, -o.z), e.makeRotationFromQuaternion(n), t.makeTranslation(o.x, o.y, o.z), i.identity(), i.multiply(t), i.multiply(e), i.multiply(A); var c = l.matrixAutoUpdate; l.matrixAutoUpdate = !1, l.applyMatrix4(i), l.matrixAutoUpdate = c, l.updateMatrixWorld(!0) } return i } }(), this._translateCurrentObject = function () { var A = new M; return function (e) { var t; if (this.object instanceof Array) t = this.object; else { if (!(this.object instanceof H)) return; t = [this.object] } A.makeTranslation(e.x, e.y, e.z); for (var i = 0, o = t.length; o > i; i += 1) { var n = t[i], r = n.matrixAutoUpdate; n.matrixAutoUpdate = !1, n.applyMatrix4(A), n.matrixAutoUpdate = r, n.updateMatrixWorld(!0) } return A } }() }; Ep.prototype = Object.assign(Object.create(H.prototype), { constructor: Ep, isTransformControls: !0 }); var Bp = function () { H.call(this), this.type = "TransformControlsGizmo"; var A = new jA({ depthTest: !1, depthWrite: !1, transparent: !0, side: 2, fog: !1 }), e = new ko({ depthTest: !1, depthWrite: !1, transparent: !0, linewidth: 1, fog: !1 }), t = A.clone(); t.opacity = .15; var i = A.clone(); i.opacity = .33; var o = A.clone(); o.color.set(16711680); var n = A.clone(); n.color.set(65280); var r = A.clone(); r.color.set(255); var a = A.clone(); a.opacity = .25; var s = a.clone(); s.color.set(16776960); var l = a.clone(); l.color.set(65535); var c = a.clone(); c.color.set(16711935), A.clone().color.set(16776960); var h = e.clone(); h.color.set(16711680); var d = e.clone(); d.color.set(65280); var p = e.clone(); p.color.set(255); var g = e.clone(); g.color.set(65535); var u = e.clone(); u.color.set(16711935); var m = e.clone(); m.color.set(16776960); var C = e.clone(); C.color.set(7895160); var v = m.clone(); v.opacity = .25; var I = new hr(0, .05, .2, 12, 1, !1), E = new Ne(.125, .125, .125), B = new he; B.setAttribute("position", new Ae([0, 0, 0, 1, 0, 0], 3)); var x, S = function (A, e) { for (var t = new he, i = [], o = 0; 64 * e >= o; ++o) i.push(0, Math.cos(o / 32 * Math.PI) * A, Math.sin(o / 32 * Math.PI) * A); return t.setAttribute("position", new Ae(i, 3)), t }, w = { X: [ [new Ue(I, o), [1, 0, 0], [0, 0, -Math.PI / 2], null, "fwd" ], [new Ue(I, o), [1, 0, 0], [0, 0, Math.PI / 2], null, "bwd" ], [new Go(B, h)] ], Y: [ [new Ue(I, n), [0, 1, 0], null, null, "fwd"], [new Ue(I, n), [0, 1, 0], [Math.PI, 0, 0], null, "bwd" ], [new Go(B, d), null, [0, 0, Math.PI / 2]] ], Z: [ [new Ue(I, r), [0, 0, 1], [Math.PI / 2, 0, 0], null, "fwd" ], [new Ue(I, r), [0, 0, 1], [-Math.PI / 2, 0, 0], null, "bwd" ], [new Go(B, p), null, [0, -Math.PI / 2, 0]] ], XYZ: [ [new Ue(new dn(.1, 0), a), [0, 0, 0], [0, 0, 0] ] ], XY: [ [new Ue(new et(.295, .295), s), [.15, .15, 0]], [new Go(B, m), [.18, .3, 0], null, [.125, 1, 1]], [new Go(B, m), [.3, .18, 0], [0, 0, Math.PI / 2], [.125, 1, 1] ] ], YZ: [ [new Ue(new et(.295, .295), l), [0, .15, .15], [0, Math.PI / 2, 0] ], [new Go(B, g), [0, .18, .3], [0, 0, Math.PI / 2], [.125, 1, 1] ], [new Go(B, g), [0, .3, .18], [0, -Math.PI / 2, 0], [.125, 1, 1] ] ], XZ: [ [new Ue(new et(.295, .295), c), [.15, 0, .15], [-Math.PI / 2, 0, 0] ], [new Go(B, u), [.18, 0, .3], null, [.125, 1, 1]], [new Go(B, u), [.3, 0, .18], [0, -Math.PI / 2, 0], [.125, 1, 1] ] ] }, b = { X: [ [new Ue(new hr(.2, 0, 1, 4, 1, !1), t), [.6, 0, 0], [0, 0, -Math.PI / 2] ] ], Y: [ [new Ue(new hr(.2, 0, 1, 4, 1, !1), t), [0, .6, 0]] ], Z: [ [new Ue(new hr(.2, 0, 1, 4, 1, !1), t), [0, 0, .6], [Math.PI / 2, 0, 0] ] ], XYZ: [ [new Ue(new dn(.2, 0), t)] ], XY: [ [new Ue(new et(.4, .4), t), [.2, .2, 0]] ], YZ: [ [new Ue(new et(.4, .4), t), [0, .2, .2], [0, Math.PI / 2, 0] ] ], XZ: [ [new Ue(new et(.4, .4), t), [.2, 0, .2], [-Math.PI / 2, 0, 0] ] ] }, U = { START: [ [new Ue(new dn(.01, 2), i), null, null, null, "helper"] ], END: [ [new Ue(new dn(.01, 2), i), null, null, null, "helper"] ], DELTA: [ [new Go((x = new he, x.setAttribute("position", new Ae([0, 0, 0, 1, 1, 1], 3)), x), i), null, null, null, "helper"] ], X: [ [new Go(B, i.clone()), [-1e3, 0, 0], null, [1e6, 1, 1], "helper"] ], Y: [ [new Go(B, i.clone()), [0, -1e3, 0], [0, 0, Math.PI / 2], [1e6, 1, 1], "helper" ] ], Z: [ [new Go(B, i.clone()), [0, 0, -1e3], [0, -Math.PI / 2, 0], [1e6, 1, 1], "helper" ] ] }, K = { X: [ [new Go(S(1, .5), h)], [new Ue(new dn(.04, 0), o), [0, 0, .99], null, [1, 3, 1]] ], Y: [ [new Go(S(1, .5), d), null, [0, 0, -Math.PI / 2]], [new Ue(new dn(.04, 0), n), [0, 0, .99], null, [3, 1, 1]] ], Z: [ [new Go(S(1, .5), p), null, [0, Math.PI / 2, 0]], [new Ue(new dn(.04, 0), r), [.99, 0, 0], null, [1, 3, 1]] ], E: [ [new Go(S(1.25, 1), v), null, [0, Math.PI / 2, 0]], [new Ue(new hr(.03, 0, .15, 4, 1, !1), v), [1.17, 0, 0], [0, 0, -Math.PI / 2], [1, 1, .001] ], [new Ue(new hr(.03, 0, .15, 4, 1, !1), v), [-1.17, 0, 0], [0, 0, Math.PI / 2], [1, 1, .001] ], [new Ue(new hr(.03, 0, .15, 4, 1, !1), v), [0, -1.17, 0], [Math.PI, 0, 0], [1, 1, .001] ], [new Ue(new hr(.03, 0, .15, 4, 1, !1), v), [0, 1.17, 0], [0, 0, 0], [1, 1, .001] ] ], XYZE: [ [new Go(S(1, 1), C), null, [0, Math.PI / 2, 0]] ] }, Q = { AXIS: [ [new Go(B, i.clone()), [-1e3, 0, 0], null, [1e6, 1, 1], "helper"] ] }, R = { X: [ [new Ue(new En(1, .1, 4, 24), t), [0, 0, 0], [0, -Math.PI / 2, -Math.PI / 2] ] ], Y: [ [new Ue(new En(1, .1, 4, 24), t), [0, 0, 0], [Math.PI / 2, 0, 0] ] ], Z: [ [new Ue(new En(1, .1, 4, 24), t), [0, 0, 0], [0, 0, -Math.PI / 2] ] ], E: [ [new Ue(new En(1.25, .1, 2, 24), t)] ], XYZE: [ [new Ue(new er(.7, 10, 8), t)] ] }, T = { X: [ [new Ue(E, o), [.8, 0, 0], [0, 0, -Math.PI / 2] ], [new Go(B, h), null, null, [.8, 1, 1]] ], Y: [ [new Ue(E, n), [0, .8, 0]], [new Go(B, d), null, [0, 0, Math.PI / 2], [.8, 1, 1] ] ], Z: [ [new Ue(E, r), [0, 0, .8], [Math.PI / 2, 0, 0] ], [new Go(B, p), null, [0, -Math.PI / 2, 0], [.8, 1, 1] ] ], XY: [ [new Ue(E, s), [.85, .85, 0], null, [2, 2, .2]], [new Go(B, m), [.855, .98, 0], null, [.125, 1, 1]], [new Go(B, m), [.98, .855, 0], [0, 0, Math.PI / 2], [.125, 1, 1] ] ], YZ: [ [new Ue(E, l), [0, .85, .85], null, [.2, 2, 2]], [new Go(B, g), [0, .855, .98], [0, 0, Math.PI / 2], [.125, 1, 1] ], [new Go(B, g), [0, .98, .855], [0, -Math.PI / 2, 0], [.125, 1, 1] ] ], XZ: [ [new Ue(E, c), [.85, 0, .85], null, [2, .2, 2]], [new Go(B, u), [.855, 0, .98], null, [.125, 1, 1]], [new Go(B, u), [.98, 0, .855], [0, -Math.PI / 2, 0], [.125, 1, 1] ] ], XYZX: [ [new Ue(new Ne(.125, .125, .125), a), [1.1, 0, 0]] ], XYZY: [ [new Ue(new Ne(.125, .125, .125), a), [0, 1.1, 0]] ], XYZZ: [ [new Ue(new Ne(.125, .125, .125), a), [0, 0, 1.1]] ] }, k = { X: [ [new Ue(new hr(.2, 0, .8, 4, 1, !1), t), [.5, 0, 0], [0, 0, -Math.PI / 2] ] ], Y: [ [new Ue(new hr(.2, 0, .8, 4, 1, !1), t), [0, .5, 0]] ], Z: [ [new Ue(new hr(.2, 0, .8, 4, 1, !1), t), [0, 0, .5], [Math.PI / 2, 0, 0] ] ], XY: [ [new Ue(E, t), [.85, .85, 0], null, [3, 3, .2]] ], YZ: [ [new Ue(E, t), [0, .85, .85], null, [.2, 3, 3]] ], XZ: [ [new Ue(E, t), [.85, 0, .85], null, [3, .2, 3]] ], XYZX: [ [new Ue(new Ne(.2, .2, .2), t), [1.1, 0, 0]] ], XYZY: [ [new Ue(new Ne(.2, .2, .2), t), [0, 1.1, 0]] ], XYZZ: [ [new Ue(new Ne(.2, .2, .2), t), [0, 0, 1.1]] ] }, D = { X: [ [new Go(B, i.clone()), [-1e3, 0, 0], null, [1e6, 1, 1], "helper"] ], Y: [ [new Go(B, i.clone()), [0, -1e3, 0], [0, 0, Math.PI / 2], [1e6, 1, 1], "helper" ] ], Z: [ [new Go(B, i.clone()), [0, 0, -1e3], [0, -Math.PI / 2, 0], [1e6, 1, 1], "helper" ] ] }, L = function (A) { var e = new H; for (var t in A) for (var i = A[t].length; i--;) { var o = A[t][i][0].clone(), n = A[t][i][1], r = A[t][i][2], a = A[t][i][3], s = A[t][i][4]; o.name = t, o.tag = s, n && o.position.set(n[0], n[1], n[2]), r && o.rotation.set(r[0], r[1], r[2]), a && o.scale.set(a[0], a[1], a[2]), o.updateMatrix(); var l = o.geometry.clone(); l.applyMatrix4(o.matrix), o.geometry = l, o.renderOrder = 1 / 0, o.position.set(0, 0, 0), o.rotation.set(0, 0, 0), o.scale.set(1, 1, 1), e.add(o) } return e }, N = new F, O = new y(0, 1, 0), V = new y(0, 0, 0), G = new M, P = new f, q = new f, j = new f, Y = new y(1, 0, 0), W = new y(0, 1, 0), J = new y(0, 0, 1); this.gizmo = {}, this.picker = {}, this.helper = {}, this.add(this.gizmo.translate = L(w)), this.add(this.gizmo.rotate = L(K)), this.add(this.gizmo.scale = L(T)), this.add(this.picker.translate = L(b)), this.add(this.picker.rotate = L(R)), this.add(this.picker.scale = L(k)), this.add(this.helper.translate = L(U)), this.add(this.helper.rotate = L(Q)), this.add(this.helper.scale = L(D)), this.picker.translate.visible = !1, this.picker.rotate.visible = !1, this.picker.scale.visible = !1, this.updateMatrixWorld = function () { var A = this.space; "scale" === this.mode && (A = "local"); var e = "local" === A ? this.worldQuaternion : j; this.gizmo.translate.visible = "translate" === this.mode, this.gizmo.rotate.visible = "rotate" === this.mode, this.gizmo.scale.visible = "scale" === this.mode, this.helper.translate.visible = "translate" === this.mode, this.helper.rotate.visible = "rotate" === this.mode, this.helper.scale.visible = "scale" === this.mode; var t = []; t = (t = (t = t.concat(this.picker[this.mode].children)).concat(this.gizmo[this.mode].children)).concat(this.helper[this.mode].children); for (var i = this.boundingBox ? this.boundingBox.makeEmpty() : new aA, o = 0; t.length > o; o++) { var n = t[o]; n.visible = !0, n.rotation.set(0, 0, 0), n.position.copy(this.worldPosition); var r = this.worldPosition.distanceTo(this.cameraPosition); if (n.scale.set(1, 1, 1).multiplyScalar(r * this.size / 7), "helper" !== n.tag) { if (n.quaternion.copy(e), "translate" === this.mode || "scale" === this.mode) { "X" !== n.name && "XYZX" !== n.name || Math.abs(O.copy(Y).applyQuaternion(e).dot(this.eye)) > .99 && (n.scale.set(1e-10, 1e-10, 1e-10), n.visible = !1), "Y" !== n.name && "XYZY" !== n.name || Math.abs(O.copy(W).applyQuaternion(e).dot(this.eye)) > .99 && (n.scale.set(1e-10, 1e-10, 1e-10), n.visible = !1), "Z" !== n.name && "XYZZ" !== n.name || Math.abs(O.copy(J).applyQuaternion(e).dot(this.eye)) > .99 && (n.scale.set(1e-10, 1e-10, 1e-10), n.visible = !1), "XY" === n.name && .2 > Math.abs(O.copy(J).applyQuaternion(e).dot(this.eye)) && (n.scale.set(1e-10, 1e-10, 1e-10), n.visible = !1), "YZ" === n.name && .2 > Math.abs(O.copy(Y).applyQuaternion(e).dot(this.eye)) && (n.scale.set(1e-10, 1e-10, 1e-10), n.visible = !1), "XZ" === n.name && .2 > Math.abs(O.copy(W).applyQuaternion(e).dot(this.eye)) && (n.scale.set(1e-10, 1e-10, 1e-10), n.visible = !1), -1 !== n.name.search("X") && (0 > O.copy(Y).applyQuaternion(e).dot(this.eye) ? "fwd" === n.tag ? n.visible = !1 : n.scale.x *= -1 : "bwd" === n.tag && (n.visible = !1)), -1 !== n.name.search("Y") && (0 > O.copy(W).applyQuaternion(e).dot(this.eye) ? "fwd" === n.tag ? n.visible = !1 : n.scale.y *= -1 : "bwd" === n.tag && (n.visible = !1)), -1 !== n.name.search("Z") && (0 > O.copy(J).applyQuaternion(e).dot(this.eye) ? "fwd" === n.tag ? n.visible = !1 : n.scale.z *= -1 : "bwd" === n.tag && (n.visible = !1)) } else "rotate" === this.mode && (q.copy(e), O.copy(this.eye).applyQuaternion(P.copy(e).inverse()), -1 !== n.name.search("E") && n.quaternion.setFromRotationMatrix(G.lookAt(this.eye, V, W)), "X" === n.name && (P.setFromAxisAngle(Y, Math.atan2(-O.y, O.z)), P.multiplyQuaternions(q, P), n.quaternion.copy(P)), "Y" === n.name && (P.setFromAxisAngle(W, Math.atan2(O.x, O.z)), P.multiplyQuaternions(q, P), n.quaternion.copy(P)), "Z" === n.name && (P.setFromAxisAngle(J, Math.atan2(O.y, O.x)), P.multiplyQuaternions(q, P), n.quaternion.copy(P))); n.visible = n.visible && (-1 === n.name.indexOf("X") || this.showX), n.visible = n.visible && (-1 === n.name.indexOf("Y") || this.showY), n.visible = n.visible && (-1 === n.name.indexOf("Z") || this.showZ), n.visible = n.visible && (-1 === n.name.indexOf("E") || this.showX && this.showY && this.showZ), n.material._opacity = n.material._opacity || n.material.opacity, n.material._color = n.material._color || n.material.color.clone(), n.material.color.copy(n.material._color), n.material.opacity = n.material._opacity, this.enabled ? this.axis && (n.name === this.axis || this.axis.split("").some((function (A) { return n.name === A })) ? (n.material.opacity = 1, n.material.color.lerp(new LA(1, 1, 1), .5)) : (n.material.opacity *= .25, n.material.color.lerp(new LA(1, 1, 1), .5))) : (n.material.opacity *= .5, n.material.color.lerp(new LA(1, 1, 1), .5)), i.expandByObject(n) } else if (n.visible = !1, "AXIS" === n.name) n.position.copy(this.worldPositionStart), n.visible = !!this.axis, "X" === this.axis && (P.setFromEuler(N.set(0, 0, 0)), n.quaternion.copy(e).multiply(P), Math.abs(O.copy(Y).applyQuaternion(e).dot(this.eye)) > .9 && (n.visible = !1)), "Y" === this.axis && (P.setFromEuler(N.set(0, 0, Math.PI / 2)), n.quaternion.copy(e).multiply(P), Math.abs(O.copy(W).applyQuaternion(e).dot(this.eye)) > .9 && (n.visible = !1)), "Z" === this.axis && (P.setFromEuler(N.set(0, Math.PI / 2, 0)), n.quaternion.copy(e).multiply(P), Math.abs(O.copy(J).applyQuaternion(e).dot(this.eye)) > .9 && (n.visible = !1)), "XYZE" === this.axis && (P.setFromEuler(N.set(0, Math.PI / 2, 0)), O.copy(this.rotationAxis), n.quaternion.setFromRotationMatrix(G.lookAt(V, O, W)), n.quaternion.multiply(P), n.visible = this.dragging), "E" === this.axis && (n.visible = !1); else if ("START" === n.name) n.position.copy(this.worldPositionStart), n.visible = this.dragging; else if ("END" === n.name) n.position.copy(this.worldPosition), n.visible = this.dragging; else if ("DELTA" === n.name) { n.position.set(0, 0, 0), n.scale.set(1, 1, 1); var a = n.geometry.getAttribute("position"); a.setXYZ(0, this.worldPositionStart.x, this.worldPositionStart.y, this.worldPositionStart.z), a.setXYZ(1, this.worldPosition.x, this.worldPosition.y, this.worldPosition.z), a.needsUpdate = !0, n.visible = this.dragging } else n.quaternion.copy(e), n.position.copy(this.dragging ? this.worldPositionStart : this.worldPosition), this.axis && (n.visible = -1 !== this.axis.search(n.name)) } this.boundingBox = i, H.prototype.updateMatrixWorld.call(this) }, this.getBoundingBox = function () { return this.boundingBox || this.updateMatrixWorld(), this.boundingBox } }; Bp.prototype = Object.assign(Object.create(H.prototype), { constructor: Bp, isTransformControlsGizmo: !0 }); var xp = function () { Ue.call(this, new et(4, 4, 2, 2), new jA({ visible: !1, wireframe: !0, side: 2, transparent: !0, opacity: .1 })), this.type = "TransformControlsPlane"; var A = new y(1, 0, 0), e = new y(0, 1, 0), t = new y(0, 0, 1), i = new y, o = new y, n = new y, r = new M, a = new f; this.updateMatrixWorld = function () { var s = this.space; switch (this.position.copy(this.worldPosition), "scale" === this.mode && (s = "local"), A.set(1, 0, 0).applyQuaternion("local" === s ? this.worldQuaternion : a), e.set(0, 1, 0).applyQuaternion("local" === s ? this.worldQuaternion : a), t.set(0, 0, 1).applyQuaternion("local" === s ? this.worldQuaternion : a), n.copy(e), this.mode) { case "translate": case "scale": switch (this.axis) { case "X": n.copy(this.eye).cross(A), o.copy(A).cross(n); break; case "Y": n.copy(this.eye).cross(e), o.copy(e).cross(n); break; case "Z": n.copy(this.eye).cross(t), o.copy(t).cross(n); break; case "XY": o.copy(t); break; case "YZ": o.copy(A); break; case "XZ": n.copy(t), o.copy(e); break; case "XYZ": case "E": o.set(0, 0, 0) } break; case "rotate": default: o.set(0, 0, 0) } 0 === o.length() ? this.quaternion.copy(this.cameraQuaternion) : (r.lookAt(i.set(0, 0, 0), o, n), this.quaternion.setFromRotationMatrix(r)); var l = this.worldPosition.distanceTo(this.cameraPosition); this.scale.set(1, 1, 1).multiplyScalar(l * this.size / 7), H.prototype.updateMatrixWorld.call(this) } }; xp.prototype = Object.assign(Object.create(Ue.prototype), { constructor: xp, isTransformControlsPlane: !0 }); var Sp = function (A) { yp.call(this, Pc.CLIP_FILL), this.viewer = A, this.scene = A.getScene(), this.enablePick = !1, this.rotX = !0, this.onClipPlane = !1, this.cameraControl = A.cameraControl, this.startPt = new s, this.endPt = new s, this.frustum = new Ze, this.modelManager = this.cameraControl.viewer.modelManager; var e = this.scene.getFillClipPlane(); e.updateClippingParams = function (e) { if (0 === e.iClipPlane.value) A.getRenderer().clippingPlanes = Object.freeze([]); else { var t = [new EA], i = e.vClipPlane.value[0], o = t[0]; o.setComponents(-i.x, -i.y, -i.z, -i.w), o.normalize(), A.getRenderer().clippingPlanes = t, this.renderClipPlane = new EA, this.renderClipPlane.setComponents(i.x, i.y, i.z, -i.w), this.renderClipPlane.normalize(), this.calculateFillClipBoundingBox(o.coplanarPoint(new y)) } }, e.init(), this.planeDistance = 0, this.offsetSpeed = .02, this.toggle = function (A, t) { e.enable(A, t), e.update() }, this.visible = function (A) { e.visible = A, e.update() }, this.rotatable = function (A) { e.rotatable = A, e.update() }, this.hit = function () { return e.hit }, this.pointToScreen = function (A) { var e = this.cameraControl.camera, t = new M; t.multiplyMatrices(e.projectionMatrix, e.matrixWorldInverse); var i = new p(A.x, A.y, A.z, 1); i.applyMatrix4(t); var o = new s; o.x = (i.x / i.w + 1) / 2, o.y = 1 - (i.y / i.w + 1) / 2; var n = this.cameraControl.getContainerDimensions(); return o.x = o.x * n.width + n.left, o.y = o.y * n.height + n.top, o }, this.getPlaneDistanceInScreen = function () { if (null === this.selectIndex) return null; if (2 > this.selectIndex) { var A = e.clipPlanes.center.clone(), t = e.clipPlanes.center.clone(); A.x -= e.clipPlanes.cubeSize.x, t.x += e.clipPlanes.cubeSize.x; var i = this.pointToScreen(A), o = this.pointToScreen(t); return i.x - o.x } var n = e.clipPlanes.center.clone(), r = e.clipPlanes.center.clone(); r.y -= e.clipPlanes.cubeSize.y, n.y += e.clipPlanes.cubeSize.y; var a = this.pointToScreen(r), s = this.pointToScreen(n); return a.y - s.y }, this.getPickPoint = function (A, e) { var t = this.cameraControl.camera, i = this.cameraControl.getContainerDimensions(), o = (A - i.left) / i.width * 2 - 1, n = (i.height - (e - i.top)) / i.height * 2 - 1, r = new Dd; return r.setFromCamera(new s(o, n), t), r.ray.intersectPlane(this.plane) }, this._isVisible = function () { return e.visible }, this.isRotate = function () { return e.rotatable }, this.offset = function (A) { e.offset(A) }, this.setOffset = function (A) { e.setOffset(A) }, this.rotate = function (A, t) { this.rotX ? e.rotX(t / 180 * Math.PI * .1) : e.rotY(A / 180 * Math.PI * .1) }, this.rotateAngleOffset = function (A, t) { e.rotateAngleOffset(A, t) }, this.setRotateAngle = function (A, t) { e.setRotateAngle(A, t) }, this.getRotateAngle = function () { return e.getRotateAngle() }, this.changeNormal = function (A) { e.changeNormal(A) }, this.update = function (A) { e.update(A) }, this.cancelHighLight = function () { e.cancelHighLight() }, this.highLight = function () { e.highLight() }, this.store = function () { return e.store() }, this.restore = function (A) { e.restore(A) }, this.setProcess = function (A) { e.setProcess(A) }, this.getProcess = function () { return e.getProcess() } }; (Sp.prototype = Object.create(yp.prototype)).constructor = Sp, Sp.prototype.destroy = function () { this.cameraControl = null, this.normal = null, this.plane = null, this.pickHelper = null, this.scene = null, this.viewer = null }, Sp.prototype.onExit = function () { this.toggle(!1, !1) }, Sp.prototype.processMouseDown = function (A) { if (this.startPt.set(A.clientX, A.clientY), !this.enablePick && A.button === t.LEFT) { var e = this.cameraControl.getRaycaster(A.clientX, A.clientY); if (this.scene.getFillClipPlane().hitTest(e), this.hit()) return this.highLight(), this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0), !0 } return yp.prototype.processMouseDown(this, A) }, Sp.prototype.processMouseUp = function (A) { this.planeDistance = 0; var e = !1; if (this.enablePick && A.button === t.LEFT) if (this.startPt.x === A.clientX && this.startPt.y === A.clientY) this.pickHelper.click(A); else if (A.shiftKey || A.ctrlKey || A.altKey) { this.endPt.set(A.clientX, A.clientY); var i = Kc.Clear; A.ctrlKey ? i = Kc.Add : A.altKey && (i = Kc.Remove); var o = this; this.scene.pickByRect(this.frustum, i, (function () { o.pickHelper.notifySelectionChanged(null, 0, A) })), this.cameraControl.updateView(!0), e = !0 } var n = this.cameraControl.getRaycaster(A.clientX, A.clientY); return this.scene.getFillClipPlane().hitTest(n), this.hit() ? (this.highLight(), this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0), this.onClipPlane || (this.onClipPlane = !0, this.modelManager.dispatchEvent({ type: Rc.ON_CLIP_HOVER, onClipPlane: !0, event: A })), e = !0) : (this.cancelHighLight(), this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0), this.onClipPlane && (this.onClipPlane = !1, this.modelManager.dispatchEvent({ type: Rc.ON_CLIP_HOVER, onClipPlane: !1, event: A }))), e }, Sp.prototype.processMouseMove = function (A) { return this.modelManager.dispatchEvent({ type: Rc.ON_CLIP_MOUSE_MOVE, event: A }), yp.prototype.processMouseMove(this, A) }, Sp.prototype.processTouchstart = function (A) { if (this.startPt.set(A.touches[0].clientX, A.touches[0].clientY), !this.enablePick) { var e = this.cameraControl.getRaycaster(A.touches[0].clientX, A.touches[0].clientY); this.scene.getFillClipPlane().hitTest(e) } return this.hit() ? (this.highLight(), this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0), !0) : yp.prototype.processTouchstart(this, A) }, Sp.prototype.processTouchmove = function (A) { if (this.hit()) { if (this.isRotate()) this.rotate(A.touches[0].clientX - this.startPt.x, A.touches[0].clientY - this.startPt.y), this.startPt.set(A.touches[0].clientX, A.touches[0].clientY); else { this.offset(Number(A.touches[0].clientX - this.startPt.x)), this.startPt.set(A.touches[0].clientX, A.touches[0].clientY) } return this.cameraControl.update(!0), !0 } return yp.prototype.processTouchmove(this, A) }, Sp.prototype.processTouchend = function (A) { return this.enablePick && (this.onUpdateUI({ visible: !1 }), this.startPt.x === A.touches[0].clientX && this.startPt.y === A.touches[0].clientY && this.pickHelper.click(A)), this.cameraControl.needUpdateRenderList(!0), this.cancelHighLight(), this.cameraControl.update(!0), yp.prototype.processTouchmove(this, A) }, Sp.prototype.processHover = function (A) { if (!this.enablePick) { var e = !1, t = this.cameraControl.getRaycaster(A.clientX, A.clientY); return this.scene.getFillClipPlane().hitTest(t), this.hit() ? (this.onClipPlane || (this.highLight(), this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0), this.onClipPlane = !0, this.modelManager.dispatchEvent({ type: Rc.ON_CLIP_HOVER, onClipPlane: !0, event: A })), e = !0) : this.onClipPlane ? (this.cancelHighLight(), this.cameraControl.needUpdateRenderList(!0), this.cameraControl.update(!0), this.onClipPlane = !1, this.modelManager.dispatchEvent({ type: Rc.ON_CLIP_HOVER, onClipPlane: !1, event: A })) : this.modelManager.dispatchEvent({ type: Rc.ON_CLIP_HOVER, onClipPlane: !1, event: A }), e } return yp.prototype.processHover(this, A) }; var wp = function () { this.vertexIndex = new Array(2), this.faceIndex = new Array(2) }, Mp = function (A, e) { var t = A.length / 3, i = new Array(t), o = new Array(t); function n(A, e) { var t = i[A], o = i[e]; return t.x !== o.x ? t.x - o.x : t.y !== o.y ? t.y - o.y : t.z - o.z } for (var r = 0; t > r; r += 1) i[r] = new y(A[3 * r], A[3 * r + 1], A[3 * r + 2]), o[r] = r; o.sort((function (A, e) { var t = n(A, e); return 0 === t ? A - e : t })); var a = {}, s = o[0]; for (r = 1; t > r; r += 1) 0 === n(s, o[r]) ? a[o[r]] = s : s = o[r]; var l = new Array(e.length); for (r = 0; e.length > r; r += 1) l[r] = a.hasOwnProperty(e[r]) ? a[e[r]] : e[r]; return l }, bp = function (A, e) { function t(A, e) { return A - e } var i = Mp(A, e); i.sort(t); var o = [], n = i[0]; o.push(n); for (var r = 1; i.length > r; r += 1) i[r] !== n && o.push(n = i[r]); return o.sort(t) }, Up = function (A, e, t) { t = void 0 === t ? Math.PI / 4 : t; var i = Mp(A, e), o = i.length, n = A.length / 3, r = new Array(n + o), a = n, s = i.length / 3; parseInt(s, 0) !== s && (Bh.error("triangleCount 不是整数"), s = parseInt(s, 0)); for (var l = 0; n > l; l += 1) r[l] = -1; var c = new Array(o), h = 0; for (l = 0; s > l; l += 1) for (var d = i[3 * l + 2], p = 0; 3 > p; p += 1) { var g = !1, u = i[3 * l + p]; if (d > u) { g = !0; var f = d; d = u, u = f } var m = new wp; m.vertexIndex[0] = d, m.vertexIndex[1] = u, m.faceIndex[0] = l, m.faceIndex[1] = l; var C = r[d]; if (-1 === C) r[d] = h, c[h] = m, r[a + h] = -1, h += 1; else for (;;) { if ((E = c[C]).vertexIndex[1] === u) { E.faceIndex[1] = l; break } var v = r[a + C]; if (-1 === v) { r[a + C] = h, c[h] = m, r[a + h] = -1, h += 1; break } C = v } g || (d = u) } var I = []; for (l = 0; h > l; l += 1) { var E; if ((E = c[l]).faceIndex[0] === E.faceIndex[1]) I.push(E.vertexIndex[0]), I.push(E.vertexIndex[1]); else { var B = E.faceIndex[0], x = i[3 * B], S = i[3 * B + 1], w = i[3 * B + 2], M = new y(A[3 * x], A[3 * x + 1], A[3 * x + 2]), b = new y(A[3 * S], A[3 * S + 1], A[3 * S + 2]), U = new y(A[3 * w], A[3 * w + 1], A[3 * w + 2]), F = M.sub(b), K = b.sub(U), Q = F.cross(K); Q.normalize(); var R = E.faceIndex[1]; S = i[3 * R + 1], w = i[3 * R + 2], M = new y(A[3 * (x = i[3 * R])], A[3 * x + 1], A[3 * x + 2]), b = new y(A[3 * S], A[3 * S + 1], A[3 * S + 2]), U = new y(A[3 * w], A[3 * w + 1], A[3 * w + 2]), F = M.sub(b), K = b.sub(U); var T = F.cross(K); T.normalize(), Math.abs(Q.dot(T)) < t && (I.push(E.vertexIndex[0]), I.push(E.vertexIndex[1])) } } return I }, Fp = function (A, e, t, i, o) { for (var n = t.length / 3, r = [], a = 0; n > a; a += 1) { var s = t[3 * a], l = new y(e[3 * s], e[3 * s + 1], e[3 * s + 2]), c = l.dot(o); if (.001 > Math.abs(c - 1)) { var h = -new y(A[3 * s], A[3 * s + 1], A[3 * s + 2]).dot(l), d = Math.abs(i.dot(l) + h); 3 > Math.abs(d) && r.push(t[3 * a], t[3 * a + 1], t[3 * a + 2]) } } return r }, Kp = new y, Qp = new y, Rp = new y, Tp = new y, kp = function (A) { this.cameraControl = A, this.scene = A.scene, this.timerId = null, this.lastIntersected = null, this.edgeDataMap = null }; kp.prototype = { constructor: kp, destroy: function () { this.cameraControl = null, this.scene = null, this.lastIntersected = null, this.timerId && (clearTimeout(this.timerId), this.timerId = null) }, click: function (A, e) { var i = this; function o() { e && !1 === e.pickable && (e = null), i.handleMousePick(A, !1, e) } A.button !== t.RIGHT ? (this.timerId && clearTimeout(this.timerId), this.timerId = setTimeout(o, 500)) : o() }, doubleClick: function (A) { A.preventDefault(), this.timerId && clearTimeout(this.timerId), this.handleMousePick(A, !0, null) }, handleMousePick: function (A, e, i) { var o = this.cameraControl, n = o.viewer.modelManager.sceneState, r = new s(A.clientX, A.clientY), a = o.screenToCanvas(A.clientX, A.clientY), l = o.viewer.modelManager; function c(t, i) { var o = null; if (t && t.objectType === Qc.Room) { var n = t.face.contourIndex, r = t.object.geometry.contour; o = n ? { startPoint: r[n.st], endPoint: r[n.ed] } : null } l.dispatchEvent({ type: Rc.ON_CLICK_PICK, event: A, doubleClick: e, canvasPos: { x: a.x, y: a.y }, intersectInfo: t ? { selectedObjectId: t.userId, modelKey: t.modelKey, objectType: t.objectType, selectable: i, worldPosition: t.worldPosition, worldBoundingBox: t.worldBoundingBox, point: t.point, index: t.index, innnerDebugging: t.innnerDebugging, object: t.object, normal: t.face ? t.face.normal : null, boundaryPoints: o } : null }) } var h = null; if (A.button !== t.RIGHT) { if (i) i.pickable && (h = i.intersect); else { var d = o.getIntersectContext(r); h = o.intersector.pick(d, null) } if (!h) { var p = n.getSelection(); if (A.ctrlKey) return; return p.length > 0 && (n.clearSelection(), o.updateView(!0)), this.setSelectedIdsForOutline(n.getSelection()), void(i && !i.pickable ? ((h = i.intersect).cx = r.x, h.cy = r.y, c(h, !1)) : c(null)) } var g = h.userId; if (mh.isMobileDevice() && (o.pivot = h.point), this.scene.intersectToWorld(h, o.viewer), h.innnerDebugging = A.altKey, h.cx = r.x, h.cy = r.y, this.lastPickedUserId = g, h.face && h.face.normal) { var u = h.face.normal; for (var f in u) u[f] = u[f] === -u[f] ? Math.abs(u[f]) : u[f] } if (A.button !== t.RIGHT) if (e) vc.EnableDemolishByDClick ? (n.setSelection([g]), c(h, !0), o.updateView(!0)) : (n.setSelection([g]), o.fitAndRotateBySelection(), c(h, !0)); else { var m = n.getSelection(); if (!!vc.MultipleSelectComponents && A.ctrlKey) { var C = m.indexOf(g); - 1 === C ? n.addSelection([g]) : (m.splice(C, 1), n.setSelection(m)) } else -1 === m.indexOf(g) ? n.setSelection([g]) : n.clearSelection(); this.setSelectedIdsForOutline(n.getSelection()), c(h, !0), o.updateView(!0) } else c(h, !1) } else c(h, !1) }, handleShiftMeasure: function (A, e, t) { var i = null, o = this.cameraControl, n = new s(A.clientX, A.clientY), r = o.getIntersectContext(n); function a(t, n, r, a, s, l) { var c = o.viewer.modelManager; if (null !== t) { var h = o.scene.drawingToWorld(t); t.copy(h) } if (null !== r) { var d = o.scene.drawingToWorld(r[0]), p = o.scene.drawingToWorld(r[1]); r[0].copy(d), r[1].copy(p) } c.dispatchEvent(i = { type: Rc.ON_MEASURE_PICK, event: A, pick: e, pickPoint: t, isAbsorbPoint: n, pickLine: r, pickPlane: a, userId: s, measureUnit: l }) } return o.intersector.pick(r, (function (A) { if (A) { var i = "", n = A.object.modelKey; if (n) { var r = o.viewer.modelManager.getModel(n); r && r.originalLengthUnit && (i = r.originalLengthUnit) } var s = new y; s.subVectors(A.point, t), s.normalize(); var l = new y(1, 0, 0), c = new y(0, 1, 0), h = new y(0, 0, 1), d = l.dot(s), p = c.dot(s), g = h.dot(s), u = new y; u.copy(t); .707 > Math.abs(p) ? Math.abs(g) < Math.abs(d) ? u.x = A.point.x : u.z = A.point.z : u.y = A.point.y, e && t.copy(u), a(u, !1, null, !1, A.userId, i) } else a(null, !1, null, !1) })), i }, handleMouseMeasure: function (A, e, t, i) { var o = null, n = this.cameraControl, r = n.scene, a = i || Rc.ON_MEASURE_PICK, s = this.pickToPoint({ x: A.clientX, y: A.clientY }, 5); function l(t, i, r, s, l, c, h) { var d = n.viewer.modelManager; if (null !== t) { var p = n.scene.drawingToWorld(t); t.copy(p) } if (null !== r) { var g = n.scene.drawingToWorld(r[0]), u = n.scene.drawingToWorld(r[1]); r[0].copy(g), r[1].copy(u) } (s || e || r || t) && d.dispatchEvent(o = { type: a, event: A, pick: e, pickPoint: t, isAbsorbPoint: i, pickLine: r, pickPlane: s, normal: l, userId: c, measureUnit: h }) } return null !== s ? (e && t.copy(s.pickPoint), l(s.pickPoint, s.isAbsorbPoint, s.pickLine, s.pickPlane, s.face.normal, s.userId, s.measureUnit)) : (r.hasGroup(gp.MEASUREPICKPLANE) && r.removeGroupByName(gp.MEASUREPICKPLANE), l(null, !1, null, !1)), o }, handleMouseHover: function (A) { var e = this, t = this.cameraControl, i = t.viewer.modelManager.sceneState; if (function () { if (!1 === e.scene.hasGroup(gp.AXISGRIDMANAGER)) return !1; var A = e.scene.getAxisGridManager(); return 0 !== A.getElements().length && !1 !== A.getIsEnableHover() }()) { var o = this.scene.getMatrixGlobal(), n = new s(A.clientX, A.clientY), r = t.getRaycaster(n.x, n.y), a = this.scene.getAxisGridManager(), l = a.getIntersectPoints(r, o), c = a.snapOnFloors(l); t.viewer.modelManager.dispatchEvent({ type: Rc.ON_AXIS_GRID_HOVER, snaps: c }) } if (vc.Hover) { var h = t.screenToCanvas(A.clientX, A.clientY), d = new s(A.clientX, A.clientY), p = t.getIntersectContext(d); t.intersector.pick(p, (function (A) { function o(A) { switch (A.objectType) { case Qc.Marker3d: A.object.setAttributeSize(A.index, A.currentSize); break; default: i.clearHover() } } if (A) { var n = vc.Hover || A.hoverEnabled; e.lastIntersected && (e.lastIntersected.userId !== A.userId && o(e.lastIntersected), e.lastIntersected.hoverEnabled && g(null)), n ? (e.lastIntersected && e.lastIntersected.userId === A.userId || (! function (A) { switch (A.objectType) { case Qc.Marker3d: var e = A.object; A.currentSize = e.getAttributeSize(A.index), e.setAttributeSize(A.index, Math.floor(1.5 * A.currentSize)); break; default: i.setHoverId(vc.EnableRenderPass ? A.object.originalId : A.userId) } }(A), e.lastIntersected = A), g(A, !0)) : e.lastIntersected = A, t.updateHighlight() } else e.lastIntersected && (o(e.lastIntersected), e.lastIntersected = null, g(null), t.updateHighlight()) })) } function g(i, o) { var n = t.viewer.modelManager; null !== i && e.scene.intersectToWorld(i, t.viewer), n.dispatchEvent({ type: Rc.ON_HOVER_PICK, event: A, canvasPos: { x: h.x, y: h.y }, intersectInfo: i ? { selectedObjectId: i.userId, objectType: i.objectType, selectable: o, modelKey: i.modelKey, worldPosition: i.worldPosition, worldBoundingBox: i.worldBoundingBox, point: i.point, innnerDebugging: i.innnerDebugging, object: i.object } : null }) } }, _canPick: function () { return this.cameraControl.viewer.modelManager.hasModelDataReady() }, setSelectedIdsForOutline: function (A) { this.cameraControl.viewer.rendererManager.composer && this.cameraControl.viewer.rendererManager.composer.setSelectedIds(A) }, pickToPoint: function (A, e) { var t = 0; t = void 0 === e ? 25 : e * e; var i = this.cameraControl, o = i.scene, n = new s(A.x, A.y), r = i.getIntersectContext(n), a = i.intersector.pick(r); if (a) { var l = "", c = a.object.modelKey, h = null; c && (h = i.viewer.modelManager.getModel(c)) && h.originalLengthUnit && (l = h.originalLengthUnit); var d = a.point, p = a.object.geometry, g = ((new M).extractRotation(a.object.matrix.clone()), a.object.matrixWorld.clone()), u = i.camera.projScreenMatrix, f = r.mouse, m = r.viewportSize, C = null; if (null != a.indexInfo && (C = a.indexInfo), !p.attributes && !p._bufferGeometry) return null; var v = p.attributes ? p : p._bufferGeometry; if (!v.index || void 0 === v.attributes.normal) return null; var I = v.attributes.position.array, E = v.attributes.normal.array, B = []; C || h && h.merged && g.multiply(a.matrix); var x = 1 / 0, S = (A = new y, []), w = new y, b = new y, U = w.set(I[3 * a.face.a], I[3 * a.face.a + 1], I[3 * a.face.a + 2]); U.applyMatrix4(g); var F = b.copy(U); F.applyMatrix4(u); var K = .5 * (F.x - f.x) * m.width, Q = .5 * (F.y - f.y) * m.height, R = K * K + Q * Q; x > R && (x = R, A.copy(U)), (U = w.set(I[3 * a.face.b], I[3 * a.face.b + 1], I[3 * a.face.b + 2])).applyMatrix4(g), (F = b.copy(U)).applyMatrix4(u), x > (R = (K = .5 * (F.x - f.x) * m.width) * K + (Q = .5 * (F.y - f.y) * m.height) * Q) && (x = R, A.copy(U)), (U = w.set(I[3 * a.face.c], I[3 * a.face.c + 1], I[3 * a.face.c + 2])).applyMatrix4(g), (F = b.copy(U)).applyMatrix4(u), x > (R = (K = .5 * (F.x - f.x) * m.width) * K + (Q = .5 * (F.y - f.y) * m.height) * Q) && (x = R, A.copy(U)); var T = d.clone(), k = !1, D = null, L = !1; if (t > x) o.hasGroup(gp.MEASUREPICKPLANE) && o.removeGroupByName(gp.MEASUREPICKPLANE), T = A.clone(), k = !0; else { x = 1 / 0; var N = new y, O = new y; A = new y; var V, G = this._getEegeData(a); if (!G) return Bh.error("no edge data"), null; S = G.positionsArray, V = G.edgeIndex; for (var P = 0; V.length > P; P += 2) { Rp.set(S[3 * V[P]], S[3 * V[P] + 1], S[3 * V[P] + 2]), Rp.applyMatrix4(g), Tp.set(S[3 * V[P + 1]], S[3 * V[P + 1] + 1], S[3 * V[P + 1] + 2]), Tp.applyMatrix4(g); var q = this._pointToLine(Rp, Tp, d); (F = q.clone()).applyMatrix4(u), x > (R = (K = .5 * (F.x - f.x) * m.width) * K + (Q = .5 * (F.y - f.y) * m.height) * Q) && (x = R, N.copy(Rp), O.copy(Tp), A.copy(q)) } if (S = null, t > x) o.hasGroup(gp.MEASUREPICKPLANE) && o.removeGroupByName(gp.MEASUREPICKPLANE), (D = []).push(N), D.push(O), T = A.clone(); else { if (vc.MeasureHighlightPlane) { B = v.index.array; var j = new M; j.getInverse(g); var H = new y(d.x, d.y, d.z); H.applyMatrix4(j); var Y = Fp(I, E, B, H, a.face.normal), W = new he; W.setIndex(Y), W.setAttribute("position", p.attributes.position, 3), W.setAttribute("normal", p.attributes.normal, 3); var J = Up(I, Y), z = new he; z.setIndex(J), z.setAttribute("position", p.attributes.position, 3), o.hasGroup(gp.MEASUREPICKPLANE) && o.removeGroupByName(gp.MEASUREPICKPLANE); var Z = o.getOrCreateGroup(gp.MEASUREPICKPLANE, { priority: 1, globalSpace: !0 }), X = new Ue(W, new jA({ color: 1170103, opacity: .1, transparent: !0 })); X.applyMatrix4(a.object.matrix), Z.add(X); var _ = new jo(z, new ko({ color: 1170103 })); _.applyMatrix4(a.object.matrix), Z.add(_), Z.updateMatrixWorld(!0), i.updateHighlight() } L = !0 } } var $ = {}; return $.pickPoint = T, $.isAbsorbPoint = k, $.measureUnit = l, $.pickLine = D, $.pickPlane = L, $.face = a.face, $.userId = a.userId, $ } return null }, _getEegeData: function (A) { var e = A.object.geometry; this.edgeDataMap || (this.edgeDataMap = {}); var t = null; null != A.indexInfo && (t = A.indexInfo); var i = e.attributes ? e : e._bufferGeometry, o = A.nodeId || A.userId; return this.edgeDataMap[i.id] ? this.edgeDataMap[i.id].version !== i.attributes.position.version ? (delete this.edgeDataMap[i.id].data, this.edgeDataMap[i.id].data[o] = this._getPositionArrayAndEdgeIndex(i, t)) : this.edgeDataMap[i.id].data[o] || (this.edgeDataMap[i.id].data[o] = this._getPositionArrayAndEdgeIndex(i, t)) : (this.edgeDataMap[i.id] = {}, this.edgeDataMap[i.id].version = i.attributes.position.version, this.edgeDataMap[i.id].data = {}, this.edgeDataMap[i.id].data[o] = this._getPositionArrayAndEdgeIndex(i, t)), this.edgeDataMap[i.id].data[o] }, _getPositionArrayAndEdgeIndex: function (A, e) { var t = [], i = 0, o = 0, n = [], r = [], a = A.attributes.position.array, s = []; if (e) { e.positionStart / 3; for (var l = uh.getMin((t = A.index.array).slice(i = e.indexStart, o = e.indexStart + e.indexCount)), c = i; o > c; c += 1) r.push(t[c] - l); n = a.slice(e.positionStart, e.positionStart + e.positionCount), s = Up(n, r) } else o = (t = bp(A.attributes.position.array, A.index.array)).length, n = a, s = Up(A.attributes.position.array, A.index.array); return { positionsArray: n, edgeIndex: s } }, _pointToLine: function (A, e, t) { Kp.subVectors(e, A), Qp.subVectors(t, A); var i = Kp.dot(Qp); if (0 > i) return A; var o = Kp.dot(Kp); if (i > o) return e; i /= o; var n = A.clone(); return n.addScaledVector(Kp, i), n } }; var Dp = "http://www.w3.org/2000/svg", Lp = function () { var A = document.createElementNS(Dp, "svg"), e = function (A, e, t, i) { var o = document.createElementNS(Dp, "defs"), n = document.createElementNS(Dp, "filter"); n.id = A, n.setAttributeNS(null, "x", "-30%"), n.setAttributeNS(null, "y", "-30%"), n.setAttributeNS(null, "width", "200%"), n.setAttributeNS(null, "height", "200%"); var r = document.createElementNS(Dp, "feGaussianBlur"); r.setAttributeNS(null, "in", "SourceAlpha"), r.setAttributeNS(null, "stdDeviation", "4"); var a = document.createElementNS(Dp, "feOffset"); a.setAttributeNS(null, "result", "offsetblur"); var s = document.createElementNS(Dp, "feMerge"), l = document.createElementNS(Dp, "feMergeNode"), c = document.createElementNS(Dp, "feMergeNode"); return c.setAttributeNS(null, "in", "SourceGraphic"), s.appendChild(l), s.appendChild(c), n.appendChild(r), n.appendChild(a), n.appendChild(s), o.appendChild(n), o }("drop-shadow"); return A.appendChild(e), A }, Np = function () { return document.createElementNS(Dp, "line") }, Op = function () { return document.createElementNS(Dp, "path") }, Vp = function (A) { var e = document.createElementNS(Dp, "circle"); return e.setAttributeNS(null, "r", A || 0), e.setAttributeNS(null, "fill", "none"), e }, Gp = function () { return document.createElementNS(Dp, "text") }, Pp = function () { return document.createElementNS(Dp, "g") }, qp = function (A, e) { var t = Math.pow(A[0] - e[0], 2), i = Math.pow(A[1] - e[1], 2), o = 0; return 3 === A.length && 3 === e.length && (o = Math.pow(A[2] - e[2], 2)), Math.sqrt(t + i + o) }, jp = function (A) { var e = Math.pow(A[0], 2), t = Math.pow(A[1], 2), i = 0; A.length > 2 && (i = Math.pow(A[2], 2)); var o = Math.sqrt(e + t + i), n = [A[0] / o, A[1] / o]; return A.length > 2 && n.push(A[2] / o), n }, Hp = function (A, e) { var t = 0; return A.length > 2 && e.length > 2 && (t = A[2] * e[2]), A[0] * e[0] + A[1] * e[1] + t }, Yp = function (A, e) { var t = A[0], i = A[1], o = A[2], n = e[0], r = e[1], a = e[2]; return [i * a - o * r, o * n - t * a, t * r - i * n] }, Wp = function (A) { return "mm" === A ? 1 : "cm" === A ? 10 : "m" === A ? 1e3 : 1 }, Jp = function (A, e, t, i) { var o = Wp(A); 2 === i ? o *= o : 3 === i && (o *= o * o); var n = Wp(e); return 2 === i ? n *= n : 3 === i && (n *= n * n), t * o / n }, zp = function (A, e) { return !(e.x > A.x + A.width || A.x > e.x + e.width || e.y > A.y + A.height || A.y > e.y + e.height) }, Zp = function () { return "undefined" != typeof window && "ontouchstart" in window }, Xp = function (A) { this.svg = A, this.maxPointsNeed = 0, this.pickedPoints = [], this.svgGroup = Pp(), this.svg.appendChild(this.svgGroup), this.unitOfModel = void 0, this.unitOnUI = void 0, this.precision = 3, this.adjustOption = void 0, this.is3DMode = !1, this.isSelected = !1, this.onclickCallback = void 0 }; Xp.prototype.addPickedPoint = function (A, e, t) { return !this.isDone() && (!!A && (this.pickedPoints.push(A), e && (this.unitOfModel = this.unitOfModel && this.unitOfModel !== e ? void 0 : e), !0)) }, Xp.prototype.getAllPickedPoint = function () { return this.pickedPoints }, Xp.prototype.draw = function (A, e) {}, Xp.prototype.adjustWithOption = function (A) { this.adjustOption = A, A && this.updateTexts() }, Xp.prototype.unAdjustWithOption = function (A) { this.adjustOption = void 0, this.updateTexts() }, Xp.prototype.changeUnit = function (A) { A && (this.unitOnUI = A, this.updateTexts()) }, Xp.prototype.changePrecision = function (A) { this.precision = A, A && this.updateTexts() }, Xp.prototype.updateTexts = function () {}, Xp.prototype.isVisible = function () { return !!(this.svg && this.svgGroup && this.svgGroup.parentNode) }, Xp.prototype.remove = function () { this.svg && this.svgGroup && this.svgGroup.parentNode && (this.svg.removeChild(this.svgGroup), this.onclickCallback = void 0) }, Xp.prototype.add = function () { this.svg && this.svgGroup && this.svg.appendChild(this.svgGroup) }, Xp.prototype.isDone = function () { return this.pickedPoints.length === this.maxPointsNeed }, Xp.prototype.setClickCallback = function (A) { this.onclickCallback = A }, Xp.prototype.measureResult = function () {}, Xp.prototype.createCircle = function () { var A = Vp(5); return A.setAttributeNS(null, "fill", "#ff9800"), A.setAttributeNS(null, "stroke", "#ffffff"), A.setAttributeNS(null, "stroke-width", 2), A.style.display = "none", A }, Xp.prototype.createLine = function () { var A = Np(); return A.setAttributeNS(null, "stroke-width", 2), A.setAttributeNS(null, "stroke", "#ffff00"), A.style.display = "none", A }, Xp.prototype.createText = function () { var A = Gp(); return A.style.fontSize = "14", A.style.display = "none", A.style.textAnchor = "middle", A.setAttributeNS(null, "fill", "#ffffff"), A }, Xp.prototype.createPath = function () { var A = Op(); return A.style.display = "none", A.setAttributeNS(null, "fill", "none"), A.setAttributeNS(null, "stroke", "#0aea06"), A }, Xp.prototype.resultToDisplayOfLength = function (A) { var e = A, t = this.unitOfModel; return this.adjustOption && (e = this.adjustOption.adjustLength(A), t = this.adjustOption.unit), this.unitOnUI && (t && (e = Jp(t, this.unitOnUI, e, 0)), t = this.unitOnUI), t || (t = ""), e = e.toFixed(this.precision), { value: Number(e), unit: t, text: e + t } }, Xp.prototype.setSelected = function (A) { return this.isSelected !== A && (this.isSelected = A, !0) }; var _p = function () { this.group = Pp(), this.group.style.display = "none"; var A = Op(); this.textBackground = A, this.group.appendChild(A), A = Op(), this.prefixTextBackground = A, this.prefixTextBackground.style.display = "none", this.group.appendChild(A); var e = Gp(); e.style.fontSize = "12", e.style.textAnchor = "middle", e.style.dominantBaseline = "central", e.style.cursor = "default", e.setAttributeNS(null, "fill", "#ffffff"), this.group.appendChild(e), this.text = e, (e = Gp()).style.fontSize = "12", e.style.textAnchor = "middle", e.style.dominantBaseline = "central", e.style.display = "none", e.setAttributeNS(null, "fill", "#ffffff"), this.group.appendChild(e), this.prefixText = e, this.textColor = "#ffffff", this.prefixTextColor = "#ffffff", this.textBackgroundColor = "#ffffff", this.prefixTextBackgroundColor = "blue", this.textContent = void 0, this.prefixTextContent = void 0, this.textPosition = { x: 0, y: 0 }, this.isShowShadow = !1, this.onclickCallback = void 0, this._onMouseDown = this._onMouseDown.bind(this), this._onMouseMove = this._onMouseMove.bind(this), this._onMouseUp = this._onMouseUp.bind(this) }; _p.prototype.draw = function (A) { if (this.textContent && this.textContent.length) { this.group.style.display = "", this.text.textContent = this.textContent; var e = null; this.prefixTextContent ? (this.prefixText.textContent = this.prefixTextContent, this.prefixText.style.display = "", e = this.prefixText.getBBox()) : (this.prefixText.style.display = "none", e = { width: 0, height: 0 }); var t = this.text.getBBox(), i = 5 + t.width + 5; this.prefixTextContent && this.prefixTextContent.length > 0 && (i = i + 5 + e.width + 5), A && (i = Math.max(A, i)); var o = this.textPosition.x - i / 2, n = this.textPosition.y - (5 + t.height + 5) / 2, r = function (A, e, t, i, o) { return "M" + A + "," + (e + o) + "a" + o + "," + o + " 0 0 1 " + o + "," + -o + "h" + (t - 2 * o) + "a" + o + "," + o + " 0 0 1 " + o + "," + o + "v" + (i - 2 * o) + "a" + o + "," + o + " 0 0 1 " + -o + "," + o + "h" + (2 * o - t) + "a" + o + "," + o + " 0 0 1 " + -o + "," + -o + "v" + (2 * o - i) + "z" }(o, n, i, t.height + 10, 5); this.textBackground.setAttributeNS(null, "d", r), this.textBackground.setAttributeNS(null, "fill", this.textBackgroundColor), this.isShowShadow ? this.group.setAttributeNS(null, "filter", "url(#drop-shadow)") : this.group.removeAttributeNS(null, "filter"), this.prefixTextContent && this.prefixTextContent.length > 0 ? (r = function (A, e, t, i, o) { return "M" + A + "," + (e + o) + "a" + o + "," + o + " 0 0 1 " + o + "," + -o + "h" + (t - o) + "v" + i + "h" + (o - t) + "a" + o + "," + o + " 0 0 1 " + -o + "," + -o + "v" + (2 * o - i) + "z" }(o, n, e.width + 10, e.height + 10, 5), this.prefixTextBackground.setAttributeNS(null, "d", r), this.prefixTextBackground.setAttributeNS(null, "fill", this.prefixTextBackgroundColor), this.prefixTextBackground.style.display = "", this.prefixText.setAttributeNS(null, "x", o + 5 + e.width / 2), this.prefixText.setAttributeNS(null, "y", n + 5 + e.height / 2), o = o + (10 + e.width) / 2 + i / 2) : o += i / 2, this.text.setAttributeNS(null, "x", o), this.text.setAttributeNS(null, "y", n + 5 + t.height / 2), this.text.setAttributeNS(null, "fill", this.textColor), this.prefixText.setAttributeNS(null, "fill", this.prefixTextColor) } }, _p.prototype.setText = function (A, e) { this.textContent = A, this.prefixTextContent = e }, _p.prototype.setPosition = function (A, e) { this.textPosition = { x: A, y: e } }, _p.prototype.hide = function () { this.group.style.display = "none" }, _p.prototype.show = function () { this.group.style.display = "" }, _p.prototype.setClickCallback = function (A) { this.onclickCallback = A, A ? (this.group.style.cursor = "pointer", this.text.style.cursor = "pointer", Zp() ? (this.group.addEventListener("touchstart", this._onMouseDown), this.group.addEventListener("touchend", this._onMouseUp), this.group.addEventListener("touchmove", this._onMouseMove)) : (this.group.addEventListener("mousedown", this._onMouseDown), this.group.addEventListener("mouseup", this._onMouseUp), this.group.addEventListener("mousemove", this._onMouseMove))) : (this.group.style.cursor = "default", this.text.style.cursor = "default", Zp() ? (this.group.removeEventListener("touchstart", this._onMouseDown), this.group.removeEventListener("touchend", this._onMouseUp), this.group.removeEventListener("touchmove", this._onMouseMove)) : (this.group.removeEventListener("mousedown", this._onMouseDown), this.group.removeEventListener("mouseup", this._onMouseUp), this.group.removeEventListener("mousemove", this._onMouseMove))) }, _p.prototype._onMouseMove = function (A) { A.stopPropagation(), A.preventDefault() }, _p.prototype._onMouseDown = function (A) { A.stopPropagation(), A.preventDefault() }, _p.prototype._onMouseUp = function (A) { A.stopPropagation(), A.preventDefault(), this.onclickCallback && this.onclickCallback() }; var $p = function (A) { Xp.call(this, A), this.maxPointsNeed = 2, this.startCircle = this.createCircle(), this.startCircle.setAttributeNS(null, "fill", "#ffffff"), this.endCircle = this.createCircle(), this.endCircle.setAttributeNS(null, "fill", "#ffffff"), this.svgGroup.appendChild(this.startCircle), this.svgGroup.appendChild(this.endCircle), this.line = this.createLine(), this.line.setAttributeNS(null, "stroke", "#ffffff"), this.line.setAttributeNS(null, "strokd-width", 2), this.svgGroup.appendChild(this.line), this.text = new _p, this.text.textBackgroundColor = "#ffffff", this.text.textColor = "#000000", this.svgGroup.appendChild(this.text.group), this._distance = void 0 }; ($p.prototype = Object.assign(Object.create(Xp.prototype), { constructor: $p })).addPickedPoint = function (A, e, t) { Xp.prototype.addPickedPoint.call(this, A, e, t) && this.isDone() && (this._enableSelect(), this._distance = qp(this.pickedPoints[0], this.pickedPoints[1])) }, $p.prototype.draw = function (A, e) { if (this.svgGroup.parentNode) { var t = this.pickedPoints; if (t.length > 0) { A && !this.isDone() && (t = t.concat([A])); var i = t; if (e) { for (var o = [], n = 0, r = t.length; r > n; n += 1) o[n] = e(t[n]); i = o } var a = i[0], s = i.length > 1 ? i[1] : a; if (this.startCircle.setAttributeNS(null, "cx", a[0]), this.startCircle.setAttributeNS(null, "cy", a[1]), this.startCircle.style.display = "", this.line.setAttributeNS(null, "x1", a[0]), this.line.setAttributeNS(null, "y1", a[1]), this.line.setAttributeNS(null, "x2", s[0]), this.line.setAttributeNS(null, "y2", s[1]), this.line.style.display = "", this.text.setPosition((a[0] + s[0]) / 2, (a[1] + s[1]) / 2), t.length > 1) { var l = qp(t[0], t[1]); this._distance = l } 2 === this.pickedPoints.length ? (this.endCircle.setAttributeNS(null, "cx", s[0]), this.endCircle.setAttributeNS(null, "cy", s[1]), this.endCircle.style.display = "") : this.endCircle.style.display = "none", this._updateText() } } }, $p.prototype.measureResult = function () { if (this.isDone()) { var A = {}; if (A.distance = this._distance, this.adjustOption) { var e = this.resultToDisplayOfLength(this._distance); A.unit = e.unit, A.value = e.value } return A } }, $p.prototype.adjustWithOption = function (A) { Xp.prototype.adjustWithOption.call(this, A), this._updateText(), this._disableSelect() }, $p.prototype.changeUnit = function (A) { Xp.prototype.changeUnit.call(this, A), A && this._updateText() }, $p.prototype.changePrecision = function (A) { Xp.prototype.changePrecision.call(this, A), A && this._updateText() }, $p.prototype._enableSelect = function () { var A = this; this.startCircle.onmousedown = function (e) { A.isDone() && (A.pickedPoints = A.pickedPoints.slice(1), e.stopPropagation(), A._disableSelect()) }, this.endCircle.onmousedown = function (e) { A.isDone() && (A.pickedPoints = A.pickedPoints.slice(0, 1), e.stopPropagation(), A._disableSelect()) } }, $p.prototype._disableSelect = function () { this.startCircle.onmousedown = void 0, this.endCircle.onmousedown = void 0 }, $p.prototype._updateText = function () { this.isDone() && this._distance && this.adjustOption && (this.text.setText(this.resultToDisplayOfLength(this._distance).text), this.text.draw()) }; var Ag = function () { this.unit = void 0, this.valueBeforeAdjust = void 0, this.valueAfterAdjust = void 0 }; Ag.prototype.adjustLength = function (A) { return this.valueAfterAdjust && this.valueBeforeAdjust ? A * this.valueAfterAdjust / this.valueBeforeAdjust : A }, Ag.prototype.adjustArea = function (A) { return this.valueAfterAdjust && this.valueBeforeAdjust ? A * Math.pow(this.valueAfterAdjust / this.valueBeforeAdjust, 2) : A }, Ag.prototype.adjustVolume = function (A) { return this.valueAfterAdjust && this.valueBeforeAdjust ? A * Math.pow(this.valueAfterAdjust / this.valueBeforeAdjust, 3) : A }; var eg = function (A) { Xp.call(this, A), this.maxPointsNeed = 3, this._angle = void 0, this.circle1 = this.createCircle(), this.circle2 = this.createCircle(), this.circle3 = this.createCircle(), this.svgGroup.appendChild(this.circle1), this.svgGroup.appendChild(this.circle2), this.svgGroup.appendChild(this.circle3), this.line1 = this.createLine(), this.line1.setAttributeNS(null, "stroke-width", 2), this.svgGroup.appendChild(this.line1), this.line2 = this.createLine(), this.line2.setAttributeNS(null, "stroke-width", 2), this.svgGroup.appendChild(this.line2), this.arc = this.createPath(), this.svgGroup.appendChild(this.arc), this.angleText = new _p, this.angleText.textBackgroundColor = "#009bff", this.svgGroup.appendChild(this.angleText.group); var e = this; this.angleText.setClickCallback((function () { e.onclickCallback && e.onclickCallback(e) })) }; (eg.prototype = Object.assign(Object.create(Xp.prototype), { constructor: eg })).addPickedPoint = function (A, e, t) { if (Xp.prototype.addPickedPoint.call(this, A, e, t) && this.isDone()) { var i = this.pickedPoints[0], o = this.pickedPoints[1], n = this.pickedPoints[2], r = (a = [n[0] - o[0], n[1] - o[1], n[2] - o[2]], s = jp([i[0] - o[0], i[1] - o[1], i[2] - o[2]]), l = jp(a), c = Hp(s, l), Math.acos(c) / Math.PI * 180); this._angle = r } var a, s, l, c }, eg.prototype.draw = function (A, e) { if (this.svgGroup.parentNode) { var t = this.pickedPoints; if (t.length > 0) { A && !this.isDone() && (t = t.concat([A])); var i = t, o = !0; if (e) { for (var n = !0, r = [], a = 0, s = t.length; s > a; a += 1) r[a] = e(t[a]), o && r[a][0] > 0 && r[a][0] < parseInt(this.svg.style.width, 10) && r[a][1] > 0 && r[a][1] < parseInt(this.svg.style.height, 10) && (o = !1), void 0 !== r[a][2] && 0 !== r[a][2] || (n = !1); i = r, n && (o = !0) } if (this.pickedPoints.length >= 1) { var l = i[0], c = i[1]; this.circle1.setAttributeNS(null, "cx", l[0]), this.circle1.setAttributeNS(null, "cy", l[1]), this.circle1.style.display = "", (A || this.pickedPoints.length > 1) && (this.line1.setAttributeNS(null, "x1", l[0]), this.line1.setAttributeNS(null, "y1", l[1]), this.line1.setAttributeNS(null, "x2", c[0]), this.line1.setAttributeNS(null, "y2", c[1]), this.line1.style.display = "") } if (this.pickedPoints.length >= 2) { var h = i[1], d = i[2]; this.circle2.setAttributeNS(null, "cx", h[0]), this.circle2.setAttributeNS(null, "cy", h[1]), this.circle2.style.display = "", (A || this.pickedPoints.length > 2) && (this.line2.setAttributeNS(null, "x1", h[0]), this.line2.setAttributeNS(null, "y1", h[1]), this.line2.setAttributeNS(null, "x2", d[0]), this.line2.setAttributeNS(null, "y2", d[1]), this.line2.style.display = "") } if (3 === this.pickedPoints.length) { if (o) return void(this.svgGroup.style.display = "none"); this.svgGroup.style.display = ""; var p = i[2]; this.circle3.setAttributeNS(null, "cx", p[0]), this.circle3.setAttributeNS(null, "cy", p[1]), this.circle3.style.display = ""; var g = i[0].slice(0, 2), u = i[1].slice(0, 2), f = i[2].slice(0, 2), m = qp(g, u), C = qp(u, f), y = Math.min(Math.min(m, C), 30), v = jp([g[0] - u[0], g[1] - u[1]]), I = [u[0] + v[0] * y, u[1] + v[1] * y], E = jp([f[0] - u[0], f[1] - u[1]]), B = [u[0] + E[0] * y, u[1] + E[1] * y], x = [(I[0] + B[0]) / 2, (I[1] + B[1]) / 2], S = [x[0] - u[0], x[1] - u[1]], w = [u[0] + (S = [1.5 * S[0], 1.5 * S[1]])[0], u[1] + S[1]], M = "M" + I[0] + "," + I[1]; M += "Q" + w[0] + "," + w[1], this.arc.setAttributeNS(null, "d", M += " " + B[0] + "," + B[1]), this.arc.style.display = "", this.angleText.setText(this._angle.toFixed(this.precision) + "°"), this.angleText.setPosition(w[0], w[1]), this.angleText.draw() } } } }, eg.prototype.setSelected = function (A) { Xp.prototype.setSelected.call(this, A) && (A ? (this.angleText.isShowShadow = !0, this.angleText.textBackgroundColor = "#ffffff", this.angleText.textColor = "#009bff", this.angleText.draw()) : (this.angleText.isShowShadow = !1, this.angleText.textBackgroundColor = "#009bff", this.angleText.textColor = "#ffffff", this.angleText.draw())) }, eg.prototype.measureResult = function () { return this._angle }; var tg = function (A) { Xp.call(this, A), this.path = Op(), this.path.setAttributeNS(null, "fill", "none"), this.path.setAttributeNS(null, "stroke", "rgb(69,195,69)"), this.svgGroup.appendChild(this.path), this._isDone = !1, this._circles = [], this._area = -1, this.resultText = new _p, this.resultText.textBackgroundColor = "#009bff", this.svgGroup.appendChild(this.resultText.group); var e = this; this.resultText.setClickCallback((function () { e.onclickCallback && e.onclickCallback(e) })) }; (tg.prototype = Object.assign(Object.create(Xp.prototype), { constructor: tg })).addPickedPoint = function (A, e, t) { if (this._pointCanClosePath(A, t)) this._isDone = !0, this._area = this.is3DMode ? this._calculateArea3D() : this._calculateArea2D(); else if (Xp.prototype.addPickedPoint.call(this, A, e, t)) { var i = this.createCircle(); this.svgGroup.appendChild(i), this._circles.push(i) } }, tg.prototype.isDone = function () { return this._isDone }, tg.prototype.draw = function (A, e) { if (this.svgGroup.parentNode) { var t = this.pickedPoints; if (t.length > 0) { if (A && !this.isDone()) { if (this._pointCanClosePath(A, e)) { var i = this.pickedPoints[0]; A = [i[0], i[1], i[2]] } t = t.concat([A]) } var o = t, n = !0; if (e) { for (var r = !0, a = [], s = 0, l = t.length; l > s; s += 1) a[s] = e(t[s]), n && a[s][0] > 0 && a[s][0] < parseInt(this.svg.style.width, 10) && a[s][1] > 0 && a[s][1] < parseInt(this.svg.style.height, 10) && (n = !1), void 0 !== a[s][2] && 0 !== a[s][2] || (r = !1); o = a, r && (n = !0) } var c = this._pathString(o); if (this.path.setAttributeNS(null, "d", c), this.isDone()) { if (n) return void(this.svgGroup.style.display = "none"); this.svgGroup.style.display = "", this.path.setAttributeNS(null, "fill", "rgba(69,195,69,0.5)"); var h = this._getPointsCenter(this.pickedPoints); e && (h = e(h)), this.resultText.setPosition(h[0], h[1]), this.updateTexts() } for (var d = 0, p = this._circles.length; p > d; d += 1) { var g = this._circles[d], u = o[d]; g.setAttributeNS(null, "cx", u[0]), g.setAttributeNS(null, "cy", u[1]), g.style.display = "" } } } }, tg.prototype.measureResult = function () { return this._area }, tg.prototype.updateTexts = function () { this.isDone() && (this.resultText.setText(this.resultToDisplayOfArea(this._area).text), this.resultText.draw()) }, tg.prototype.setSelected = function (A) { Xp.prototype.setSelected.call(this, A) && (A ? (this.resultText.isShowShadow = !0, this.resultText.textBackgroundColor = "#ffffff", this.resultText.textColor = "#009bff", this.resultText.draw()) : (this.resultText.isShowShadow = !1, this.resultText.textBackgroundColor = "#009bff", this.resultText.textColor = "#ffffff", this.resultText.draw())) }, tg.prototype.resultToDisplayOfArea = function (A) { var e = A, t = this.unitOfModel; return this.adjustOption && (e = this.adjustOption.adjustArea(A), t = this.adjustOption.unit), this.unitOnUI && (t && (e = Jp(t, this.unitOnUI, e, 2)), t = this.unitOnUI), t || (t = ""), e = e.toFixed(this.precision), "mm" === t ? t = "mm²" : "m" === t ? t = "m²" : "cm" === t && (t = "cm²"), { value: Number(e), unit: t, text: e + t } }, tg.prototype._pointCanClosePath = function (A, e) { if (this.pickedPoints.length > 0) { var t = this.pickedPoints[0]; e && (t = e(t), A = e(A)); var i = A[0] - t[0], o = A[1] - t[1]; if (200 >= i * i + o * o + 0) return !0 } return !1 }, tg.prototype._pathString = function (A) { if (!A || 0 === A.length) return ""; for (var e = "M" + A[0][0] + " " + A[0][1], t = 1, i = A.length; i > t; t += 1) e = e + "L" + A[t][0] + " " + A[t][1]; return this.isDone() && (e += "Z"), e }, tg.prototype._calculateArea2D = function () { if (this.isDone() && this.pickedPoints.length >= 3) { for (var A = this.pickedPoints, e = this.pickedPoints[0], t = [], i = 1, o = A.length; o > i; i += 1) t.push([A[i][0] - e[0], A[i][1] - e[1]]); for (var n = 0, r = 0, a = t.length; a - 1 > r; r += 1) { var s = t[r], l = t[r + 1]; n += s[0] * l[1] - s[1] * l[0] } return Math.abs(n / 2) } return 0 }, tg.prototype._calculateArea3D = function () { if (this.isDone() && this.pickedPoints.length >= 3) { for (var A = this.pickedPoints, e = this.pickedPoints[0], t = jp(Yp([this.pickedPoints[1][0] - e[0], this.pickedPoints[1][1] - e[1], this.pickedPoints[1][2] - e[2]], [this.pickedPoints[2][0] - e[0], this.pickedPoints[2][1] - e[1], this.pickedPoints[2][2] - e[2]])), i = 0, o = 1, n = A.length; n > o; o += 1) { i += Hp(Yp([this.pickedPoints[o - 1][0] - e[0], this.pickedPoints[o - 1][1] - e[1], this.pickedPoints[o - 1][2] - e[2]], [this.pickedPoints[o][0] - e[0], this.pickedPoints[o][1] - e[1], this.pickedPoints[o][2] - e[2]]), t) } return Math.abs(i / 2) } return 0 }, tg.prototype._getPointsCenter = function (A) { var e = A.length; return [A.reduce((function (A, e) { return A + e[0] }), 0) / e, A.reduce((function (A, e) { return A + e[1] }), 0) / e, A.reduce((function (A, e) { return A + e[2] }), 0) / e] }, tg.prototype._crossProduct = function (A, e) { var t = A[0], i = A[1], o = A[2], n = e[0], r = e[1], a = e[2]; return [i * a - o * r, o * n - t * a, t * r - i * n] }; var ig = function (A, e, t) { Xp.call(this, A), this.maxPointsNeed = 2, this.isMobile = e, this.number = t, this._drawPoints = [], this.startCircle = this.createCircle(), this.endCircle = this.createCircle(), this.svgGroup.appendChild(this.startCircle), this.svgGroup.appendChild(this.endCircle), this.distanceLine = this.createLine(), this.svgGroup.appendChild(this.distanceLine), this.deltaXLine = this.createLine(), this.deltaXLine.setAttributeNS(null, "stroke", "#ec4545"), this.deltaXLine.setAttributeNS(null, "stroke-dasharray", "6,4"), this.isMobile || this.svgGroup.appendChild(this.deltaXLine), this.deltaYLine = this.createLine(), this.deltaYLine.setAttributeNS(null, "stroke", "#45c345"), this.deltaYLine.setAttributeNS(null, "stroke-dasharray", "6,4"), this.isMobile || this.svgGroup.appendChild(this.deltaYLine), this.deltaZLine = this.createLine(), this.deltaZLine.setAttributeNS(null, "stroke", "#5757da"), this.deltaZLine.setAttributeNS(null, "stroke-dasharray", "6,4"), this.isMobile || this.svgGroup.appendChild(this.deltaZLine), this.deltaXText = new _p, this.deltaXText.textColor = "#ec4545", this.deltaXText.prefixTextBackgroundColor = "#ec4545", this.svgGroup.appendChild(this.deltaXText.group), this.deltaYText = new _p, this.deltaYText.textColor = "#45c345", this.deltaYText.prefixTextBackgroundColor = "#45c345", this.svgGroup.appendChild(this.deltaYText.group), this.deltaZText = new _p, this.deltaZText.textColor = "#5757da", this.deltaZText.prefixTextBackgroundColor = "#5757da", this.svgGroup.appendChild(this.deltaZText.group), this.distanceText = new _p, this.distanceText.textBackgroundColor = "#009bff"; var i = this; this.distanceText.setClickCallback((function () { i.onclickCallback && i.onclickCallback(i) })), this.svgGroup.appendChild(this.distanceText.group), this._distance = void 0, this._deltaXDistance = void 0, this._deltaYDistance = void 0, this._deltaZDistance = void 0 }; (ig.prototype = Object.assign(Object.create(Xp.prototype), { constructor: ig })).addPickedPoint = function (A, e, t) { if (Xp.prototype.addPickedPoint.call(this, A, e, t) && (this._drawPoints.push(A), this.isDone())) { if (3 === A.length) { var i = []; i[0] = this.pickedPoints[1][0], i[1] = this.pickedPoints[0][1], i[2] = this.pickedPoints[1][2]; var o = []; o[0] = this.pickedPoints[1][0], o[1] = this.pickedPoints[0][1], o[2] = this.pickedPoints[0][2], this._drawPoints.push(i), this._drawPoints.push(o) } this._distance = qp(this._drawPoints[0], this._drawPoints[1]), this._deltaYDistance = qp(this._drawPoints[1], this._drawPoints[2]), this._deltaZDistance = qp(this._drawPoints[2], this._drawPoints[3]), this._deltaXDistance = qp(this._drawPoints[3], this._drawPoints[0]), this.updateTexts() } }, ig.prototype.draw = function (A, e) { if (this.svgGroup.parentNode) { var t = this._drawPoints; if (t.length > 0) { A && !this.isDone() && (t = t.concat([A])); var i = t, o = !0; if (e) { for (var n = !0, r = [], a = 0, s = t.length; s > a; a += 1) r[a] = e(t[a]), o && r[a][0] > 0 && r[a][0] < parseInt(this.svg.style.width, 10) && r[a][1] > 0 && r[a][1] < parseInt(this.svg.style.height, 10) && (o = !1), void 0 !== r[a][2] && 0 !== r[a][2] || (n = !1); i = r, n && (o = !0) } var l = i[0], c = i.length > 1 ? i[1] : l; if (this.startCircle.setAttributeNS(null, "cx", l[0]), this.startCircle.setAttributeNS(null, "cy", l[1]), this.startCircle.style.display = "", this.distanceLine.setAttributeNS(null, "x1", l[0]), this.distanceLine.setAttributeNS(null, "y1", l[1]), this.distanceLine.setAttributeNS(null, "x2", c[0]), this.distanceLine.setAttributeNS(null, "y2", c[1]), this.distanceLine.style.display = "", 2 > t.length) return; if (this.distanceText.setPosition((l[0] + c[0]) / 2, (l[1] + c[1]) / 2), !this.isDone()) { var h = qp(t[0], t[1]); this._distance = h } if (4 === t.length) { if (o) return void(this.svgGroup.style.display = "none"); this.svgGroup.style.display = "", this.isSelected ? (this.distanceText.isShowShadow = !0, this.distanceText.textBackgroundColor = "#ffffff", this.distanceText.textColor = "#009bff") : (this.distanceText.isShowShadow = !1, this.distanceText.textBackgroundColor = "#009bff", this.distanceText.textColor = "#ffffff"), this.distanceText.draw(), this.endCircle.style.display = "", this.deltaYLine.style.display = "", this.deltaXLine.style.display = "", this.deltaZLine.style.display = "", this.endCircle.setAttributeNS(null, "cx", c[0]), this.endCircle.setAttributeNS(null, "cy", c[1]); var d = i[2], p = i[3]; this.deltaYLine.setAttributeNS(null, "x1", c[0]), this.deltaYLine.setAttributeNS(null, "y1", c[1]), this.deltaYLine.setAttributeNS(null, "x2", d[0]), this.deltaYLine.setAttributeNS(null, "y2", d[1]), this.deltaYText.setPosition((d[0] + c[0]) / 2, (d[1] + c[1]) / 2), this.deltaZLine.setAttributeNS(null, "x1", d[0]), this.deltaZLine.setAttributeNS(null, "y1", d[1]), this.deltaZLine.setAttributeNS(null, "x2", p[0]), this.deltaZLine.setAttributeNS(null, "y2", p[1]), this.deltaZText.setPosition((d[0] + p[0]) / 2, (d[1] + p[1]) / 2), this.deltaXLine.setAttributeNS(null, "x1", p[0]), this.deltaXLine.setAttributeNS(null, "y1", p[1]), this.deltaXLine.setAttributeNS(null, "x2", l[0]), this.deltaXLine.setAttributeNS(null, "y2", l[1]), this.deltaXText.setPosition((p[0] + l[0]) / 2, (p[1] + l[1]) / 2), this.isSelected && (this.isMobile || (this.deltaXText.draw(), this.deltaYText.draw(), this.deltaZText.draw()), this.layoutResultText()) } } } }, ig.prototype.layoutResultText = function () { for (var A = this.distanceText.group.getBBox(), e = this.deltaXText.group.getBBox(), t = this.deltaYText.group.getBBox(), i = this.deltaZText.group.getBBox(), o = [e, t, i], n = !1, r = 0; o.length > r; r += 1) if (zp(A, o[r])) { n = !0; break } if (n || (n = zp(e, t)), n || (n = zp(e, i)), n || (n = zp(t, i)), n) { var a = Math.max(A.width, e.width, t.width, i.width), s = A.x + A.width / 2, l = A.y + A.height + 8; return this.deltaXText.setPosition(s, l + e.height / 2), this.deltaYText.setPosition(s, (l += e.height) + t.height / 2), this.deltaZText.setPosition(s, (l += t.height) + i.height / 2), this.isMobile || (this.deltaXText.draw(a), this.deltaYText.draw(a), this.deltaZText.draw(a)), this.distanceText.draw(a), n } }, ig.prototype.measureResult = function () { if (this._distance) return [this._distance, this._deltaXDistance, this._deltaYDistance, this._deltaZDistance] }, ig.prototype.updateTexts = function () { this._distance && (this.distanceText.setText(this.isMobile ? "线段" + this.number + ": " + this.resultToDisplayOfLength(this._distance).text : this.resultToDisplayOfLength(this._distance).text, void 0), this.distanceText.draw(), this.isDone() && (0 !== this._deltaXDistance && this.deltaXText.setText(this.resultToDisplayOfLength(this._deltaXDistance).text, "X"), 0 !== this._deltaYDistance && this.deltaYText.setText(this.resultToDisplayOfLength(this._deltaYDistance).text, "Y"), 0 !== this._deltaZDistance && this.deltaZText.setText(this.resultToDisplayOfLength(this._deltaZDistance).text, "Z"), this.isSelected && !this.isMobile && (this.deltaXText.draw(), this.deltaYText.draw(), this.deltaZText.draw()))) }, ig.prototype.setSelected = function (A) { Xp.prototype.setSelected.call(this, A) && (A ? (this.distanceText.isShowShadow = !0, this.distanceText.textBackgroundColor = "#ffffff", this.distanceText.textColor = "#009bff", this.isMobile || (this.deltaXText.draw(), this.deltaYText.draw(), this.deltaZText.draw()), this.distanceText.draw(), this.layoutResultText()) : (this.deltaXText.hide(), this.deltaYText.hide(), this.deltaZText.hide(), this.distanceText.isShowShadow = !1, this.distanceText.textBackgroundColor = "#009bff", this.distanceText.textColor = "#ffffff", this.distanceText.draw())) }; var og = function (A) { Xp.call(this, A), this.maxPointsNeed = 2, this.startCircle = this.createCircle(), this.endCircle = this.createCircle(), this.svgGroup.appendChild(this.startCircle), this.svgGroup.appendChild(this.endCircle), this.distanceLine = this.createLine(), this.svgGroup.appendChild(this.distanceLine), this.distanceText = new _p, this.distanceText.textBackgroundColor = "#009bff", this.svgGroup.appendChild(this.distanceText.group); var e = this; this.distanceText.setClickCallback((function () { e.onclickCallback && e.onclickCallback(e) })), this.pickedComponentKeys = [], this._distance = void 0 }; (og.prototype = Object.assign(Object.create(Xp.prototype), { constructor: og })).setData = function (A, e, t) { this.pickedPoints = A, this._distance = e, t && (this.unitOfModel = this.unitOfModel && this.unitOfModel !== t ? void 0 : t) }, og.prototype.draw = function (A, e) { if (this.svgGroup.parentNode && this.isDone()) { var t = this.pickedPoints; if (e) { for (var i = [], o = 0, n = t.length; n > o; o += 1) i[o] = e(t[o]); t = i } var r = t[0], a = t[1]; this.startCircle.setAttributeNS(null, "cx", r[0]), this.startCircle.setAttributeNS(null, "cy", r[1]), this.startCircle.style.display = "", this.endCircle.setAttributeNS(null, "cx", a[0]), this.endCircle.setAttributeNS(null, "cy", a[1]), this.endCircle.style.display = "", this.distanceLine.setAttributeNS(null, "x1", r[0]), this.distanceLine.setAttributeNS(null, "y1", r[1]), this.distanceLine.setAttributeNS(null, "x2", a[0]), this.distanceLine.setAttributeNS(null, "y2", a[1]), this.distanceLine.style.display = "", this.distanceText.setPosition((r[0] + a[0]) / 2, (r[1] + a[1]) / 2), this.updateTexts() } }, og.prototype.measureResult = function () { if (void 0 !== this._distance) return this._distance }, og.prototype.updateTexts = function () { void 0 !== this._distance && (this.distanceText.setText(this.resultToDisplayOfLength(this._distance).text, void 0), this.distanceText.draw()) }, og.prototype.setSelected = function (A) { Xp.prototype.setSelected.call(this, A) && (A ? (this.distanceText.isShowShadow = !0, this.distanceText.textBackgroundColor = "#ffffff", this.distanceText.textColor = "#009bff", this.distanceText.draw()) : (this.distanceText.isShowShadow = !1, this.distanceText.textBackgroundColor = "#009bff", this.distanceText.textColor = "#ffffff", this.distanceText.draw())) }; var ng = function (A) { Xp.call(this, A), this.maxPointsNeed = 2; var e = Np(); e.setAttributeNS(null, "stroke-width", "2"), e.setAttributeNS(null, "stroke", "#0aea06"), this.svgGroup.appendChild(e), this._line = e, this.distanceText = new _p, this.distanceText.textBackgroundColor = "#009bff", this.svgGroup.appendChild(this.distanceText.group) }; (ng.prototype = Object.assign(Object.create(Xp.prototype), { constructor: ng })).setData = function (A, e) { A && e && (this._points = [A, e]) }, ng.prototype.draw = function (A, e) { if (2 === this._points.length) { var t = e(this._points[0]), i = e(this._points[1]); this._line.setAttributeNS(null, "x1", t[0]), this._line.setAttributeNS(null, "y1", t[1]), this._line.setAttributeNS(null, "x2", i[0]), this._line.setAttributeNS(null, "y2", i[1]), this.distanceText.setPosition((t[0] + i[0]) / 2, (t[1] + i[1]) / 2); var o = qp(this._points[0], this._points[1]); this.distanceText.setText(this.resultToDisplayOfLength(o).text, void 0), this.distanceText.draw() } }; var rg, ag, sg = function (A, e) { this.x = A || 0, this.y = e || 0 }; Object.defineProperties(sg.prototype, { width: { get: function () { return this.x }, set: function (A) { this.x = A } }, height: { get: function () { return this.y }, set: function (A) { this.y = A } } }), Object.assign(sg.prototype, { isVector2: !0, set: function (A, e) { return this.x = A, this.y = e, this }, setScalar: function (A) { return this.x = A, this.y = A, this }, setX: function (A) { return this.x = A, this }, setY: function (A) { return this.y = A, this }, setComponent: function (A, e) { switch (A) { case 0: this.x = e; break; case 1: this.y = e; break; default: throw new Error("index is out of range: " + A) } return this }, getComponent: function (A) { switch (A) { case 0: return this.x; case 1: return this.y; default: throw new Error("index is out of range: " + A) } }, clone: function () { return new this.constructor(this.x, this.y) }, copy: function (A) { return this.x = A.x, this.y = A.y, this }, add: function (A, e) { return void 0 !== e ? (console.warn("Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead."), this.addVectors(A, e)) : (this.x += A.x, this.y += A.y, this) }, addScalar: function (A) { return this.x += A, this.y += A, this }, addVectors: function (A, e) { return this.x = A.x + e.x, this.y = A.y + e.y, this }, addScaledVector: function (A, e) { return this.x += A.x * e, this.y += A.y * e, this }, sub: function (A, e) { return void 0 !== e ? (console.warn("Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."), this.subVectors(A, e)) : (this.x -= A.x, this.y -= A.y, this) }, subScalar: function (A) { return this.x -= A, this.y -= A, this }, subVectors: function (A, e) { return this.x = A.x - e.x, this.y = A.y - e.y, this }, multiply: function (A) { return this.x *= A.x, this.y *= A.y, this }, multiplyScalar: function (A) { return this.x *= A, this.y *= A, this }, divide: function (A) { return this.x /= A.x, this.y /= A.y, this }, divideScalar: function (A) { return this.multiplyScalar(1 / A) }, applyMatrix3: function (A) { var e = this.x, t = this.y, i = A.elements; return this.x = i[0] * e + i[3] * t + i[6], this.y = i[1] * e + i[4] * t + i[7], this }, min: function (A) { return this.x > A.x && (this.x = A.x), this.y > A.y && (this.y = A.y), this }, max: function (A) { return A.x > this.x && (this.x = A.x), A.y > this.y && (this.y = A.y), this }, clamp: function (A, e) { return this.x = Math.max(A.x, Math.min(e.x, this.x)), this.y = Math.max(A.y, Math.min(e.y, this.y)), this }, clampScalar: (rg = new sg, ag = new sg, function (A, e) { return rg.set(A, A), ag.set(e, e), this.clamp(rg, ag) } ), clampLength: function (A, e) { var t = this.length(); return this.divideScalar(t || 1).multiplyScalar(Math.max(A, Math.min(e, t))) }, floor: function () { return this.x = Math.floor(this.x), this.y = Math.floor(this.y), this }, ceil: function () { return this.x = Math.ceil(this.x), this.y = Math.ceil(this.y), this }, round: function () { return this.x = Math.round(this.x), this.y = Math.round(this.y), this }, roundToZero: function () { return this.x = 0 > this.x ? Math.ceil(this.x) : Math.floor(this.x), this.y = 0 > this.y ? Math.ceil(this.y) : Math.floor(this.y), this }, negate: function () { return this.x = -this.x, this.y = -this.y, this }, dot: function (A) { return this.x * A.x + this.y * A.y }, cross: function (A) { return this.x * A.y - this.y * A.x }, lengthSq: function () { return this.x * this.x + this.y * this.y }, length: function () { return Math.sqrt(this.x * this.x + this.y * this.y) }, manhattanLength: function () { return Math.abs(this.x) + Math.abs(this.y) }, normalize: function () { return this.divideScalar(this.length() || 1) }, angle: function () { var A = Math.atan2(this.y, this.x); return 0 > A && (A += 2 * Math.PI), A }, distanceTo: function (A) { return Math.sqrt(this.distanceToSquared(A)) }, distanceToSquared: function (A) { var e = this.x - A.x, t = this.y - A.y; return e * e + t * t }, manhattanDistanceTo: function (A) { return Math.abs(this.x - A.x) + Math.abs(this.y - A.y) }, setLength: function (A) { return this.normalize().multiplyScalar(A) }, lerp: function (A, e) { return this.x += (A.x - this.x) * e, this.y += (A.y - this.y) * e, this }, lerpVectors: function (A, e, t) { return this.subVectors(e, A).multiplyScalar(t).add(A) }, equals: function (A) { return A.x === this.x && A.y === this.y }, fromArray: function (A, e) { return void 0 === e && (e = 0), this.x = A[e], this.y = A[e + 1], this }, toArray: function (A, e) { return void 0 === A && (A = []), void 0 === e && (e = 0), A[e] = this.x, A[e + 1] = this.y, A }, rotateAround: function (A, e) { var t = Math.cos(e), i = Math.sin(e), o = this.x - A.x, n = this.y - A.y; return this.x = o * t - n * i + A.x, this.y = o * i + n * t + A.y, this } }); var lg = function () { this.elements = [1, 0, 0, 0, 1, 0, 0, 0, 1] }; function cg(A, e) { this.normal = void 0 !== A ? A : new $c(1, 0, 0), this.constant = void 0 !== e ? e : 0 } lg.prototype.clear = function () { return this.elements = [1, 0, 0, 0, 1, 0, 0, 0, 1], this }, lg.prototype.set = function (A, e, t, i, o, n, r, a, s) { var l = this.elements; return l[0] = A, l[1] = i, l[2] = r, l[3] = e, l[4] = o, l[5] = a, l[6] = t, l[7] = n, l[8] = s, this }, lg.prototype.clone = function () { return (new this.constructor).fromArray(this.elements) }, lg.prototype.fromArray = function (A, e) { void 0 === e && (e = 0); for (var t = 0; 9 > t; t += 1) this.elements[t] = A[t + e]; return this }, lg.prototype.multiply = function (A) { return this.multiplyMatrices(this, A) }, lg.prototype.multiplyMatrices = function (A, e) { var t = A.elements, i = e.elements, o = this.elements, n = t[0], r = t[3], a = t[6], s = t[1], l = t[4], c = t[7], h = t[2], d = t[5], p = t[8], g = i[0], u = i[3], f = i[6], m = i[1], C = i[4], y = i[7], v = i[2], I = i[5], E = i[8]; return o[0] = n * g + r * m + a * v, o[3] = n * u + r * C + a * I, o[6] = n * f + r * y + a * E, o[1] = s * g + l * m + c * v, o[4] = s * u + l * C + c * I, o[7] = s * f + l * y + c * E, o[2] = h * g + d * m + p * v, o[5] = h * u + d * C + p * I, o[8] = h * f + d * y + p * E, this }, lg.prototype.scale = function (A, e) { var t = this.elements; return t[0] *= A, t[3] *= A, t[6] *= A, t[1] *= e, t[4] *= e, t[7] *= e, this }, lg.prototype.rotate = function (A) { var e = Math.cos(A), t = Math.sin(A), i = this.elements, o = i[0], n = i[3], r = i[6], a = i[1], s = i[4], l = i[7]; return i[0] = e * o + t * a, i[3] = e * n + t * s, i[6] = e * r + t * l, i[1] = -t * o + e * a, i[4] = -t * n + e * s, i[7] = -t * r + e * l, this }, lg.prototype.makeRotate = function (A) { var e = Math.cos(A), t = Math.sin(A); return this.set(e, -t, 0, t, e, 0, 0, 0, 1), this }, lg.prototype.translate = function (A, e) { var t = this.elements; return t[0] += A * t[2], t[3] += A * t[5], t[6] += A * t[8], t[1] += e * t[2], t[4] += e * t[5], t[7] += e * t[8], this }, lg.prototype.makeShear = function (A, e) { return this.set(1, e, 0, A, 1, 0, 0, 0, 1), this }, lg.prototype.fromCanvasTransform = function (A, e, t, i, o, n) { return this.set(A, t, o, e, i, n, 0, 0, 1), this }, lg.prototype.toCanvasTransform = function () { var A = this.elements; return [A[0], A[3], A[1], A[4], A[6], A[7]] }, lg.prototype.getInverse = function (A, e) { A && A.isMatrix4 && console.error("THREE.Matrix3: .getInverse() no longer takes a Matrix4 argument."); var t = A.elements, i = this.elements, o = t[0], n = t[1], r = t[2], a = t[3], s = t[4], l = t[5], c = t[6], h = t[7], d = t[8], p = d * s - l * h, g = l * c - d * a, u = h * a - s * c, f = o * p + n * g + r * u; if (0 === f) { var m = "THREE.Matrix3: .getInverse() can't invert matrix, determinant is 0"; if (!0 === e) throw new Error(m); return console.warn(m), this.identity() } var C = 1 / f; return i[0] = p * C, i[1] = (r * h - d * n) * C, i[2] = (l * n - r * s) * C, i[3] = g * C, i[4] = (d * o - r * c) * C, i[5] = (r * a - l * o) * C, i[6] = u * C, i[7] = (n * c - h * o) * C, i[8] = (s * o - n * a) * C, this }, Object.assign(cg.prototype, { isPlane: !0, set: function (A, e) { return this.normal.copy(A), this.constant = e, this }, setComponents: function (A, e, t, i) { return this.normal.set(A, e, t), this.constant = i, this }, setFromNormalAndCoplanarPoint: function (A, e) { return this.normal.copy(A), this.constant = -e.dot(this.normal), this }, setFromCoplanarPoints: function () { var A = new $c, e = new $c; return function (t, i, o) { var n = A.subVectors(o, i).cross(e.subVectors(t, i)).normalize(); return this.setFromNormalAndCoplanarPoint(n, t), this } }(), clone: function () { return (new this.constructor).copy(this) }, copy: function (A) { return this.normal.copy(A.normal), this.constant = A.constant, this }, normalize: function () { var A = 1 / this.normal.length(); return this.normal.multiplyScalar(A), this.constant *= A, this }, negate: function () { return this.constant *= -1, this.normal.negate(), this }, distanceToPoint: function (A) { return this.normal.dot(A) + this.constant }, distanceToSphere: function (A) { return this.distanceToPoint(A.center) - A.radius }, projectPoint: function (A, e) { return void 0 === e && (console.warn("THREE.Plane: .projectPoint() target is now required"), e = new $c), e.copy(this.normal).multiplyScalar(-this.distanceToPoint(A)).add(A) }, intersectLine: function () { var A = new $c; return function (e, t) { void 0 === t && (console.warn("THREE.Plane: .intersectLine() target is now required"), t = new $c); var i = e.delta(A), o = this.normal.dot(i); if (0 === o) return 0 === this.distanceToPoint(e.start) ? t.copy(e.start) : void 0; var n = -(e.start.dot(this.normal) + this.constant) / o; return 0 > n || n > 1 ? void 0 : t.copy(i).multiplyScalar(n).add(e.start) } }(), intersectsLine: function (A) { var e = this.distanceToPoint(A.start), t = this.distanceToPoint(A.end); return 0 > e && t > 0 || 0 > t && e > 0 }, intersectsBox: function (A) { return A.intersectsPlane(this) }, intersectsSphere: function (A) { return A.intersectsPlane(this) }, coplanarPoint: function (A) { return void 0 === A && (console.warn("THREE.Plane: .coplanarPoint() target is now required"), A = new $c), A.copy(this.normal).multiplyScalar(-this.constant) }, applyMatrix4: function () { var A = new $c, e = new lg; return function (t, i) { var o = i || e.getNormalMatrix(t), n = this.coplanarPoint(A).applyMatrix4(t), r = this.normal.applyMatrix3(o).normalize(); return this.constant = -n.dot(r), this } }(), translate: function (A) { return this.constant -= A.dot(this.normal), this }, equals: function (A) { return A.normal.equals(this.normal) && A.constant === this.constant } }); var hg = function (A, e) { this._point = void 0, this._normal = void 0, this.viewer = e, this.svg = A; var t = document.createElementNS(Dp, "polygon"); t.setAttribute("fill", "rgba(10,234,6,0.2)"), t.setAttribute("stroke", "#0aea06"), t.setAttribute("stroke-width", 1), t.style.pointerEvents = "none", this._panel = t, this.hoverPanelSize = { width: 20, height: 20 } }; hg.prototype.setupWithPoint = function (A, e) { this._point = A, this._normal = e }, hg.prototype.remove = function () { this.svg && this._panel.parentNode && this.svg.removeChild(this._panel) }, hg.prototype.add = function () { this.svg && this._panel && this.svg.appendChild(this._panel) }, hg.prototype.isVisible = function () { return !!this._panel.parentNode }, hg.prototype.stretchOnDirection = function (A, e, t) { var i = A.clone().add(e).multiplyScalar(.5), o = e.clone().sub(A).normalize(); return [i.clone().sub(o.clone().multiplyScalar(t / 2)), i.clone().add(o.clone().multiplyScalar(t / 2))] }, hg.prototype.draw = function () { var A = this.viewer.getScene().worldToDrawing(this._normal); A.normalize(); var e = this.viewer.worldToClient(this._point), t = this.viewer.getScene().worldToDrawing(this._point), i = this.viewer.cameraControl, o = new cg; o.setFromNormalAndCoplanarPoint(A, t); var n = new sg(e.x - 10, e.y - 10), r = new sg(e.x + 10, e.y - 10), a = t, s = i.getRaycaster(n.x, n.y), l = new $c, c = new $c; if (s.ray.intersectPlane(o, l), (s = i.getRaycaster(r.x, r.y)).ray.intersectPlane(o, c), null !== l && null !== c) { var h = new $c(1, 0, 0), d = new $c(0, 0, 1), p = new $c(0, 1, 0), g = .0025 >= Math.abs(A.clone().dot(h)), u = .0025 >= Math.abs(A.clone().dot(p)); if (g && u) var f = h.clone(), m = p.clone(); else f = d.clone().cross(A).normalize(), m = A.clone().cross(f).normalize(); var C = l.distanceTo(c) / 2, y = f.clone().multiplyScalar(C), v = m.clone().multiplyScalar(C), I = a.clone().sub(y).add(v), E = a.clone().add(y).add(v), B = a.clone().sub(y).sub(v), x = a.clone().add(y).sub(v), S = []; S.push(I, E, x, B); for (var w = [], M = i.getContainerDimensions(), b = 0; S.length > b; b += 1) { var U = new $c(S[b].x, S[b].y, S[b].z); U.project(i.camera); var F = { x: 0, y: 0, z: 0 }; F.x = Math.floor(.5 * (U.x + 1) * M.width + .5), F.y = Math.floor(-.5 * (U.y - 1) * M.height + .5), F.z = U.z || 0, w.push(new $c(F.x, F.y, 0)) } var K = this.hoverPanelSize, Q = w[0].distanceTo(w[1]), R = w[0].distanceTo(w[3]) / K.height; if (1 !== Q / K.width) { var T = this.stretchOnDirection(w[0], w[1], K.width), k = this.stretchOnDirection(w[2], w[3], K.width); w = T.concat(k) } if (1 !== R) { T = this.stretchOnDirection(w[0], w[3], K.height), k = this.stretchOnDirection(w[1], w[2], K.height); w = [T[0], k[0], k[1], T[1]] } for (var D = "", L = 0; w.length > L; L += 1) D += w[L].x + ",", D += w[L].y + " "; this._panel.setAttribute("points", D) } }; var dg = function (A) { this._point = void 0, this.svg = A; var e = Vp(5); e.setAttributeNS(null, "fill", "#00ff00"), this._circle = e }; dg.prototype.setupWithPoint = function (A) { A && (this._point = A) }, dg.prototype.remove = function () { this.svg && this._circle.parentNode && this.svg.removeChild(this._circle) }, dg.prototype.add = function () { this.svg && this._circle && this.svg.appendChild(this._circle) }, dg.prototype.isVisible = function () { return !!this._circle.parentNode }, dg.prototype.draw = function (A) { if (this._point) { var e = A(this._point); this._circle.setAttributeNS(null, "cx", e[0]), this._circle.setAttributeNS(null, "cy", e[1]) } }; var pg = function (A) { Xp.call(this, A), this.volumeText = new _p, this.volumeText.textBackgroundColor = "#009bff", this.svgGroup.appendChild(this.volumeText.group); var e = this; this.volumeText.setClickCallback((function () { e.onclickCallback && e.onclickCallback(e) })), this.pickedComponentKeys = [], this._position = void 0, this._volume = void 0 }; (pg.prototype = Object.assign(Object.create(Xp.prototype), { constructor: pg })).setData = function (A, e, t) { this._position = A, this._volume = e, t && (this.unitOfModel = this.unitOfModel && this.unitOfModel !== t ? void 0 : t) }, pg.prototype.isDone = function () { return this.pickedComponentKeys[0] && this._position }, pg.prototype.draw = function (A, e) { if (this.svgGroup.parentNode && this.isDone()) { var t = this._position; e && (t = e(t)), this.volumeText.setPosition(t[0], t[1]), this.updateTexts() } }, pg.prototype.measureResult = function () { if (this._volume) return this._volume }, pg.prototype.resultToDisplayOfVolume = function (A) { var e = A, t = this.unitOfModel; return this.adjustOption && (e = this.adjustOption.adjustVolume(A), t = this.adjustOption.unit), this.unitOnUI && (t && (e = Jp(t, this.unitOnUI, e, 3)), t = this.unitOnUI), t || (t = ""), e = e.toFixed(this.precision), "mm" === t ? t = "mm³" : "m" === t ? t = "m³" : "cm" === t && (t = "cm³"), { value: Number(e), unit: t, text: e + t } }, pg.prototype.updateTexts = function () { this._volume && (this.volumeText.setText(this.resultToDisplayOfVolume(this._volume).text, void 0), this.volumeText.draw()) }, pg.prototype.setSelected = function (A) { Xp.prototype.setSelected.call(this, A) && (A ? (this.volumeText.isShowShadow = !0, this.volumeText.textBackgroundColor = "#ffffff", this.volumeText.textColor = "#009bff", this.volumeText.draw()) : (this.volumeText.isShowShadow = !1, this.volumeText.textBackgroundColor = "#009bff", this.volumeText.textColor = "#ffffff", this.volumeText.draw())) }; var gg = function () { this.pointTransformer = void 0, this.parentDom = void 0, this.viewer = void 0, this.is3DMode = !1, this.isMobile = !1 }, ug = "Distance", fg = "Angle", mg = "Adjust", Cg = "Area", yg = "MinDistance", vg = "Volume", Ig = function (A) { this.config = A, this.config.viewer.measure = this, this.svg = this._createSVG(A.parentDom.clientWidth, A.parentDom.clientHeight), A.parentDom.appendChild(this.svg), this._resize = this._resize.bind(this), this.config.viewer.addEventListener("resize", this._resize), this.setCurrentMode(ug), this.isOpen = !1, this.didEndMeasureCallback = void 0, this._items = [], this._adjustItem = void 0, this._adjustOption = void 0, this._precision = 3, this._unitSetByUser = "mm", this._pickedLine = void 0, this._pickedPoint = void 0, this._pickedPanel = void 0, this._selectedItem = void 0, this.open() }; Ig.prototype.supportUnits = function () { return [{ unit: "mm", title: "毫米" }, { unit: "cm", title: "厘米" }, { unit: "m", title: "米" }] }, Ig.prototype.open = function () { this.isOpen || (this.isOpen = !0, this._handleKeyUp = this._handleKeyUp.bind(this), document.addEventListener("keyup", this._handleKeyUp)) }, Ig.prototype.close = function () { this.svg.parentNode.removeChild(this.svg), this.isOpen = !1, this.config.is3DMode && (this.config.viewer.clearSelection(), this.config.viewer.render()), this.config.viewer.measure = void 0, document.removeEventListener("keyup", this._handleKeyUp), this.config.viewer.removeEventListener("resize", this._resize) }, Ig.prototype.setCurrentMode = function (A) { if (this.config.is3DMode || A !== vg && A !== yg) if (this._currentMode !== A && (this._currentMode = A, this._currentMeasureItem && (this._currentMeasureItem instanceof og && this.config.is3DMode && (this.config.viewer.clearSelection(), this.config.viewer.render()), this._currentMeasureItem.remove(), this._currentMeasureItem = void 0)), this._currentMode === mg) { var e = this._adjustItem ? this._adjustItem : this._currentMeasureItem; (e || e instanceof $p) && e.isDone() && (e.add(), e.draw(void 0, this.config.pointTransformer), this.didEndMeasureCallback && this.didEndMeasureCallback(e.measureResult())) } else this._adjustItem && this._adjustItem.remove() }, Ig.prototype.getCurrentMode = function () { return this._currentMode }, Ig.prototype.getCurrentUnit = function () { return this._unitSetByUser }, Ig.prototype.setUnit = function (A) { if (A && this._unitSetByUser !== A) { this._unitSetByUser = A; for (var e = 0, t = this._items.length; t > e; e += 1) { this._items[e].changeUnit(A) } this._adjustOption && (this._adjustOption.valueAfterAdjust = Jp(this._adjustOption.unit, A, this._adjustOption.valueAfterAdjust, 0), this._adjustOption.unit = A) } }, Ig.prototype.getCurrentPrecision = function () { return this._precision }, Ig.prototype.setPrecision = function (A) { if (A && this._precision !== A) { this._precision = A; for (var e = 0, t = this._items.length; t > e; e += 1) { this._items[e].changePrecision(A) } this._adjustItem && this._adjustItem.changePrecision(A) } }, Ig.prototype.clearAllMeasure = function () { for (var A = 0, e = this._items.length; e > A; A += 1) { this._items[A].remove() } this._items = [], this._selectedItem = void 0 }, Ig.prototype.removeSelectedMeasure = function () { if (this._selectedItem) { for (var A = 0, e = this._items.length; e > A; A += 1) if (this._items[A] === this._selectedItem) { this._selectedItem.remove(), this._items.splice(A, 1); break } (this._selectedItem instanceof pg || this._selectedItem instanceof og) && this.config.is3DMode && (this.config.viewer.clearSelection(), this.config.viewer.render()), this._selectedItem = void 0, this._items.length > 0 && (this._selectedItem = this._items[this._items.length - 1], this._selectedItem.setSelected(!0)) } }, Ig.prototype.setAdjustForCurrentAdjustItem = function (A, e) { if (A && e && this._currentMode === mg && (this._currentMeasureItem && this._currentMeasureItem instanceof $p && this._currentMeasureItem.isDone() && (this._adjustItem && this._adjustItem.remove(), this._adjustItem = this._currentMeasureItem, this._currentMeasureItem = void 0), this._adjustItem && this._adjustItem.isDone())) { var t = new Ag; t.unit = A, t.valueBeforeAdjust = this._adjustItem.measureResult().distance, t.valueAfterAdjust = e, this._adjustOption = t; for (var i = 0, o = this._items.length; o > i; i += 1) { this._items[i].adjustWithOption(this._adjustOption) } this._adjustItem.adjustWithOption(this._adjustOption) } }, Ig.prototype.cancelCurrentAdjust = function () { if (this._adjustItem && (this._adjustItem.remove(), this._adjustItem = void 0), this._currentMeasureItem instanceof $p && (this._currentMeasureItem.remove(), this._currentMeasureItem = void 0), this._adjustOption) { for (var A = 0, e = this._items.length; e > A; A += 1) { this._items[A].unAdjustWithOption(this._adjustOption) } this._adjustOption = void 0 } }, Ig.prototype.cancelCurrentMeasure = function () { !this._currentMeasureItem || this._currentMeasureItem instanceof $p || (this._currentMeasureItem.remove(), this._currentMeasureItem = void 0) }, Ig.prototype.processIntersect = function (A) { if (this.isOpen) { if (!A) return this._hidePickedLine(), void this._hidePickedPoint(); if (A.pickPoint) { var e = [A.pickPoint.x, A.pickPoint.y, void 0 === A.pickPoint.z ? 0 : A.pickPoint.z], t = e; if (A.pick) { if (this._currentMode === mg && this._currentMeasureItem && this._currentMeasureItem.isDone() && (this._currentMeasureItem.remove(), this._currentMeasureItem = void 0), this._currentMeasureItem || this._createNewItem(), !this._currentMeasureItem) return; if (this._currentMeasureItem instanceof og) { var i = this._currentMeasureItem.pickedComponentKeys; if (i.push(A.userId), 2 === i.length) { var o = this.config.viewer.calculateMinDistance(i[0], i[1]); if (o && o.start && o.end) this._currentMeasureItem.setData([ [o.start.x, o.start.y, o.start.z], [o.end.x, o.end.y, o.end.z] ], o.minDistance, A.measureUnit), this._currentMeasureItem.draw(void 0, this.config.pointTransformer); else this._currentMeasureItem = void 0 } this.config.viewer.addToSelection(i), this.config.viewer.render() } else if (this._currentMeasureItem instanceof pg) { var n = this._currentMeasureItem.pickedComponentKeys; if (0 === n.length) { n.push(A.userId); var r = this.config.viewer.calculateComponentVolume(n[0]); r && (this._currentMeasureItem.setData(r.position, r.volume, A.measureUnit), this._currentMeasureItem.draw(void 0, this.config.pointTransformer)), this.config.viewer.addToSelection(n), this.config.viewer.render() } } else t = void 0, this._currentMeasureItem.addPickedPoint(e, A.measureUnit, this.config.pointTransformer), this._currentMeasureItem.draw(t, this.config.pointTransformer); if (this._currentMeasureItem && this._currentMeasureItem.isDone()) { this._currentMeasureItem instanceof $p || !this._adjustOption || this._currentMeasureItem.adjustWithOption(this._adjustOption); var a = this._currentMeasureItem.measureResult(); this._currentMeasureItem instanceof $p || (this._items.push(this._currentMeasureItem), this._selectedItem && (this._selectedItem.setSelected(!1), this._selectedItem = void 0), this._selectedItem = this._currentMeasureItem, this._selectedItem.setSelected(!0), this._currentMeasureItem = void 0), this.didEndMeasureCallback && this.didEndMeasureCallback(a) } } else this._currentMeasureItem && this._currentMeasureItem.draw(t, this.config.pointTransformer) } this._currentMode !== yg && this._currentMode !== vg && (A.pickPoint && A.isAbsorbPoint ? this._showPickedPoint(A.pickPoint) : this._hidePickedPoint(), A.pickPlane ? this._showPickedPanel(A.pickPoint, A.normal) : this._hidePickedPanel(), A.pickLine ? this._showPickedLine(A.pickLine[0], A.pickLine[1], A.measureUnit) : this._hidePickedLine()) } }, Ig.prototype.update = function () { if (this.isOpen) { for (var A = 0, e = this._items.length; e > A; A += 1) { this._items[A].draw(void 0, this.config.pointTransformer) } this._currentMeasureItem && this._currentMeasureItem.draw(void 0, this.config.pointTransformer), this._adjustItem && this._adjustItem.draw(void 0, this.config.pointTransformer), this._pickedLine && this._pickedLine.isVisible() && this._pickedLine.draw(void 0, this.config.pointTransformer), this._pickedPanel && this._pickedPanel.isVisible() && this._pickedPanel.draw(this.config.pointTransformer) } }, Ig.prototype.changeSelect = function () { for (var A = 0, e = this._items.length; e > A; A += 1) { var t = this._items[A]; t.setSelected(this._selectedItem === t) } }, Ig.prototype._resize = function () { this.svg.style.width = this.config.parentDom.clientWidth, this.svg.style.height = this.config.parentDom.clientHeight }, Ig.prototype._createNewItem = function () { switch (this._currentMode) { case ug: this._currentMeasureItem = new ig(this.svg, this.config.isMobile, this._items.length + 1); break; case fg: this._currentMeasureItem = new eg(this.svg); break; case mg: this._currentMeasureItem = new $p(this.svg); break; case Cg: this._currentMeasureItem = new tg(this.svg); break; case yg: this._currentMeasureItem = new og(this.svg); break; case vg: this._currentMeasureItem = new pg(this.svg) } if (this._currentMeasureItem) { this._currentMeasureItem.is3DMode = this.config.is3DMode, this._currentMeasureItem instanceof $p || (this._adjustOption && this._currentMeasureItem.adjustWithOption(this._adjustOption), this._unitSetByUser && this._currentMeasureItem.changeUnit(this._unitSetByUser)), this._currentMeasureItem.changePrecision(this._precision); var A = this; this._currentMeasureItem.setClickCallback((function (e) { e.isDone() && (A._selectedItem = e, A.changeSelect()) })) } }, Ig.prototype._showPickedLine = function (A, e, t) { var i = [A.x, A.y, void 0 === A.z ? 0 : A.z], o = [e.x, e.y, void 0 === e.z ? 0 : e.z]; this._pickedLine || (this._pickedLine = new ng(this.svg), this._pickedLine.unitOfModel = t), this._adjustOption && this._pickedLine.adjustWithOption(this._adjustOption), this._pickedLine.changeUnit(this._unitSetByUser ? this._unitSetByUser : t), this._pickedLine.changePrecision(this._precision), this._pickedLine.add(), this._pickedLine.setData(i, o), this._pickedLine.draw(void 0, this.config.pointTransformer) }, Ig.prototype._hidePickedLine = function () { this._pickedLine && this._pickedLine.remove() }, Ig.prototype._showPickedPoint = function (A) { this._pickedPoint || (this._pickedPoint = new dg(this.svg)), this._pickedPoint.add(), this._pickedPoint.setupWithPoint(A), this._pickedPoint.draw(this.config.pointTransformer) }, Ig.prototype._hidePickedPoint = function () { this._pickedPoint && this._pickedPoint.remove() }, Ig.prototype._showPickedPanel = function (A, e) { this._pickedPanel || (this._pickedPanel = new hg(this.svg, this.config.viewer)), this._pickedPanel.add(), this._pickedPanel.setupWithPoint(A, e), this._pickedPanel.draw(this.config.pointTransformer) }, Ig.prototype._hidePickedPanel = function () { this._pickedPanel && this._pickedPanel.remove() }, Ig.prototype._createSVG = function (A, e) { var t = Lp(); return t.style.width = A + "px", t.style.height = e + "px", t.style.position = "absolute", t.style.left = "0", t.style.top = "0", t }, Ig.prototype._handleKeyUp = function (A) { var e = A.keyCode; 27 === e ? this.cancelCurrentMeasure() : 46 === e && this.removeSelectedMeasure() }; var Eg = function (A) { yp.call(this, Pc.PICK_BY_MEASURE), this.controlManager = A.controlManager, this.pickHelper = new kp(A.cameraControl), this.mouseDown = new s, this.lastEvent = null, this.pick = !1, this.pickPoint = new y; var e = A.getRenderer().domElement.parentElement, t = new gg; t.parentDom = e, t.pointTransformer = A.getScreenCoordFromSceneCoord.bind(A), t.viewer = A, t.is3DMode = !0, this.measure = new Ig(t); var i = this; A.cameraControl.addEventListener(Rc.ON_CAMERA_CHANGE, (function () { i.measure.update() })), A.clearSelection() }; (Eg.prototype = Object.create(yp.prototype)).constructor = Eg, Eg.prototype.destroy = function () { yp.prototype.destroy.call(this), this.editorManager = null, this.mouseDown = null, this.lastEvent = null, this.pickPoint = null, this.pickHelper.destroy(), this.pickHelper = null }, Eg.prototype.processMouseDown = function (A) { return !!mh.isMobileDevice() || (A.button === t.LEFT ? (this.mouseDown.x = A.clientX, this.mouseDown.y = A.clientY, !1) : yp.prototype.processMouseDown.call(this, A)) }, Eg.prototype.processMouseMove = function (A) { return !1 }, Eg.prototype.processMouseUp = function (A) { if (mh.isMobileDevice()) return !0; if (A.button === t.LEFT) { if (2 >= new s(A.clientX, A.clientY).distanceTo(this.mouseDown)) { var e = this.pickPoint.clone(), i = void 0; return i = A.shiftKey ? this.pickHelper.handleShiftMeasure(A, !0, e) : this.pickHelper.handleMouseMeasure(A, !0, e), this.measure.processIntersect(i), e.equals(this.pickPoint) || (this.pick = !this.pick, this.pickPoint.copy(e)), this.controlManager.isUpdateRenderList = !0, !0 } return !0 } return yp.prototype.processMouseUp.call(this, A) }, Eg.prototype.processKeyDown = function (A) { return 16 === A.keyCode || yp.prototype.processKeyDown.call(this, A) }, Eg.prototype.processHover = function (A) { if (mh.isMobileDevice()) return !0; var e = void 0; return e = A.shiftKey ? this.pickHelper.handleShiftMeasure(A, !1, this.pickPoint) : this.pickHelper.handleMouseMeasure(A, !1, this.pickPoint), this.measure.processIntersect(e), !0 }, Eg.prototype.processTouchstart = function (A) { return this.mouseDown.x = A.touches[0].clientX, this.mouseDown.y = A.touches[0].clientY, A.clientX = A.touches[0].clientX, A.clientY = A.touches[0].clientY, this.lastEvent = A, yp.prototype.processTouchstart.call(this, A) }, Eg.prototype.processTouchmove = function (A) { return this.lastEvent = null, yp.prototype.processTouchmove.call(this, A) }, Eg.prototype.processTouchend = function (A) { if (null !== this.lastEvent) { var e = this.pickHelper.handleMouseMeasure(this.lastEvent, !0, this.pickPoint); this.measure.processIntersect(e), this.controlManager.isUpdateRenderList = !0 } return yp.prototype.processTouchend.call(this, A) }, Eg.prototype.touchPointMove = function (A) { this.measure.processIntersect(this.pickHelper.handleMouseMeasure(A, !1, this.pickPoint)) }, Eg.prototype.touchPointEnd = function (A) { var e = this.pickPoint.clone(), t = this.pickHelper.handleMouseMeasure(A, !0, e); return this.measure.processIntersect(t), e.equals(this.pickPoint) || (this.pick = !this.pick, this.pickPoint.copy(e)), this.controlManager.isUpdateRenderList = !0, !0 }, Eg.prototype.onExit = function (A) { this.measure.close(); var e = this.pickHelper.scene; e.hasGroup(gp.MEASUREPICKPLANE) && e.removeGroupByName(gp.MEASUREPICKPLANE) }; var Bg, xg, Sg, wg = { pickByRect: function (A, e, t, i, o, n) { var r = [], a = i.octantToObjectMap, s = (A.getMatrixGlobal(), i.sceneState), l = new aA; function c(A, t, i) { A && A.frustumIntersect(e, t, i) } var h = i.filter, d = h._hasVisibleFilter(), p = h._hasPickableFilter(); if (t !== Kc.Clear) { var g, u, f = null, m = []; for (var C in a) if (a.hasOwnProperty(C)) { var y = i.getModel(C); (f = a[C]).mesh; var v = y && y.kdTreeNode, I = []; if (Array.isArray(v)) for (var E = 0, B = v.length; B > E; E += 1) { var x = v[E], S = x.modelKey, w = (new M).copy(y.getModelMatrix()); S && w.multiply(y.subModel[S]), c(x, I, w) } else c(v, I, y.getModelMatrix()); var b = Object.keys(y.manager.explosionList); y && y.manager && b.length > 0 && (I = I.concat(b)); for (var U = 0, F = (m = uh.unique(I)).length; F > U; U += 1) { var K = f.info[m[U]]; if (K) for (var Q = 0, R = K.length; R > Q; Q += 1) { var T = K[Q]; (u = void 0, u = i.isHiddenSourceObjectUserId((g = T).userId), d && !h._isVisible(g) || p && !h._isPickable(g) || u) || (l.copy(T.boundingBox), l.applyMatrix4(y.getModelMatrix()), this._intersectBox(e, l, n) && !this._clipBox(o, l) && r.push(T.userId)) } } } return (r = r.concat(this.pickNonModelObjectsByRect(o, i, e, n))).length > 0 && (Kc.Remove === t ? (s.removeSelection(r), i.dispatchEvent({ type: Rc.ON_RECTPICK_REMOVE, list: r })) : Kc.Add === t && (s.addSelection(r), i.dispatchEvent({ type: Rc.ON_RECTPICK_ADD, list: r }))), r } s.clearSelection() }, getObjectsInBox: function (A, e, t, i, o) { var n = {}, r = t.octantToObjectMap, a = (A.getMatrixGlobal(), new aA); function s(A) { for (var e = new y, t = 0; 8 > t; t += 1) if (e.x = 4 > t ? A.min.x : A.max.x, e.y = 2 > t / 2 ? A.min.y : A.max.y, e.z = t % 2 == 0 ? A.min.z : A.max.z, !i.clipPoint(e)) return !1; return !0 } function l(A) { return o ? !(e.min.x > A.min.x || A.max.x > e.max.x || e.min.y > A.min.y || A.max.y > e.max.y || e.min.z > A.min.z || A.max.z > e.max.z) : !(e.min.x > A.max.x || A.min.x > e.max.x || e.min.y > A.max.y || A.min.y > e.max.y || e.min.z > A.max.z || A.min.z > e.max.z) } function c(A) { return Boolean(!(e.max.x > A.max.x || A.min.x > e.min.x || e.max.y > A.max.y || A.min.y > e.min.y || e.max.z > A.max.z || A.min.z > e.min.z)) } var h = t.filter, d = h._hasVisibleFilter(), p = h._hasPickableFilter(); var g, u, f = null; for (var m in r) if (r.hasOwnProperty(m)) { var C = t.getModel(m); for (var v in (f = r[m]).info) if (f.info.hasOwnProperty(v)) { var I = f.info[v]; if (!I) continue; for (var E = 0, B = I.length; B > E; E += 1) { var x = I[E]; (u = void 0, u = t.isHiddenSourceObjectUserId((g = x).userId), d && !h._isVisible(g) || p && !h._isPickable(g) || u) || (a.copy(x.boundingBox), a.applyMatrix4(C.getModelMatrix()), !l(a) || c(a) || s(a) || (n[x.userId] = !0)) } } } var S = []; for (var w in n) S.push(w); return S }, pickNonModelObjectsByRect: function (A, e, t, i) { var o = [], n = e.getNodeInfosInPlugins(), r = new aA; for (var a in n) if (n.hasOwnProperty(a)) { var s = n[a]; for (var a in s) if (s.hasOwnProperty(a)) { var l = s[a][0].mesh; if (l) { l instanceof Array || (l = [l]), r.empty(); for (var c = 0, h = l.length; h > c; c += 1) { var d = l[c]; d instanceof H && r.expandByObject(d) } this._intersectBox(t, r, i) && !this._clipBox(A, r) && o.push(a) } } } return o }, _intersectBox: (xg = new y, Sg = new y, function (A, e, t) { for (var i = 0, o = A.planes, n = 0; 6 > n; n += 1) { var r = o[n]; xg.x = r.normal.x > 0 ? e.min.x : e.max.x, Sg.x = r.normal.x > 0 ? e.max.x : e.min.x, xg.y = r.normal.y > 0 ? e.min.y : e.max.y, Sg.y = r.normal.y > 0 ? e.max.y : e.min.y, xg.z = r.normal.z > 0 ? e.min.z : e.max.z, Sg.z = r.normal.z > 0 ? e.max.z : e.min.z; var a = r.distanceToPoint(xg), s = r.distanceToPoint(Sg); if (0 > a && 0 > s) return !1; 0 > a * s || (i += 1) } return t ? i >= 2 : 6 === i } ), _clipBox: (Bg = new y, function (A, e) { for (var t = 0; 8 > t; t += 1) if (Bg.x = 4 > t ? e.min.x : e.max.x, Bg.y = 2 > t / 2 ? e.min.y : e.max.y, Bg.z = t % 2 == 0 ? e.min.z : e.max.z, !A.clipPoint(Bg)) return !1; return !0 } ) }, Mg = function (A, e, t) { yp.call(this, A), this.cameraControl = e, this.frustum = new Ze, this.startPt = new s, this.endPt = new s, this.eventDispatcher = t }; (Mg.prototype = Object.create(yp.prototype)).constructor = Mg, Mg.prototype.destroy = function (A) { yp.prototype.destroy.call(this), this.cameraControl = null, this.frustum = null, this.startPt = null, this.endPt = null, this.eventDispatcher = null }, Mg.prototype.onUpdateUI = function (A) { this.eventDispatcher.dispatchEvent({ type: Rc.ON_CONTROL_UPDATEUI, data: A, editor: this.name }) }, Mg.prototype.updateFrustum = function (A, e) { var t = this.startPt.x, i = this.endPt.x, o = this.startPt.y, n = this.endPt.y; if (t > i) { var r = t; t = i, i = r } if (o > n) { var a = o; o = n, n = a } if (i - t == 0 || n - o == 0) return !1; var s = this.cameraControl, l = s.getContainerDimensions(); return A && s.computeFrustum(t, i, o, n, this.frustum, l), e && this.onUpdateUI({ visible: !0, dir: this.endPt.x > this.startPt.x, left: t - l.left, top: o - l.top, width: i - t, height: n - o }), !0 }; var bg = function (A) { Mg.call(this, Pc.PICK_BY_RECT, A.cameraControl, A.modelManager), this.viewer = A, this.scene = A.getScene(), this.pickHelper = new kp(this.cameraControl), this.activatePick = !1, this.pressKey = "", this.pickPoint = new y, this.snapIsEnabled = !1 }; (bg.prototype = Object.create(Mg.prototype)).constructor = bg, bg.prototype.destroy = function () { Mg.prototype.destroy.call(this), this.pickHelper.destroy(), this.pickHelper = null, this.viewer = null, this.scene = null, this.pickPoint = null }, bg.prototype.setPressKey = function (A) { this.pressKey = A }, bg.prototype.processMouseDown = function (A) { return A.preventDefault(), this.activatePick = A.ctrlKey || A.altKey, this.activatePick && A.button === t.LEFT ? (this.startPt.set(A.clientX, A.clientY), !0) : Mg.prototype.processMouseDown(this, A) }, bg.prototype.processMouseMove = function (A) { return this.activatePick && A.button === t.LEFT ? (this.endPt.set(A.clientX, A.clientY), this.updateFrustum(!1, !0), !0) : Mg.prototype.processMouseMove(this, A) }, bg.prototype.processMouseUp = function (A) { if (this.onUpdateUI({ visible: !1 }), this.activatePick && A.button === t.LEFT) { if (this.activatePick = !1, 2 > Math.abs(this.startPt.x - A.clientX) && 2 > Math.abs(this.startPt.y - A.clientY)) return this.pickHelper.click(A, null), !0; if (this.endPt.set(A.clientX, A.clientY), !this.updateFrustum(!0, !1)) return this.pickHelper.click(A), !0; var e = Kc.Clear, i = this.pressKey || A.ctrlKey && "ctrl" || A.altKey && "alt" || ""; return "ctrl" === i ? e = Kc.Add : "alt" === i && (e = Kc.Remove), wg.pickByRect(this.scene, this.frustum, e, this.cameraControl.viewer.modelManager, this.viewer, this.startPt.x > this.endPt.x), this.pickHelper.lastPickedUserId = "", this.cameraControl.updateView(!0), !0 } return Mg.prototype.processMouseUp(this, A) }, bg.prototype.processTouchstart = function (A) { return A.preventDefault(), this.pressKey ? (this.startPt.set(A.changedTouches[0].pageX, A.changedTouches[0].pageY), !0) : Mg.prototype.processTouchstart(this, A) }, bg.prototype.processTouchmove = function (A) { return this.pressKey ? (this.endPt.set(A.changedTouches[0].pageX, A.changedTouches[0].pageY), this.updateFrustum(!1, !0), !0) : Mg.prototype.processMouseMove(this, A) }, bg.prototype.processTouchend = function (A) { this.onUpdateUI({ visible: !1 }); var e = A.changedTouches[0].pageX, t = A.changedTouches[0].pageY; if (this.pressKey) { if (2 > Math.abs(this.startPt.x - e) && 2 > Math.abs(this.startPt.y - t)) return this.pickHelper.click(A, null), !0; if (this.endPt.set(e, t), !this.updateFrustum(!0, !1)) return this.pickHelper.click(A), !0; var i = Kc.Clear, o = this.pressKey; return "ctrl" === o ? i = Kc.Add : "alt" === o && (i = Kc.Remove), wg.pickByRect(this.scene, this.frustum, i, this.cameraControl.viewer.modelManager, this.viewer, this.startPt.x > this.endPt.x), this.pickHelper.lastPickedUserId = "", this.cameraControl.updateView(!0), !0 } return Mg.prototype.processTouchend(this, A) }, bg.prototype.processHover = function (A) { if (this.snapIsEnabled) return vc.IsMobile || this.pickHelper.handleMouseMeasure(A, !1, this.pickPoint, Rc.ON_HOVER_SNAP), !0 }, bg.prototype.enableSnap = function (A) { this.snapIsEnabled = A }; var Ug = function (A) { Mg.call(this, Pc.ZOOM_BY_RECT, A.cameraControl, A.modelManager), this.scene = A.getScene(), this.activateZoom = !1 }; (Ug.prototype = Object.create(Mg.prototype)).constructor = Ug, Ug.prototype.destroy = function () { Mg.prototype.destroy.call(this), this.scene = null }, Ug.prototype.processMouseDown = function (A) { return A.button === t.LEFT ? (this.startPt.set(A.clientX, A.clientY), this.activateZoom = !0, !0) : Mg.prototype.processMouseDown.call(this, A) }, Ug.prototype.processMouseMove = function (A) { return this.activateZoom ? (this.endPt.set(A.clientX, A.clientY), this.updateFrustum(!1, !0), !0) : Mg.prototype.processMouseMove.call(this, A) }, Ug.prototype.processMouseUp = function (A) { return this.activateZoom ? (this.activateZoom = !1, this.onUpdateUI({ visible: !1 }), this.endPt.set(A.clientX, A.clientY), this.updateFrustum(!0, !1) && this.zoomToRectangle(), !0) : Mg.prototype.processMouseUp.call(this, A) }, Ug.prototype.zoomToRectangle = function () { var A = this.cameraControl.camera, e = this.cameraControl.camera.target, t = this.cameraControl.getContainerDimensions(), i = this.startPt.x, o = this.startPt.y, n = this.endPt.x, r = this.endPt.y, a = Math.abs(n - i), l = Math.abs(o - r); if (0 !== a && 0 !== l) { var c = new s((i + n) / 2, (o + r) / 2), h = A.position.clone(), d = e.clone().sub(h), p = d.length(), g = 0, u = this.cameraControl.getIntersectContext(c), f = this.cameraControl.intersector.hitTest(u); if (f) { var m = a / l > t.width / t.height ? a / t.width : l / t.height, C = f.distanceTo(h) * m; d.normalize(), g = d.clone().negate().multiplyScalar(C) } else { var v = {}; v.left = Math.min(i, n), v.top = Math.min(o, r), v.right = Math.max(i, n), v.bottom = Math.max(o, r); var I = this.scene.getNearDepthByRect(this.frustum, A); if (I === 1 / 0) return; var E = new y((i + n) / 2, (o + r) / 2, I), B = new y(v.left, v.top, I), x = this.clientToWorld(E), S = this.clientToWorld(B), w = x.clone().sub(S).length(); f = x.clone(), d.normalize(), g = d.clone().negate().multiplyScalar(w) } h = f.clone().add(g), A.position.copy(h), e.copy(h).sub(g.clone().normalize().multiplyScalar(p)), this.cameraControl.updateView(!0) } }, Ug.prototype.worldToClient = function (A) { var e = this.cameraControl.camera, t = new y(A.x, A.y, A.z); return t.project(e), t }, Ug.prototype.clientToWorld = function (A) { var e = this.cameraControl.getContainerDimensions(), t = this.cameraControl.camera, i = new y; return i.x = A.x / e.width * 2 - 1, i.y = -A.y / e.height * 2 + 1, i.z = A.z, i.unproject(t), i }; var Fg = function (A, e) { this.name = A, this.cameraControl = e, this.mouseButtons = { ORBIT: t.LEFT, PAN2: t.MIDDLE, PAN: t.RIGHT }, this.StateType = { NONE: -1, ROTATE: 0, DOLLY: 1, PAN: 2 }, this.state = this.StateType.NONE, this.zoomSpeed = Math.pow(.95, .2), this.defaultMovementSpeed = .005 * vc.SceneSize, this.movementSpeed = this.defaultMovementSpeed, this.minMovementSpeed = .001, this.defaultKeyPanSpeed = 2, this.keyPanSpeed = this.defaultKeyPanSpeed, this.minKeyPanSpeed = .01, this.wheelZoomFactor = 45e-5, this.pointerLock = !1 }; Fg.prototype.getName = function () { return this.name }, Fg.prototype.destroy = function () { this.scene = null, this.domElement = null, this.cameraControl = null, this.mouseButtons = null, this.StateType = null }, Fg.prototype.onExit = function () {}, Fg.prototype.onEnter = function () {}, Fg.prototype.processMouseDown = function (A) {}, Fg.processMouseMove = function (A) {}, Fg.prototype.processMouseUp = function (A) {}, Fg.prototype.processMouseWheel = function (A) {}, Fg.prototype.processMouseDoubleClick = function (A) {}, Fg.prototype.processKeyDown = function (A) {}, Fg.prototype.processKeyUp = function (A) {}, Fg.prototype.processTouchstart = function (A) {}, Fg.prototype.processTouchmove = function (A) {}, Fg.prototype.processTouchend = function (A) {}, Fg.prototype.processHover = function (A) {}, Fg.prototype.processMovement = function (A) {}, Fg.prototype.processPointerLockEnter = function (A) {}, Fg.prototype.processPointerLockExit = function (A) {}, Fg.prototype.moveTo = function (A, e, t) {}, Fg.prototype.rotateTo = function (A) {}, Fg.prototype.dispatchEvent = function (A) { this.cameraControl.viewer.getControlManager().dispatchEvent(A) }, Fg.prototype.getDomElement = function () { return this.domElement }, Fg.prototype.getRendererDomElement = function () { return this.rendererDomElement }, Fg.prototype.updateButtons = function (A) { void 0 !== A.ORBIT && (this.mouseButtons.ORBIT = A.ORBIT), void 0 !== A.PAN && (this.mouseButtons.PAN = A.PAN), void 0 !== A.PAN2 && (this.mouseButtons.PAN2 = A.PAN2), void 0 !== A.ZOOM && (this.mouseButtons.ZOOM = A.ZOOM) }; var Kg = function (A) { Fg.call(this, Gc.FLY, A), this.lookSpeed = .001, this.constrainPitch = !0, this.pitchMin = a.degToRad(5) - .5 * Math.PI, this.pitchMax = .5 * Math.PI - this.pitchMin, this.pitchDeltaTotal = 0, this.moveState = qc.NONE, this.rotateStart = new s, this.rotateEnd = new s, this.rotateDelta = new s, this._panStart = new s, this._panEnd = new s, this._panDelta = new s, this._pan = new y, this._worldDimension = new s, this.lastMousePoint = new s, this.isLockHeight = !1, this.lockedHeight = 0, this.pickHelper = new kp(A), this.intersectOfMouseDown = null }; (Kg.prototype = Object.create(Fg.prototype)).constructor = Kg, Kg.prototype.destroy = function () { Fg.prototype.destroy.call(this), this.cameraControl = null, this.scene = null, this.rotateStart = null, this.rotateEnd = null, this.rotateDelta = null, this._panStart = null, this._panEnd = null, this._panDelta = null, this._pan = null, this._worldDimension = null, this.lastMousePoint = null, this.intersectOfMouseDown = null, this.pickHelper.destroy(), this.pickHelper = null }, Kg.prototype.processMouseDown = function (A) { A.preventDefault(), A.stopPropagation(), this.lastMousePoint.set(A.clientX, A.clientY); var e = this.cameraControl; if (this.intersectOfMouseDown = null, A.button === this.mouseButtons.ORBIT) { if (jh.NoRotate) return; this.rotateStart.set(A.clientX, A.clientY), this.state = this.StateType.ROTATE, this.dispatchEvent({ type: Rc.ON_CONTROL_BEGIN, name: "look", control: this.name }) } else if (A.button === this.mouseButtons.PAN || A.button === this.mouseButtons.PAN2) { if (jh.NoPan) return; this._panStart.set(A.clientX, A.clientY), this._worldDimension = e.getWorldDimension(A.clientX, A.clientY), this.intersectOfMouseDown = e.getLastIntersect(), this.state = this.StateType.PAN, this.isLockHeight && (this.lockedHeight = A.clientY) } }, Kg.prototype.doPan = function (A, e) { var t = this.cameraControl; this._panEnd.set(A, this.isLockHeight ? this.lockedHeight : e), this._panDelta.subVectors(this._panEnd, this._panStart), 0 === this._panDelta.x && 0 === this._panDelta.y || (t.panOnWorld(this._panStart, this._panEnd, this._pan, this._worldDimension), t.adjustCameraForPan(this._pan), this._panStart.copy(this._panEnd), t.update(!0)) }, Kg.prototype.processMouseMove = function (A) { var e = this.cameraControl; (A.preventDefault(), this.state === this.StateType.ROTATE) ? (this.rotateEnd.set(A.clientX, A.clientY), this.rotateDelta.subVectors(this.rotateEnd, this.rotateStart), this.rotateStart.copy(this.rotateEnd), (0 !== this.rotateDelta.x || 0 !== this.rotateDelta.y) && e.rotateForFly(this.rotateDelta.x * this.lookSpeed, this.rotateDelta.y * this.lookSpeed, this.pitchMin, this.pitchMax)) : this.state === this.StateType.PAN && this.doPan(A.clientX, A.clientY) }, Kg.prototype.processMouseUp = function (A) { if (A.preventDefault(), A.stopPropagation(), A.button !== t.LEFT || this.lastMousePoint.x !== A.clientX || this.lastMousePoint.y !== A.clientY) { this.intersectOfMouseDown = null; var e = this.cameraControl; switch (this.state) { case this.StateType.ROTATE: this.rotateDelta.set(0, 0); e.rotateForFly(0, 0, this.pitchMin, this.pitchMax), this.dispatchEvent({ type: Rc.ON_CONTROL_END, name: "look", control: this.name }); break; case this.StateType.PAN: this.doPan(A.clientX, A.clientY) } e.endOperation(), this.state = this.StateType.NONE } else this.pickHelper.click(A, this.intersectOfMouseDown) }, Kg.prototype.processHover = function (A) { this.pickHelper.handleMouseHover(A) }, Kg.prototype.processMouseWheel = function (A) { A.preventDefault(), A.stopPropagation(); var e = this.cameraControl; if (!jh.NoZoom) { var t = A.wheelDelta || A.detail; t = Math.abs(t) > 10 ? t : 40 * -t, t *= 5e-4, jh.ReverseWheelDirection && (t *= -1), this.cameraControl.delayHandle(); var i = e.getContainerDimensions(); e.zoom(t, i.left + .5 * i.width, i.top + .5 * i.height) } }, Kg.prototype.processKeyDown = function (A) { if (!jh.NoKey && !A.altKey) { var e = qc, t = e.NONE; switch (A.keyCode) { case Ph: this.movementSpeed = this.defaultMovementSpeed; break; case Vh: this.movementSpeed *= 1.1; break; case Gh: this.movementSpeed *= .9, this.minMovementSpeed > this.movementSpeed && (this.movementSpeed = this.minMovementSpeed); break; case Fh: case Nh: t = e.FORWARD; break; case Qh: case Lh: t = e.BACK; break; case Uh: case Rh: t = e.LEFT; break; case Kh: case Th: t = e.RIGHT; break; case Dh: t = e.UP; break; case kh: t = e.DOWN } t !== e.NONE && (this.moveState |= t, this.dispatchEvent({ type: Rc.ON_CONTROL_KEYDOWN, event: A, state: t, direction: e, control: this.name }), this.cameraControl.delayHandle(), this.cameraControl.updateFlyMove(this.moveState, this.movementSpeed * jh.MovementSpeedRate)) } }, Kg.prototype.processKeyUp = function (A) { if (!jh.NoKey) { var e = qc, t = e.NONE; switch (A.keyCode) { case Fh: case Nh: t = e.FORWARD; break; case Qh: case Lh: t = e.BACK; break; case Uh: case Rh: t = e.LEFT; break; case Kh: case Th: t = e.RIGHT; break; case Dh: t = e.UP; break; case kh: t = e.DOWN } t !== e.NONE && (this.dispatchEvent({ type: Rc.ON_CONTROL_KEYUP, event: A, state: t, direction: e, control: this.name }), this.moveState &= ~t) } }, Kg.prototype.moveTo = function (A) { this.cameraControl.updateFlyMove(A, this.movementSpeed * jh.MovementSpeedRate) }; var Qg = function (A, e) { Fg.call(this, A, e), this.oldMouseX = -1, this.oldMouseY = -1, this.rotatePivot = null, this._rotateStart = new s, this._rotateEnd = new s, this._rotateDelta = new s, this._lastTrackingPoint = null, this.rotateSpeed = 1, this._dollyStart = new s, this._dollyEnd = new s, this._dollyDelta = new s, this._dollyCenter = new s, this.zoomSpeed = Math.pow(.95, .2), this.modelManager = e.viewer.modelManager, this._panStart = new s, this._panEnd = new s, this._panDelta = new s, this._pan = new y, this._worldDimension = new s, this.pickHelper = new kp(e), this.intersectOfMouseDown = null, this.timeId = null, this.longTapFlag = !1, this.selectPad = (mh.isMobileDevice(), null), this.startPt = new s; var t = this; this.longTap = function () { t.longTapFlag = !0, Bh.log("long tap"), t.selectPad && t.selectPad.showOverlay(t.startPt) }, this._reqid = 0, this._animateBinded = this._animate.bind(this), this._clock = new as, this._moving = !1 }; (Qg.prototype = Object.create(Fg.prototype)).constructor = Qg, Qg.prototype.destroy = function () { Fg.prototype.destroy.call(this), this.modelManager = null, this.intersectOfMouseDown = null, this.rotatePivot = null, this._rotateStart = null, this._rotateEnd = null, this._rotateDelta = null, this._lastTrackingPoint = null, this._dollyStart = null, this._dollyEnd = null, this._dollyDelta = null, this._dollyCenter = null, this._panStart = null, this._panEnd = null, this._panDelta = null, this._pan = null, this._worldDimension = null, this.startPt = null, this._animateBinded = null, this._clock = null, this.timeId && (clearTimeout(this.timeId), this.timeId = null), this.pickHelper.destroy(), this.pickHelper = null, this.selectPad && (this.selectPad.destroy(), this.selectPad = null) }, Qg.prototype.beginPan = function (A, e) { this._panStart.set(A, e), this._worldDimension = this.getWorldDimension(A, e) }, Qg.prototype.processMouseDown = function (A) { this.oldMouseX = A.clientX, this.oldMouseY = A.clientY; var e = this.cameraControl; this.intersectOfMouseDown = null, A.preventDefault(); var t = ""; if (A.button === this.mouseButtons.ORBIT) { if (jh.NoRotate) return; this.rotatePivot = e.calculatePivot(jh.RotatePivotMode, { x: A.clientX, y: A.clientY }), this.state = this.StateType.ROTATE, this._rotateStart.set(A.clientX, A.clientY), this._lastTrackingPoint = null, t = Gc.ORBIT } else if (A.button === this.mouseButtons.ZOOM) { if (jh.NoZoom) return; this.state = this.StateType.DOLLY, this._dollyStart.set(A.clientX, A.clientY), t = Gc.ZOOM } else if (A.button === this.mouseButtons.PAN || A.button === this.mouseButtons.PAN2) { if (jh.NoPan) return; this._panStart.set(A.clientX, A.clientY), this._worldDimension = e.getWorldDimension(A.clientX, A.clientY), this.state = this.StateType.PAN, t = Gc.PAN } this.dispatchEvent({ type: Rc.ON_CONTROL_BEGIN, name: t, control: this.name }) }, Qg.prototype.processMouseMove = function (A) { var e = this.cameraControl; switch (A.preventDefault(), this.state) { case this.StateType.ROTATE: if (this._rotateEnd.set(A.clientX, A.clientY), this._rotateDelta.subVectors(this._rotateEnd, this._rotateStart), 0 === this._rotateDelta.x && 0 === this._rotateDelta.y) return; this._rotateStart.copy(this._rotateEnd), e.processRotate(this._rotateDelta, this.rotatePivot); break; case this.StateType.DOLLY: if (this._dollyEnd.set(A.clientX, A.clientY), this._dollyDelta.subVectors(this._dollyEnd, this._dollyStart), 0 === this._dollyDelta.x && 0 === this._dollyDelta.y) return; this.cameraControl.adjustCameraForDolly(this._dollyDelta.y > 0 ? this.zoomSpeed : 1 / this.zoomSpeed, null), this._dollyStart.copy(this._dollyEnd); break; case this.StateType.PAN: if (this._panEnd.set(A.clientX, A.clientY), this._panDelta.subVectors(this._panEnd, this._panStart), 0 === this._panDelta.x && 0 === this._panDelta.y) return; this.cameraControl.panOnWorld(this._panStart, this._panEnd, this._pan, this._worldDimension), this.cameraControl.adjustCameraForPan(this._pan), this._panStart.copy(this._panEnd) } this.state !== this.StateType.NONE && this.cameraControl.update(!0) }, Qg.prototype.processMouseUp = function (A) { if (this.state === this.StateType.NONE) return !1; this.intersectOfMouseDown = null; var e = this.cameraControl; this.oldMouseX === A.clientX && this.oldMouseY === A.clientY || e.update(!0), this.state = this.StateType.NONE, this.rotatePivot = null, e.endOperation(); var t = ""; return A.button === this.mouseButtons.ORBIT ? t = Gc.ORBIT : A.button === this.mouseButtons.ZOOM ? t = Gc.ZOOM : A.button !== this.mouseButtons.PAN && A.button !== this.mouseButtons.PAN2 || (t = Gc.PAN), this.dispatchEvent({ type: Rc.ON_CONTROL_END, name: t, control: this.name }), !0 }, Qg.prototype.processMouseWheel = function (A) { var e = this.cameraControl; if (!jh.NoZoom) { A.preventDefault(), A.stopPropagation(); var t = 0; A.wheelDelta ? t = A.wheelDelta : A.deltaY && (t = 40 * -A.deltaY), Math.abs(t) > 720 && (t = t > 0 ? 720 : -720), t *= this.wheelZoomFactor, jh.ReverseWheelDirection && (t *= -1), e.zoom(t, A.clientX, A.clientY), e.delayHandle(), this.dispatchEvent({ type: Rc.ON_CONTROL_ZOOM }) } }, Qg.prototype.processKeyDown = function (A) { if (!jh.NoKey && !jh.NoPan) { var e = this.cameraControl, t = null; vc.MergeComponent ? (this.animationStarted || (this.animationStarted = !0, this._start()), t = !1) : (t = !0, e.delayHandle()), this._moving = !0; var i = !1, o = this.movementSpeed * jh.MovementSpeedRate, n = this.keyPanSpeed * jh.MovementSpeedRate; switch (A.keyCode) { case Ph: this.keyPanSpeed = e.defaultKeyPanSpeed, this.movementSpeed = e.defaultMovementSpeed; break; case Vh: this.keyPanSpeed *= 1.1, this.movementSpeed *= 1.1; break; case Gh: this.keyPanSpeed *= .9, this.minKeyPanSpeed > this.keyPanSpeed && (this.keyPanSpeed = this.minKeyPanSpeed), this.movementSpeed *= .9, this.minMovementSpeed > this.movementSpeed && (this.movementSpeed = this.minMovementSpeed); break; case Dh: e.pan(0, n), i = !0; break; case kh: e.pan(0, -n), i = !0; break; case Uh: e.processRotate({ x: -10, y: 0 }, this.rotatePivot), i = !0; break; case Rh: e.pan(n, 0), i = !0; break; case Kh: e.processRotate({ x: 10, y: 0 }, this.rotatePivot), i = !0; break; case Th: e.pan(-n, 0), i = !0; break; case Fh: e.processRotate({ x: 0, y: -10 }, this.rotatePivot), i = !0; break; case Nh: e.moveStraight(o, !A.shiftKey), i = !0; break; case Qh: e.processRotate({ x: 0, y: 10 }, this.rotatePivot), i = !0; break; case Lh: e.moveStraight(-o, !A.shiftKey), i = !0 } i && t && e.update(!0) } }, Qg.prototype.processKeyUp = function (A) { if (!jh.NoKey && !jh.NoPan) switch (A.keyCode) { case qh: this.cameraControl.viewer.modelManager.sceneState.clearSelection(), this.pickHelper.lastPickedUserId = void 0, this.cameraControl.updateView(!0) } }, Qg.prototype.processTouchstart = function (A) { this.startPt.set(A.touches[0].clientX, A.touches[0].clientY), this.timeId && clearTimeout(this.timeId); var e = this.cameraControl; switch (this.timeId = setTimeout(this.longTap, 400), this.selectPad && this.selectPad.hideOverlay(), A.touches.length) { case 1: if (jh.NoRotate) return; this.rotatePivot = e.calculatePivot(jh.RotatePivotMode, { x: A.touches[0].clientX, y: A.touches[0].clientY }), this._rotateStart.set(A.touches[0].clientX, A.touches[0].clientY), this.state = this.StateType.ROTATE; break; case 2: if (!jh.NoZoom) { var t = A.touches[0].clientX - A.touches[1].clientX, i = A.touches[0].clientY - A.touches[1].clientY; this._dollyStart.set(0, Math.sqrt(t * t + i * i)) } if (!jh.NoPan) this._panStart.set(.5 * (A.touches[0].clientX + A.touches[1].clientX), .5 * (A.touches[0].clientY + A.touches[1].clientY)); break; default: this.state = this.StateType.NONE } }, Qg.prototype.processTouchmove = function (A) { var e = this.cameraControl; switch (A.preventDefault(), A.touches.length) { case 1: if (jh.NoRotate) return; this._rotateEnd.set(A.touches[0].clientX, A.touches[0].clientY), this._rotateDelta.subVectors(this._rotateStart, this._rotateEnd); var t = this.cameraControl.getClientSize(), i = 2 * Math.PI * this._rotateDelta.x / t.x * this.rotateSpeed, o = 2 * Math.PI * this._rotateDelta.y / t.y * this.rotateSpeed; e.handleRotation(i, o, this.rotatePivot), this._rotateStart.copy(this._rotateEnd); break; case 2: if (e.clearTouchRotateState(), !jh.NoZoom) { var n = A.touches[0].clientX - A.touches[1].clientX, r = A.touches[0].clientY - A.touches[1].clientY, a = Math.sqrt(n * n + r * r); if (this._dollyEnd.set(0, a), this._dollyDelta.subVectors(this._dollyEnd, this._dollyStart), Math.abs(this._dollyDelta.y) > 3) { var s = 0; this._dollyDelta.y > 0 ? s = 1 / Math.pow(this.zoomSpeed, .5 * this._dollyDelta.y) : 0 > this._dollyDelta.y && (s = Math.pow(this.zoomSpeed, .5 * -this._dollyDelta.y)), this._dollyStart.copy(this._dollyEnd), e.touchDolly(.5 * (A.touches[0].clientX + A.touches[1].clientX), .5 * (A.touches[0].clientY + A.touches[1].clientY), s), this.state = this.StateType.DOLLY } } if (!jh.NoPan) { var l = .5 * (A.touches[0].clientX + A.touches[1].clientX), c = .5 * (A.touches[0].clientY + A.touches[1].clientY); if (this._panEnd.set(l, c), this._panDelta.subVectors(this._panEnd, this._panStart), 3 > Math.abs(this._panDelta.x) && 3 > Math.abs(this._panDelta.y)) return; this._worldDimension = e.getWorldDimension(l, c), e.panOnWorld(this._panStart, this._panEnd, this._pan, this._worldDimension), e.adjustCameraForPan(this._pan), this._panStart.copy(this._panEnd), this.state = this.StateType.PAN } } e.touchUpdate() }, Qg.prototype.processTouchend = function (A) { this.timeId && clearTimeout(this.timeId), this.longTapFlag && (this.longTapFlag = !1, A.preventDefault()); var e = this.cameraControl; switch (A.touches.length) { case 0: this.state = this.StateType.NONE, e.touchEndHandler(A); break; case 1: if (jh.NoRotate) return; this._rotateStart.set(A.touches[0].clientX, A.touches[0].clientY), this.state = this.StateType.ROTATE } }, Qg.prototype.processHover = function (A) { this.pickHelper.handleMouseHover(A) }, Qg.prototype.moveTo = function (A) { if (void 0 !== A) { var e = this.cameraControl; if (!jh.NoKey && !jh.NoPan) { var t = this.movementSpeed * jh.MovementSpeedRate, i = this.keyPanSpeed * jh.MovementSpeedRate, o = qc; switch (A) { case o.FORWARD: e.moveForward(t, !0); break; case o.BACK: e.moveBackward(t, !0); break; case o.LEFT: e.pan(i, 0); break; case o.RIGHT: e.pan(-i, 0); break; case o.UP: e.pan(0, i); break; case o.DOWN: e.pan(0, -i); break; default: A = o.NONE } A !== o.NONE && e.update(!0, !0) } } }, Qg.prototype._updateMove = function () { this._moving && (this._moving = !1, this.cameraControl.update(!0)) }, Qg.prototype._animate = function () { this._reqid = requestAnimationFrame(this._animateBinded), this._updateMove() }, Qg.prototype._start = function () { this._animate() }, Qg.prototype._stop = function () { cancelAnimationFrame(this._reqid) }, Qg.prototype.onExit = function () { vc.MergeComponent && this.animationStarted && (this._stop(), this.animationStarted = !1) }; var Rg = function (A) { Qg.call(this, Gc.ORBIT, A), this.mouseButtons = { ORBIT: t.LEFT, PAN2: t.MIDDLE, PAN: t.RIGHT } }; (Rg.prototype = Object.create(Qg.prototype)).constructor = Rg; var Tg = function (A) { Qg.call(this, Gc.PAN, A), this.mouseButtons = { ORBIT: t.RIGHT, PAN2: t.MIDDLE, PAN: t.LEFT } }; (Tg.prototype = Object.create(Qg.prototype)).constructor = Tg; var kg = function (A) { Rg.call(this, A, Gc.PICK) }; (kg.prototype = Object.create(Rg.prototype)).constructor = kg, kg.prototype.processMouseUp = function (A) { A.preventDefault(); var e = 1 >= Math.abs(this.oldMouseX - A.clientX) && 1 >= Math.abs(this.oldMouseY - A.clientY); A.button !== t.LEFT && A.button !== t.RIGHT || e && (this.pickHelper.click(A, this.intersectOfMouseDown), this.intersectOfMouseDown = null), e || A.button !== this.mouseButtons.ORBIT && A.button !== this.mouseButtons.PAN || this.cameraControl.update(!0), this.intersectOfMouseDown = null, this.state = this.StateType.NONE; var i = ""; A.button === this.mouseButtons.ORBIT ? i = Gc.ORBIT : A.button === this.mouseButtons.ZOOM ? i = Gc.ZOOM : A.button !== this.mouseButtons.PAN && A.button !== this.mouseButtons.PAN2 || (i = Gc.PAN, e || this.dispatchEvent({ type: Rc.ON_MOUSE_DRAGGED, event: A })), this.dispatchEvent({ type: Rc.ON_CONTROL_END, name: i, Control: this.name }) }, kg.prototype.processMouseDoubleClick = function (A) { A.button === t.LEFT && this.pickHelper.doubleClick(A) }; var Dg = function (A) { this.control = A, this.cameraControl = A.cameraControl, this.dim = this.cameraControl.getContainerDimensions(), this.pad = null, this.padSize = 96, this.startPt = new s, this.position = new s, this.callback = null, this.intersect = null, this.destroy = function () { this.control = null, this.cameraControl = null, this.dim = null, this.pad = null, this.startPt = null, this.position = null, this.callback = null, this.intersect = null }, this.init = function () { window.addEventListener("resize", this.padInitBind, !1), this.pad = document.createElement("div"), this.padInit(), this.cameraControl.domElement.appendChild(this.pad), this.addEventListener() }, this.addEventListener = function () { this.pad.addEventListener("touchstart", this.padOnTouchStartBind, !1), this.pad.addEventListener("touchmove", this.padOnTouchMoveBind, !1), this.pad.addEventListener("touchend", this.padOnTouchEndBind, !1) }, this.padInit = function () { null !== this.pad && (this.pad.style.backgroundImage = "url(images/selectPad.png)", this.pad.style.backgroundSize = "100%", this.pad.style.position = "absolute", this.pad.style.width = this.padSize.toString() + "px", this.pad.style.height = this.padSize.toString() + "px", this.pad.style.zIndex = "10", this.pad.style.display = "none") }, this.showOverlay = function (A) { this.position = A, this.pad.style.left = this.position.x.toString() + "px", this.pad.style.top = (this.position.y - this.dim.top).toString() + "px", this.pad.style.display = "" }, this.hideOverlay = function () { this.pad.style.display = "none" }, this.pick = function () { var A = this.position.x, e = this.position.y, t = this.cameraControl, i = t.viewer.modelManager.sceneState, o = this, n = new s(A, e), r = t.getIntersectContext(n); t.intersector.pick(r, (function (A) { if (i.clearSelection(), !A) return t.updateView(!0), void(o.intersect = null); var e = A.userId; t.viewer.getScene().intersectToWorld(A, t.viewer), i.addSelection([e]), o.intersect = A, t.updateView(!0) })), null !== o.intersect && (o.intersect.cx = A, o.intersect.cy = e) }, this.onTouchStart = function (A) { 1 === A.touches.length && (A.stopPropagation(), A.preventDefault(), this.startPt.set(A.touches[0].clientX, A.touches[0].clientY)) }, this.onTouchMove = function (A) { if (1 === A.touches.length) { A.stopPropagation(), A.preventDefault(); var e = A.touches[0].clientY - this.startPt.y; this.position.x += A.touches[0].clientX - this.startPt.x, this.position.y += e, this.pad.style.left = this.position.x.toString() + "px", this.pad.style.top = (this.position.y - this.dim.top).toString() + "px", this.startPt.set(A.touches[0].clientX, A.touches[0].clientY), this.pick(A) } }, this.onTouchEnd = function (A) { A.stopPropagation(), null !== this.callback ? this.callback(this.intersect) : console.log("selectPad click", this.intersect) }, this.padInitBind = this.padInit.bind(this), this.padOnTouchStartBind = this.onTouchStart.bind(this), this.padOnTouchEndBind = this.onTouchEnd.bind(this), this.padOnTouchMoveBind = this.onTouchMove.bind(this), this.init() }, Lg = function (A) { Fg.call(this, Gc.WALK, A), this.mouseButtons = { ORBIT: t.LEFT, PAN2: t.MIDDLE, PAN: t.RIGHT }, this.pickHelper = new kp(A), this.lastMousePoint = new s, this._reqid = 0, this._animateBinded = this._animate.bind(this), this._clock = new as, this.moveState = { up: 0, down: 0, left: 0, right: 0, forward: 0, back: 0, pitchUp: 0, pitchDown: 0, yawLeft: 0, yawRight: 0, rollLeft: 0, rollRight: 0 }, this.startPt = new s, this.timeId = null, this.rotateSpeed = 1, this._rotateStart = new s, this._rotateEnd = new s, this._rotateDelta = new s, this._dollyStart = new s, this._dollyEnd = new s, this._dollyDelta = new s, this._dollyCenter = new s, this.zoomSpeed = Math.pow(.95, .2), this._panStart = new s, this._panEnd = new s, this._panDelta = new s, this._pan = new y, this.selectPad = mh.isMobileDevice() ? new Dg(this) : null, this.moveVector = new y(0, 0, 0), this.rotationVector = new y(0, 0, 0), this.zoomDelta = 0, this.rotateStart = new s, this.rotateEnd = new s, this.rotateDelta = new s, this.firstRotate = !0, this.dragLook = !0, this.lockHeightEnabled = !1, this.isLockHeight = !1, this.lockedHeight = 0, this.pickEnabled = !0, this.mouseType = null; var e = A.viewer.getScene().getBoundingBoxWorld(); this.defaultMovementSpeed = e ? e.getSize(new y(0, 0, 0)).length() / 10 : 1500, this.movementSpeed = this.defaultMovementSpeed, this.shiftSpeedup = !1, this.setFocuse = function () { var A = document.querySelector(".main-canvas"); A && A.focus && A.focus() } }; (Lg.prototype = Object.create(Fg.prototype)).constructor = Lg, Lg.prototype.destroy = function () { Fg.prototype.destroy.call(this), this.pickHelper.destroy(), this.pickHelper = null, this.selectPad && (this.selectPad.destroy(), this.selectPad = null), this.timeId && (clearTimeout(this.timeId), this.timeId = null), this._clock = null, this._animateBinded = null, this.mouseButtons = null, this.moveState = null, this.startPt = null, this.lastMousePoint = null, this.rotateStart = null, this.rotateEnd = null, this.rotateDelta = null, this._rotateStart = null, this._rotateEnd = null, this._rotateDelta = null, this._dollyStart = null, this._dollyEnd = null, this._dollyDelta = null, this._dollyCenter = null, this._panStart = null, this._panEnd = null, this._panDelta = null, this._pan = null, this.moveVector = null, this.rotationVector = null, this.rotateStart = null, this.rotateEnd = null, this.rotateDelta = null }, Lg.prototype._animate = function () { this._reqid = requestAnimationFrame(this._animateBinded), this.updateWalkMove() }, Lg.prototype._start = function () { this.moveState = { up: 0, down: 0, left: 0, right: 0, forward: 0, back: 0, pitchUp: 0, pitchDown: 0, yawLeft: 0, yawRight: 0, rollLeft: 0, rollRight: 0 }, this._animate() }, Lg.prototype._stop = function () { cancelAnimationFrame(this._reqid) }, Lg.prototype._updateMovement = function () { this.moveVector.x = -this.moveState.left + this.moveState.right, this.moveVector.z = this.isLockHeight ? 0 : -this.moveState.down + this.moveState.up, this.moveVector.y = -this.moveState.forward + this.moveState.back }, Lg.prototype._updateRotation = function () { this.rotationVector.x = jh.LockAxisZ ? 0 : -this.moveState.pitchDown + this.moveState.pitchUp, this.rotationVector.z = -this.moveState.yawRight + this.moveState.yawLeft, this.rotationVector.y = -this.moveState.rollRight + this.moveState.rollLeft }, Lg.prototype._doRotate = function (A) { vc.WalkingWithViewLock && (A.y = 0); var e = this.cameraControl.getClientSize(), t = e.y / 2; this.moveState.yawLeft = A.x / (e.x / 2), this.moveState.pitchDown = A.y / t, this._updateRotation() }, Lg.prototype.processMouseDown = function (A) { this.oldMouseX = A.clientX, this.oldMouseY = A.clientY; var e = this.cameraControl; if (A.button === this.mouseButtons.ORBIT) { if (A.preventDefault(), A.stopPropagation(), this.mouseType = A.button, this.lastMousePoint.set(A.clientX, A.clientY), this.firstRotate = !1, A.button === this.mouseButtons.ORBIT) { if (jh.NoRotate) return; this.rotateStart.set(A.clientX, A.clientY), this.state = this.StateType.ROTATE, this.dispatchEvent({ type: Rc.ON_CONTROL_BEGIN, name: "look", control: this.name }) } } else if (A.button === this.mouseButtons.PAN || A.button === this.mouseButtons.PAN2) { if (jh.NoPan) return; this._panStart.set(A.clientX, A.clientY), this._worldDimension = e.getWorldDimension(A.clientX, A.clientY), this.state = this.StateType.PAN, this.dispatchEvent({ type: Rc.ON_CONTROL_BEGIN, name: Gc.PAN, control: this.name }) } }, Lg.prototype.processMouseUp = function (A) { return A.preventDefault(), A.stopPropagation(), A.button === this.mouseButtons.PAN && this.setFocuse(), this.mouseType = null, this.pickEnabled && (A.button === t.LEFT || A.button === t.RIGHT) && 2 > Math.abs(this.lastMousePoint.x - A.clientX) && 2 > Math.abs(this.lastMousePoint.y - A.clientY) ? (this.state = this.StateType.NONE, void this.pickHelper.click(A)) : (this.state === this.StateType.ROTATE && (this.moveState.yawLeft = this.moveState.pitchDown = 0, this.dispatchEvent({ type: Rc.ON_CONTROL_END, name: "look", control: this.name })), this.state = this.StateType.NONE, !0) }, Lg.prototype.processMouseMove = function (A) { if (A.preventDefault(), this.dragLook && this.state === this.StateType.ROTATE && 0 === this.mouseType) { if (this.rotateEnd.set(A.clientX, A.clientY), this.rotateDelta.subVectors(this.rotateEnd, this.rotateStart), 0 === this.rotateDelta.x && 0 === this.rotateDelta.y) return; this.rotateStart.copy(this.rotateEnd), this._doRotate(this.rotateDelta) } else { switch (this.state) { case this.StateType.DOLLY: if (this._dollyEnd.set(A.clientX, A.clientY), this._dollyDelta.subVectors(this._dollyEnd, this._dollyStart), 0 === this._dollyDelta.x && 0 === this._dollyDelta.y) return; this.cameraControl.adjustCameraForDolly(this._dollyDelta.y > 0 ? this.zoomSpeed : 1 / this.zoomSpeed, null), this._dollyStart.copy(this._dollyEnd); break; case this.StateType.PAN: if (this._panEnd.set(A.clientX, A.clientY), this._panDelta.subVectors(this._panEnd, this._panStart), 0 === this._panDelta.x && 0 === this._panDelta.y) return; this.cameraControl.panOnWorld(this._panStart, this._panEnd, this._pan, this._worldDimension), this.cameraControl.adjustCameraForPan(this._pan), this._panStart.copy(this._panEnd) } this.state !== this.StateType.NONE && this.cameraControl.update(!0) } }, Lg.prototype.processTouchstart = function (A) { this.startPt.set(A.touches[0].clientX, A.touches[0].clientY), this.timeId && clearTimeout(this.timeId); switch (this.timeId = setTimeout(this.longTap, 400), this.selectPad && this.selectPad.hideOverlay(), A.touches.length) { case 1: if (jh.NoRotate) return; this._rotateStart.set(A.touches[0].clientX, A.touches[0].clientY), this.state = this.StateType.ROTATE; break; case 2: if (!jh.NoZoom) { var e = A.touches[0].clientX - A.touches[1].clientX, t = A.touches[0].clientY - A.touches[1].clientY; this._dollyStart.set(0, Math.sqrt(e * e + t * t)) } if (!jh.NoPan) this._panStart.set(.5 * (A.touches[0].clientX + A.touches[1].clientX), .5 * (A.touches[0].clientY + A.touches[1].clientY)); break; default: this.state = this.StateType.NONE } }, Lg.prototype.processTouchmove = function (A) { this.timeId && clearTimeout(this.timeId); var e = this.cameraControl; switch (A.preventDefault(), A.touches.length) { case 1: this.dragLook && this.state === this.StateType.ROTATE && (this._rotateEnd.set(A.touches[0].clientX, A.touches[0].clientY), this._rotateDelta.subVectors(this._rotateEnd, this._rotateStart), this._rotateStart.copy(this._rotateEnd), this._doRotate(this._rotateDelta)); break; case 2: if (e.clearTouchRotateState(), !jh.NoZoom) { var t, i = A.touches[0].clientX - A.touches[1].clientX, o = A.touches[0].clientY - A.touches[1].clientY, n = Math.sqrt(i * i + o * o); if (this._dollyEnd.set(0, n), this._dollyDelta.subVectors(this._dollyEnd, this._dollyStart), Math.abs(this._dollyDelta.y) > 3) this._dollyDelta.y > 0 ? t = 1 / Math.pow(this.zoomSpeed, .5 * this._dollyDelta.y) : 0 > this._dollyDelta.y && (t = Math.pow(this.zoomSpeed, .5 * -this._dollyDelta.y)), this._dollyStart.copy(this._dollyEnd), e.touchDolly(.5 * (A.touches[0].clientX + A.touches[1].clientX), .5 * (A.touches[0].clientY + A.touches[1].clientY), t), this.state = this.StateType.DOLLY } if (!jh.NoPan) { var r = .5 * (A.touches[0].clientX + A.touches[1].clientX), a = .5 * (A.touches[0].clientY + A.touches[1].clientY); if (this._panEnd.set(r, a), this._panDelta.subVectors(this._panEnd, this._panStart), 3 > Math.abs(this._panDelta.x) && 3 > Math.abs(this._panDelta.y)) return; this._worldDimension = e.getWorldDimension(r, a), e.panOnWorld(this._panStart, this._panEnd, this._pan, this._worldDimension), e.adjustCameraForPan(this._pan), this._panStart.copy(this._panEnd), this.state = this.StateType.PAN } } e.touchUpdate() }, Lg.prototype.processTouchend = function (A) { this.timeId && clearTimeout(this.timeId), this.longTapFlag && (this.longTapFlag = !1, A.preventDefault()); var e = this.cameraControl; switch (A.touches.length) { case 0: this.state = this.StateType.NONE, e.touchEndHandler(A); break; case 1: if (jh.NoRotate) return; this._rotateStart.set(A.touches[0].clientX, A.touches[0].clientY), this.state = this.StateType.ROTATE } }, Lg.prototype.processHover = function (A) { this.dragLook || (this.firstRotate && (this.firstRotate = !1, this.rotateStart.set(A.clientX, A.clientY)), this.rotateEnd.set(A.clientX, A.clientY), this.rotateDelta.subVectors(this.rotateEnd, this.rotateStart), this.rotateStart.copy(this.rotateEnd), this._doRotate(this.rotateDelta)) }, Lg.prototype.processMouseWheel = function (A) { var e = this.cameraControl; if (A.preventDefault(), A.stopPropagation(), !jh.NoZoom) { var t = 0; A.wheelDelta ? t = A.wheelDelta : A.deltaY && (t = 40 * -A.deltaY), Math.abs(t) > 720 && (t = t > 0 ? 720 : -720), t *= this.wheelZoomFactor, jh.ReverseWheelDirection && (t *= -1), e.zoom(t, A.clientX, A.clientY), e.delayHandle(), this.dispatchEvent({ type: Rc.ON_CONTROL_ZOOM }) } }, Lg.prototype.processKeyDown = function (A) { if (!jh.NoKey && !A.altKey) { var e = qc.NONE; switch (A.key) { case "0": this.movementSpeed = this.defaultMovementSpeed; break; case "=": case "+": this.movementSpeed *= 1.1; break; case "-": case "——": this.movementSpeed *= .9, this.minMovementSpeed > this.movementSpeed && (this.movementSpeed = this.minMovementSpeed); break; case "ArrowUp": case "w": case "W": e = qc.FORWARD, this.moveState.forward = 1; break; case "ArrowDown": case "s": case "S": e = qc.BACK, this.moveState.back = 1; break; case "ArrowLeft": case "a": case "A": e = qc.LEFT, this.moveState.left = 1; break; case "ArrowRight": case "d": case "D": e = qc.RIGHT, this.moveState.right = 1; break; case "q": case "Q": e = qc.UP, this.moveState.up = 1; break; case "e": case "E": e = qc.DOWN, this.moveState.down = 1; break; case "Shift": this.shiftSpeedup || (this.movementSpeed += this.defaultMovementSpeed, this.shiftSpeedup = !0); break; case "Tab": return this.moveVector.set(0, 0, 0), this.moveState.forward = 0, this.moveState.back = 0, this.moveState.left = 0, this.moveState.right = 0, this.moveState.up = 0, void(this.moveState.down = 0) } this._updateMovement(), this._updateRotation(), e !== qc.NONE && this.dispatchEvent({ type: Rc.ON_CONTROL_KEYDOWN, event: A, direction: e, control: this.name }) } }, Lg.prototype.processKeyUp = function (A) { if (!jh.NoKey) { var e = qc.NONE; switch (A.key) { case "ArrowUp": case "W": case "w": e = qc.FORWARD, this.moveState.forward = 0; break; case "ArrowDown": case "s": case "S": e = qc.BACK, this.moveState.back = 0; break; case "ArrowLeft": case "a": case "A": e = qc.LEFT, this.moveState.left = 0; break; case "ArrowRight": case "d": case "D": e = qc.RIGHT, this.moveState.right = 0; break; case "q": case "Q": e = qc.UP, this.moveState.up = 0; break; case "e": case "E": e = qc.DOWN, this.moveState.down = 0; break; case "Shift": this.shiftSpeedup && (this.movementSpeed -= this.defaultMovementSpeed, this.shiftSpeedup = !1); break; default: e = qc.NONE } this._updateMovement(), this._updateRotation(), e !== qc.NONE && this.dispatchEvent({ type: Rc.ON_CONTROL_KEYUP, event: A, direction: e, control: this.name }) } }, Lg.prototype.updateWalkMove = function () { var A = this._clock.getDelta(), e = this.cameraControl, t = e.camera.position.z; if (0 !== this.moveVector.x || 0 !== this.moveVector.y || 0 !== this.moveVector.z || 0 !== this.rotationVector.x || 0 !== this.rotationVector.y || 0 !== this.rotationVector.z || 0 !== this.zoomDelta) { var i = this.movementSpeed * jh.WalkSpeedRate * A; if (!0 === vc.WalkingWithGravity && (this.moveVector.z = 0, e.computeManHeight(), e.computeGravity()), e.dirtyCamera(!0), 0 !== this.zoomDelta) e.zoomCameraForWalk(1 + this.zoomDelta * A), this.zoomDelta = 0; 0 !== i && e.translateCameraForWalk(this.moveVector, i), e.rotateCameraForWalk(this.rotationVector, this.dragLook ? 1 : 2), e.flyOnWorld(!1), this.moveState.pitchUp = 0, this.moveState.pitchDown = 0, this.moveState.yawLeft = 0, this.moveState.yawRight = 0, this.moveState.rollLeft = 0, this.moveState.rollRight = 0, t !== e.camera.position.z && e.viewer.modelManager.dispatchEvent({ type: Rc.ON_CAMERA_HEIGHT_CHANGED, cameraPosition: e.camera.position.clone() }) } }, Lg.prototype.onEnter = function () { var A = this.cameraControl.getCamera(); A.isPerspective || (console.log("Current camera is Orthographic"), A.toPerspective()), this._start() }, Lg.prototype.onExit = function () { this._stop() }, Lg.prototype.rotateTo = function (A) { this._doRotate(A) }, Lg.prototype.moveTo = function (A, e, t) { if (void 0 === t && (t = !0), void 0 === e && (e = 1), t) switch (A) { case qc.FORWARD: this.moveState.forward = e; break; case qc.BACK: this.moveState.back = e; break; case qc.LEFT: this.moveState.left = e; break; case qc.RIGHT: this.moveState.right = e; break; case qc.UP: this.moveState.up = e; break; case qc.DOWN: this.moveState.down = e } else switch (A) { case qc.FORWARD: this.moveState.forward = 0; break; case qc.BACK: this.moveState.back = 0; break; case qc.LEFT: this.moveState.left = 0; break; case qc.RIGHT: this.moveState.right = 0; break; case qc.UP: this.moveState.up = 0; break; case qc.DOWN: this.moveState.down = 0 } this._updateMovement() }, Lg.prototype.setHeightLocked = function (A) { this.lockHeightEnabled && this.isLockHeight !== A && (this.isLockHeight = A) }, Lg.prototype.setDragLook = function (A) { this.dragLook !== A && (this.firstRotate = !0, this.dragLook = A) }, Lg.prototype.processPointerLockEnter = function () { this.pointerLock = !0 }, Lg.prototype.processPointerLockExit = function () { this.pointerLock = !1 }, Lg.prototype.processMovement = function (A) { this.rotateDelta.set(A.movementX || A.mozMovementX || A.webkitMovementX || 0, A.movementY || A.mozMovementY || A.webkitMovementY || 0), this._doRotate(this.rotateDelta) }; var Ng = function (A) { Qg.call(this, Gc.ZOOM, A), this.mouseButtons = { ZOOM: t.LEFT, PAN2: t.MIDDLE, PAN: t.RIGHT } }; (Ng.prototype = Object.create(Qg.prototype)).constructor = Ng; var Og = function () { this.control = null, this.controls = {}, this.tools = [], this.domElement = null, this.enabled = !0, this.isUpdateRenderList = !0; var A = !1, e = this; function t(t) { if (e.enabled) { for (var i = e.tools, o = i.length - 1; o >= 0; o -= 1) if (i[o].onEvent(t)) { switch (t.type) { case "mouseup": A = !1 } return } switch (t.type) { case "touchmove": e.control.processTouchmove(t); break; case "touchstart": e.control.processTouchstart(t); break; case "touchend": e.control.processTouchend(t); break; case "keydown": e.control.processKeyDown(t); break; case "keyup": e.control.processKeyUp(t); break; case "wheel": case "mousewheel": case "DOMMouseScroll": e.cameraChange = !0, e.control.processMouseWheel(t); break; case "mousedown": ! function (t) { e.setFocuse(), A = !0, e.isUpdateRenderList = !1, e.control ? e.control.processMouseDown(t) : Bh.warn("control is null") }(t); break; case "mousemove": ! function (t) { e.pointerLock ? e.control.processMovement(t) : A ? (e.isUpdateRenderList = !1, e.cameraChange = !0, e.control.processMouseMove(t)) : e.control.processHover(t) }(t); break; case "mouseup": ! function (t) { e.isUpdateRenderList = !0, A && (e.control.processMouseUp(t), A = !1) }(t); break; case "dblclick": e.control.processMouseDoubleClick(t) } } else e.cameraChange = !1 } function i(A) { A.preventDefault() } function o(A) { document.pointerLockElement === e.domElement || document.mozPointerLockElement === e.domElement || document.webkitPointerLockElement === e.domElement ? (e.pointerLock = !0, e.control.processPointerLockEnter(A)) : (e.pointerLock = !1, e.control.processPointerLockExit(A), e.domElement.focus(), e.control.dispatchEvent({ type: Rc.ON_POINTERLOCK_EXIST, name: e.control.getName() })) } function n(A) { e.pointerLock = !1, e.control.processPointerLockExit(A), e.control.dispatchEvent({ type: Rc.ON_POINTERLOCK_EXIST, name: e.control.getName() }) } this.setFocuse = function () { if (e.domElement) { var A = e.domElement.querySelector(".main-canvas"); A && A.focus && A.focus() } }, this.setFocus = this.setFocuse, this.getCameraControl = function () { return this.cameraControl }, this.registerDomEventListeners = function (A) { this.domElement = A, A.addEventListener("contextmenu", i, !1), A.addEventListener("mousedown", t, !1), A.addEventListener("mousewheel", t, !1), A.addEventListener("DOMMouseScroll", t, !1), A.addEventListener("wheel", t, !1), A.addEventListener("dblclick", t, !1), window.addEventListener("mousemove", t, !1), window.addEventListener("mouseup", t, !1), A.addEventListener("touchstart", t, !1), A.addEventListener("touchend", t, !1), A.addEventListener("touchmove", t, !1), window.addEventListener("touchmove", (function (A) {}), !1), A.addEventListener("keydown", t, !1), window.addEventListener("keyup", t, !1), document.addEventListener("pointerlockchange", o, !1), document.addEventListener("mozpointerlockchange", o, !1), document.addEventListener("webkitpointerlockchange", o, !1), document.addEventListener("pointerlockerror", n, !1), document.addEventListener("mozpointerlockerror", n, !1), document.addEventListener("webkitpointerlockerror", n, !1), this.setFocuse() }, this.unregisterDomEventListeners = function (A) { A.removeEventListener("contextmenu", i, !1), A.removeEventListener("mousedown", t, !1), A.removeEventListener("mousewheel", t, !1), A.removeEventListener("DOMMouseScroll", t, !1), A.removeEventListener("dblclick", t, !1), window.removeEventListener("mousemove", t, !1), window.removeEventListener("mouseup", t, !1), A.removeEventListener("touchstart", t, !1), A.removeEventListener("touchend", t, !1), A.removeEventListener("touchmove", t, !1), A.removeEventListener("keydown", t, !1), window.removeEventListener("keyup", t, !1), document.removeEventListener("pointerlockchange", o, !1), document.removeEventListener("mozpointerlockchange", o, !1), document.removeEventListener("webkitpointerlockchange", o, !1), document.removeEventListener("pointerlockerror", n, !1), document.removeEventListener("mozpointerlockerror", n, !1), document.removeEventListener("webkitpointerlockerror", n, !1) } }; Og.prototype = { constructor: Og, destroy: function () { for (var A in this.control = null, this.controls) { this.controls[A].destroy() } this.controls = {}; for (var e = 0, t = this.tools.length; t > e; e += 1) this.tools[e].destroy(); this.tools = null, this.unregisterDomEventListeners(this.domElement), this.domElement = null }, getCurrentControlName: function () { return this.control ? this.control.name : "" }, _getControlByName: function (A, e) { var t = this.controls[e]; if (t) return t; var i = Gc; this.viewer = A, this.cameraControl = A.cameraControl; var o = A.cameraControl; switch (e) { case i.ORBIT: t = new Rg(o); break; case i.PICK: t = new kg(o); break; case i.PAN: t = new Tg(o); break; case i.FLY: t = new Kg(o); break; case i.WALK: t = new Lg(o); break; case i.ZOOM: t = new Ng(o); break; default: t = null, Bh.error("invalid control name") } return t && (t.name = e, this.controls[e] = t), t }, getCurrentControlMode: function () { return this.control }, getCurrentControl: function () { return this.control }, setControlMode: function (A, e) { var t = this._getControlByName(A, e); t && this.control !== t && (null !== this.control && (this.control.dispatchEvent({ type: Rc.ON_CONTROL_EXIST, name: this.control.getName() }), this.control.onExit()), this.control = t, this.control.onEnter(), this.control.dispatchEvent({ type: Rc.ON_CONTROL_ENTER, name: this.control.getName() })) }, getToolByName: function (A) { for (var e = this.tools.length, t = 0; e > t; t += 1) if (this.tools[t].name === A) return this.tools[t] }, enableTool: function (A, e) { for (var t = Pc, i = this.tools, o = 0, n = i.length; n > o; o += 1) if (i[o].name === e) return; var r = null; switch (e) { case t.PICK_BY_RECT: r = new bg(A); break; case t.ZOOM_BY_RECT: r = new Ug(A); break; case t.CLIP_BY_BOX: r = new vp(A); break; case t.CLIP_FILL: r = new Sp(A); break; case t.PICK_BY_MEASURE: r = new Eg(A); break; case t.COMPONENT_TRANSFORM: r = new Ip(A.getScene(), A.camera, A.domElement) } r && i.push(r) }, disableTool: function (A) { for (var e = this.tools, t = 0, i = e.length; i > t; t += 1) if (e[t].name === A) { e[t].onExit(), this.dispatchEvent({ type: Rc.ON_CONTROL_EXIST, name: A }), e.splice(t, 1); break } }, setInteractiveState: function (A) { this.enabled = A }, requestPointerLock: function () { this.control instanceof Lg && (this.domElement.requestPointerLock = this.domElement.requestPointerLock || this.domElement.mozRequestPointerLock || this.domElement.webkitRequestPointerLock, this.domElement.requestPointerLock()) } }, Object.assign(Og.prototype, Ld.prototype); var Vg = function () { this.className = "FilterAction" }; Vg.prototype.getClassName = function () { return this.className }, Vg.prototype.applyFilter = function (A) {}; var Gg = function () { Vg.call(this), this.className = "IdsFilterAction", this.ids = [] }; (Gg.prototype = Object.create(Vg.prototype)).arrayToMap = function (A) { for (var e = {}, t = 0; A.length > t; t += 1) { var i = A[t]; e[i] = i } return e }, Gg.prototype.constructor = Gg, Gg.prototype.setIds = function (A) { this.ids = A }; var Pg = function (A, e) { Gg.call(this), this.className = "VisibleIdsFA", this.flag = A, this.isVisible = e }; (Pg.prototype = Object.create(Gg.prototype)).constructor = Pg, Pg.prototype.applyFilter = function (A) { console.log('applyFilter :>> '); Array.isArray(this.ids) ? (A.setVisible(this.ids, this.isVisible, this.flag), A.calculateVisibleComponentsBbox()) : Bh.warn("Ids should be type of array.") }; var qg = function (A, e) { Gg.call(this), this.className = "OverrideIdsFA", this.flag = A, this.material = e }; (qg.prototype = Object.create(Gg.prototype)).constructor = qg, qg.prototype.applyFilter = function (A) { console.log('applyFilter :sss>> '); Array.isArray(this.ids) ? A.setMaterial(this.ids, this.material, this.flag) : Bh.warn("Ids should be type of array.") }; var jg = function (A, e) { Gg.call(this), this.className = "WireframeIdsFA", this.flag = A, this.material = e }; (jg.prototype = Object.create(Gg.prototype)).constructor = jg, jg.prototype.applyFilter = function (A) { Array.isArray(this.ids) ? A.setMaterial(this.ids, this.material, this.flag) : Bh.warn("Ids should be type of array.") }; var Hg = function (A) { Gg.call(this), this.className = "IsolateIdsFA", this.isolateHide = A }; (Hg.prototype = Object.create(Gg.prototype)).constructor = Hg, Hg.prototype.applyFilter = function (A) { console.log('applyFilter :>dddd> '); Array.isArray(this.ids) ? (A.clearIsolates(), this.isolateHide ? (A.setIsolateHide(this.ids, !0, !1), A.calculateVisibleComponentsBbox()) : A.setIsolateTransparent(this.ids, !0, !1)) : Bh.warn("Ids should be type of array.") }; var Yg = function (A, e) { Gg.call(this), this.className = "TransparentIdsFA", this.flag = A, this.isOpaque = e }; (Yg.prototype = Object.create(Gg.prototype)).constructor = Yg, Yg.prototype.applyFilter = function (A) { console.log('applyFilter :>dddd> '); Array.isArray(this.ids) ? A.setTransparent(this.ids, !this.isOpaque, this.flag) : Bh.warn("Ids should be type of array.") }; var Wg = function () { Vg.call(this), this.className = "ConditionFilterAction", this.conditions = null }; (Wg.prototype = Object.create(Vg.prototype)).constructor = Wg; var Jg = function (A, e) { Wg.call(this), this.className = "VisibleConditionFA", this.flag = A, this.isVisible = e }; (Jg.prototype = Object.create(Wg.prototype)).constructor = Jg, Jg.prototype.applyFilter = function (A) { console.log('applyFilter :>sdfdf> '); var e = this; Array.isArray(this.conditions) ? (A.matchConditions(this.conditions, (function (t, i) { e.flag === i && (A.setVisible(t, e.isVisible), t = null) })), A.calculateVisibleComponentsBbox()) : Bh.warn("Conditions should be type of array.") }; var zg = function (A, e) { Wg.call(this), this.className = "OverrideConditionFA", this.flag = A, this.material = e }; (zg.prototype = Object.create(Wg.prototype)).constructor = zg, zg.prototype.applyFilter = function (A, e) { console.log('applyFilter :>ddddddd> '); var t = this; Array.isArray(this.conditions) ? A.matchConditions(this.conditions, (function (e, i) { t.flag === i && (A.setMaterial(e, t.material), e = null) })) : Bh.warn("Conditions should be type of array.") }; var Zg = function (A, e) { Wg.call(this), this.className = "TransparentConditionFA", this.flag = A, this.isOpaque = e }; (Zg.prototype = Object.create(Wg.prototype)).constructor = Zg, Zg.prototype.applyFilter = function (A) { console.log('applyFilter :>erqwqer> '); var e = this; Array.isArray(this.conditions) ? A.matchConditions(this.conditions, (function (t, i) { e.flag === i && (A.setTransparent(t, !e.isOpaque), t = null) })) : Bh.warn("Conditions should be type of array.") }; var Xg = function (A) { Wg.call(this), this.className = "IsolateConditionFA", this.isolateHide = A }; (Xg.prototype = Object.create(Wg.prototype)).constructor = Xg, Xg.prototype.applyFilter = function (A) { console.log('applyFilter :dfasf>> '); A.clearIsolates(); var e = this.isolateHide; Array.isArray(this.conditions) ? A.matchConditions(this.conditions, (function (t, i) { !0 !== i ? (e ? (A.setIsolateHide(t, !i), A.calculateVisibleComponentsBbox()) : A.setIsolateTransparent(t, !i), t = null) : t = null })) : Bh.warn("Conditions should be type of array.") }; var _g = function (A) { this._activeFilterList = [], this._filterResultModes = {}, this._defaultReturnValue = A, this._filterPriority = null }; _g.prototype.setFilterMode = function (A) { this._filterResultModes = A }, _g.prototype.setFilterPriority = function (A) { this._filterPriority = A }, _g.prototype.addBaseFilter = function (A) { var e = this._activeFilterList, t = e.indexOf(A); if (null === this._filterPriority) - 1 === t ? e.push(A) : t !== e.length - 1 && (e.splice(t, 1), e.push(A)); else if (0 === e.length) e.push(A); else { -1 !== t && t !== e.length - 1 && e.splice(t, 1); for (var i = this._filterPriority[A.getType()], o = 0, n = e.length; n > o; o += 1) if (this._filterPriority[e[o].getType()] > i) { e.splice(o, 0, A); break } o === n && e.push(A) } }, _g.prototype.removeBaseFilter = function (A) { var e = this._activeFilterList.indexOf(A); - 1 !== e && this._activeFilterList.splice(e, 1) }, _g.prototype.isEmpty = function () { return 0 === this._activeFilterList.length }, _g.prototype.hasFilterNotIn = function (A) { for (var e = this._activeFilterList, t = e.length - 1; t >= 0; t -= 1) { if (void 0 === A._filterResultModes[e[t].getType()]) return !0 } return !1 }, _g.prototype.apply = function (A) { for (var e = Jc, t = null, i = this._activeFilterList.length - 1; i >= 0; i -= 1) switch (this._filterResultModes[(t = this._activeFilterList[i]).getType()]) { case e.MATCH_RETURN_TRUE: if (t.match(A)) return !0; break; case e.MATCH_RETURN_FALSE: if (t.match(A)) return !1; break; case e.NOMATCH_RETURN_TRUE: if (!t.match(A)) return !0; break; case e.NOMATCH_RETURN_FALSE: if (!t.match(A)) return !1; break; default: return !1 } return this._defaultReturnValue }, _g.prototype.getApplyFilterId = function (A) { for (var e = Jc, t = null, i = this._activeFilterList.length - 1; i >= 0; i -= 1) switch (this._filterResultModes[(t = this._activeFilterList[i]).getType()]) { case e.MATCH_RETURN_TRUE: case e.MATCH_RETURN_FALSE: if (t.match(A)) return t.getType(); break; case e.NOMATCH_RETURN_TRUE: case e.NOMATCH_RETURN_FALSE: if (!t.match(A)) return t.getType(); break; default: return -1 } return -1 }, Math.log2 = Math.log2 || function (A) { return Math.log(A) / Math.LN2 }, "function" != typeof String.prototype.startsWith && (String.prototype.startsWith = function (A) { return this.slice(0, A.length) === A }), Array.prototype.remove || Object.defineProperty(Array.prototype, "remove", { enumerable: !1, value: function (A) { var e = this.indexOf(A); e > -1 && this.splice(e, 1) } }), "undefined" != typeof window && mh.isIE11() && function () { function A(A, e) { e = e || { bubbles: !1, cancelable: !1, detail: void 0 }; var t = document.createEvent("CustomEvent"); return t.initCustomEvent(A, e.bubbles, e.cancelable, e.detail), t } A.prototype = window.CustomEvent.prototype, window.CustomEvent = A }(), "function" != typeof String.prototype.startsWith && (String.prototype.startsWith = function (A) { return this.slice(0, A.length) === A }), "function" != typeof String.prototype.endsWith && (String.prototype.endsWith = function (A) { return -1 !== this.indexOf(A, this.length - A.length) }), "undefined" != typeof window && (window.BlobBuilder = window.BlobBuilder || window.WebKitBlobBuilder || window.MozBlobBuilder || window.MSBlobBuilder), Number.isInteger = Number.isInteger || function (A) { return "number" == typeof A && isFinite(A) && Math.floor(A) === A }, String.prototype.repeat = String.prototype.repeat || function (A) { if (1 > A) return ""; for (var e = "", t = this.valueOf(); A > 1;) 1 & A && (e += t), A >>= 1, t += t; return e + t }, Array.prototype.fill || Object.defineProperty(Array.prototype, "fill", { enumerable: !1, value: function (A, e, t) { t = void 0 === t ? this.length : t; for (var i = e = void 0 === e ? 0 : e; t > i; i += 1) this[i] = A } }), Array.prototype.find || Object.defineProperty(Array.prototype, "find", { enumerable: !1, value: function (A, e) { for (var t = this.length, i = 0; t > i; i += 1) { var o = this[i]; if (A.call(e, o, i, this)) return o } } }), Array.prototype.hasValue || Object.defineProperty(Array.prototype, "hasValue", { enumerable: !1, value: function (A) { return this.indexOf(A) > -1 } }), "function" != typeof Object.assign && Object.defineProperty(Object, "assign", { value: function (A, e) { if (null == A) throw new TypeError("Cannot convert undefined or null to object"); for (var t = Object(A), i = 1; arguments.length > i; i += 1) { var o = arguments[i]; if (null != o) for (var n in o) Object.prototype.hasOwnProperty.call(o, n) && (t[n] = o[n]) } return t }, writable: !0, configurable: !0 }), ArrayBuffer.prototype.slice || (ArrayBuffer.prototype.slice = function (A, e) { if (!e || e > this.byteLength ? e = this.byteLength : 0 > e && 0 > (e = this.byteLength + e) && (e = 0), 0 > A && 0 > (A = this.byteLength + A) && (A = 0), A >= e) return new ArrayBuffer; for (var t = e - A, i = new Uint8Array(this, A, t), o = new Uint8Array(t), n = 0; t > n; n += 1) o[n] = i[n]; return o.buffer }), Float32Array.prototype.slice || (Float32Array.prototype.slice = Float32Array.prototype.subarray), Uint32Array.prototype.slice || (Uint32Array.prototype.slice = Uint32Array.prototype.subarray), Int32Array.prototype.slice || (Int32Array.prototype.slice = Int32Array.prototype.subarray), Int16Array.prototype.slice || (Int16Array.prototype.slice = Int16Array.prototype.subarray); var $g, Au = "function" == typeof Symbol && "symbol" === lc(Symbol.iterator) ? function (A) { return lc(A) } : function (A) { return A && "function" == typeof Symbol && A.constructor === Symbol && A !== Symbol.prototype ? "symbol" : lc(A) }, eu = function () { function A(A, e) { for (var t = 0; e.length > t; t += 1) { var i = e[t]; i.enumerable = i.enumerable || !1, i.configurable = !0, "value" in i && (i.writable = !0), Object.defineProperty(A, i.key, i) } } return function (e, t, i) { return t && A(e.prototype, t), i && A(e, i), e } }(); HTMLElement.prototype.tap = function (A) { var e = 0; this.addEventListener("touchstart", (function (A) { e = Date.now() })), this.addEventListener("touchend", (function (t) { 200 > Date.now() - e && A(t) })) }, (Boolean(window.ActiveXObject) || "ActiveXObject" in window) && (HTMLElement.prototype.remove = function () { var A = this.parentNode || this.parentElement; A && A.removeChild(this) }, window.Element && (($g = Element.prototype).matches = $g.matches || $g.matchesSelector || $g.webkitMatchesSelector || $g.msMatchesSelector || function (A) { for (var e = (this.parentNode || this.document).querySelectorAll(A), t = -1; e[t += 1] && e[t] !== this;) ; return Boolean(e[t]) }), window.Element && function (A) { A.closest = A.closest || function (A) { for (var e = this; e.matches && !e.matches(A);) e = e.parentNode; return e.matches ? e : null } }(Element.prototype)), SVGElement.prototype.getClass = HTMLElement.prototype.getClass = function (A) { return this.getAttribute("class") }, SVGElement.prototype.hasClass = HTMLElement.prototype.hasClass = function (A) { var e = this.getClass(); return !!e && (e && e.split(" ")).indexOf(A) > -1 }, SVGElement.prototype.addClass = HTMLElement.prototype.addClass = function (A) { var e = this.getClass(), t = e && e.split(" "); return e ? -1 === t.indexOf(A) && (t.push(A), e = t.join(" "), this.setAttribute("class", String(e))) : this.setAttribute("class", String(A)), this }, SVGElement.prototype.removeClass = HTMLElement.prototype.removeClass = function (A) { if (!this.hasClass(A)) return this; var e = this.getClass().replace(A, "").trim(); return e ? this.setAttribute("class", String(e)) : this.removeAttribute("class"), this }, SVGElement.prototype.toggleClass = HTMLElement.prototype.toggleClass = function (A, e) { this.getClass(); var t = this.hasClass(A); return null != e ? (e && !t && this.addClass(A), e || this.removeClass(A)) : t ? this.removeClass(A) : this.addClass(A), !t }, Array.prototype.getObjectByAttribute || Object.defineProperty(Array.prototype, "getObjectByAttribute", { enumerable: !1, value: function (A, e) { for (var t = this.length, i = 0; t > i; i += 1) if (this[i][A] === e) return this[i]; return !1 } }), Array.prototype.removeObjectByAttribute || Object.defineProperty(Array.prototype, "removeObjectByAttribute", { enumerable: !1, value: function (A, e) { for (var t = this, i = t.length, o = 0; i > o; o += 1) if (t[o][A] === e) return t = t.splice(o, 1); return !1 } }), Array.prototype.getAllObjectByAttribute || Object.defineProperty(Array.prototype, "getAllObjectByAttribute", { enumerable: !1, value: function (A, e) { for (var t = this.length, i = 0, o = []; t > i; i += 1) this[i][A] === e && o.push(this[i]); return o } }), Array.prototype.removeByValue || Object.defineProperty(Array.prototype, "removeByValue", { enumerable: !1, value: function (A) { for (var e = this.length - 1; e >= 0; e -= 1) this[e] === A && this.splice(e, 1); return this } }), Array.prototype.insert || Object.defineProperty(Array.prototype, "insert", { enumerable: !1, value: function (A, e) { return this.splice(A, 0, e), this } }), SVGElement.prototype.setCss = HTMLElement.prototype.setCss = function (A) { if (A) for (var e in A) this.style[e] = A[e] }, SVGElement.prototype.getCss = HTMLElement.prototype.getCss = function () { return this.style }; var tu = function (A, e) { this._type = A, this._name = e, this._enabled = !1, this._items = {}, this._relatedCompoundFilterList = [] }; tu.prototype.getType = function () { return this._type }, tu.prototype.getName = function () { return this._name }, tu.prototype.get = function () { return this._items }, tu.prototype.getAll = function () { return this._items }, tu.prototype.clearAll = function () { this._items = {}, this._enabled && (this._enabled = !1, this.enableStateChanged()) }, tu.prototype.clear = function () { this.clearAll() }, tu.prototype.isEmpty = function () { return !this._enabled }, tu.prototype.forceEnable = function () { this._enabled || (this._enabled = !0, this.enableStateChanged()) }, tu.prototype.setByData = function (A) { ! function (A) { if (null === A) return !0; if ("object" !== (void 0 === A ? "undefined" : Au(A))) return !0; for (var e in A) if (A.hasOwnProperty(e)) return !1; return !0 }(A) ? (this._items = A, this._enabled || (this._enabled = !0, this.enableStateChanged())) : (this._items = {}, this._enabled && (this._enabled = !1, this.enableStateChanged())) }, tu.prototype.match = function (A) { return !1 }, tu.prototype.registerToCompoundFilter = function (A) { this._relatedCompoundFilterList.push(A) }, tu.prototype.enableStateChanged = function () { for (var A = 0, e = this._relatedCompoundFilterList.length; e > A; A += 1) this._enabled ? this._relatedCompoundFilterList[A].addBaseFilter(this) : this._relatedCompoundFilterList[A].removeBaseFilter(this) }; var iu = function (A, e) { tu.call(this, A, e) }; (iu.prototype = Object.create(tu.prototype)).constructor = iu, iu.prototype.match = function (A) { var e = A.userData; return !e || function (A, e) { for (var t = !1, i = 0, o = A.length; o > i; i += 1) { t = !0; var n = A[i]; for (var r in n) { if (!Array.isArray(n[r]) && e[r] !== n[r]) { t = !1; break } if (Array.isArray(n[r]) && -1 === n[r].indexOf(e[r])) { t = !1; break } } if (t) return !0 } return !1 }(this._items, e) }; var ou = function (A, e) { tu.call(this, A, e) }; (ou.prototype = Object.create(tu.prototype)).constructor = ou, ou.prototype.add = function (A) { var e = this._items; if (A && A.length > 0) { for (var t = 0, i = A.length; i > t; t += 1) e[A[t]] = !0; this._enabled || (this._enabled = !0, this.enableStateChanged()) } }, ou.prototype.remove = function (A) { var e = this._items; if (A && A.length > 0) { for (var t = 0, i = A.length; i > t; t += 1) { var o = A[t]; e.hasOwnProperty(o) && delete e[o] } 0 === Object.keys(e).length && this._enabled && (this._enabled = !1, this.enableStateChanged()) } }; var nu = function (A, e) { ou.call(this, A, e) }; (nu.prototype = Object.create(ou.prototype)).constructor = nu, nu.prototype.match = function (A) { var e = A.name; if (e) { var t = e.indexOf("."); if (-1 !== t) { var i = e.substring(0, t); return !!this._items[i] } } var o = A.userData; if (o && (i = o.sceneId)) return !!this._items[i]; return !1 }; var ru = function (A, e) { ou.call(this, A, e) }; (ru.prototype = Object.create(ou.prototype)).constructor = ru, ru.prototype.match = function (A) { return !!this._items[A.name] }; var au = function () { this.defaultWireframeColor = { color: new LA(0, 0, 0), opacity: .4 }, this.wireframeMaterial = new jA(this.defaultWireframeColor), !1 === vc.TranslucentDepthDisabled && (this.wireframeMaterial.transparent = !0), this.instanceWireframeMaterial = Kd.createInstanceMaterial(Kd.getMaterialParameters(this.wireframeMaterial)), !1 === vc.TranslucentDepthDisabled && (this.instanceWireframeMaterial.transparent = !0), this.wireframeGeometryMap = {} }; au.prototype.destroy = function () { this.wireframeMaterial.dispose(), this.wireframeMaterial = null, this.instanceWireframeMaterial.destroy(), this.instanceWireframeMaterial = null, this.wireframeGeometryMap = null, this.defaultWireframeColor.color = null, this.defaultWireframeColor = null }, au.prototype.setWireframeColor = function (A, e) { this.wireframeMaterial.color = A, this.wireframeMaterial.opacity = e, this.wireframeMaterial.transparent = 1 !== e, this.instanceWireframeMaterial.color = A, this.instanceWireframeMaterial.opacity = e, this.instanceWireframeMaterial.transparent = 1 !== e }, au.prototype.getWireframeColor = function () { var A = this.wireframeMaterial.color.clone(); return A.opacity = this.wireframeMaterial.opacity, A }, au.prototype.restoreWireframeColor = function () { var A = this.defaultWireframeColor; this.setWireframeColor(A.color, A.opacity) }; var su = function () { new au; var A = [{ name: "scene", param: { name: "scene", color: 8947848, opacity: .4, transparent: !0, side: 2 } }, { name: "darkRed", param: { name: "darkRed", color: 10496040, opacity: 1, transparent: !1, side: 2 } }, { name: "lightBlue", param: { name: "lightBlue", color: 1275840, opacity: 1, transparent: !1, side: 2 } }, { name: "black", param: { name: "black", color: 0, opacity: .3, transparent: !0, side: 2 } }, { name: "add", param: { name: "add", color: 65280, opacity: 1, transparent: !0, side: 2 } }, { name: "delete", param: { name: "delete", color: 16711680, opacity: .5, transparent: !0, side: 2 } }, { name: "beforeEdit", param: { name: "beforeEdit", color: 16432389, opacity: .5, transparent: !0, side: 2 } }, { name: "afterEdit", param: { name: "afterEdit", color: 16432389, opacity: 1, transparent: !0, side: 2 } }], e = {}; e.selection = Kd.createHighlightMaterial(), e.selection.name = "selection"; for (var t = 0, i = A.length; i > t; t += 1) { var o = A[t], n = o.name; e[n] = Kd.createStandardMaterial(o.param), e[n].createByBos = !0 } e.red = e.delete, e.green = e.add, e.yellow = e.beforeEdit, e.blue = e.selection; var r = { color: 8947848, opacity: .2, transparent: !0, side: 2 }, a = Kd.createStandardMaterial(r); a.name = "isolate"; var s = { color: 8947848, opacity: .2, transparent: !0, side: 2 }, l = Kd.createStandardMaterial(s); l.name = "looming"; var c = { color: 0, opacity: 1, transparent: !1, wireframe: !0, side: 2 }, h = Kd.createStandardMaterial(c); h.name = "wireframe", e.wireframe = h; var d = { color: 15293, side: 2 }, p = Kd.createStandardMaterial(d); for (var g in p.name = "selected", this.getDefaultMaterialName = function () { return "lightBlue" }, this.get = function (A) { return e[A] }, this.getAll = function () { return e }, this.add = function (A) { var t, i = null, o = {}; return A && A.hasOwnProperty("color") && (o.color = A.color, o.side = 2, A.hasOwnProperty("opacity") && (o.opacity = A.opacity, o.transparent = 1 !== A.opacity)), t = this._getMaterialName(A), (i = e[t]) || (o.name = t, i = Kd.createStandardMaterial(o), e[t] = i, e[t].createByBos = !0), t }, this.remove = function (A) { var t; t = this._getMaterialName(A), e[t] && delete e[t] }, this.has = function (A) { return Boolean(e[A]) }, this.getMaterialNameByColor = function (A) { var t; return t = this._getMaterialName(A), e[t] ? t : this.add(A) }, this.getMaterialNameByWireframe = function (A) { var t; return (t = this._getMaterialName(A)) && !e[t] ? this.add(A) : t }, this.addOverrideMaterial = function (A) { if (A) { var t = A.name; e[t] || (e[t] = A) } }, this.updateOverrideMaterial = function (A) { A && (e[A.name] = A) }, this.getMaterialParamsFromName = function (A) { var e = {}, t = A.split("_"); return "mat" === t[0] ? (e.color = parseInt(t[1], 0), e.opacity = 1) : (e.color = parseInt(t[0], 0), e.opacity = parseFloat(t[1], 0)), e }, this._getMaterialName = function (A) { var e = null; return A && A.hasOwnProperty("color") ? e = A.hasOwnProperty("opacity") ? A.color + "_" + A.opacity : "mat_" + A.color : A && A.hasOwnProperty("wireframe") ? A.wireframe && (e = "wireframe") : e = "mat_" + A, e }, this.setWireframeMaterial = function (A) { e.wireframe.color.setHex(void 0 !== A.color ? A.color : c.color), e.wireframe.opacity = void 0 !== A.opacity ? A.opacity : c.opacity, e.wireframe.transparent = void 0 !== A.transparent ? A.transparent : c.transparent, e.wireframe.side = void 0 !== A.side ? A.side : c.side, e.wireframe.needsUpdate = !0 }, this.getWireframeMaterial = function () { return e.wireframe }, this.setFrozonMaterial = function (A) { l.color.setHex(void 0 !== A.color ? A.color : s.color), l.opacity = void 0 !== A.opacity ? A.opacity : s.opacity, l.transparent = void 0 !== A.transparent ? A.transparent : s.transparent, l.side = void 0 !== A.side ? A.side : s.side, l.needsUpdate = !0 }, this.getFrozonMaterial = function () { return l }, this.setSelectedMaterial = function (A) { p.color.setHex(void 0 !== A.color ? A.color : d.color), p.opacity = void 0 !== A.opacity ? A.opacity : d.opacity, p.transparent = void 0 !== A.transparent ? A.transparent : d.transparent, p.side = void 0 !== A.side ? A.side : d.side, p.needsUpdate = !0 }, this.getSelectedMaterial = function () { return p }, this.setIsolateMaterial = function (A) { a.color.setHex(void 0 !== A.color ? A.color : r.color), a.opacity = void 0 !== A.opacity ? A.opacity : r.opacity, a.transparent = void 0 !== A.transparent ? A.transparent : r.transparent, a.side = void 0 !== A.side ? A.side : r.side, a.needsUpdate = !0 }, this.getIsolateMaterial = function () { return a }, this.resetIsolateMaterial = function () { a.color.setHex(r.color), a.opacity = r.opacity, a.transparent = r.transparent, a.side = r.side, a.needsUpdate = !0 }, e) e[g].createByBos = !0 }, lu = function (A, e) { tu.call(this, A, e) }; (lu.prototype = Object.create(tu.prototype)).constructor = lu, lu.prototype.match = function (A) { return null !== this.getMatchItem(A) }, lu.prototype.getMatchItem = function (A) { var e = this._items, t = A.userData, i = !1; if (t) for (var o = e.length, n = 0; o > n; n += 1) { var r = e[n], a = r.condition; for (var s in i = !0, a) if (a[s] !== t[s]) { i = !1; break } if (i) return r } return null }; var cu = function (A, e) { tu.call(this, A, e) }; (cu.prototype = Object.create(tu.prototype)).constructor = cu, cu.prototype.remove = function (A, e) { var t = this._items[A]; if (t && e && e.length > 0) { for (var i = 0, o = e.length; o > i; i += 1) { var n = e[i]; t.hasOwnProperty(n) && delete t[n] } uh.isEmptyObject(this._items) && this._enabled && (this._enabled = !1, this.enableStateChanged()) } }, cu.prototype.add = function (A, e, t) { var i = this._items, o = i[A]; if (e && e.length > 0) { void 0 === t && (t = !0), o || (o = i[A] = {}); for (var n = 0, r = e.length; r > n; n += 1) o[e[n]] = t; this._enabled || (this._enabled = !0, this.enableStateChanged()) } }, cu.prototype.clear = function (A) { var e = this._items; e.hasOwnProperty(A) && (delete e[A], uh.isEmptyObject(e) && this._enabled && (this._enabled = !1, this.enableStateChanged())) }; var hu = function (A, e) { tu.call(this, A, e) }; (hu.prototype = Object.create(cu.prototype)).constructor = hu, hu.prototype.match = function (A) { return null !== this.getMatchItem(A) }, hu.prototype.getMatchItem = function (A) { var e = this._items, t = A.name; for (var i in e) { var o = e[i]; if (o[t]) return o[t] } return null }; var du = function (A, e) { tu.call(this, A, e) }; (du.prototype = Object.create(cu.prototype)).constructor = du, du.prototype.match = function (A) { return null !== this.getMatchItem(A) }, du.prototype.getMatchItem = function (A) { var e = this._items, t = A.userData; if (t) for (var i in e) { var o = e[i], n = t[i]; if (n && void 0 !== o[n]) return o[n] } return null }; var pu = function () { var A = Jc, e = { IDFILTER_OFFSET: 0, FILE_VISIBLE: 0, FILE_HIDDEN: 1, VISIBLE: 2, HIDDEN: 3, TRANSLUCENT: 4, TRANSLUCENT_OTHERS: 5, WIREFRAME: 24, COLORFUL: 25, RENDER_PROMOTION: 6, IDFILTER_ENDOFFSET: 6, ISOLATEFILTER_OFFSET: 7, ISOLATE_HIDDEN: 7, ISOLATE_HIDDEN_OTHERS: 8, ISOLATE_TRANSLUCENT: 9, ISOLATE_TRANSLUCENT_OTHERS: 10, ISOLATEFILTER_ENDOFFSET: 10, USERFILTER_OFFSET: 11, USER_HIDDEN: 11, USER_OVERRIDE: 12, USER_WITH_BOARDLINE: 13, USERFILTER_ENDOFFSET: 13, CONDITIONFILTER_OFFSET: 14, CONDITION_HIDDEN_OTHERS: 14, CONDITION_TRANSLUCENT_OTHERS: 15, CONDITION_OVERRIDE: 16, CONDITION_BORDERLINE: 26, CONDITIONFILTER_ENDOFFSET: 16, ISOLATECONDITIONFILTER_OFFSET: 17, ISOLATE_CONDITION_HIDDEN: 17, ISOLATE_CONDITION_HIDDEN_OTHERS: 18, ISOLATE_CONDITION_TRANSLUCENT: 19, ISOLATE_CONDITION_TRANSLUCENT_OTHERS: 20, ISOLATECONDITIONFILTER_ENDOFFSET: 20, FROZENFILTER: 21, FROZENCONDITIONFILTER: 22, OVERRIDEFILTER: 23, BASICFILTER_COUNT: 23 }, t = new _g(!0), i = new _g(!0), o = new _g(!1), n = new _g(!0), r = new _g(!1), a = new _g(!1), s = new _g(!1), l = [], c = null, h = null, d = Vc.DISABLED, p = new su; ! function () { l[e.FILE_VISIBLE] = new nu(e.FILE_VISIBLE, "FILE_VISIBLE"), l[e.FILE_HIDDEN] = new nu(e.FILE_HIDDEN, "FILE_HIDDEN"), l[e.VISIBLE] = new ru(e.VISIBLE, "VISIBLE"), l[e.HIDDEN] = new ru(e.HIDDEN, "HIDDEN"), l[e.TRANSLUCENT] = new ru(e.TRANSLUCENT, "TRANSLUCENT"), l[e.TRANSLUCENT_OTHERS] = new ru(e.TRANSLUCENT_OTHERS, "TRANSLUCENT_OTHERS"), l[e.RENDER_PROMOTION] = new ru(e.RENDER_PROMOTION, "RENDER_PROMOTION"), l[e.WIREFRAME] = new ru(e.WIREFRAME, "WIREFRAME"), l[e.COLORFUL] = new ru(e.COLORFUL, "COLORFUL"), l[e.ISOLATE_HIDDEN] = new ru(e.ISOLATE_HIDDEN, "ISOLATE_HIDDEN"), l[e.ISOLATE_HIDDEN_OTHERS] = new ru(e.ISOLATE_HIDDEN_OTHERS, "ISOLATE_HIDDEN_OTHERS"), l[e.ISOLATE_TRANSLUCENT] = new ru(e.ISOLATE_TRANSLUCENT, "ISOLATE_TRANSLUCENT"), l[e.ISOLATE_TRANSLUCENT_OTHERS] = new ru(e.ISOLATE_TRANSLUCENT_OTHERS, "ISOLATE_TRANSLUCENT_OTHERS"), l[e.USER_HIDDEN] = new du(e.USER_HIDDEN, "USER_HIDDEN"), l[e.USER_OVERRIDE] = new du(e.USER_OVERRIDE, "USER_OVERRIDE"), l[e.CONDITION_BORDERLINE] = new iu(e.CONDITION_BORDERLINE, "CONDITION_BORDERLINE"), l[e.CONDITION_HIDDEN_OTHERS] = new iu(e.CONDITION_HIDDEN_OTHERS, "CONDITION_HIDDEN_OTHERS"), l[e.CONDITION_TRANSLUCENT_OTHERS] = new iu(e.CONDITION_TRANSLUCENT_OTHERS, "CONDITION_TRANSLUCENT_OTHERS"), l[e.CONDITION_OVERRIDE] = new lu(e.CONDITION_OVERRIDE, "CONDITION_OVERRIDE"), l[e.ISOLATE_CONDITION_HIDDEN] = new iu(e.ISOLATE_CONDITION_HIDDEN, "ISOLATE_CONDITION_HIDDEN"), l[e.ISOLATE_CONDITION_HIDDEN_OTHERS] = new iu(e.ISOLATE_CONDITION_HIDDEN_OTHERS, "ISOLATE_CONDITION_HIDDEN_OTHERS"), l[e.ISOLATE_CONDITION_TRANSLUCENT] = new iu(e.ISOLATE_CONDITION_TRANSLUCENT, "ISOLATE_CONDITION_TRANSLUCENT"), l[e.ISOLATE_CONDITION_TRANSLUCENT_OTHERS] = new iu(e.ISOLATE_CONDITION_TRANSLUCENT_OTHERS, "ISOLATE_CONDITION_TRANSLUCENT_OTHERS"), h = new ru(e.FROZENFILTER, "FROZENFILTER"), l[e.FROZENCONDITIONFILTER] = new iu(e.FROZENCONDITIONFILTER, "FROZENCONDITIONFILTER"), l[e.FROZENFILTER] = h, c = new hu(e.OVERRIDEFILTER, "OVERRIDEFILTER"), l[e.OVERRIDEFILTER] = c; var d = null, p = {}; for (d in p[e.HIDDEN] = A.MATCH_RETURN_FALSE, p[e.VISIBLE] = A.NOMATCH_RETURN_FALSE, p[e.USER_HIDDEN] = A.MATCH_RETURN_FALSE, p[e.CONDITION_HIDDEN_OTHERS] = A.NOMATCH_RETURN_FALSE, p[e.ISOLATE_HIDDEN] = A.MATCH_RETURN_FALSE, p[e.ISOLATE_HIDDEN_OTHERS] = A.NOMATCH_RETURN_FALSE, p[e.ISOLATE_CONDITION_HIDDEN_OTHERS] = A.NOMATCH_RETURN_FALSE, t.setFilterMode(p), p) l[d].registerToCompoundFilter(t); var g = {}; for (d in g[e.FROZENFILTER] = A.MATCH_RETURN_FALSE, g[e.FROZENCONDITIONFILTER] = A.MATCH_RETURN_FALSE, g[e.TRANSLUCENT] = A.MATCH_RETURN_FALSE, g[e.TRANSLUCENT_OTHERS] = A.NOMATCH_RETURN_FALSE, g[e.CONDITION_TRANSLUCENT_OTHERS] = A.NOMATCH_RETURN_FALSE, g[e.ISOLATE_TRANSLUCENT] = A.MATCH_RETURN_FALSE, g[e.ISOLATE_TRANSLUCENT_OTHERS] = A.NOMATCH_RETURN_FALSE, g[e.ISOLATE_CONDITION_TRANSLUCENT_OTHERS] = A.NOMATCH_RETURN_FALSE, n.setFilterMode(g), g) l[d].registerToCompoundFilter(n); var u = {}; u[e.ISOLATE_TRANSLUCENT] = A.MATCH_RETURN_TRUE, u[e.ISOLATE_TRANSLUCENT_OTHERS] = A.NOMATCH_RETURN_TRUE, u[e.ISOLATE_CONDITION_TRANSLUCENT_OTHERS] = A.NOMATCH_RETURN_TRUE, u[e.CONDITION_TRANSLUCENT_OTHERS] = A.NOMATCH_RETURN_TRUE, u[e.TRANSLUCENT] = A.MATCH_RETURN_TRUE, u[e.TRANSLUCENT_OTHERS] = A.NOMATCH_RETURN_TRUE, u[e.OVERRIDEFILTER] = A.MATCH_RETURN_TRUE, u[e.USER_OVERRIDE] = A.MATCH_RETURN_TRUE, u[e.CONDITION_OVERRIDE] = A.MATCH_RETURN_TRUE, u[e.FROZENFILTER] = A.MATCH_RETURN_TRUE, u[e.FROZENCONDITIONFILTER] = A.MATCH_RETURN_TRUE; var f = {}; for (d in f[e.ISOLATE_TRANSLUCENT] = 5, f[e.ISOLATE_TRANSLUCENT_OTHERS] = 5, f[e.ISOLATE_CONDITION_TRANSLUCENT_OTHERS] = 5, f[e.CONDITION_TRANSLUCENT_OTHERS] = 5, f[e.TRANSLUCENT] = 5, f[e.TRANSLUCENT_OTHERS] = 5, f[e.OVERRIDEFILTER] = 0, f[e.USER_OVERRIDE] = 0, f[e.CONDITION_OVERRIDE] = 0, f[e.FROZENFILTER] = 3, f[e.FROZENCONDITIONFILTER] = 3, i.setFilterMode(u), i.setFilterPriority(f), u) l[d].registerToCompoundFilter(i); var m = {}; for (d in m[e.OVERRIDEFILTER] = A.MATCH_RETURN_TRUE, m[e.USER_OVERRIDE] = A.MATCH_RETURN_TRUE, m[e.CONDITION_OVERRIDE] = A.MATCH_RETURN_TRUE, m[e.CONDITION_TRANSLUCENT_OTHERS] = A.MATCH_RETURN_TRUE, o.setFilterMode(m), m) l[d].registerToCompoundFilter(o); var C = {}; for (d in C[e.FILE_VISIBLE] = A.NOMATCH_RETURN_TRUE, C[e.FILE_HIDDEN] = A.MATCH_RETURN_TRUE, r.setFilterMode(C), C) l[d].registerToCompoundFilter(r); var y = {}; for (d in y[e.RENDER_PROMOTION] = A.MATCH_RETURN_TRUE, y[e.ISOLATE_CONDITION_TRANSLUCENT_OTHERS] = A.MATCH_RETURN_TRUE, a.setFilterMode(y), y) l[d].registerToCompoundFilter(a); var v = {}; for (d in v[e.CONDITION_BORDERLINE] = A.MATCH_RETURN_TRUE, s.setFilterMode(v), v) l[d].registerToCompoundFilter(s) }(), this.getMaterialSelector = function () { return p }, this.getBasicFilterList = function () { return l }, this.getFilterType = function () { return e }, this.saveState = function () { for (var A = {}, e = null, t = 0, i = l.length; i > t; t += 1) A[(e = l[t]).getName()] = e.getAll(); return A.sceneState = this.getSceneState(), A.version = "1.0", A }, this.loadState = function (A) { if (this.clearAll(), A.hasOwnProperty("version")) { if ("1.0" === A.version) { for (var t = {}, i = 0, o = l.length; o > i; i += 1) t[l[i].getName()] = i; for (var n in A) "sceneState" !== n && "version" !== n && (t.hasOwnProperty(n) ? l[t[n]].setByData(A[n]) : Bh.warn("Warning: Not supported filter '" + n + "'")) } } else for (var r in A) "sceneState" !== r && (2 > r ? l[r].setByData(A[r]) : r > 2 ? e.BASICFILTER_COUNT + 2 > r && l[r - 1].setByData(A[r]) : 2 !== r && "2" !== r || Bh.warn("Warning: Old version filter data! The selection state is out of the filter, can not restore it.")); this.setSceneState(A.sceneState) }, this.clear = function () { for (var A = 0, t = l.length; t > A; A += 1) { var i = l[A].getType(); i !== e.FROZENFILTER && i !== e.CONDITION_BORDERLINE && l[A].clearAll() } this.setSceneState(Vc.DISABLED) }, this.clearAll = function () { for (var A = 0, e = l.length; e > A; A += 1) l[A].clearAll(); this.setSceneState(Vc.DISABLED) }, this.clearIsolate = function () { this.clearAllIsolateList(), this.clearAllIsolateConditions() }, this.clearFrozenList = function () { h.clearAll() }, this.addToFrozenList = function (A) { h.add(A) }, this.removeFromFrozenList = function (A) { h.remove(A) }, this.setFrozenList = function (A) { this.clearFrozenList(), this.addToFrozenList(A) }, this.setFrozenConditions = function (A) { l[e.FROZENCONDITIONFILTER].setByData(A) }, this.getFrozenConditions = function () { return l[e.FROZENCONDITIONFILTER].getAll() }, this.clearFrozenConditions = function () { l[e.FROZENCONDITIONFILTER].clear() }, this.clearFrozen = function () { this.clearFrozenList(), this.clearFrozenConditions() }, this.clearAllIdList = function () { var A = null; for (A = e.IDFILTER_OFFSET; e.IDFILTER_ENDOFFSET >= A; A += 1) l[A].clearAll() }, this.clearIdList = function (A) { var t = e.IDFILTER_OFFSET + A; e.IDFILTER_OFFSET > t || t > e.IDFILTER_ENDOFFSET || l[t].clear() }, this.addToIdList = function (A, t) { var i = e.IDFILTER_OFFSET + A; e.IDFILTER_OFFSET > i || i > e.IDFILTER_ENDOFFSET || l[i].add(t) }, this.removeFromIdList = function (A, t) { var i = e.IDFILTER_OFFSET + A; e.IDFILTER_OFFSET > i || i > e.IDFILTER_ENDOFFSET || l[i].remove(t) }, this.setIdList = function (A, e) { this.clearIdList(A), this.addToIdList(A, e) }, this.clearAllOverrideList = function () { c.clearAll() }, this.clearOverrideList = function (A) { c.clear(A) }, this.addToOverrideList = function (A, e, t) { e && e.length > 0 && (p.has(t) || (t = p.getDefaultMaterialName()), c.add(A, e, t)) }, this.removeFromOverrideList = function (A, e) { c.remove(A, e) }, this.setOverrideList = function (A, e, t) { this.clearOverrideList(A), this.addToOverrideList(A, e, t) }, this.addToOverrideListByColor = function (A, e, t) { var i = p.add(t); c.add(A, e, i) }, this.setOverrideListByColor = function (A, e, t) { this.clearOverrideList(A), this.addToOverrideListByColor(A, e, t) }, this.clearAllUserList = function () { var A = null; for (A = e.USERFILTER_OFFSET; e.USERFILTER_ENDOFFSET >= A; A += 1) l[A].clearAll() }, this.clearUserListByType = function (A) { var t = e.USERFILTER_OFFSET + A; e.USERFILTER_OFFSET > t || t > e.USERFILTER_ENDOFFSET || l[t].clearAll() }, this.clearUserList = function (A, t) { var i = e.USERFILTER_OFFSET + A; e.USERFILTER_OFFSET > i || i > e.USERFILTER_ENDOFFSET || l[i].clear(t) }, this.addToUserList = function (A, t, i, o) { var n = e.USERFILTER_OFFSET + A; e.USERFILTER_OFFSET > n || n > e.USERFILTER_ENDOFFSET || l[n].add(t, i, o) }, this.removeFromUserList = function (A, t, i) { var o = e.USERFILTER_OFFSET + A; e.USERFILTER_OFFSET > o || o > e.USERFILTER_ENDOFFSET || l[o].remove(t, i) }, this.setUserList = function (A, e, t, i) { this.clearUserList(A, e), this.addToUserList(A, e, t, i) }, this.isIsolate = function () { var A = null; for (A = e.ISOLATEFILTER_OFFSET; e.ISOLATEFILTER_ENDOFFSET >= A; A += 1) if (!l[A].isEmpty()) return !0; return !1 }, this.isFiltering = function () { return !!this.isIsolate() || !(l[e.HIDDEN].isEmpty() && l[e.VISIBLE].isEmpty() && l[e.TRANSLUCENT].isEmpty() && l[e.TRANSLUCENT_OTHERS].isEmpty() && this.getSceneState() === Vc.DISABLED) }, this.setFrozonMaterial = function (A) { p.setFrozonMaterial(A) }, this.getFrozonMaterial = function () { return p.getFrozonMaterial() }, this.setSelectedMaterial = function (A) { p.setSelectedMaterial(A) }, this.getSelectedMaterial = function () { return p.getSelectedMaterial() }, this.setIsolateMaterial = function (A) { p.setIsolateMaterial(A) }, this.getIsolateMaterial = function () { return p.getIsolateMaterial() }, this.resetIsolateMaterial = function () { p.resetIsolateMaterial() }, this.clearAllIsolateList = function () { var A = null; for (A = e.ISOLATEFILTER_OFFSET; e.ISOLATEFILTER_ENDOFFSET >= A; A += 1) l[A].clear() }, this.clearIsolateList = function (A) { var t = e.ISOLATEFILTER_OFFSET + A; e.ISOLATEFILTER_OFFSET > t || t > e.ISOLATEFILTER_ENDOFFSET || l[t].clear() }, this.addToIsolateList = function (A, t) { var i = e.ISOLATEFILTER_OFFSET + A; e.ISOLATEFILTER_OFFSET > i || i > e.ISOLATEFILTER_ENDOFFSET || l[i].add(t) }, this.removeFromIsolateList = function (A, t) { var i = e.ISOLATEFILTER_OFFSET + A; e.ISOLATEFILTER_OFFSET > i || i > e.ISOLATEFILTER_ENDOFFSET || l[i].remove(t) }, this.setIsolateList = function (A, e) { this.clearIsolateList(A), this.addToIsolateList(A, e) }, this.setIsolateConditions = function (A, t) { var i = e.ISOLATECONDITIONFILTER_OFFSET + t; e.ISOLATECONDITIONFILTER_OFFSET > i || i > e.ISOLATECONDITIONFILTER_ENDOFFSET || l[i].setByData(A) }, this.getIsolateConditions = function (A) { var t = null, i = e.ISOLATECONDITIONFILTER_OFFSET + A; return e.ISOLATECONDITIONFILTER_OFFSET > i || i > e.ISOLATECONDITIONFILTER_ENDOFFSET || (t = l[i].getAll()), t }, this.clearIsolateConditions = function (A) { var t = e.ISOLATECONDITIONFILTER_OFFSET + A; e.ISOLATECONDITIONFILTER_OFFSET > t || t > e.ISOLATECONDITIONFILTER_ENDOFFSET || l[t].clear() }, this.clearAllIsolateConditions = function () { var A = null; for (A = e.ISOLATECONDITIONFILTER_OFFSET; e.ISOLATECONDITIONFILTER_ENDOFFSET >= A; A += 1) l[A].clearAll() }, this.setConditions = function (A, t) { var i = e.CONDITIONFILTER_OFFSET + A; e.CONDITIONFILTER_OFFSET > i || i > e.CONDITIONFILTER_ENDOFFSET || l[i].setByData(t) }, this.getConditions = function (A) { var t = null, i = e.CONDITIONFILTER_OFFSET + A; return e.CONDITIONFILTER_OFFSET > i || i > e.CONDITIONFILTER_ENDOFFSET || (t = l[i].get()), t }, this.clearConditions = function (A) { var t = e.CONDITIONFILTER_OFFSET + A; e.CONDITIONFILTER_OFFSET > t || t > e.CONDITIONFILTER_ENDOFFSET || l[t].clearAll() }, this.clearAllConditions = function () { var A = null; for (A = e.CONDITIONFILTER_OFFSET; e.CONDITIONFILTER_ENDOFFSET >= A; A += 1) l[A].clear() }, this.makeSceneTranslucent = function () { this.setSceneState(Vc.TRANSLUCENT) }, this.cancelSceneTranslucent = function () { this.setSceneState(Vc.DISABLED) }, this.hideScene = function () { this.setSceneState(Vc.HIDDEN) }, this.showScene = function () { this.setSceneState(Vc.DISABLED) }, this.setSceneState = function (A) { d = A }, this.getSceneState = function () { return d }, this.cancelTranslucent = function () { this.clearIdList(Dc.TRANSLUCENT), this.clearIdList(Dc.TRANSLUCENT_OTHERS) }, this._addIdsToFilter = function (A, t) { var i = e.IDFILTER_OFFSET + A; e.IDFILTER_OFFSET > i || i > e.IDFILTER_ENDOFFSET || l[i].add(t) }, this.hideByIds = function (A) { this._addIdsToFilter(Dc.HIDDEN, A) }, this.showByIds = function (A) { this._addIdsToFilter(Dc.VISIBLE, A) }, this.makeTranslucentByIds = function (A) { this._addIdsToFilter(Dc.TRANSLUCENT, A) }, this.makeTranslucentOthersByIds = function (A) { this._addIdsToFilter(Dc.TRANSLUCENT_OTHERS, A) }, this._isVisible = function (A) { return this.getSceneState() !== Vc.HIDDEN && t.apply(A) }, this._isSelectable = function (A) { return this.getSceneState() !== Vc.TRANSLUCENT && n.apply(A, this.getSceneState()) }, this._isSelectableById = function (A) { return !h.get()[A] }, this.getMaterialNameByColor = function (A) { return p.getMaterialNameByColor(A) }, this.getMaterialNameByWireframe = function (A) { return p.getMaterialNameByWireframe(A) }, this.addOverrideMaterial = function (A) { p.addOverrideMaterial(A) }, this.updateOverrideMaterial = function (A) { p.updateOverrideMaterial(A) }, this.getMaterialByName = function (A) { return p.get(A) }, this._getOverrideMaterial = function (A) { if (this.getSceneState() === Vc.TRANSLUCENT) return p.get("scene"); var t = i.getApplyFilterId(A), o = null, n = ""; switch (t) { case e.ISOLATE_TRANSLUCENT: case e.ISOLATE_TRANSLUCENT_OTHERS: case e.ISOLATE_CONDITION_TRANSLUCENT_OTHERS: o = this.getIsolateMaterial(); break; case e.CONDITION_TRANSLUCENT_OTHERS: case e.TRANSLUCENT: case e.TRANSLUCENT_OTHERS: o = p.get("scene"); break; case e.FROZENFILTER: case e.FROZENCONDITIONFILTER: break; case e.OVERRIDEFILTER: case e.USER_OVERRIDE: case e.CONDITION_OVERRIDE: var r = l[t].getMatchItem(A); n = r.hasOwnProperty("color") ? p.getMaterialNameByColor(r.color) : r.material ? r.material : r } return o || "" === n || (p.has(n) || (n = p.getDefaultMaterialName()), o = p.get(n)), o }, this._getMaterialName = function (A) { if (this.getSceneState() === Vc.TRANSLUCENT) return "scene"; var t = i.getApplyFilterId(A), o = ""; switch (t) { case e.ISOLATE_TRANSLUCENT: case e.ISOLATE_TRANSLUCENT_OTHERS: case e.ISOLATE_CONDITION_TRANSLUCENT_OTHERS: o = this.getIsolateMaterial().name; break; case e.CONDITION_TRANSLUCENT_OTHERS: case e.TRANSLUCENT: case e.TRANSLUCENT_OTHERS: o = "scene"; break; case e.FROZENFILTER: case e.FROZENCONDITIONFILTER: break; case e.OVERRIDEFILTER: case e.USER_OVERRIDE: case e.CONDITION_OVERRIDE: var n = l[t].getMatchItem(A); o = n.hasOwnProperty("color") ? p.getMaterialNameByColor(n.color) : n.material ? n.material : n } return o }, this._getMaterialByName = function (A) { return A instanceof qA ? A : "isolate" === A ? p.getIsolateMaterial() : "looming" === A || "scene" === A ? p.getFrozonMaterial() : "selected" === A ? p.getSelectedMaterial() : p.get(A) }, this._hasHighPriorityOverrideMaterial = function (A) { return this.getSceneState() === Vc.TRANSLUCENT || o.apply(A) }, this._hasOverrideMaterial = function (A) { return this.getSceneState() === Vc.TRANSLUCENT || o.apply(A) || i.apply(A) }, this._isHiddenFileId = function (A) { return r.apply(A) }, this._hasHiddenFileIdFilter = function () { return !r.isEmpty() }, this._hasVisibleFilter = function () { return this.getSceneState() === Vc.HIDDEN || !t.isEmpty() }, this._hasPickableFilter = function () { return this.getSceneState() === Vc.TRANSLUCENT || !n.isEmpty() }, this._hasOverrideMaterialFilter = function () { return this.getSceneState() === Vc.TRANSLUCENT || !i.isEmpty() }, this._hasLowPriorityOverride = function () { return i.hasFilterNotIn(o) }, this._isRenderPromotion = function (A) { return a.apply(A) }, this._hasRenderPromotionFilter = function () { return !a.isEmpty() }, this._isRenderWithBoardline = function (A) { return s.apply(A) }, this._hasRenderWithBoardlineFilter = function () { return !s.isEmpty() }, this._getFilterObjectsKeys = function (A) { var e = l[A].get(), t = []; for (var i in e) t.push(i); return t } }, gu = function (A) { this.materialSelector = A; var e = function (A) { var e = []; for (var t in A) !0 === A[t] && e.push(t); return e }; this.saveState = function (A) { var e = A.getIsolateFilterAction(), t = A.getModelIsolateFilterAction(), i = A.getFilterActionList(), o = { isolateAction: e, modelIsolateAction: t, modelActions: A.getModelFilterActionList(), actions: i, sceneState: A.getSceneState(), version: "1.0" }; return JSON.stringify(o) }, this.createAction = function (A) { var e = A.className, t = null; switch (e) { case "IsolateIdsFA": (t = new Hg(A.isolateHide)).ids = A.ids; break; case "VisibleIdsFA": (t = new Pg(A.flag, A.isVisible)).ids = A.ids; break; case "OverrideIdsFA": if (o = A.material) { var i = this.materialSelector.getMaterialNameByColor({ opacity: A.material.opacity, color: A.material.color }); o = this.materialSelector.get(i) } (t = new qg(A.flag, o)).ids = A.ids; break; case "TransparentIdsFA": (t = new Yg(A.flag, A.isOpaque)).ids = A.ids; break; case "VisibleConditionFA": (t = new Jg(A.flag, A.isVisible)).conditions = A.conditions; break; case "OverrideConditionFA": var o; if (o = A.material) { i = this.materialSelector.getMaterialNameByColor({ opacity: o.opacity, color: o.color }); o = this.materialSelector.get(i) } (t = new zg(A.flag, o)).conditions = A.conditions; break; case "TransparentConditionFA": (t = new Zg(A.flag, A.isOpaque)).conditions = A.conditions; break; case "IsolateConditionFA": (t = new Xg(A.isolateHide)).conditions = A.conditions; break; default: Bh.warn("Warning: Not supported filterAction '" + e + "'") } return t }, this.createActionByOldFilter = function (A, t) { var i = []; switch (A) { case "CONDITION_OVERRIDE": for (var o = [], n = 0; t.length > n; n += 1) { var r = t[n]; o.push(r.condition) } var a = this.materialSelector.add(p = r.color), s = this.materialSelector.get(a); (g = new zg(!0, s)).conditions = o, i.push(g); break; case "CONDITION_TRANSLUCENT_OTHERS": (g = new Zg(!1, !1)).conditions = t, i.push(g); break; case "ISOLATE_CONDITION_HIDEEN_OTHERS": (g = new Xg(!0)).conditions = t, i.push(g); break; case "ISOLATE_CONDITION_TRANSLUCENT_OTHERS": (g = new Xg(!1)).conditions = t, i.push(g); break; case "ISOLATE_HIDDEN_OTHERS": (g = new Hg(!0)).ids = e(t), i.push(g); break; case "ISOLATE_TRANSLUCENT_OTHERS": (g = new Hg(!1)).ids = e(t), i.push(g); break; case "OVERRIDEFILTER": for (var l in t) if (t.hasOwnProperty(l)) { var c = [], h = t[l]; for (var d in h) c.push(d); var p = this.materialSelector.getMaterialParamsFromName(h[d]); a = this.materialSelector.add(p), s = this.materialSelector.get(a); (g = new qg(!0, s)).ids = c, i.push(g) } break; case "TRANSLUCENT": (g = new Yg(!0, !1)).ids = e(t), i.push(g); break; case "TRANSLUCTANT_OTHERS": (g = new Yg(!1, !1)).ids = e(t), i.push(g); break; case "VISIBLE": var g; (g = new Pg(!0, !0)).ids = e(t), i.push(g); break; default: Bh.warn("Warning: Not supported filter '" + A + "'") } return i }, this.loadState = function (A, e) { e.clearFilterActionList(), e.clearModelFilterActionList(), e.getObjectInfoManager().resetAll(), e.getModelInfoManager().resetAll(); var t = JSON.parse(A); if (t.hasOwnProperty("version") && "1.0" === t.version) { var i = t.isolateAction; if (i) { var o = this.createAction(i); e.pushBack(o) } for (var n = t.actions, r = 0; n.length > r; r += 1) { o = this.createAction(n[r]); e.pushBack(o) } var a = t.modelIsolateAction; if (a) { o = this.createAction(a); e.pushModelBack(o) } for (var s = t.modelActions, l = 0; s.length > l; l += 1) { o = this.createAction(s[l]); e.pushModelBack(o) } } e.setSceneState(t.sceneState) } }, uu = function () { var A = {}, e = [], t = !1, i = !1, o = !1, n = !1, r = !1, a = new aA; this.init = function (A) {}, this.clearData = function () {}, this.getObjectsMap = function () {}, this.add = function (t) { A[t] = { state: Lc.Visible, modelKey: t, material: null }, e = Object.keys(A) }, this.remove = function (t) { delete A[t], e = Object.keys(A) }, this.calculateVisibleComponentsBbox = function () {}, this.getVisibleComponentsBbox = function () { return a.isEmpty() && this.calculateVisibleComponentsBbox(), a }, this.arrayToMap = function (A) { for (var e = {}, t = 0; A.length > t; t += 1) { var i = A[t]; e[i] = i } return e }, this.isMatchConditions = function (A, e) { for (var t = !0, i = 0, o = e.length; o > i; i += 1) { var n = e[i]; for (var r in n) { if (!Array.isArray(n[r]) && A[r] !== n[r]) { t = !1; break } if (Array.isArray(n[r]) && -1 === n[r].indexOf(A[r])) { t = !1; break } } if (!0 === t) break; e.length - 1 > i && (t = !0) } return t }, this.matchConditions = function (A, e) {}, this.setVisible = function (t, o, n) { var r = function (A) { o ? A.state = Lc.Visible : (i = !0, A.state &= ~Lc.Visible) }; if (void 0 === n || !0 === n) for (var a = 0, s = t.length; s > a; a += 1) A.hasOwnProperty(t[a]) && r(A[t[a]]); else for (var l = this.arrayToMap(t), c = 0, h = e.length; h > c; c += 1) l.hasOwnProperty(e[c]) || r(A[e[c]]) }, this.isVisible = function (e) { if (A.hasOwnProperty(e)) return A[e].state & Lc.Visible > 0 }, this.clearVisible = function () { for (var e in i = !1, A) { if (A.hasOwnProperty(e)) A[e].state = Lc.Visible } }, this.hideAll = function () { for (var e in i = !0, A) { if (A.hasOwnProperty(e)) A[e].state &= ~Lc.Visible } }, this.setTransparent = function (i, o, r) { var a = function (A) { o ? (A.state |= Lc.Transparent, t = !0, n = !0) : A.state &= ~Lc.Transparent }; if (void 0 === r || !0 === r) for (var s = 0, l = i.length; l > s; s += 1) A.hasOwnProperty(i[s]) && a(A[i[s]]); else for (var c = this.arrayToMap(i), h = 0, d = e.length; d > h; h += 1) c.hasOwnProperty(e[h]) || a(A[e[h]]) }, this.isTransparent = function (e) { if (A.hasOwnProperty(e)) { var t = A[e], i = (t.state & Lc.Transparent) > 0; return i = i || (t.state & Lc.TransparentByIsolate) > 0 } }, this.clearTransparent = function () { for (var e in n = !1, A) { if (A.hasOwnProperty(e)) A[e].state &= ~Lc.Transparent } }, this.setMaterial = function (i, o, n) { if (void 0 === n || !0 === n) for (var r = 0, a = i.length; a > r; r += 1) { if (A.hasOwnProperty(i[r])) A[i[r]].material = o, t = !0 } else for (var s = this.arrayToMap(i), l = 0, c = e.length; c > l; l += 1) { if (!s.hasOwnProperty(e[l])) A[e[l]].material = o, t = !0 } }, this.getMaterial = function (e) { if (A.hasOwnProperty(e)) return A[e].material }, this.clearMaterial = function () { for (var e in A) { A[e].material = null } }, this.setIsolateHide = function (t, i, n) { var r = function (A) { i ? (o = !0, A.state |= Lc.HideByIsolate) : A.state &= ~Lc.HideByIsolate }; if (void 0 === n || !0 === n) for (var a = 0, s = t.length; s > a; a += 1) A.hasOwnProperty(t[a]) && r(A[t[a]]); else for (var l = this.arrayToMap(t), c = 0, h = e.length; h > c; c += 1) l.hasOwnProperty(e[c]) || r(A[e[c]]) }, this.isIsolateHide = function (e) { if (A.hasOwnProperty(e)) return (A[e].state & Lc.HideByIsolate) > 0 }, this.setIsolateTransparent = function (i, o, n) { var a = function (A) { o ? (A.state |= Lc.TransparentByIsolate, t = !0, r = !0) : A.state &= ~Lc.TransparentByIsolate }; if (void 0 === n || !0 === n) for (var s = 0, l = i.length; l > s; s += 1) A.hasOwnProperty(i[s]) && a(A[i[s]]); else for (var c = this.arrayToMap(i), h = 0, d = e.length; d > h; h += 1) c.hasOwnProperty(e[h]) || a(A[e[h]]) }, this.isIsolateTransparent = function (e) { if (A.hasOwnProperty(e)) return (A[e].state & Lc.TransparentByIsolate) > 0 }, this.clearIsolateHide = function () { o = !1; var e = Object.keys(A); e.length > 0 && this.setIsolateHide(e, !1) }, this.clearIsolates = function () { r = !1, o = !1; var e = Object.keys(A); e.length > 0 && (this.setIsolateHide(e, !1), this.setIsolateTransparent(e, !1)) }, this.clearTransparentByIsolate = function () { for (var e in r = !1, A) { if (A.hasOwnProperty(e)) A[e].state &= ~Lc.TransparentByIsolate } }, this.isHidden = function (e) { if (A.hasOwnProperty(e)) { var t = A[e], i = 0 == (t.state & Lc.Visible); return i = i || (t.state & Lc.HideByIsolate) > 0 } }, this.isFrozen = function (e) { if (A.hasOwnProperty(e)) { var t = A[e], i = (t.state & Lc.Transparent) > 0; return i = i || (t.state & Lc.TransparentByIsolate) > 0 } }, this.resetAll = function () { for (var e in A) A.hasOwnProperty(e) && (A[e].state = Lc.Visible, A[e].material = null); t = !1, i = o = !1, n = r = !1 }, this.hasOverrideMaterial = function (e) { return void 0 === e ? t : A.hasOwnProperty(e) ? null !== A[e].material || this.isTransparent(e) : void 0 }, this.hasObjectHidden = function () { return i || o }, this.hasObjectCantSelected = function () { return i || n || r }, this.hasObjectTransparent = function () { return n || r } }, fu = function () { var A = {}, e = {}; this.init = function (t) { for (var i in A = t) e.hasOwnProperty(i) && !uh.isEmptyObject(e[i]) || uh.isEmptyObject(A[i]) || (e[i] = Object.keys(A[i])) }, this.reinit = function (t) { for (var i in e = {}, A = t) e[i] = Object.keys(t[i]) }, this.clear = function () { A = {}, e = {} }, this.getObjectsMap = function () { return A }, this.getObjectIds = function (A) { return e.hasOwnProperty(A) ? e[A] : [] } }, mu = function () { var A = new fu, e = !1, t = !1, i = !1, o = !1, n = !1, r = !1, a = new aA, s = !1; this.inactivatedIdMap = {}, this.inactivatedIds = [], this.bIsInactivateAll = !1, this.init = function (e) { A.init(e) }, this.reinit = function (e) { A.reinit(e) }, this.clearData = function () { A.clear() }, this.getObjectsMap = function () { return A.getObjectsMap() }, this.calculateVisibleComponentsBbox = function () { a.makeEmpty(); var e = A.getObjectsMap(); for (var t in e) for (var i = e[t], o = A.getObjectIds(t), n = null, r = 0, l = o.length; l > r; r += 1) { var c = o[r]; if (!this.isHidden(c)) { var h = i[c][0]; if (h.boundingBox) { !n && h.model && (n = h.model.getModelMatrix()); var d = h.boundingBox.clone(); n && d.applyMatrix4(n), d.isEmpty() || (a.expandByPoint(d.min), a.expandByPoint(d.max)) } } } s = !1 }, this.getVisibleComponentsBbox = function () { return (s || a.isEmpty()) && this.calculateVisibleComponentsBbox(), a }, this.needUpdateBoxAfterExplode = function () { s = !0 }, this.arrayToMap = function (A) { for (var e = {}, t = 0; A.length > t; t += 1) { var i = A[t]; e[i] = i } return e }, this.isMatchConditions = function (A, e) { for (var t = !0, i = 0, o = e.length; o > i; i += 1) { var n = e[i]; for (var r in n) { if (!Array.isArray(n[r]) && A[r] !== n[r]) { t = !1; break } if (Array.isArray(n[r]) && -1 === n[r].indexOf(A[r])) { t = !1; break } } if (!0 === t) break; e.length - 1 > i && (t = !0) } return t }, this.matchConditions = function (e, t) { var i = A.getObjectsMap(); for (var o in i) for (var n = [], r = [], a = i[o], s = A.getObjectIds(o), l = 0, c = s.length; c > l; l += 1) { var h = s[l], d = a[h][0].userData || {}; d.elementId = a[h][0].userId, this.isMatchConditions(d, e) ? n.push(h) : r.push(h) } t && t(n, !0), t && t(r, !1) }, this.getMatchIds = function (e) { var t = A.getObjectsMap(), i = []; for (var o in t) for (var n = t[o], r = A.getObjectIds(o), a = 0, s = r.length; s > a; a += 1) { var l = r[a], c = n[l][0].userData || {}; c.elementId = n[l][0].userId, !0 === this.isMatchConditions(c, e) && i.push(l) } return i }, this.setVisible = function (e, t, o) { var n = function (A) { t ? A.state = Lc.Visible : (i = !0, A.state &= ~Lc.Visible) }, r = A.getObjectsMap(); for (var a in r) { var s = r[a]; if (void 0 === o || !0 === o) for (var l = 0, c = e.length; c > l; l += 1) { if (s.hasOwnProperty(f = e[l]) && this.isActive(f)) { var h = s[f][0]; n(h) } } else { for (var d = this.arrayToMap(e), p = A.getObjectIds(a), g = 0, u = p.length; u > g; g += 1) { var f; !d.hasOwnProperty(f = p[g]) && this.isActive(f) && n(h = s[f][0]) } d = null } } }, this.isVisible = function (e) { var t = A.getObjectsMap(); for (var i in t) { var o = t[i]; if (o.hasOwnProperty(e)) return o[e][0].state & Lc.Visible > 0 } }, this.clearVisible = function () { var e = A.getObjectsMap(); for (var t in i = !1, this.inactivatedIds.length > 0 && (i = !0), e) for (var o = e[t], n = A.getObjectIds(t), r = 0, a = n.length; a > r; r += 1) { var s = n[r], l = o[s][0]; this.isActive(s) && (l.state = Lc.Visible) } }, this.hideAll = function () { var e = A.getObjectsMap(); for (var t in i = !0, e) for (var o = e[t], n = A.getObjectIds(t), r = 0, a = n.length; a > r; r += 1) { o[n[r]][0].state &= ~Lc.Visible } }, this.setTransparent = function (t, i, o) { var r = function (A) { i ? (A.state |= Lc.Transparent, e = !0, n = !0) : A.state &= ~Lc.Transparent }, a = A.getObjectsMap(); for (var s in a) { var l = a[s]; if (void 0 === o || !0 === o) for (var c = 0, h = t.length; h > c; c += 1) { if (this.isActive(m = t[c]) && l.hasOwnProperty(m)) { var d = l[m][0]; r(d) } } else { for (var p = this.arrayToMap(t), g = A.getObjectIds(s), u = 0, f = g.length; f > u; u += 1) { var m; this.isActive(m = g[u]) && !p.hasOwnProperty(m) && r(d = l[m][0]) } p = null } } }, this.isTransparent = function (e) { var t = A.getObjectsMap(); for (var i in t) { var o = t[i]; if (o.hasOwnProperty(e) && this.isActive(e)) { var n = o[e][0], r = (n.state & Lc.Transparent) > 0; return r = r || (n.state & Lc.TransparentByIsolate) > 0 } } }, this.clearTransparent = function () { var e = A.getObjectsMap(); for (var t in n = !1, e) for (var i = e[t], o = A.getObjectIds(t), r = 0, a = o.length; a > r; r += 1) { var s = o[r]; if (this.isActive(s)) i[s][0].state &= ~Lc.Transparent } }, this.setMaterial = function (t, i, o) { var n = A.getObjectsMap(); for (var r in n) { var a = n[r]; if (void 0 === o || !0 === o) for (var s = 0, l = t.length; l > s; s += 1) { if (this.isActive(u = t[s]) && a.hasOwnProperty(u)) { var c = a[u][0]; c.material = i, e = !0 } } else { for (var h = this.arrayToMap(t), d = A.getObjectIds(r), p = 0, g = d.length; g > p; p += 1) { var u; this.isActive(u = d[p]) && !h.hasOwnProperty(u) && ((c = a[u][0]).material = i, e = !0) } h = null } } }, this.getMaterial = function (e) { var t = A.getObjectsMap(); for (var i in t) { var o = t[i]; if (o.hasOwnProperty(e)) return o[e][0].material } }, this.clearMaterial = function () { var e = A.getObjectsMap(); for (var t in e) { var i = e[t]; for (var o in i) this.isActive(o) && (i[o][0].material = null) } }, this.setWireFrameMaterial = function (e, i, o) { var n = A.getObjectsMap(); for (var r in n) { var a = n[r]; if (void 0 === o || !0 === o) for (var s = 0, l = e.length; l > s; s += 1) { if (a.hasOwnProperty(u = e[s])) { var c = a[u][0]; c.wireFrameMaterial = i, t = !0 } } else { for (var h = this.arrayToMap(e), d = A.getObjectIds(r), p = 0, g = d.length; g > p; p += 1) { var u; h.hasOwnProperty(u = d[p]) || ((c = a[u][0]).wireFrameMaterial = i, t = !0) } h = null } } }, this.getWireFrameMaterial = function (e) { var t = A.getObjectsMap(); for (var i in t) { var o = t[i]; if (o.hasOwnProperty(e)) return o[e][0].wireFrameMaterial } }, this.clearWireFrameMaterial = function () { var e = A.getObjectsMap(); for (var t in e) { var i = e[t]; for (var o in i) i[o][0].wireFrameMaterial = null } }, this.clearMaterialByKey = function (e) { var t = A.getObjectsMap(); for (var i in t) { var o = t[i]; for (var n in o) - 1 !== e.indexOf(n) && (o[n][0].material = null) } }, this.setIsolateHide = function (e, t, i) { var n = function (A) { t ? (o = !0, A.state |= Lc.HideByIsolate) : A.state &= ~Lc.HideByIsolate }, r = A.getObjectsMap(); for (var a in r) { var s = r[a]; if (void 0 === i || !0 === i) for (var l = 0, c = e.length; c > l; l += 1) { if (this.isActive(f = e[l]) && s.hasOwnProperty(f)) { var h = s[f][0]; n(h) } } else { for (var d = this.arrayToMap(e), p = A.getObjectIds(a), g = 0, u = p.length; u > g; g += 1) { var f; this.isActive(f = p[g]) && !d.hasOwnProperty(f) && n(h = s[f][0]) } d = null } } }, this.isIsolateHide = function (e) { var t = A.getObjectsMap(); for (var i in t) { var o = t[i]; if (o.hasOwnProperty(e)) return (o[e][0].state & Lc.HideByIsolate) > 0 } }, this.setIsolateTransparent = function (t, i, o) { var n = function (A) { i ? (A.state |= Lc.TransparentByIsolate, e = !0, r = !0) : A.state &= ~Lc.TransparentByIsolate }, a = A.getObjectsMap(); for (var s in a) { var l = a[s]; if (void 0 === o || !0 === o) for (var c = 0, h = t.length; h > c; c += 1) { if (l.hasOwnProperty(m = t[c])) { var d = l[m][0]; n(d) } } else { for (var p = this.arrayToMap(t), g = A.getObjectIds(s), u = 0, f = g.length; f > u; u += 1) { var m; !p.hasOwnProperty(m = g[u]) && this.isActive(m) && n(d = l[m][0]) } p = null } } }, this.isIsolateTransparent = function (e) { var t = A.getObjectsMap(); for (var i in t) { var o = t[i]; if (o.hasOwnProperty(e) && this.isActive(e)) return (o[e][0].state & Lc.TransparentByIsolate) > 0 } }, this.clearIsolateHide = function () { var e = A.getObjectsMap(); for (var t in o = !1, e) { var i = A.getObjectIds(t); i.length > 0 && this.setIsolateHide(i, !1) } }, this.clearIsolates = function () { var e = A.getObjectsMap(); for (var t in r = !1, o = !1, e) { var i = A.getObjectIds(t); i.length > 0 && (this.setIsolateHide(i, !1), this.setIsolateTransparent(i, !1)) } }, this.clearTransparentByIsolate = function () { var e = A.getObjectsMap(); for (var t in r = !1, e) for (var i = e[t], o = A.getObjectIds(t), n = 0, a = o.length; a > n; n += 1) { var s = o[n]; if (this.isActive(s)) i[s][0].state &= ~Lc.TransparentByIsolate } }, this.isHidden = function (e) { var t = A.getObjectsMap(); for (var i in t) { var o = t[i]; if (o.hasOwnProperty(e)) { var n = o[e][0], r = 0 == (n.state & Lc.Visible); return r = r || (n.state & Lc.HideByIsolate) > 0 } } }, this.isFrozen = function (e) { var t = A.getObjectsMap(); for (var i in t) { var o = t[i]; if (o.hasOwnProperty(e)) { var n = o[e][0], r = (n.state & Lc.Transparent) > 0; return r = r || (n.state & Lc.TransparentByIsolate) > 0 } } }, this.resetAll = function () { var t = A.getObjectsMap(); for (var a in t) for (var s = t[a], l = A.getObjectIds(a), c = 0, h = l.length; h > c; c += 1) { var d = l[c]; s[d][0].state = Lc.Visible, this.isActive(d) && (s[d][0].material = null) } e = !1, i = o = !1, n = r = !1, this.inactivatedIds.length > 0 && (i = !0) }, this.hasOverrideMaterial = function (t) { var i = A.getObjectsMap(); if (void 0 === t) return e; for (var o in i) { var n = i[o]; if (n.hasOwnProperty(t)) return null !== n[t][0].material || this.isTransparent(t) } }, this.hasOverrideMaterialForWireFrame = function (e) { var i = A.getObjectsMap(); if (null == e) return t; for (var o in i) { var n = i[o]; if (n.hasOwnProperty(e)) return null !== n[e][0].wireFrameMaterial } }, this.hasObjectInactivated = function () { return this.inactivatedIds.length > 0 }, this.hasObjectHidden = function () { return i || o }, this.hasObjectCantSelected = function () { return this.hasObjectHidden() || this.hasObjectTransparent() || this.hasObjectInactivated() }, this.hasObjectTransparent = function () { if (this.hasObjectInactivated()) { var A = !1, e = !0, t = !1, i = void 0; try { for (var o, a = this.inactivatedIds[Symbol.iterator](); !(e = (o = a.next()).done); e = !0) { if (this.isTransparent(o.value)) { A = !0; break } } } catch (A) { t = !0, i = A } finally { try { !e && a.return && a.return() } finally { if (t) throw i } } return A } return n || r }, this.deactivateByIds = function (e) { var t = !0, o = !1, n = void 0, r = A.getObjectsMap(); try { for (var a, s = e[Symbol.iterator](); !(t = (a = s.next()).done); t = !0) { var l = a.value; for (var c in r) { var h = r[c]; if (h.hasOwnProperty(l)) h[l][0].state &= ~Lc.Visible } this.inactivatedIdMap[l] = !0 } } catch (A) { o = !0, n = A } finally { try { !t && s.return && s.return() } finally { if (o) throw n } } i = !0, this.inactivatedIds = Object.keys(this.inactivatedIdMap) }, this.activateByIds = function (e) { for (var t = A.getObjectsMap(), o = 0, n = e.length; n > o; o += 1) { var r = e[o]; for (var a in delete this.inactivatedIdMap[r], t) { var s = t[a]; if (s.hasOwnProperty(r)) s[r][0].state = Lc.Visible } } this.inactivatedIds = Object.keys(this.inactivatedIdMap), this.inactivatedIds.length > 0 && (i = !0) }, this.clearInactivatedIdMap = function () { this.inactivatedIdMap = {}, this.inactivatedIds = [] }, this.isActive = function (A) { return !1 === this.bIsInactivateAll && !(!0 === this.inactivatedIdMap[A]) }, this.deactivateAll = function () { this.bIsInactivateAll = !0 }, this.activateAll = function () { this.bIsInactivateAll = !1 }, this.getInactivatedIdMap = function () { return this.inactivatedIdMap } }, Cu = function (A, e) { Wg.call(this), this.className = "OverrideConditionForWireFrameFA", this.flag = A, this.material = e }; (Cu.prototype = Object.create(Wg.prototype)).constructor = Cu, Cu.prototype.applyFilter = function (A, e) { console.log('applyFilter :>ddfdff> '); var t = this; this.conditions instanceof Array ? A.matchConditions(this.conditions, (function (e, i) { t.flag === i && (A.setWireFrameMaterial(e, t.material), e = null) })) : Bh.warn("Conditions should be type of array.") }; var yu = function (A, e) { Gg.call(this), this.className = "OverrideIdsForWireFrameFA", this.flag = A, this.material = e }; (yu.prototype = Object.create(Gg.prototype)).constructor = yu, yu.prototype.applyFilter = function (A) { console.log('applyFilter :dfasfsa>> '); this.ids instanceof Array ? A.setWireFrameMaterial(this.ids, this.material, this.flag) : Bh.warn("Ids should be type of array.") }; var vu = function () { function A(e, t) { cc(this, A), this.id = e, this.object = t } return dc(A, [{ key: "destroy", value: function () { this.object = null } }, { key: "_inDistanceRange", value: function (A, e) { return A >= e.near && e.far >= A } }, { key: "raycast", value: function (A, e, t, i, o) {} }]), A }(); vu.prototype.destroy = function () {}; var Iu = function (A) { function e(A, t) { return cc(this, e), Cc(this, fc(e).call(this, A, t)) } return uc(e, A), dc(e, [{ key: "raycast", value: function (A, e, t, i, o, n) { var r = []; if (this.object.raycast(A, r), r.length > 0) { r.sort((function (A, e) { return A.distance - e.distance })); for (var a = 0, s = r.length; s > a; a += 1) { var l = r[a]; if (this._inDistanceRange(l.distance, t) && !i.clipPoint(l.point)) { n || (t.far = l.distance - uh.MinusEpsilon), o.push(l); break } } } } }]), e }(vu), Eu = function (A) { function e(A, t) { return cc(this, e), Cc(this, fc(e).call(this, A, t)) } return uc(e, A), dc(e, [{ key: "raycast", value: function (A, e, t, i, o, n) { var r = this.object, a = r._indicesGroup; if (a) { var s = a[e.userId]; if (s) { for (var l, c = !1, h = 0, d = s.length; d > h; h += 1) if (s[h].nodeId === e.nodeId) { l = s[h], c = !0; break } if (c) { var p = []; if (r.raycastByIndices(A, p, l), p.length > 0) { p.sort((function (A, e) { return A.distance - e.distance })); for (var g = 0, u = p.length; u > g; g += 1) { var f = p[g]; if (this._inDistanceRange(f.distance, t) && !i.clipPoint(f.point)) { n || (t.far = f.distance - uh.MinusEpsilon), f.userId = l.userId, f.indexInfo = l, o.push(f); break } } } } } } } }]), e }(vu), Bu = function (A) { function e(A, t) { return cc(this, e), Cc(this, fc(e).call(this, A, t)) } return uc(e, A), dc(e, [{ key: "raycast", value: function (A, e, t, i, o, n) { var r = []; if (this.object.raycastByIndices(A, r, null, e.matrix), r.length > 0) { r.sort((function (A, e) { return A.distance - e.distance })); for (var a = 0, s = r.length; s > a; a += 1) { var l = r[a]; if (this._inDistanceRange(l.distance, t) && !i.clipPoint(l.point)) { n || (t.far = l.distance - uh.MinusEpsilon), l.userId = e.userId, l.matrix = e.matrix, o.push(l); break } } } } }]), e }(vu), xu = function () { this._filterImpl = new pu; var A = [], e = [], t = null, i = null, o = this._filterImpl.getMaterialSelector(), n = new mu, r = new uu, a = new gu(o); this.observerForSceneState = null, this.setObserverForSceneState = function (A) { this.observerForSceneState = A }, this.setSceneStateHelper = function (A) {}, this.getFilterActionList = function () { return A }, this.getModelFilterActionList = function () { return e }, this.addModel = function (A) { r.add(A) }, this.removeModel = function (A) { r.remove(A) }, this.clearFilterActionList = function () { A = [] }, this.clearModelFilterActionList = function () { e = [] }, this.initFilterManager = function (A) { n.init(A) }, this.reinitFilterManager = function (A) { n.reinit(A) }, this.clearFilterManager = function () { n.clearData() }; var s = !1; this.isStateChanged = function () { return s }, this.enableStateChanged = function () { s = !0 }, this.disableStateChanged = function () { s = !1 }, this.getIsolateFilterAction = function () { return t }, this.getModelIsolateFilterAction = function () { return i }, this.setIsolateAction = function (A) { (t = A).apply() }, this.getVisibleComponentsBbox = function () { return n.getVisibleComponentsBbox() }, this.pushBack = function (e) { var i = e.getClassName(); "IsolateIdsFA" === i || "IsolateConditionFA" === i ? t = e : A.push(e), s = !0, e.applyFilter(n) }, this.pushModelBack = function (A) { var t = A.getClassName(); "IsolateIdsFA" === t || "IsolateConditionFA" === t ? i = A : e.push(A), s = !0, A.applyFilter(r) }; var l = function (e) { for (var t = [], i = 0; A.length > i;) { var o = A[i]; e === o.getClassName() ? (t = t.concat(o.ids), A.splice(i, 1)) : i += 1 } return t }, c = function (A) { for (var t = 0; e.length > t;) { A === e[t].getClassName() ? e.splice(t, 1) : t += 1 } }; function h(A, e) { var t = e || ""; return A.map((function (A) { var e = A.clone(); for (var i in e.name += "_" + t, A) A.hasOwnProperty(i) && (A[i] instanceof d || A[i] instanceof ut) && (e[i] = A[i].clone(), e[i].needsUpdate = !0); return e })) } function p(A, e, t, i, o, n, r) { var a = Boolean(r || 0 === r), s = []; a && !Array.isArray(r) && (r = [r]); var l = !0, c = !1, h = void 0; try { for (var d, p = o[Symbol.iterator](); !(l = (d = p.next()).done); l = !0) { var g = d.value; A._filterImpl.getMaterialByName(g.name) || A._filterImpl.addOverrideMaterial(g) } } catch (A) { c = !0, h = A } finally { try { l || null == p.return || p.return() } finally { if (c) throw h } } var u = t[0], f = u.materialId; if (u.originMId === f && (u.originMId = [].concat(f)), null === u.material) for (var m = 0, C = f.length; C > m; m += 1) s[m] = e.models[u.model.modelKey].materialManager.getMaterialById(f[m]); else s = u.material; for (var y = null, v = null, I = 0, E = s.length; E > I; I += 1) { if (a) { if (!r[I]) break; y = r[I].compMatOrder, v = r[I].replMatOrder } else y = v = I; if (!o[v] || y >= o.length) { o[v] ? console.log('构件材质数组越界,越界位置:{"componentKey":'.concat(i, ',"order":').concat(y, "}")) : console.log('替换材质数组越界,越界位置:{"componentKey":'.concat(i, ',"order":').concat(v, "}")); break } s[y] = o[v], f[y] = o[v].name } var B = new qg(!0, s); B.ids = [u.componentKey], n[u.componentKey] = s, A.pushBack(B) } function g(A, e, t, i, o, n, r) { var a, s = []; (a = Boolean(r || 0 === r)) && !Array.isArray(r) && (r = [r]); var l = !0, c = !1, h = void 0; try { for (var d, p = o[Symbol.iterator](); !(l = (d = p.next()).done); l = !0) { A._filterImpl.updateOverrideMaterial(d.value) } } catch (A) { c = !0, h = A } finally { try { l || null == p.return || p.return() } finally { if (c) throw h } } for (var g = 0, u = t.length; u > g; g += 1) { var f = t[g], m = t[0].material; if (null === m) s[g] = e.models[f.model.modelKey].materialManager.getMaterialById(f.materialId), s[g].materialId = f.materialId; else if (Array.isArray(m)) { s[g] = m[g] } else s[g] = m } for (var C = null, y = null, v = 0, I = s.length; I > v; v += 1) { if (a) { if (!r[v]) break; C = r[v].compMatOrder, y = r[v].replMatOrder } else C = y = v; if (!o[y] || C >= t.length) { o[y] ? console.log('构件材质数组越界,越界位置:{"componentKey":'.concat(i, ',"order":').concat(C, "}")) : console.log('替换材质数组越界,越界位置:{"componentKey":'.concat(i, ',"order":').concat(y, "}")); break } var E = t[C].nodeId, B = s[C].mapNodeIdToOrigMatId && s[C].mapNodeIdToOrigMatId[E] ? s[C].mapNodeIdToOrigMatId[E] : s[C].materialId; t[C].mesh.geometry.getAttribute("uv") || null === o[y].map && null === o[y].aoMap ? (s[C] = o[y], s[C].mapNodeIdToOrigMatId || (s[C].mapNodeIdToOrigMatId = {}), s[C].materialId = o[y].name, s[C].mapNodeIdToOrigMatId[E] = B) : console.log('构件node缺少uv:{"componentKey":'.concat(i, ',"order":').concat(y, ",nodeId:").concat(t[C].nodeId, "}")) } var x = new qg(!0, s); x.ids = [i], n && (n[i] = s), A.pushBack(x) } function u(A, e, t) { var i = A.models[e], o = i._handler.defaultManager.meshManager, n = i._handler.instancedManager.meshManager, r = i.loader.getDescriptor(), a = n.getNodeIdxMapByUserId(t), s = i.group.children.find((function (A) { return "Geometry" === A.name })); s || ((s = new Xi).name = "Geometry", i.group.add(s)); var l = new Xi, c = []; s.add(l); var h = r.mapNodeInfoByComponentKey[t], d = function (r) { var s = a[r][0], d = n.getInstanceGeometries(r); d[0].attributes.vState.array[s] = -1, d[0].attributes.vState.needsUpdate = !0; var p = new he; d[0].removed || (d[0].removed = {}), d[0].removed[s] = !0; for (var g = d[0].attributes.position.array, u = [], f = new y, m = n.matrixInfoMapFromUserId[t][r][0].matrix, C = 0, v = g.length; v > C; C += 3) f.set(g[C], g[C + 1], g[C + 2]).applyMatrix4(m), u.push(f.x, f.y, f.z); d[0].attributes.uv && p.setAttribute("uv", d[0].attributes.uv.clone()), d[0].attributes.normal && p.setAttribute("normal", d[0].attributes.normal.clone()); var I = d[0].index.clone(); p.setAttribute("position", new YA(new Float32Array(u), 3)), p.setIndex(I); var E = n.getMaterialIdByMeshId(r), B = n.manager.model.materialManager.getInstanceMaterialById(E)[0], x = Kd.getMaterialParameters(B), S = Kd.createStandardMaterial(x), w = new Ue(p, S), M = r.split("&")[1], b = E + "_" + s + "_cm", U = "", F = !0, K = !1, Q = void 0; try { for (var R, T = h[Symbol.iterator](); !(F = (R = T.next()).done); F = !0) { var k = R.value; k.geometryId !== M && k.geometryId.toString() !== M || (U = k.nodeId, k.instanceOrNot = !1, k.isBatched = !1, k.mesh = w, k.instancedRenderOrder = s, k.RenderTypeChange = !0, k.materialId = b, k.uv = !0, c.push(k)) } } catch (A) { K = !0, Q = A } finally { try { F || null == T.return || T.return() } finally { if (K) throw Q } } var D = b + "&1&meshes"; l.add(w), w.geometry.computeBoundingBox(), w.modelKey = e; var L = pc({}, t, [{ boundingBox: w.geometry.boundingBox, indexCount: I.count, indexStart: 0, lightmapIdx: void 0, nodeId: U, positionCount: p.attributes.position.count, positionStart: 0, userId: t }]); o.mapMaterialIdToMergedNode[D] = [{ geometry: p, indices: L, mesh: w, RenderTypeChange: !0 }], w._indicesGroup = L, w.computeBoundingBox = function () { var A = this.matrixWorld, e = new aA; return e.copy(this.geometry.boundingBox), e.applyMatrix4(A), e }, w.intersectBoxWithDistanceByIndices = function (A) { return A.ray.intersectBoxWithDistance(this.computeBoundingBox()) }, w.raycastByIndices = function (A, e) { w.raycast(A, e) }, i.materialManager.materials[b] = S, A.addMeshToOctantMap(e, D, new Eu(D, w)) }; for (var p in a) d(p); return A.octantToObjectMap[e].info[t] = c, r.mapNodeInfoByCategory[1] || (r.mapNodeInfoByCategory[1] = {}), r.mapNodeInfoByCategory[1][t] = c, delete r.instancedComponent[t], delete r.mapNodeInfoByCategory[0][t], delete n.nodeIdxMapFromUserId[t], o.getPickingNodeGenerator().clearData(), l } this.showAll = function () { l("VisibleIdsFA"), l("VisibleConditionFA"), n.clearVisible(), n.calculateVisibleComponentsBbox(), this.enableStateChanged() }, this.showAllModel = function () { c("VisibleIdsFA"), r.clearVisible(), this.enableStateChanged() }, this.hideAll = function () { var A = new Pg(!1, !1); A.ids = [], this.pushBack(A) }, this.hideAllModel = function () { var A = new Pg(!1, !1); A.ids = [], this.pushModelBack(A) }, this.getObjectInfoManager = function () { return n }, this.getModelInfoManager = function () { return r }, this.getMatchIds = function (A) { return n.getMatchIds(A) }, this._isVisible = function (A) { return !n.isHidden(A.userId) }, this._isModelVisible = function (A) { return !r.isHidden(A) }, this._isTransparent = function (A) { return n.isTransparent(A.userId) }, this._isModelTransparent = function (A) { return r.isTransparent(A) }, this._isModelPickable = function (A) { return !r.isFrozen(A) || vc.EnableSelectionByTranslucent }, this._isSelectable = function (A) { if (vc.EnableSelectionByTranslucent) return !0; var e = A.userId; return !n.isFrozen(e) && this._filterImpl._isSelectableById(e) }, this._isPickable = function (A) { var e = A.userId; return this.isComponentActive(e) && this._filterImpl._isSelectableById(e) && (!n.isFrozen(e) || vc.EnableSelectionByTranslucent) }, this._isSelectableById = function (A) { return !!vc.EnableSelectionByTranslucent || !n.isFrozen(A) && this._filterImpl._isSelectableById(A) }, this._getOverrideMaterial = function (A) { var e = A.userId; return n.isFrozen(e) ? this._filterImpl.getFrozonMaterial() : n.getMaterial(e) }, this._getModelOverrideMaterial = function (A) { return r.isFrozen(A) ? this._filterImpl.getFrozonMaterial() : r.getMaterial(A) }, this._getMaterialName = function (A) { return this._filterImpl._getMaterialName(A) }, this._getMaterialByName = function (A) { return this._filterImpl._getMaterialByName(A) }, this._hasOverrideMaterial = function (A) { return n.hasOverrideMaterial(A.userId) }, this._hasModelOverrideMaterial = function (A) { return r.hasOverrideMaterial(A) }, this._hasHighPriorityOverrideMaterial = function (A) { return this._filterImpl._hasHighPriorityOverrideMaterial(A) }, this._isHiddenFileId = function (A) { return this._filterImpl._isHiddenFileId(A) }, this._isRenderPromotion = function (A) { return this._filterImpl._isRenderPromotion(A) }, this._isRenderWithBoardline = function (A) { return this._filterImpl._isRenderWithBoardline(A) }, this._hasHiddenFileIdFilter = function () { return this._filterImpl._hasHiddenFileIdFilter() }, this._hasVisibleFilter = function () { return n.hasObjectHidden() }, this._hasPickableFilter = function () { return n.hasObjectCantSelected() || this._filterImpl._hasPickableFilter() }, this._hasTransparentFilter = function () { return n.hasObjectTransparent() }, this._hasOverrideMaterialFilter = function () { return n.hasOverrideMaterial() }, this._hasModelVisibleFilter = function () { return r.hasObjectHidden() }, this._hasModelSelectableFilter = function () { return r.hasObjectCantSelected() }, this._hasModelTransparentFilter = function () { return r.hasObjectTransparent() }, this._hasModelOverrideMaterialFilter = function () { return r.hasOverrideMaterial() }, this._hasLowPriorityOverride = function () { return this._filterImpl._hasLowPriorityOverride() }, this._hasRenderPromotionFilter = function () { return this._filterImpl._hasRenderPromotionFilter() }, this._hasRenderWithBoardlineFilter = function () { return this._filterImpl._hasRenderWithBoardlineFilter() }, this.saveState = function () { return a.saveState(this) }, this.loadState = function (A) { a.loadState(A, this) }, this.clear = function () { n.resetAll(), s = !0 }, this.clearAll = function () { return this.enableStateChanged(), this._filterImpl.clearAll() }, this.clearIsolate = function () { n.clearIsolates() }, this.clearFrozenList = function () { return this.enableStateChanged(), this._filterImpl.clearFrozenList() }, this.addToFrozenList = function (A) { return this.enableStateChanged(), this._filterImpl.addToFrozenList(A) }, this.removeFromFrozenList = function (A) { return this.enableStateChanged(), this._filterImpl.removeFromFrozenList(A) }, this.setFrozenList = function (A) { return this.enableStateChanged(), this._filterImpl.setFrozenList(A) }, this.setFrozenConditions = function (A) { this.enableStateChanged(), this._filterImpl.setFrozenConditions(A) }, this.getFrozenConditions = function () { return this._filterImpl.getFrozenConditions() }, this.clearFrozenConditions = function () { this.enableStateChanged(), this._filterImpl.clearFrozenConditions() }, this.clearFrozen = function () { this.enableStateChanged(), this.clearFrozenList(), this.clearFrozenConditions() }, this.clearAllIdList = function () { return this.enableStateChanged(), this._filterImpl.clearAllIdList() }, this.clearIdList = function (A) { return this.enableStateChanged(), this._filterImpl.clearIdList(A) }, this.addToIdList = function (A, e) { return this.enableStateChanged(), this._filterImpl.addToIdList(A, e) }, this.removeFromIdList = function (A, e) { return this.enableStateChanged(), this._filterImpl.removeFromIdList(A, e) }, this.setIdList = function (A, e) { return this.enableStateChanged(), this._filterImpl.setIdList(A, e) }, this.clearAllOverrideList = function () { l("OverrideIdsFA"), l("OverrideConditionFA"), n.clearMaterial(); for (var e = 0, t = A.length; t > e; e += 1) { var i = A[e]; "WireframeIdsFA" === i.getClassName() && i.applyFilter(n) } this.enableStateChanged() }, this.clearModelAllOverrideList = function () { c("OverrideIdsFA"), r.clearMaterial(), this.enableStateChanged() }, this.clearOverrideList = function (A) { return this.enableStateChanged(), this._filterImpl.clearOverrideList(A) }, this.addToOverrideList = function (A, e, t) { return this.enableStateChanged(), this._filterImpl.addToOverrideList(A, e, t) }, this.removeFromOverrideList = function (A, e) { return this.enableStateChanged(), this._filterImpl.removeFromOverrideList(A, e) }, this.setOverrideList = function (A, e, t) { return this.enableStateChanged(), this._filterImpl.setOverrideList(A, e, t) }, this.addToOverrideListByColor = function (A, e) { var t = null; if (e) { var i = this._filterImpl.getMaterialNameByColor(e); t = this._filterImpl.getMaterialByName(i) } var o = new qg(!0, t); o.ids = A, this.pushBack(o) }, this.addToOverrideListByCustomerMaterial = function (A, e, t, i, o) { var n = this, r = {}; Array.isArray(t) || (t = [t]); var a = t; return e.forEach((function (e) { for (var s in e) i || (a = h(t, s)), e[s][0].isBatched || e[s][0].instanceOrNot || e[s][0].RenderTypeChange ? !e[s][0].instanceOrNot && e[s][0].isBatched || e[s][0].RenderTypeChange ? g(n, A, e[s], s, a, r, o) : e[s][0].instanceOrNot && e[s][0].isBatched && (u(A, e[s][0].model.modelKey, s), g(n, A, e[s], s, a, r, o)) : p(n, A, e[s], s, a, r, o) })), r }, this.addToModelOverrideListByColor = function (A, e) { var t = null; if (e) { var i = this._filterImpl.getMaterialNameByColor(e); t = this._filterImpl.getMaterialByName(i) } var o = new qg(!0, t); o.ids = A, this.pushModelBack(o) }, this.addToOverrideListByConditions = function (A, e) { var t = null; if (e) { var i = this._filterImpl.getMaterialNameByColor(e); t = this._filterImpl.getMaterialByName(i) } var o = new zg(!0, t); o.conditions = A, this.pushBack(o) }, this.addToOverrideListByConditions = function (A, e) { var t = null; if (e) { var i = this._filterImpl.getMaterialNameByColor(e); t = this._filterImpl.getMaterialByName(i) } var o = new zg(!0, t); o.conditions = A, this.pushBack(o) }, this.addToOverrideListByMaterial = function (A, e) { this._filterImpl.addOverrideMaterial(e); var t = new zg(!0, e); t.conditions = A, this.pushBack(t) }, this.setOverrideListByColor = function (A, e, t) { for (var i = 0; e.length > i; i += 1) { var o = this._filterImpl.getMaterialNameByColor(t), r = this._filterImpl.getMaterialByName(o); n.setMaterial(e[i], r) } }, this.getVisibleComponentSet = function (A) { for (var e = {}, t = Object.keys(A), i = 0; t.length > i; i += 1) this._isVisible({ userId: t[i] }) && (e[t[i]] = !0); return e }, this.clearAllWireframeList = function () { n.clearMaterialByKey(l("WireframeIdsFA")), this.enableStateChanged() }, this.addToWireframeByWireframe = function (A, e) { var t = null; if (e) { var i = this._filterImpl.getMaterialNameByWireframe(e); t = this._filterImpl.getMaterialByName(i) } var o = new jg(!0, t); o.ids = A, this.pushBack(o) }, this.clearAllUserList = function () { return this.enableStateChanged(), this._filterImpl.clearAllUserList() }, this.clearUserListByType = function (A) { return this.enableStateChanged(), this._filterImpl.clearUserListByType(A) }, this.clearUserList = function (A, e) { return this.enableStateChanged(), this._filterImpl.clearUserList(A, e) }, this.addToUserList = function (A, e, t, i) { return this.enableStateChanged(), this._filterImpl.addToUserList(A, e, t, i) }, this.removeFromUserList = function (A, e, t) { this.enableStateChanged(), this._filterImpl.removeFromUserList(A, e, t) }, this.setUserList = function (A, e, t, i) { this.enableStateChanged(), this._filterImpl.setUserList(A, e, t, i) }, this.isIsolate = function () { var A = n.getObjectsMap(); for (var e in A) { if (A.hasOwnProperty(e)) var t = A[e]; for (var i in t) { var o = n.isIsolateHide(i); if (o |= n.isIsolateTransparent(i)) return !0 } } return !1 }, this.isFiltering = function () { var A = this.filterActionList.length > 0; return this.isIsolate() || A }, this.getFrozonMaterial = function () { return this._filterImpl.getFrozonMaterial() }, this.setIsolateMaterial = function (A) { this.enableStateChanged(), this._filterImpl.setIsolateMaterial(A) }, this.getIsolateMaterial = function () { return this._filterImpl.getIsolateMaterial() }, this.resetIsolateMaterial = function () { this.enableStateChanged(), this._filterImpl.resetIsolateMaterial() }, this.clearAllIsolateList = function () { n.clearIsolates() }, this.clearIsolation = function () { n.clearIsolates(), t = null, s = !0 }, this.clearModelIsolation = function () { r.clearIsolates(), i = null, s = !0 }, this.addToIsolateList = function (A, e) { var t = new Hg("HideOthers" === e); t.ids = A.concat(), this.pushBack(t), this.clearFilterActionList() }, this.removeFromIsolateList = function (A) { t && Array.isArray(A) && (A.forEach((function (A) { t.ids.remove(A) })), 1 > t.ids.length ? (n.clearIsolates(), t = null) : t.applyFilter(n), this.enableStateChanged()) }, this.removeModelFromIsolateList = function (A) { i && Array.isArray(A) && (A.forEach((function (A) { i.ids.remove(A) })), 1 > i.ids.length ? (r.clearIsolates(), i = null) : i.applyFilter(r), this.enableStateChanged()) }, this.setIsolateList = function (A, e) { var t = new Hg(e); t.ids = A.concat(), this.pushBack(t) }, this.setModelIsolateList = function (A, e) { var t = new Hg(e); t.ids = A.concat(), this.pushModelBack(t) }, this.setIsolateConditions = function (A, e) { var t = new Xg(e === Nc.HIDDEN_OTHERS); t.conditions = A, this.pushBack(t), this.clearFilterActionList() }, this.getIsolateConditions = function (A) { return this._filterImpl.getIsolateConditions(A) }, this.clearIsolateConditions = function (A) { this.enableStateChanged(), this._filterImpl.clearIsolateConditions(A) }, this.clearAllIsolateConditions = function () { this.enableStateChanged(), this._filterImpl.clearAllIsolateConditions() }, this.setConditions = function (A, e) { if (0 === A) { n.hideAll(); var t = new Jg(!0, !0); t.conditions = e, this.pushBack(t) } 3 === A && this._filterImpl.setConditions(A, e) }, this.getConditions = function (A) { return this._filterImpl.getConditions(A) }, this.clearConditions = function (A) { this.enableStateChanged(), this._filterImpl.clearConditions(A) }, this.clearAllConditions = function () { this.enableStateChanged(), this._filterImpl.clearAllConditions() }, this.makeSceneTranslucent = function () { this.enableStateChanged(), this._filterImpl.makeSceneTranslucent() }, this.cancelSceneTranslucent = function () { this.enableStateChanged(), this._filterImpl.cancelSceneTranslucent() }, this.hideScene = function () { this.enableStateChanged(), this._filterImpl.hideScene() }, this.showScene = function () { this.enableStateChanged(), this._filterImpl.showScene() }, this.setSceneState = function (A) { this.enableStateChanged(), this._filterImpl.setSceneState(A) }, this.getSceneState = function () { return this._filterImpl.getSceneState() }, this.cancelHidden = function () { this.enableStateChanged(), this._filterImpl.cancelHidden() }, this.cancelTranslucent = function () { this.enableStateChanged(), this._filterImpl.cancelTranslucent() }, this.hideByIds = function (A) { var e = new Pg(!0, !1); e.ids = A, this.pushBack(e) }, this.hideModelByIds = function (A) { var e = new Pg(!0, !1); e.ids = A, this.pushModelBack(e) }, this.hideByConditions = function (A) { var e = new Jg(!0, !1); e.conditions = A, this.pushBack(e) }, this.hideOthersByConditions = function (A) { var e = new Jg(!1, !1); e.conditions = A, this.pushBack(e) }, this.showByIds = function (A) { var e = new Pg(!0, !0); e.ids = A, this.pushBack(e) }, this.showModelByIds = function (A) { var e = new Pg(!0, !0); e.ids = A, this.pushModelBack(e) }, this.showByConditions = function (A) { var e = new Jg(!0, !0); e.conditions = A, this.pushBack(e) }, this.makeTranslucentByIds = function (A) { var e = new Yg(!0, !1); e.ids = A, this.pushBack(e) }, this.makeModelTranslucentByIds = function (A) { var e = new Yg(!0, !1); e.ids = A, this.pushModelBack(e) }, this.makeTranslucentByConditions = function (A) { var e = new Zg(!0, !1); e.conditions = A, this.pushBack(e) }, this.opaqueByIds = function (A) { var e = new Yg(!0, !0); e.ids = A, this.pushBack(e) }, this.opaqueModelByIds = function (A) { var e = new Yg(!0, !0); e.ids = A, this.pushModelBack(e) }, this.opaqueByConditions = function (A) { var e = new Zg(!0, !0); e.conditions = A, this.pushBack(e) }, this.setFrozonMaterial = function (A) { this._filterImpl.setFrozonMaterial(A) }, this.makeTranslucentOthersByIds = function (A) { var e = new Yg(!1, !1); e.ids = A, this.pushBack(e) }, this.makeTranslucentOthersModelByIds = function (A) { var e = new Yg(!1, !1); e.ids = A, this.pushModelBack(e) }, this.opaqueAll = function () { l("TransparentIdsFA"), l("TransparentConditionFA"), n.clearTransparent(), this.enableStateChanged() }, this.opaqueAllModel = function () { c("TransparentIdsFA"), c("TransparentConditionFA"), r.clearTransparent(), this.enableStateChanged() }, this.deactivateByIds = function (A) { n.deactivateByIds(A), this.observerForSceneState && this.observerForSceneState(A), this.enableStateChanged() }, this.activateByIds = function (A) { n.activateByIds(A), this.enableStateChanged() }, this.clearInactivatedIdMap = function () { n.clearInactivatedIdMap() }, this.getInactivatedIdMap = function () { return n.getInactivatedIdMap() }, this.deactivateAll = function () { n.deactivateAll() }, this.activateAll = function () { n.activateAll() }, this.isComponentActive = function (A) { return n.isActive(A) }, this.getFilterType = function () { return this._filterImpl._getFilterType() }, this._hasOverrideMaterialForWireFrame = function (A) { return n.hasOverrideMaterialForWireFrame(A.name) }, this._hasOverrideMaterialFilterForWireFrame = function () { return n.hasOverrideMaterialForWireFrame() }, this._getOverrideMaterialForWireFrame = function (A) { return n.getWireFrameMaterial(A.name) }, this._getOverrideWireFrameMaterial = function (A) { return n.getWireFrameMaterial(A.name) }, this.addToOverrideListForWireFrameByColor = function (A, e) { var t = null; if (e) { var i = this._filterImpl.getMaterialNameByColor(e); t = this._filterImpl.getMaterialByName(i) } var o = new yu(!0, t); o.ids = A, this.pushBack(o) }, this.addToOverrideListForWireFrameByConditions = function (A, e) { var t = null; if (e) { var i = this._filterImpl.getMaterialNameByColor(e); t = this._filterImpl.getMaterialByName(i) } var o = new Cu(!0, t); o.conditions = A, this.pushBack(o) }, this._getFilterObjectsKeys = function (A) { return this._filterImpl._getFilterObjectsKeys(A) }, this.transparentComponentsByKey = function (A, e, t) {}, this.closeOrigMatModelTransparent = function (A, e) { var t = A.models[e].materialManager.materials; for (var i in t) { var o = t[i]; void 0 !== o._origTransparent && (o.transparent = o._origTransparent, o.needsUpdate = !0), void 0 !== o._origOpacity && (o.opacity = o._origOpacity, o.needsUpdate = !0) } var n = A.models[e].materialManager.instanceMaterials; for (var r in n) n[r].forEach((function (A) { void 0 !== A._origTransparent && (A.transparent = A._origTransparent, A.needsUpdate = !0), void 0 !== A._origOpacity && (A.opacity = A._origOpacity, A.needsUpdate = !0) })) }, this.transparentModelOrigMatByKey = function (A, e) { var t = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : .5, i = A.models[e].materialManager.materials; for (var o in i) { var n = i[o]; void 0 === n._origTransparent && (n._origTransparent = n.transparent), void 0 === n._origOpacity && (n._origOpacity = n.opacity), n.transparent = !0, n.opacity = t, n.needsUpdate = !0 } var r = A.models[e].materialManager.instanceMaterials; for (var a in r) r[a].forEach((function (A) { void 0 === A._origTransparent && (A._origTransparent = A.transparent), void 0 === A._origOpacity && (A._origOpacity = A.opacity), A.transparent = !0, A.opacity = t, A.needsUpdate = !0 })) } }; var Su = function (A) { ji.call(this), this.type = "InstancedDepthMaterial", this.uniforms = it.depth.uniforms, this.vertexShader = function (A) { return A.replace("#include ", "\n vec4 mvPosition = modelViewMatrix * vec4(getInstancePosition(transformed), 1.0);\n gl_Position = projectionMatrix * mvPosition;\n ") }(it.depth.vertexShader.replace("void main() {", "\n attribute float vState; \n attribute vec4 aColor; \n attribute vec3 mcol0;\n attribute vec3 mcol1;\n attribute vec3 mcol2;\n attribute vec3 mcol3;\n #if defined(USE_MAP)\n attribute vec2 muvCol0;\n attribute vec2 muvCol1;\n attribute vec2 muvCol2;\n #endif\n \n varying float vfState;\n \n vec3 getInstancePosition(vec3 position) {\n return vec3(mat4(vec4(mcol0, 0.0),\n vec4(mcol1, 0.0),\n vec4(mcol2, 0.0),\n vec4(mcol3, 1.0)) * vec4(position, 1.0));\n }\n \n void main() {\n vfState = vState;\n ")), this.fragmentShader = it.depth.fragmentShader.replace("void main() {", "\n varying float vfState; \n void main() {\n if (vfState <= -0.99 && vfState >= -1.01) discard;\n \n "), void 0 !== A && this.setValues(A) }; function wu(A, e, t) { var i = this, o = !1, n = 0, r = 0, a = void 0, s = []; this.onStart = void 0, this.onLoad = A, this.onProgress = e, this.onError = t, this.itemStart = function (A) { r += 1, !1 === o && void 0 !== i.onStart && i.onStart(A, n, r), o = !0 }, this.itemEnd = function (A) { n += 1, void 0 !== i.onProgress && i.onProgress(A, n, r), n === r && (o = !1, void 0 !== i.onLoad && i.onLoad()) }, this.itemError = function (A) { void 0 !== i.onError && i.onError(A) }, this.resolveURL = function (A) { return a ? a(A) : A }, this.setURLModifier = function (A) { return a = A, this }, this.addHandler = function (A, e) { return s.push(A, e), this }, this.removeHandler = function (A) { var e = s.indexOf(A); return -1 !== e && s.splice(e, 2), this }, this.getHandler = function (A) { for (var e = 0, t = s.length; t > e; e += 2) { var i = s[e], o = s[e + 1]; if (i.global && (i.lastIndex = 0), i.test(A)) return o } return null } } (Su.prototype = Object.create(ji.prototype)).constructor = Su; var Mu = new wu, bu = function (A) { this.manager = null != A ? A : Mu, this.model = A.model, this.cacheViable = !0, this.modelKey = A.model.modelKey }; Object.assign(bu.prototype, { _load: function (A, e, t, i) { void 0 === A && (A = ""), null != this.path && (A = this.path + A); var o = this, n = A.match(/^data:(.*?)(;base64)?,(.*)$/); if (n) { var r = n[1], a = Boolean(n[2]), s = n[3]; s = window.decodeURIComponent(s), a && (s = window.atob(s)); try { var l = null, c = (this.responseType || "").toLowerCase(); switch (c) { case "arraybuffer": case "blob": l = new ArrayBuffer(s.length); for (var h = new Uint8Array(l), d = 0; s.length > d; d += 1) h[d] = s.charCodeAt(d); "blob" === c && (l = new Blob([l], { type: r })); break; case "document": var p = new DOMParser; l = p.parseFromString(s, r); break; case "json": l = JSON.parse(s); break; default: l = s } window.setTimeout((function () { e && e(l), o.manager.itemEnd(A) }), 0) } catch (e) { window.setTimeout((function () { i && i(e), o.manager.itemEnd(A), o.manager.itemError(A) }), 0) } } else { var g = new XMLHttpRequest; for (var u in g.open("GET", A, !0), g.addEventListener("load", (function (t) { var n = t.target.response; if (200 === this.status) { var r = o.model.getStorage(); if (null == n) return i && i(t), o.manager.itemEnd(A), o.manager.itemError(A), void Bh.error("response 为 null"); if (!(n instanceof ArrayBuffer || n instanceof Array || n instanceof Blob || n instanceof Object)) try { n = JSON.parse(n) } catch (A) {} if (n instanceof Blob && mh.isIOSDevice()) { var a = new FileReader; a.readAsDataURL(n), a.onloadend = function (t) { r && o.cacheViable && r.put(A, t.target.result, o.modelKey, (function () { o.manager.progress.loaded += 1 }), (function () { Bh.warn(A, "缓存失败"), o.manager.progress.failed += 1 })), e && e(t.target.result) } } else { if (r && o.cacheViable) if (n.byteLength && n.byteLength > 12e7) { for (var s = [], l = Math.floor(n.byteLength / 4e7), c = 0; l >= c; c += 1) { o.manager.progress.total += 1; var h = null; h = c === l ? n.slice(4e7 * c) : n.slice(4e7 * c, 4e7 * (c + 1)); var d = A + "_" + c; s.push(d), r.put(d, h, o.modelKey, (function () { o.manager.progress.loaded += 1 }), (function () { o.manager.progress.failed += 1 })) } r.put(A, { split: !0, list: s, length: n.byteLength }, o.modelKey, (function () {}), (function () { Bh.warn(A, "缓存失败") })) } else r.put(A, n, o.modelKey, (function () { o.manager.progress && (o.manager.progress.loaded += 1) }), (function () { o.manager.progress && (Bh.warn(A, "缓存失败"), o.manager.progress.failed += 1) })); e && e(n) } o.manager.itemEnd(A) } else 0 === this.status ? (Bh.warn("THREE.FileLoader: HTTP Status 0 received."), e && e(n), o.manager.itemEnd(A)) : (i && i(t), o.manager.itemEnd(A), o.manager.itemError(A)) }), !1), "function" == typeof t && g.addEventListener("progress", (function (A) { t(A) }), !1), g.addEventListener("error", (function (e) { i && i(e), o.manager.itemEnd(A), o.manager.itemError(A) }), !1), void 0 !== this.responseType && (g.responseType = this.responseType), void 0 !== this.withCredentials && (g.withCredentials = this.withCredentials), g.overrideMimeType && g.overrideMimeType(void 0 !== this.mimeType ? this.mimeType : "text/plain"), this.requestHeader) g.setRequestHeader(u, this.requestHeader[u]); g.send(null) } return o.manager.itemStart(A), g }, load: function (A, e, t, i) { void 0 === A && (A = ""), null != this.path && (A = this.path + A); return this._load.call(this, A, e, t, i) }, setPath: function (A) { return this.path = A, this }, setResponseType: function (A) { return this.responseType = A, this }, setWithCredentials: function (A) { return this.withCredentials = A, this }, setMimeType: function (A) { return this.mimeType = A, this }, setCacheViable: function (A) { return this.cacheViable = A, this }, setRequestHeader: function (A) { return this.requestHeader = A, this } }); var Uu = function (A) { this.compArr = [], this.compArr = A, Bh.debug(this.compArr) }; Uu.prototype = { constructor: Uu, getComponent: function (A) {} }; var Fu, Ku, Qu, Ru, Tu = { EmptyGeometry: new he, UnitCylinderInstance: new hr(1, 1, 1, 8, 1, !1), UnitBoxInstance: new Ne(1, 1, 1), UnitTextureCylinder: null, UnitTextureBox: null, initializeUnitInstances: function () { Tu.UnitCylinderInstance.boundingBox || Tu.UnitCylinderInstance.computeBoundingBox(), Tu.UnitBoxInstance.boundingBox || Tu.UnitBoxInstance.computeBoundingBox() }, destroyUnitInstances: function () { Tu.UnitCylinderInstance.dispose(), Tu.UnitBoxInstance.dispose() }, getBoxData: function (A) { for (var e = [ [], [], [], [], [], [] ], t = 0; 4 > t; t += 1) e[0].push(-1, 0, 0); for (t = 0; 4 > t; t += 1) e[1].push(0, -1, 0); for (t = 0; 4 > t; t += 1) e[2].push(0, 0, -1); for (t = 0; 4 > t; t += 1) e[3].push(0, 0, 1); for (t = 0; 4 > t; t += 1) e[4].push(0, 1, 0); for (t = 0; 4 > t; t += 1) e[5].push(1, 0, 0); var i = [ [], [], [], [], [], [] ]; return i[0] = i[2] = i[4] = [-.5, -.5, -.5, .5, .5, -.5, .5, .5], i[1] = i[3] = i[5] = [-.5, -.5, -.5, .5, .5, -.5, .5, .5], { vertex: [ [-.5, -.5, -.5, -.5, -.5, .5, -.5, .5, -.5, -.5, .5, .5], [-.5, -.5, -.5, -.5, -.5, .5, .5, -.5, -.5, .5, -.5, .5], [-.5, -.5, -.5, -.5, .5, -.5, .5, -.5, -.5, .5, .5, -.5], [-.5, -.5, .5, -.5, .5, .5, .5, -.5, .5, .5, .5, .5], [-.5, .5, -.5, -.5, .5, .5, .5, .5, -.5, .5, .5, .5], [.5, -.5, -.5, .5, -.5, .5, .5, .5, -.5, .5, .5, .5] ][A], normal: e[A], uv: i[A], index: [ [0, 1, 2, 3, 2, 1], [2, 1, 0, 1, 2, 3], [0, 1, 2, 3, 2, 1], [2, 1, 0, 1, 2, 3], [0, 1, 2, 3, 2, 1], [2, 1, 0, 1, 2, 3] ][A] } }, getPipeData2: (Fu = [.5, 0, .5, .353530875, .353530875, .5, 0, .5, .5, -.353530875, .353530875, .5, -.5, 0, .5, -.353530875, -.353530875, .5, 0, -.5, .5, .353530875, -.353530875, .5, .5, 0, .5, .5, 0, -.5, .353530875, .353530875, -.5, 0, .5, -.5, -.353530875, .353530875, -.5, -.5, 0, -.5, -.353530875, -.353530875, -.5, 0, -.5, -.5, .353530875, -.353530875, -.5, .5, 0, -.5, .5, 0, .5, .353530875, .353530875, .5, 0, .5, .5, -.353530875, .353530875, .5, -.5, 0, .5, -.353530875, -.353530875, .5, 0, -.5, .5, .353530875, -.353530875, .5, .5, 0, -.5, .353530875, .353530875, -.5, 0, .5, -.5, -.353530875, .353530875, -.5, -.5, 0, -.5, -.353530875, -.353530875, -.5, 0, -.5, -.5, .353530875, -.353530875, -.5], Ku = [0, 9, 1, 1, 9, 10, 1, 10, 2, 2, 10, 11, 2, 11, 3, 3, 11, 12, 3, 12, 4, 4, 12, 13, 4, 13, 5, 5, 13, 14, 5, 14, 6, 6, 14, 15, 6, 15, 7, 7, 15, 16, 7, 16, 8, 8, 16, 17, 18, 19, 20, 18, 20, 21, 18, 21, 22, 18, 22, 23, 18, 23, 24, 18, 24, 25, 26, 28, 27, 26, 29, 28, 26, 30, 29, 26, 31, 30, 26, 32, 31, 26, 33, 32], Qu = [1, 0, 0, .7, .7, 0, 0, 1, 0, -.7, .7, 0, -1, 0, 0, -.7, -.7, 0, 0, -1, 0, .7, -.7, 0, 1, 0, 0, 1, 0, 0, .7, .7, 0, 0, 1, 0, -.7, .7, 0, -1, 0, 0, -.7, -.7, 0, 0, -1, 0, .7, -.7, 0, 1, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1], Ru = [-.5, .5, -.375, .5, -.25, .5, -.125, .5, 0, .5, .125, .5, .25, .5, .375, .5, .5, .5, -.5, -.5, -.375, -.5, -.25, -.5, -.125, -.5, 0, -.5, .125, -.5, .25, -.5, .375, -.5, .5, -.5, .5, 0, .353530875, .353530875, 0, .5, -.353530875, .353530875, -.5, 0, -.353530875, -.353530875, 0, -.5, .353530875, -.353530875, .5, 0, .353530875, .353530875, 0, .5, -.353530875, .353530875, -.5, 0, -.353530875, -.353530875, 0, -.5, .353530875, -.353530875], function () { return { vertex: Fu, normal: Qu, uv: Ru, index: Ku } } ), getPipeData: function (A) { (void 0 === A || 8 > A) && (A = 8), A > 256 && (A = 256); var e = 4 * A + 2, t = 3 * (4 * A - 4), i = A + 1, o = 1 / A, n = 6.28318530714 / A, r = null, a = null, s = []; for (r = 0; A > r; r += 1) s.push(.5 * Math.cos(r * n)), s.push(.5 * Math.sin(r * n)); s.push(.5), s.push(0); var l = []; for (a = 2 * i, r = 0; a > r; r += 2) l.push(s[r]), l.push(s[r + 1]), l.push(.5); for (r = 0; a > r; r += 2) l.push(s[r]), l.push(s[r + 1]), l.push(-.5); for (a = 2 * A, r = 0; a > r; r += 2) l.push(s[r]), l.push(s[r + 1]), l.push(.5); for (r = a; r > 0; r -= 2) l.push(s[r]), l.push(s[r + 1]), l.push(-.5); var c = [], h = A + 1; for (r = 0; A > r; r += 1) c.push(r), c.push(r + h), c.push(r + 1), c.push(r + 1), c.push(r + h), c.push(r + h + 1); var d = 2 * i; for (r = 1; A - 1 > r; r += 1) c.push(d), c.push(d + r), c.push(d + r + 1); for (d += A, r = 1; A - 1 > r; r += 1) c.push(d), c.push(d + r), c.push(d + r + 1); var p = []; for (r = A; r >= 0; r -= 1) p.push(r * o - .5), p.push(-.5); for (r = A; r >= 0; r -= 1) p.push(r * o - .5), p.push(.5); for (a = 2 * A, r = 0; a > r; r += 2) p.push(s[r]), p.push(s[r + 1]); for (r = a; r > 0; r -= 2) p.push(s[r]), p.push(s[r + 1]); a = 3 * e; var g = []; for (r = 0; a > r; r += 1) g.push(0); var u = null, f = null, m = null, C = new y, v = new y, I = new y, E = new y, B = new y; for (r = 0; t > r; r += 3) f = 3 * c[r + 1], m = 3 * c[r + 2], C.fromArray(l, u = 3 * c[r]), v.fromArray(l, f), I.fromArray(l, m), E.subVectors(I, v), B.subVectors(C, v), E.cross(B), g[u] += E.x, g[u + 1] += E.y, g[u + 2] += E.z, g[f] += E.x, g[f + 1] += E.y, g[f + 2] += E.z, g[m] += E.x, g[m + 1] += E.y, g[m + 2] += E.z; var x = new y; for (a = 3 * e, r = 0; a > r; r += 3) x.fromArray(g, r), x.normalize(), g[r] = x.x, g[r + 1] = x.y, g[r + 2] = x.z; return { vertex: l, normal: g, uv: p, index: c, edges: A } }, getInstancePipeData: function (A, e) { var t = this.getPipeData(A); (void 0 === A || 8 > A) && (A = 8), A > 256 && (A = 256); var i = 2 * (A + 1), o = i + A, n = 4 * A + 2, r = [ [], [], [] ]; r[0] = t.vertex.slice(0, 3 * i), r[1] = t.vertex.slice(3 * i, 3 * o), r[2] = t.vertex.slice(3 * o, 3 * n); var a = [ [], [], [] ], s = A + 1, l = 0; for (l = 0; A > l; l += 1) a[0].push(l), a[0].push(l + s), a[0].push(l + 1), a[0].push(l + 1), a[0].push(l + s), a[0].push(l + s + 1); for (l = 1; A - 1 > l; l += 1) a[1].push(0), a[1].push(l), a[1].push(l + 1); for (l = 1; A - 1 > l; l += 1) a[2].push(0), a[2].push(l), a[2].push(l + 1); var c = [ [], [], [] ]; c[0] = t.uv.slice(0, 2 * i), c[1] = t.uv.slice(2 * i, 2 * o), c[2] = t.uv.slice(2 * o, 2 * n); var h = [ [], [], [] ]; return h[0] = t.normal.slice(0, 3 * i), h[1] = t.normal.slice(3 * i, 3 * o), h[2] = t.normal.slice(3 * o, 3 * n), { vertex: r[e], normal: h[e], uv: c[e], index: a[e] } }, getUnitTextureCylinder: function () { if (null === Tu.UnitTextureCylinder) { Tu.UnitTextureCylinder = new Array(3); for (var A = 0; 3 > A; A += 1) { var e = Tu.getInstancePipeData(32, A); Tu.UnitTextureCylinder[A] = new he, Tu.UnitTextureCylinder[A].setIndex(e.index), Tu.UnitTextureCylinder[A].addAttribute("position", new Ae(e.vertex, 3)), Tu.UnitTextureCylinder[A].addAttribute("normal", new Ae(e.normal, 3)), Tu.UnitTextureCylinder[A].addAttribute("uv", new Ae(e.uv, 2)) } } return Tu.UnitTextureCylinder }, getUnitTextureBox: function () { if (null === Tu.UnitTextureBox) { Tu.UnitTextureBox = new Array(6); for (var A = 0; 6 > A; A += 1) { var e = Tu.getBoxData(A); Tu.UnitTextureBox[A] = new he, Tu.UnitTextureBox[A].setIndex(e.index), Tu.UnitTextureBox[A].addAttribute("position", new Ae(e.vertex, 3)), Tu.UnitTextureBox[A].addAttribute("normal", new Ae(e.normal, 3)), Tu.UnitTextureBox[A].addAttribute("uv", new Ae(e.uv, 2)) } } return Tu.UnitTextureBox }, getBoxBufferGeometryWithUvMatrices: function (A) { for (var e = [], t = null, i = new l, o = new y, n = !!A, r = 0; 6 > r; r += 1) { t = new he; var a = Tu.getBoxData(r); if (n) { var s = []; i.set(A[6 * r], A[6 * r + 2], A[6 * r + 4], A[6 * r + 1], A[6 * r + 3], A[6 * r + 5], 0, 0, 1); for (var c = 0, h = a.uv.length; h > c; c += 2) o.set(a.uv[c], a.uv[c + 1], 1), o.applyMatrix3(i), s.push(o.x), s.push(o.y); t.addAttribute("uv", new Ae(s, 2)) } t.setIndex(new YA(Uint32Array.from(a.index), 1)), t.addAttribute("position", new Ae(a.vertex, 3)), t.addAttribute("normal", new Ae(a.normal, 3)), e.push(t) } return Tu.mergeBufferGeometries2(e) }, getPipeBufferGeometryWithUvMatrices: function (A) { var e = Tu.getPipeData(32), t = e.edges, i = !(!A || 18 !== A.length), o = new he; if (i) { for (var n = [], r = 0, a = A.length; a > r; r += 6) { var s = new l; s.set(A[6 * r], A[6 * r + 2], A[6 * r + 4], A[6 * r + 1], A[6 * r + 3], A[6 * r + 5], 0, 0, 1), n.push(s) } for (var c = [], h = new y, d = 4 * (t + 1), p = d + 2 * t, g = 0, u = e.uv.length; u > g; g += 2) h.set(e.uv[g], e.uv[g + 1], 1), h.applyMatrix3(d > g ? n[0] : p > g ? n[1] : n[2]), c.push(h.x), c.push(h.y); o.addAttribute("uv", new Ae(c, 2)) } return o.setIndex(new $A(e.index, 1)), o.addAttribute("position", new Ae(e.vertex, 3)), o.addAttribute("normal", new Ae(e.normal, 3)), o }, getGeometryFromBox3: function (A) { var e = new he, t = [], i = [], o = A.min, n = A.max, r = o.x, a = o.y, s = o.z, l = n.x, c = n.y, h = n.z; return t.push(r, a, s), t.push(l, a, s), t.push(r, a, h), t.push(l, a, h), t.push(r, c, s), t.push(l, c, s), t.push(r, c, h), t.push(l, c, h), i.push(0, 1, 3), i.push(0, 3, 2), i.push(1, 5, 7), i.push(1, 7, 3), i.push(5, 4, 6), i.push(5, 6, 7), i.push(4, 2, 6), i.push(4, 0, 2), i.push(0, 4, 5), i.push(0, 5, 1), i.push(2, 3, 7), i.push(2, 7, 6), e.setIndex(new YA(new Uint32Array(i), 1)), e.setAttribute("position", new YA(new Float32Array(t), 3)), e }, getWorldMatrixOfMesh: function (A) { for (var e = [], t = A.parent; t;) e.push(t.matrix), t = t.parent; var i = new M; if (e.length > 0) { i = e[e.length - 1]; for (var o = e.length - 2; o >= 0; o -= 1) i.multiply(e[o]) } var n = new M; return n.multiplyMatrices(i, A.matrix), n }, getWorldPositionOfMesh: function (A, e) { e || (e = new M); var t = new M; t.getInverse(e); var i = A.clone(); return i.applyMatrix4(t), i }, getBoundingBoxWorldOfMesh: function (A, e) { var t = A.boundingBox; t || (A.geometry.boundingBox || A.geometry.computeBoundingBox(), t = A.geometry.boundingBox); var i = t.clone(); i.applyMatrix4(A.matrixWorld); var o = new M; return o.getInverse(e), i.applyMatrix4(o), i }, getBoundingBoxByBuffer: function (A) { for (var e = 1 / 0, t = 1 / 0, i = 1 / 0, o = -1 / 0, n = -1 / 0, r = -1 / 0, a = new ph, s = 0, l = A.length; l > s; s += 3) { var c = A[s], h = A[s + 1], d = A[s + 2]; e > c && (e = c), t > h && (t = h), i > d && (i = d), c > o && (o = c), h > n && (n = h), d > r && (r = d) } return a.min.set(e, t, i), a.max.set(o, n, r), a }, mergeBufferGeometriesFromMeshs: function (A, e) { for (var t = null !== A[0].geometry.index, i = new Set(Object.keys(A[0].geometry.attributes)), o = new Set(Object.keys(A[0].geometry.morphAttributes)), n = {}, r = {}, a = new he, s = 0; A.length > s; s += 1) { var l = A[s].geometry; if (t !== (null !== l.index)) return null; for (var c in l.attributes) { if (!i.has(c)) return console.log("attributes not Used: ", c), null; void 0 === n[c] && (n[c] = []), n[c].push(l.attributes[c]) } for (var c in l.morphAttributes) { if (!o.has(c)) return null; void 0 === r[c] && (r[c] = []), r[c].push(l.morphAttributes[c]) } null != l.userData && (a.userData = a.userData || {}, a.userData.mergedUserData = a.userData.mergedUserData || [], a.userData.mergedUserData.push(l.userData)) } if (t) { var h = 0, d = [], p = 0, g = 0; for (s = 0; A.length > s; s += 1) { var u = A[s].geometry.index; if (h > 0) { u = u.clone(); for (var f = 0; u.count > f; f += 1) u.setX(f, u.getX(f) + h) } d.push(u), h += A[s].geometry.attributes.position.count, void 0 === e[A[s].userId] && (e[A[s].userId] = []), e[A[s].userId].push({ nodeId: A[s].nodeId, indexStart: p, indexCount: u.count, positionStart: g, positionCount: A[s].geometry.attributes.position.count }), g += A[s].geometry.attributes.position.count, p += u.count } var m = this.mergeBufferAttributes(d); if (!m) return null; a.index = m } for (var c in n) { var C = this.mergeBufferAttributes(n[c]); if (!C) return null; a.setAttribute(c, C) } for (var c in r) { var y = r[c][0].length; if (0 === y) break; a.morphAttributes = a.morphAttributes || {}, a.morphAttributes[c] = []; for (s = 0; y > s; s += 1) { var v = []; for (f = 0; r[c].length > f; f += 1) v.push(r[c][f][s]); var I = this.mergeBufferAttributes(v); if (!I) return null; a.morphAttributes[c].push(I) } } return a }, mergeBufferGeometries: function (A, e) { for (var t = null !== A[0].index, i = new Set(Object.keys(A[0].attributes)), o = {}, n = new he, r = 0; A.length > r; r += 1) { var a = A[r]; if (t !== (null !== a.index)) return null; for (var s in a.attributes) { if (!i.has(s)) return null; void 0 === o[s] && (o[s] = []), o[s].push(a.attributes[s]) } } if (t) { var l = 0, c = []; for (r = 0; A.length > r; r += 1) { var h = A[r].index; if (l > 0) { h = h.clone(); for (var d = 0; h.count > d; d += 1) h.setX(d, h.getX(d) + l) } c.push(h), l += A[r].attributes.position.count } var p = this.mergeBufferAttributes(c); if (!p) return null; n.index = p } for (var s in o) { var g = this.mergeBufferAttributes(o[s], e); if (!g) return null; n.setAttribute(s, g) } return n }, reducedGeometry: function (A, e) { for (var t = {}, i = 0, o = e.length; o > i; i += 1) { var n = e[i]; t[n] || (t[n] = []), t[n].push(i) } var r = 0, a = new Float32Array(3 * Object.keys(t).length); for (var s in t) { for (var l = t[s], c = 0, h = l.length; h > c; c += 1) e[l[c]] = r, a[3 * r] = A[3 * s], a[3 * r + 1] = A[3 * s + 1], a[3 * r + 2] = A[3 * s + 2]; r += 1 } return { buffer: a, index: e } }, mergeBufferAttributes: function (A, e) { for (var t = null, i = null, o = null, n = 0, r = 0; A.length > r; r += 1) { var a = A[r]; if (a.isInterleavedBufferAttribute) return null; if (null === t && (t = a.array.constructor), t !== a.array.constructor) return null; if (null === i && (i = a.itemSize), i !== a.itemSize) return null; if (null === o && (o = a.normalized), o !== a.normalized) return null; n += a.array.length } for (var s = new t(n), c = 0, h = !1, d = 0; A.length > d; d += 1) { if (e && !e[d].equals(Bc) && ("position" === A[d].name || "normal" === A[d].name)) { if ("position" === A[d].name && e[d].applyToBufferAttribute(A[d]), "normal" === A[d].name) (new l).getNormalMatrix(e[d]).applyToBufferAttribute(A[d]); h = !0 } if (s.set(A[d].array, c), c += A[d].array.length, h) { var p = (new M).getInverse(e[d]); if ("position" === A[d].name && p.applyToBufferAttribute(A[d]), "normal" === A[d].name) (new l).getNormalMatrix(p).applyToBufferAttribute(A[d]); h = !1 } } return new YA(s, i, o) }, applyMatrix3ToBuffer: function () { var A = new y; return function (e, t, i, o) { if (e.equals(xc)) return t; for (var n = i || 0, r = o || t.length; r > n; n += 3) A.x = t[n + 0], A.y = t[n + 1], A.z = t[n + 2], A.applyMatrix3(e), t[n + 0] = A.x, t[n + 1] = A.y, t[n + 2] = A.z; return t } }(), applyMatrix4ToBuffer: function () { var A = new y; return function (e, t, i, o) { if (e.equals(Bc)) return t; for (var n = i || 0, r = o || t.length; r > n; n += 3) A.x = t[n + 0], A.y = t[n + 1], A.z = t[n + 2], A.applyMatrix4(e), t[n + 0] = A.x, t[n + 1] = A.y, t[n + 2] = A.z; return t } }(), normalizeBuffer: function (A) { for (var e = null, t = null, i = null, o = null, n = 0, r = A.length; r > n; n += 3) e = A[n], t = A[n + 1], i = A[n + 2], o = 1 / Math.sqrt(e * e + t * t + i * i), A[n] = e * o, A[n + 1] = t * o, A[n + 2] = i * o }, disposeBufferFromGeometry: function (A, e) { for (var t = 0, i = e.length; i > t; t += 1) { var o = A.getAttribute(e[t]); o && (o.array = null) } }, disposeIndexBufferFromGeometry: function (A) { A.index && (A.index.array = null) }, copyMeshProperties: function (A, e) { A.name = e.name, A.up.copy(e.up), A.position.copy(e.position), A.quaternion.copy(e.quaternion), A.scale.copy(e.scale), A.matrix.copy(e.matrix), A.matrixWorld.copy(e.matrixWorld), A.matrixAutoUpdate = e.matrixAutoUpdate, A.matrixWorldNeedsUpdate = e.matrixWorldNeedsUpdate }, createBufferGeometryWithPosAndSkin: function (A) { var e = new he; if (A.isBufferGeometry || A._bufferGeometry) { var t = A.isBufferGeometry ? A : A._bufferGeometry; e.addAttribute("position", t.getAttribute("position")), t.getAttribute("skinIndex") && e.addAttribute("skinIndex", t.getAttribute("skinIndex")), t.getAttribute("skinWeight") && e.addAttribute("skinWeight", t.getAttribute("skinWeight")); var i = t.getIndex(); i && e.setIndex(i) } else if (A.isGeometry) { var o = new Ae(3 * A.vertices.length, 3); if (e.addAttribute("position", o.copyVector3sArray(A.vertices)), A.skinIndices.length > 0) { var n = new Ae(4 * A.skinIndices.length, 4); e.addAttribute("skinIndex", n.copyVector4sArray(A.skinIndices)) } if (A.skinWeights.length > 0) { var r = new Ae(4 * A.skinWeights.length, 4); this.addAttribute("skinWeight", r.copyVector4sArray(A.skinWeights)) } if (A.faces.length) { for (var a = A.faces, s = [], l = 0; a.length > l; l += 1) { var c = a[l]; s.push(c.a, c.b, c.c) } var h = new(uh.arrayMax(s) > 65535 ? Uint32Array : Uint16Array)(3 * s.length); e.setIndex(new YA(h, 1).copyIndicesArray(s)) } } return e }, calculateVolumeOfGeometry: function (A, e, t, i) { if (A && e) { var o = 0, n = new y, r = new y, a = new y; t || (t = 0), i || (i = e.length); for (var s = 0, l = 0, c = 0, h = t, d = t + i; d > h; h += 3) { l = e[h + 1], c = e[h + 2], n.set(A[3 * (s = e[h])], A[3 * s + 1], A[3 * s + 2]), r.set(A[3 * l], A[3 * l + 1], A[3 * l + 2]), a.set(A[3 * c], A[3 * c + 1], A[3 * c + 2]), o += n.clone().cross(r).dot(a) / 6 } return o } }, minDistanceBetweenTriToMesh: function (A, e, t, i) { function o(A, e) { return new y(A.x - e.x, A.y - e.y, A.z - e.z) } function n(A, e) { return new y(A.x + e.x, A.y + e.y, A.z + e.z) } function r(A, e, t) { return new y(A.x + e.x * t, A.y + e.y * t, A.z + e.z * t) } function a(A, e) { return A.x * e.x + A.y * e.y + A.z * e.z } function s(A, e) { return new y(A.y * e.z - A.z * e.y, A.z * e.x - A.x * e.z, A.x * e.y - A.y * e.x) } function l(A, e, t, i) { var l, c = a(e, i), h = a(e, e), d = a(i, i), p = o(t, A), g = a(e, p), u = a(i, p), f = null; 0 > (f = (g * d - u * c) / (h * d - c * c)) || isNaN(f) ? f = 0 : f > 1 && (f = 1); var m = null, C = null, y = null, v = null; return 0 >= (l = (f * c - u) / d) || isNaN(l) ? (C = t, 0 >= (f = g / h) || isNaN(f) ? (m = A, y = o(t, A)) : 1 > f ? (m = r(A, e, f), v = s(p, e), y = s(e, v)) : y = o(t, m = n(A, e))) : 1 > l ? (C = r(t, i, l), 0 >= f || isNaN(f) ? (m = A, v = s(p, i), y = s(i, v)) : 1 > f ? (m = r(A, e, f), 0 > a(y = s(e, i), p) && y.multiplyScalar(-1)) : (v = s(p = o(t, m = n(A, e)), i), y = s(i, v))) : (C = n(t, i), 0 >= (f = (c + g) / h) || isNaN(f) ? (m = A, y = o(C, A)) : 1 > f ? (m = r(A, e, f), v = s(p = o(C, A), e), y = s(e, v)) : y = o(C, m = n(A, e))), { vec: y, closestP: m, closestQ: C } } function c(A, e) { var t = null, i = null, n = [], c = [], h = null; n[0] = o(A[1], A[0]), n[1] = o(A[2], A[1]), n[2] = o(A[0], A[2]), c[0] = o(e[1], e[0]), c[1] = o(e[2], e[1]), c[2] = o(e[0], e[2]); for (var d = null, p = null, g = null, u = 0, f = A[0].distanceToSquared(e[0]) + 1, m = 0; 3 > m; m += 1) for (var C = 0; 3 > C; C += 1) { var y = l(A[m], n[m], e[C], c[C]); h = y.vec; var v = a(d = o(i = y.closestQ, t = y.closestP), d); if (f >= v) { p = t.clone(), g = i.clone(), f = v; var I = a(o(A[(m + 2) % 3], t), h), E = a(o(e[(C + 2) % 3], i), h); if (0 >= I && E >= 0) return { start: t.clone(), end: i.clone(), minDistance: Math.sqrt(v) }; 0 > I && (I = 0), E > 0 && (E = 0), a(d, h) - I + E > 0 && (u = 1) } } var B = s(n[0], n[1]), x = a(B, B); if (x > 1e-15) { var S = []; d = o(A[0], e[0]), S[0] = a(d, B), d = o(A[0], e[1]), S[1] = a(d, B), d = o(A[0], e[2]), S[2] = a(d, B); var w = -1; if (S[0] > 0 && S[1] > 0 && S[2] > 0 ? S[w = S[1] > S[0] ? 0 : 1] > S[2] && (w = 2) : 0 > S[0] && 0 > S[1] && 0 > S[2] && S[2] > S[w = S[0] > S[1] ? 0 : 1] && (w = 2), w >= 0 && (u = 1, a(d = o(e[w], A[0]), s(B, n[0])) > 0 && a(d = o(e[w], A[1]), s(B, n[1])) > 0 && a(d = o(e[w], A[2]), s(B, n[2])) > 0)) return t = r(e[w], B, S[w] / x), i = e[w].clone(), { start: t.clone(), end: i, minDistance: t.distanceTo(i) } } var M = s(c[0], c[1]), b = a(M, M); if (b > 1e-15) { var U = []; d = o(e[0], A[0]), U[0] = a(d, M), d = o(e[0], A[1]), U[1] = a(d, M), d = o(e[0], A[2]), U[2] = a(d, M); w = -1; if (U[0] > 0 && U[1] > 0 && U[2] > 0 ? U[w = U[1] > U[0] ? 0 : 1] > U[2] && (w = 2) : 0 > U[0] && 0 > U[1] && 0 > U[2] && U[2] > U[w = U[0] > U[1] ? 0 : 1] && (w = 2), w >= 0 && (u = 1, a(d = o(A[w], e[0]), s(M, c[0])) > 0 && a(d = o(A[w], e[1]), s(M, c[1])) > 0 && a(d = o(A[w], e[2]), s(M, c[2])) > 0)) return { start: t = A[w].clone(), end: (i = r(A[w], M, U[w] / b)).clone(), minDistance: t.distanceTo(i) } } return u ? (t = p, i = g, { start: p.clone(), end: g.clone(), minDistance: Math.sqrt(f) }) : { start: p.clone(), end: g.clone(), minDistance: 0 } } var h = new y, d = new y, p = new y; function g(A, e, t, i, o, n) { h.fromBufferAttribute(e, t), d.fromBufferAttribute(e, i), p.fromBufferAttribute(e, o), n && (h.applyMatrix4(n), d.applyMatrix4(n), p.applyMatrix4(n)), A.push(h), A.push(d), A.push(p) } for (var u = { start: null, end: null, minDistance: Number.POSITIVE_INFINITY }, f = e.geometry, m = f.attributes.position, C = t ? t.indexStart : 0, v = f.getIndex().array, I = C, E = t ? t.indexStart + t.indexCount : v.length; E > I; I += 3) { var B = []; g(B, m, v[I], v[I + 1], v[I + 2], i); var x = c(A, B); if (0 >= x.minDistance) return u.minDistance = 0, u.start = x.start.clone(), u.end = x.end.clone(), u; u.minDistance > x.minDistance && (u.minDistance = x.minDistance, u.start = x.start.clone(), u.end = x.end.clone()) } return u }, minDistanceBetweenTriToTri: function (A, e) { function t(A, e) { return new y(A.x - e.x, A.y - e.y, A.z - e.z) } function i(A, e) { return new y(A.x + e.x, A.y + e.y, A.z + e.z) } function o(A, e, t) { return new y(A.x + e.x * t, A.y + e.y * t, A.z + e.z * t) } function n(A, e) { return A.x * e.x + A.y * e.y + A.z * e.z } function r(A, e) { return new y(A.y * e.z - A.z * e.y, A.z * e.x - A.x * e.z, A.x * e.y - A.y * e.x) } function a(A, e, a, s) { var l, c = n(e, s), h = n(e, e), d = n(s, s), p = t(a, A), g = n(e, p), u = n(s, p), f = null; 0 > (f = (g * d - u * c) / (h * d - c * c)) || isNaN(f) ? f = 0 : f > 1 && (f = 1); var m = null, C = null, y = null, v = null; return 0 >= (l = (f * c - u) / d) || isNaN(l) ? (C = a, 0 >= (f = g / h) || isNaN(f) ? (m = A, y = t(a, A)) : 1 > f ? (m = o(A, e, f), v = r(p, e), y = r(e, v)) : y = t(a, m = i(A, e))) : 1 > l ? (C = o(a, s, l), 0 >= f || isNaN(f) ? (m = A, v = r(p, s), y = r(s, v)) : 1 > f ? (m = o(A, e, f), 0 > n(y = r(e, s), p) && y.multiplyScalar(-1)) : (v = r(p = t(a, m = i(A, e)), s), y = r(s, v))) : (C = i(a, s), 0 >= (f = (c + g) / h) || isNaN(f) ? (m = A, y = t(C, A)) : 1 > f ? (m = o(A, e, f), v = r(p = t(C, A), e), y = r(e, v)) : y = t(C, m = i(A, e))), { vec: y, closestP: m, closestQ: C } } function s(A, e) { var i = null, s = null, l = [], c = [], h = null; l[0] = t(A[1], A[0]), l[1] = t(A[2], A[1]), l[2] = t(A[0], A[2]), c[0] = t(e[1], e[0]), c[1] = t(e[2], e[1]), c[2] = t(e[0], e[2]); for (var d = null, p = null, g = null, u = 0, f = A[0].distanceToSquared(e[0]) + 1, m = 0; 3 > m; m += 1) for (var C = 0; 3 > C; C += 1) { var y = a(A[m], l[m], e[C], c[C]); h = y.vec; var v = n(d = t(s = y.closestQ, i = y.closestP), d); if (f >= v) { p = i.clone(), g = s.clone(), f = v; var I = n(t(A[(m + 2) % 3], i), h), E = n(t(e[(C + 2) % 3], s), h); if (0 >= I && E >= 0) return { start: i.clone(), end: s.clone(), minDistance: Math.sqrt(v) }; 0 > I && (I = 0), E > 0 && (E = 0), n(d, h) - I + E > 0 && (u = 1) } } var B = r(l[0], l[1]), x = n(B, B); if (x > 1e-15) { var S = []; d = t(A[0], e[0]), S[0] = n(d, B), d = t(A[0], e[1]), S[1] = n(d, B), d = t(A[0], e[2]), S[2] = n(d, B); var w = -1; if (S[0] > 0 && S[1] > 0 && S[2] > 0 ? S[w = S[1] > S[0] ? 0 : 1] > S[2] && (w = 2) : 0 > S[0] && 0 > S[1] && 0 > S[2] && S[2] > S[w = S[0] > S[1] ? 0 : 1] && (w = 2), w >= 0 && (u = 1, n(d = t(e[w], A[0]), r(B, l[0])) > 0 && n(d = t(e[w], A[1]), r(B, l[1])) > 0 && n(d = t(e[w], A[2]), r(B, l[2])) > 0)) return i = o(e[w], B, S[w] / x), s = e[w].clone(), { start: i.clone(), end: s, minDistance: i.distanceTo(s) } } var M = r(c[0], c[1]), b = n(M, M); if (b > 1e-15) { var U = []; d = t(e[0], A[0]), U[0] = n(d, M), d = t(e[0], A[1]), U[1] = n(d, M), d = t(e[0], A[2]), U[2] = n(d, M); w = -1; if (U[0] > 0 && U[1] > 0 && U[2] > 0 ? U[w = U[1] > U[0] ? 0 : 1] > U[2] && (w = 2) : 0 > U[0] && 0 > U[1] && 0 > U[2] && U[2] > U[w = U[0] > U[1] ? 0 : 1] && (w = 2), w >= 0 && (u = 1, n(d = t(A[w], e[0]), r(M, c[0])) > 0 && n(d = t(A[w], e[1]), r(M, c[1])) > 0 && n(d = t(A[w], e[2]), r(M, c[2])) > 0)) return { start: i = A[w].clone(), end: (s = o(A[w], M, U[w] / b)).clone(), minDistance: i.distanceTo(s) } } return u ? (i = p, s = g, { start: p.clone(), end: g.clone(), minDistance: Math.sqrt(f) }) : { start: p.clone(), end: g.clone(), minDistance: 0 } } for (var l = { start: null, end: null, minDistance: Number.POSITIVE_INFINITY }, c = 0, h = A.length; h > c; c += 1) for (var d = 0, p = e.length; p > d; d += 1) { var g = s(A[c], e[d]); if (0 >= g.minDistance) return l.minDistance = 0, l.start = g.start.clone(), l.end = g.end.clone(), l; l.minDistance > g.minDistance && (l.minDistance = g.minDistance, l.start = g.start.clone(), l.end = g.end.clone()) } return l }, calculateTheIntersectionOfGeometryAndPlane: function (A, e) { var t = A.getIndex().array, i = A.attributes.position, o = t.length, n = e.clone(), r = 0; - 1 === n.normal.x ? r = 0 : 1 === n.normal.x ? (n.normal.x = -1, n.constant *= -1, r = 1) : -1 === n.normal.y ? r = 2 : 1 === n.normal.y ? (n.normal.y = -1, n.constant *= -1, r = 3) : -1 === n.normal.z ? r = 4 : 1 === n.normal.z && (n.normal.z = -1, n.constant *= -1, r = 5); for (var a, s, l, c, h, d, p, g, u = [], f = new Hs, m = 0, C = o; C > m; m += 3) { var v = []; a = v, s = i, l = t[m], c = t[m + 1], h = t[m + 2], d = new y, p = new y, g = new y, d.fromBufferAttribute(s, l), p.fromBufferAttribute(s, c), g.fromBufferAttribute(s, h), a.push(d), a.push(p), a.push(g); var I = v[0], E = v[1], B = v[2], x = !1, S = !1, w = !1; switch (r) { case 0: case 1: x = n.constant > I.x, S = n.constant > E.x, w = n.constant > B.x; break; case 2: case 3: x = n.constant > I.y, S = n.constant > E.y, w = n.constant > B.y; break; case 4: case 5: x = n.constant > I.z, S = n.constant > E.z, w = n.constant > B.z } var M = null, b = null; x ? S ? w || (f.set(B, E), (M = n.intersectLine(f, new y)) && u.push(M), f.set(B, I), (b = n.intersectLine(f, new y)) && u.push(b)) : w ? (f.set(E, B), (M = n.intersectLine(f, new y)) && u.push(M), f.set(E, I), (b = n.intersectLine(f, new y)) && u.push(b)) : (f.set(E, I), (M = n.intersectLine(f, new y)) && u.push(M), f.set(B, I), (b = n.intersectLine(f, new y)) && u.push(b)) : S ? w ? (f.set(I, E), (M = n.intersectLine(f, new y)) && u.push(M), f.set(I, B), (b = n.intersectLine(f, new y)) && u.push(b)) : (f.set(I, E), (M = n.intersectLine(f, new y)) && u.push(M), f.set(B, E), (b = n.intersectLine(f, new y)) && u.push(b)) : w && (f.set(I, B), (M = n.intersectLine(f, new y)) && u.push(M), f.set(E, B), (b = n.intersectLine(f, new y)) && u.push(b)) } if (u.length >= 1) { for (var U = {}, F = [], K = [], Q = 0, R = u.length; R > Q; Q += 1) { var T = u[Q].toArray(F).toString(); U[T] || (U[T] = []), 2 > U[T].length || (T = T + "_" + Math.floor(U[T].length / 2 + .6), U[T] || (U[T] = [])), U[T].push(Q), K.push(T) } var k = [], D = K[0]; return k.push(u[0], u[1]), function A(e, t) { var i = U[K[e]], o = i[0] === e ? i[1] : i[0], n = o % 2 ? o - 1 : o + 1; if (t.push(u[n]), K[n] !== D) { if (isNaN(n)) return void(k = null); A(n, t) } }(1, k), k } }, getShapeGeometryFromGeometryAndPlane: function (A, e) { var t = Tu.calculateTheIntersectionOfGeometryAndPlane(A, e); if (t) { var i = 0; - 1 === e.normal.x ? i = 0 : 1 === e.normal.x ? i = 1 : -1 === e.normal.y ? i = 2 : 1 === e.normal.y ? i = 3 : -1 === e.normal.z ? i = 4 : 1 === e.normal.z && (i = 5); var o = [], n = [], r = [], a = [], l = []; A.boundingBox || A.computeBoundingBox(); for (var c = A.boundingBox.getSize(new y), h = e.normal.x * c.x * 1e-4, d = e.normal.y * c.y * 1e-4, p = e.normal.z * c.z * 1e-4, g = 0, u = t.length; u > g; g += 1) { var f = t[g], m = new s; switch (n.push(f.x + h, f.y + d, f.z + p), i) { case 0: case 1: r.push(1, 0, 0), a.push(f.y, f.z), m.set(f.y, f.z); break; case 2: case 3: r.push(0, 1, 0), a.push(f.x, f.z), m.set(f.x, f.z); break; case 4: case 5: r.push(0, 0, 1), a.push(f.x, f.y), m.set(f.x, f.y) } l.push(m) } for (var C = Hn.triangulateShape(l, []), v = 0, I = C.length; I > v; v += 1) { var E = C[v]; o.push(E[0], E[1], E[2]) } var B = new he; return B.setIndex(o), B.setAttribute("position", new Ae(n, 3)), B.setAttribute("normal", new Ae(r, 3)), B.setAttribute("uv", new Ae(a, 2)), B } } }; Tu.getBoxMBuffer = function () { for (var A = null, e = null, t = [], i = [], o = [], n = 0, r = 0; 6 > r; r += 1) { var a = Tu.getBoxData(r); for (A = 0, e = a.vertex.length; e > A; A += 1) t.push(a.vertex[A]); for (A = 0, e = a.index.length; e > A; A += 1) o.push(a.index[A] + n); for (n += a.vertex.length / 3, A = 0, e = a.normal.length; e > A; A += 1) i.push(a.normal[A]) } return function (A) { var e = null; if (A) { var n = new l, r = new y; e = []; for (var a = 0; 6 > a; a += 1) { var s = Tu.getBoxData(a); n.set(A[6 * a], A[6 * a + 2], A[6 * a + 4], A[6 * a + 1], A[6 * a + 3], A[6 * a + 5], 0, 0, 1); for (var c = 0, h = s.uv.length; h > c; c += 2) r.set(s.uv[c], s.uv[c + 1], 1), r.applyMatrix3(n), e.push(r.x), e.push(r.y) } } return { vertex: t, normal: i, uv: e, index: o } } }(), Tu.getPipeMBuffer = function () { var A = Tu.getPipeData(32), e = A.edges, t = A.vertex, i = A.normal, o = A.index; return function (A) { var n = null; if (!(!A || 18 !== A.length)) { n = []; for (var r = [], a = 0, s = A.length / 6; s > a; a += 1) { var c = new l; c.set(A[6 * a], A[6 * a + 2], A[6 * a + 4], A[6 * a + 1], A[6 * a + 3], A[6 * a + 5], 0, 0, 1), r.push(c) } for (var h = Tu.getPipeData(32), d = 4 * (e + 1), p = d + 2 * e, g = new y, u = 0, f = h.uv.length; f > u; u += 2) g.set(h.uv[u], h.uv[u + 1], 1), g.applyMatrix3(d > u ? r[0] : p > u ? r[1] : r[2]), n.push(g.x), n.push(g.y) } return { vertex: t, normal: i, uv: n, index: o } } }(); var ku = { geoHeader: function (A) { var e = new Int32Array(A); this.geoCount = e[0], this.headerBuffer = e.slice(1, 4 * this.geoCount + 1) }, GeometryReader: function (A, e) { Bh.time("GeometryReader"), this.geomMap = [], this.geoCount = new Uint32Array(A, 0, 1)[0]; var t = this.geoCount, i = [], o = 0, n = null, r = null, a = null, s = null, l = null, c = null, h = null, d = 0, p = null, g = 0, u = null, f = 0, m = null, C = 0, y = null, v = 0, I = null; if (np(e, "2")) for (var E = 0; t > E; E += 1) { if (i = {}, o = 4 * (1 + 7 * t), r = (n = new Uint32Array(A, 4 * (1 + 7 * E), 7))[0], a = n[2], s = n[3], l = n[4], c = n[5], h = n[6], d = o + n[1], p = new Float32Array(A.slice(d, 4 * a + d)), g = 4 * a + d, u = new Float32Array(A.slice(g, g + 4 * s)), f = g + 4 * s, m = new Uint32Array(A.slice(f, f + 4 * l)), C = f + 4 * l, y = new Float32Array(A.slice(C, C + 4 * c)), v = C + 4 * c, I = new Int16Array(A.slice(v, v + 2 * h)), vc.DataReduction) { var B = (new M).makeScale(.001, .001, .001); Tu.applyMatrix4ToBuffer(B, p) } i.position = p, i.normal = u, i.index = m, i.uv = y, i.materialIndex = I, i.geoId = r, this.geomMap.push(i) } else for (var x = 0; t > x; x += 1) i = {}, o = 4 * (1 + 6 * t), r = (n = new Uint32Array(A, 4 * (1 + 6 * x), 6))[0], a = n[2], s = n[3], l = n[4], c = n[5], d = o + n[1], p = new Float32Array(A.slice(d, 4 * a + d)), g = 4 * a + d, u = new Float32Array(A.slice(g, g + 4 * s)), f = g + 4 * s, m = new Uint32Array(A.slice(f, f + 4 * l)), C = f + 4 * l, y = new Float32Array(A.slice(C, C + 4 * c)), i.position = p, i.normal = u, i.index = m, i.uv = y, i.geoId = r, this.geomMap.push(i); Bh.debug(this.geomMap), Bh.timeEnd("GeometryReader") }, BatchedGeometryReader: function (A, e) { Bh.time("BatchedGeometryReader"), this.geomMap = [], this.geoCount = new Uint32Array(A, 0, 1)[0]; for (var t = this.geoCount, i = 0, o = 0, n = 0, r = [], a = 4, s = 0; t > s; s += 1) { var l = {}; r.push(l); var c = new Uint32Array(A, a, 7); l.geoId = c[0], l.offset = c[1], l.vertexLength = c[2], l.normalLength = c[5], l.indicesLength = c[3], l.uvLength = c[4], l.componentCount = o = c[6], l.nodeInfo = [], a += 28; for (var h = 0; o > h; h += 1) { var d = new Uint32Array(A, a, 1)[0]; a += 4; for (var p = 0; d > p; p += 1) { var g = new Uint32Array(A, a, 3); a += 12, l.nodeInfo.push(g) } } l.materialKeyLength = new Uint32Array(A, a, 1)[0], a += 4 } for (var u = 0; t > u; u += 1) { var f = r[u], m = f.normalLength, C = f.indicesLength, y = f.uvLength; i = a + f.offset, n = 4 * f.vertexLength; var v = new Float32Array(A.slice(i, i + n)); i += n, n = 4 * C; var I = new Uint32Array(A.slice(i, i + n)); i += n, n = 4 * y; var E = new Float32Array(A.slice(i, i + n)); i += n, n = 4 * m; var B = new Float32Array(A.slice(i, i + n)); i += n, o = f.componentCount; for (var x = {}, S = 0, w = f.nodeInfo.length; w > S; S += 1) { var b = f.nodeInfo[S]; n = 2 * b[0]; var U = uh.ab2str(new Int16Array(A.slice(i, i + n))); i += n, n = 2 * b[1]; var F = uh.ab2str(new Int16Array(A.slice(i, i + n))); i += n; var K = new Uint32Array(A.slice(i, i + 4))[0]; i += 4; var Q = new Uint32Array(A.slice(i, i + 4))[0]; i += 4; var R = new Uint32Array(A.slice(i, i + 4))[0]; i += 4; var T = new Uint32Array(A.slice(i, i + 4))[0]; i += 4; var k = {}; k.userId = U, k.nodeId = F, k.positionStart = K, k.positionCount = Q, k.indexStart = R, k.indexCount = T, x[U] || (x[U] = []), x[U].push(k) } n = 2 * f.materialKeyLength; var D = uh.ab2str(new Int16Array(A.slice(i, i + n))); if (vc.DataReduction) { var L = (new M).makeScale(.001, .001, .001); Tu.applyMatrix4ToBuffer(L, v) } var N = {}; N.position = v, N.normal = B, N.index = I, N.uv = E, N.materialIndex = null, N.geoId = f.geoId, N.materialKey = D, N.componentInfo = x, this.geomMap.push(N) } Bh.debug(this.geomMap), Bh.timeEnd("BatchedGeometryReader") }, NodesReader: function (A, e) { Bh.time("NodesReader"), this.geomMap = [], this.nodeCount = new Uint32Array(A, 0, 1)[0]; for (var t = this.nodeCount, i = 0, o = 0, n = [], r = 4, a = 0; t > a; a += 1) { var s = {}; n.push(s); var l = new Uint32Array(A, r, 5); s.geoId = l[0], s.offset = l[1], s.nodeIdLength = l[2], s.materialKeyLength = l[3], s.matrixLength = l[4], r += 20 } for (var c = 0; t > c; c += 1) { var h = n[c], d = h.materialKeyLength, p = h.matrixLength, g = uh.ab2str(A.slice(i = r + h.offset, i + (o = h.nodeIdLength))), u = uh.ab2str(A.slice(i += o, i + (o = d))); i += o, o = 8 * p; var f = new Float64Array(A.slice(i, i + o)); i += o; var m = {}; m.nodeId = g, m.geoId = h.geoId, m.material = u, m.matrix = f, this.geomMap.push(m) } Bh.debug(this.geomMap), Bh.timeEnd("NodesReader") }, InstancedGeometryReader: function (A, e) { Bh.time("InstancedGeometryReader"), this.geomMap = [], this.geoCount = new Uint32Array(A, 0, 1)[0]; for (var t = this.geoCount, i = null, o = 0, n = 0, r = 0, a = [], s = 4, l = 0; t > l; l += 1) { var c = {}; a.push(c), i = new Uint32Array(A, s, 7), c.geoId = i[0], c.offset = i[1], c.vertexLength = i[2], c.normalLength = i[5], c.indicesLength = i[3], c.uvLength = i[4], c.componentCount = n = i[6], c.nodeInfo = {}, s += 28; var h = []; c.componentKeyLength = h, c.matrixArrayLength = []; for (var d = 0; n > d; d += 1) { h.push(new Uint32Array(A, s, 1)[0]), s += 4; var p = new Uint32Array(A, s, 1)[0]; s += 4, c.nodeInfo[d] = []; for (var g = 0; p > g; g += 1) { var u = new Uint32Array(A, s, 1)[0]; s += 4, c.nodeInfo[d].push(u) } } c.matrixArrayLength = new Uint32Array(A, s, 1)[0], s += 4, c.materialKeyLength = new Uint32Array(A, s, 1)[0], s += 4 } for (var f = 0; t > f; f += 1) { var m = a[f], C = m.normalLength, y = m.indicesLength, v = m.uvLength; o = s + m.offset, r = 4 * m.vertexLength; var I = new Float32Array(A.slice(o, o + r)); o += r, r = 4 * y; var E = new Uint32Array(A.slice(o, o + r)); o += r, r = 4 * v; var B = new Float32Array(A.slice(o, o + r)); o += r, r = 4 * C; var x = new Float32Array(A.slice(o, o + r)); o += r; for (var S = {}, w = [], b = [], U = 0, F = 0, K = n = m.componentCount; K > F; F += 1) { var Q = uh.ab2str(A.slice(o, o + (r = m.componentKeyLength[F]))); o += r, b.push(Q), S[Q] || (S[Q] = []); for (var R = m.nodeInfo[F], T = 0, k = R.length; k > T; T += 1) { var D = uh.ab2str(A.slice(o, o + (r = R[T]))); o += r, S[Q].push(U), w.push(D), U += 1 } } r = 8 * m.matrixArrayLength; var L = new Float64Array(A.slice(o, o + r)); o += r; var N = new Float64Array(A.slice(o, o + r)); o += r; var O = new Float64Array(A.slice(o, o + r)); o += r; var V = new Float64Array(A.slice(o, o + r)), G = uh.ab2str(A.slice(o += r, o + (r = m.materialKeyLength))); o += r, r = 4 * w.length * 4; var P = new Float32Array(A.slice(o, o + r)); if (o += r, vc.DataReduction) { var q = (new M).makeScale(.001, .001, .001); Tu.applyMatrix4ToBuffer(q, I) } var j = {}; j.position = I, j.normal = x, j.index = E, j.uv = B, j.materialIndex = null, j.geoId = m.geoId, j.materialKey = G, j.componentInfo = S, j.mcol0 = L, j.mcol1 = N, j.mcol2 = O, j.mcol3 = V, j.color = P, j.nodeIdInfo = w, j.componentKeyInfo = b, this.geomMap.push(j) } Bh.debug(this.geomMap), Bh.timeEnd("InstancedGeometryReader") }, BoneReader: function (A, e) { Bh.time("BoneReader"), this.boneMap = [], this.boneCount = new Uint32Array(A, 0, 1)[0]; for (var t = this.boneCount, i = [], o = 0, n = null, r = null, a = null, s = null, l = null, c = null, h = 0, d = null, p = 0, g = null, u = 0, f = null, m = 0, C = [], y = "[]", v = 0; t > v; v += 1) { i = {}, o = 4 * (1 + 5 * t), r = (n = new Uint32Array(A, 4 * (1 + 5 * v), 5))[0], a = n[2], s = n[3], l = n[3], c = n[4], h = o + n[1], d = new Float32Array(A.slice(h, 4 * a + h)), p = 4 * a + h, g = new Uint16Array(A.slice(p, p + 2 * s)), u = p + 2 * s, f = new Float32Array(A.slice(u, u + 4 * l)), m = u + 4 * l; var I = new Uint8Array(A.slice(m, m + c)); y = mh.isIE11() ? uh.decodeUTF8(I) : new TextDecoder("utf-8").decode(I); try { C = JSON.parse(y) } catch (A) { Bh.error("解析name出错:", A) } i.offsetMatrix = d, i.skinIndex = g, i.skinWeight = f, i.name = C, i.geoId = r, this.boneMap.push(i) } Bh.debug(this.boneMap), Bh.time("BoneReader") } }; ku.GeometryReader.prototype = { constructor: ku.GeometryReader, getPositionBuffer: function (A) { return this.geos[A].position }, getIndexBuffer: function (A) { return this.geos[A].index }, getNormalBuffer: function (A) { return this.geos[A].normal }, getUVBuffer: function (A) { return [] } }; var Du = function (A, e) { if (this.materialMap = [], np(e, "2")) this.materialMap = A; else for (var t = this.materialCount = new Uint32Array(A, 0, 1)[0], i = 4 * (1 + 6 * t), o = 0; t > o; o += 1) { var n = new Uint32Array(A, 4 * (1 + 6 * o), 6), r = n[0], a = n[1], s = n[2], l = n[3], c = n[4], h = n[5], d = new Float32Array(A.slice(i + a, 4 * s + i + a)), p = new Int16Array(A.slice(4 * s + i + a, 4 * s + i + a + 2 * l)), g = new Uint8Array(A.slice(4 * s + i + a + 2 * l, 4 * s + i + a + 2 * l + c)), u = 4 * s + i + a + 2 * l + c, f = new Int16Array(A.slice(u, u + 2 * h)), m = "[]"; m = mh.isIE11() ? uh.decodeUTF8(g) : new TextDecoder("utf-8").decode(g); var C = []; try { C = JSON.parse(m) } catch (A) { Bh.error("解析纹理出错:", A) } var y = {}; y.matId = r, y.color = d, y.colorIndex = p, y.texture = C, y.textureIndex = f, this.materialMap.push(y) } Bh.debug(this.materialMap) }, Lu = { geoHeader: function (A) { var e = new Int32Array(A); this.geoCount = e[0], this.headerBuffer = e.slice(1, 4 * this.geoCount + 1) }, GeometryReader: function (A, e) { this.geomMap = [], this.geoCount = new Uint32Array(A, 0, 1)[0]; for (var t = this.geoCount, i = [], o = 0, n = null, r = null, a = null, s = null, l = 0, c = null, h = null, d = 0, p = 0; t > p; p += 1) i = {}, o = 4 * (1 + 4 * t), r = (n = new Uint32Array(A, 4 * (1 + 4 * p), 4))[0], a = n[3], s = n[2], l = o + n[1], h = new Uint32Array(A.slice(l, l + 4 * s)), d = l + 4 * s, c = new Float32Array(A.slice(d, 4 * a + d)), i.position = c, i.index = h, i.geoId = r, this.geomMap.push(i); Bh.debug(this.geomMap) }, BoneReader: function (A, e) { this.boneMap = [], this.boneCount = new Uint32Array(A, 0, 1)[0]; for (var t = this.boneCount, i = [], o = 0, n = null, r = null, a = null, s = null, l = null, c = null, h = 0, d = null, p = 0, g = null, u = 0, f = null, m = 0, C = [], y = "[]", v = 0; t > v; v += 1) { i = {}, o = 4 * (1 + 5 * t), r = (n = new Uint32Array(A, 4 * (1 + 5 * v), 5))[0], a = n[2], s = n[3], l = n[3], c = n[4], h = o + n[1], d = new Float32Array(A.slice(h, 4 * a + h)), p = 4 * a + h, g = new Uint16Array(A.slice(p, p + 2 * s)), u = p + 2 * s, f = new Float32Array(A.slice(u, u + 4 * l)), m = u + 4 * l; var I = new Uint8Array(A.slice(m, m + c)); y = mh.isIE11() ? uh.decodeUTF8(I) : new TextDecoder("utf-8").decode(I); try { C = JSON.parse(y) } catch (A) { Bh.error("解析name出错:", A) } i.offsetMatrix = d, i.skinIndex = g, i.skinWeight = f, i.name = C, i.geoId = r, this.boneMap.push(i) } Bh.debug(this.boneMap) } }; Lu.GeometryReader.prototype = { constructor: Lu.GeometryReader, getPositionBuffer: function (A) { return this.geos[A].position }, getIndexBuffer: function (A) { return this.geos[A].index }, getNormalBuffer: function (A) { return this.geos[A].normal }, getUVBuffer: function (A) { return [] } }; var Nu = function (A) { this.MaxThreadCount = A || 8, this.todoList = [], this.doingCount = 0, this.addItem = function (A) { void 0 !== A && this.todoList.push(A) }, this.run = function (A, e, t) { if (0 >= this.doingCount) if (0 !== this.todoList.length) { var i = this.todoList, o = i.length; this.todoList = [], this.doingCount = o; for (var n = Math.min(this.MaxThreadCount, vc.ConcurrencyRequestCount, o), r = this, a = 0; n > a; a += 1) s(a) } else t(); function s(a) { o > a ? (e(r.doingCount, o), A(i[a], a + n, s)) : 1 > r.doingCount && (r.run(A, e, t), e(r.doingCount, o), t()) } } }, Ou = function (A, e) { this.type = e, this.manager = A, this.worker = new Nu(4), this.working = !0 }; function Vu(A, e, t, i) { for (var o = function (A, e) { var t = void 0; t = "Line" === e || "LineSegments" === e ? new Ba : new Ja; for (var i = new s, o = new s, n = new s, r = !0, a = !1, l = A.match(/[a-df-z][^a-df-z]*/gi), c = 0, h = l.length; h > c; c++) { var d = l[c], p = (e = d.charAt(0), d.substr(1).trim()); switch (!0 === r && (a = !0, r = !1), e) { case "M": for (var g = Gu(p), u = 0, f = g.length; f > u; u += 2) i.x = g[u + 0], i.y = g[u + 1], o.x = i.x, o.y = i.y, 0 === u ? t.moveTo(i.x, i.y) : t.lineTo(i.x, i.y), 0 === u && !0 === a && n.copy(i); break; case "H": for (g = Gu(p), u = 0, f = g.length; f > u; u++) i.x = g[u], o.x = i.x, o.y = i.y, t.lineTo(i.x, i.y), 0 === u && !0 === a && n.copy(i); break; case "V": for (g = Gu(p), u = 0, f = g.length; f > u; u++) i.y = g[u], o.x = i.x, o.y = i.y, t.lineTo(i.x, i.y), 0 === u && !0 === a && n.copy(i); break; case "L": for (g = Gu(p), u = 0, f = g.length; f > u; u += 2) i.x = g[u + 0], i.y = g[u + 1], o.x = i.x, o.y = i.y, t.lineTo(i.x, i.y), 0 === u && !0 === a && n.copy(i); break; case "C": for (g = Gu(p), u = 0, f = g.length; f > u; u += 6) t.bezierCurveTo(g[u + 0], g[u + 1], g[u + 2], g[u + 3], g[u + 4], g[u + 5]), o.x = g[u + 2], o.y = g[u + 3], i.x = g[u + 4], i.y = g[u + 5], 0 === u && !0 === a && n.copy(i); break; case "S": for (g = Gu(p), u = 0, f = g.length; f > u; u += 4) t.bezierCurveTo(Pu(i.x, o.x), Pu(i.y, o.y), g[u + 0], g[u + 1], g[u + 2], g[u + 3]), o.x = g[u + 0], o.y = g[u + 1], i.x = g[u + 2], i.y = g[u + 3], 0 === u && !0 === a && n.copy(i); break; case "Q": for (g = Gu(p), u = 0, f = g.length; f > u; u += 4) t.quadraticCurveTo(g[u + 0], g[u + 1], g[u + 2], g[u + 3]), o.x = g[u + 0], o.y = g[u + 1], i.x = g[u + 2], i.y = g[u + 3], 0 === u && !0 === a && n.copy(i); break; case "T": for (g = Gu(p), u = 0, f = g.length; f > u; u += 2) { var m = Pu(i.x, o.x), C = Pu(i.y, o.y); t.quadraticCurveTo(m, C, g[u + 0], g[u + 1]), o.x = m, o.y = C, i.x = g[u + 0], i.y = g[u + 1], 0 === u && !0 === a && n.copy(i) } break; case "A": for (g = Gu(p), u = 0, f = g.length; f > u; u += 7) { var y = i.clone(); i.x = g[u + 5], i.y = g[u + 6], o.x = i.x, o.y = i.y, qu(t, g[u], g[u + 1], g[u + 2], g[u + 3], g[u + 4], y, i), 0 === u && !0 === a && n.copy(i) } break; case "m": for (g = Gu(p), u = 0, f = g.length; f > u; u += 2) i.x += g[u + 0], i.y += g[u + 1], o.x = i.x, o.y = i.y, 0 === u ? t.moveTo(i.x, i.y) : t.lineTo(i.x, i.y), 0 === u && !0 === a && n.copy(i); break; case "h": for (g = Gu(p), u = 0, f = g.length; f > u; u++) i.x += g[u], o.x = i.x, o.y = i.y, t.lineTo(i.x, i.y), 0 === u && !0 === a && n.copy(i); break; case "v": for (g = Gu(p), u = 0, f = g.length; f > u; u++) i.y += g[u], o.x = i.x, o.y = i.y, t.lineTo(i.x, i.y), 0 === u && !0 === a && n.copy(i); break; case "l": for (g = Gu(p), u = 0, f = g.length; f > u; u += 2) i.x += g[u + 0], i.y += g[u + 1], o.x = i.x, o.y = i.y, t.lineTo(i.x, i.y), 0 === u && !0 === a && n.copy(i); break; case "c": for (g = Gu(p), u = 0, f = g.length; f > u; u += 6) t.bezierCurveTo(i.x + g[u + 0], i.y + g[u + 1], i.x + g[u + 2], i.y + g[u + 3], i.x + g[u + 4], i.y + g[u + 5]), o.x = i.x + g[u + 2], o.y = i.y + g[u + 3], i.x += g[u + 4], i.y += g[u + 5], 0 === u && !0 === a && n.copy(i); break; case "s": for (g = Gu(p), u = 0, f = g.length; f > u; u += 4) t.bezierCurveTo(Pu(i.x, o.x), Pu(i.y, o.y), i.x + g[u + 0], i.y + g[u + 1], i.x + g[u + 2], i.y + g[u + 3]), o.x = i.x + g[u + 0], o.y = i.y + g[u + 1], i.x += g[u + 2], i.y += g[u + 3], 0 === u && !0 === a && n.copy(i); break; case "q": for (g = Gu(p), u = 0, f = g.length; f > u; u += 4) t.quadraticCurveTo(i.x + g[u + 0], i.y + g[u + 1], i.x + g[u + 2], i.y + g[u + 3]), o.x = i.x + g[u + 0], o.y = i.y + g[u + 1], i.x += g[u + 2], i.y += g[u + 3], 0 === u && !0 === a && n.copy(i); break; case "t": for (g = Gu(p), u = 0, f = g.length; f > u; u += 2) { m = Pu(i.x, o.x), C = Pu(i.y, o.y); t.quadraticCurveTo(m, C, i.x + g[u + 0], i.y + g[u + 1]), o.x = m, o.y = C, i.x = i.x + g[u + 0], i.y = i.y + g[u + 1], 0 === u && !0 === a && n.copy(i) } break; case "a": for (g = Gu(p), u = 0, f = g.length; f > u; u += 7) { y = i.clone(); i.x += g[u + 5], i.y += g[u + 6], o.x = i.x, o.y = i.y, qu(t, g[u], g[u + 1], g[u + 2], g[u + 3], g[u + 4], y, i), 0 === u && !0 === a && n.copy(i) } break; case "Z": case "z": t.currentPath.autoClose = !0, t.currentPath.curves.length > 0 && (i.copy(n), t.currentPath.currentPoint.copy(i), r = !0); break; default: console.warn(d) } a = !1 } return t }(A), n = "Shape" === o.type ? [o] : o.toShapes(!0), r = new H, a = 0; n.length > a; a++) { var l = n[a]; if ("Line" === e || "LineSegments" === e) { for (var c = l.getPoints(), h = 0; c.length > h; h += 1) { var d = c[h]; d.y = -d.y, i && (d.z = i) } if ("LineSegments" === e) { var p = new jo((new De).setFromPoints(c), t); r.add(p) } else if ("Line" === e) { var g = new Go((new De).setFromPoints(c), t); r.add(g) } } else if ("Mesh" === e) { for (var u = new ar(l), f = u.getAttribute("position"), m = f.array, C = 0, y = m.length; y > C; C += 3) m[C + 1] = -m[C + 1], m[C + 2] = i; f.needsUpdate = !0; var v = new Ue(u, t); r.add(v) } } return r } function Gu(A) { for (var e = A.split(/[\s,]+|(?=\s?[+\-])/), t = 0; e.length > t; t += 1) { var i = e[t]; if (i.indexOf(".") !== i.lastIndexOf(".")) for (var o = i.split("."), n = 2; o.length > n; n += 1) e.splice(t + n - 1, 0, "0." + o[n]); e[t] = parseFloat(i) } return e } function Pu(A, e) { return A - (e - A) } function qu(A, e, t, i, o, n, r, a) { i = i * Math.PI / 180, e = Math.abs(e), t = Math.abs(t); var s = (r.x - a.x) / 2, l = (r.y - a.y) / 2, c = Math.cos(i) * s + Math.sin(i) * l, h = -Math.sin(i) * s + Math.cos(i) * l, d = e * e, p = t * t, g = c * c, u = h * h, f = g / d + u / p; if (f > 1) { var m = Math.sqrt(f); d = (e *= m) * e, p = (t *= m) * t } var C = d * u + p * g, y = Math.sqrt(Math.max(0, (d * p - C) / C)); o === n && (y = -y); var v = y * e * h / t, I = -y * t * c / e, E = Math.cos(i) * v - Math.sin(i) * I + (r.x + a.x) / 2, B = Math.sin(i) * v + Math.cos(i) * I + (r.y + a.y) / 2, x = svgAngle(1, 0, (c - v) / e, (h - I) / t), S = svgAngle((c - v) / e, (h - I) / t, (-c - v) / e, (-h - I) / t) % (2 * Math.PI); A.currentPath.absellipse(E, B, e, t, x, x + S, 0 === n, i) } function ju(A) { this.group = A; var e = new LA(16711680); this._lineMaterial = new ko({ color: e, side: 2 }), this._meshMaterial = new jA({ color: e, side: 2 }) } function Hu() { this.axisNet = void 0, this.visibleByUser = !1 } Ou.prototype = { constructor: Ou, addTask: function (A) { this.worker.addItem(A) }, processTasks: function (A, e, t) { var i = this, o = this.worker; this.worker.run((function (e, t, n) { i.working && A(e, (function () { o.doingCount -= 1, n(t) })) }), e = e || function () {}, t = t || function () {}) }, stop: function () { this.working = !1 }, start: function () { this.working = !0 } }, ju.prototype.fromJSON = function (A, e) { for (var t in A) if (A.hasOwnProperty(t)) { var i = A[t]; for (var o in i) if (i.hasOwnProperty(o)) { var n = i[o], r = n.G.Path; if (r && r.length > 0) { var a = n.P.matrix || [0, 0]; if (n.P.Type && "LINE" === n.P.Type) { for (var s = "", l = 0, c = r.length; c > l; l += 1) s += r[l]; var h = Vu(s, "LineSegments", this._lineMaterial, e); h.position.setX(a[0]), h.position.setY(-a[1]), this.group.add(h), h.updateMatrixWorld(!0) } else for (var d = 0, p = r.length; p > d; d += 1) { var g = void 0, u = Vu(r[d], g = n.G.Fill && n.G.Fill.length === p && 0 !== n.G.Fill[d].length ? "Mesh" : "Line", "Line" === g ? this._lineMaterial : this._meshMaterial, e); u.position.setX(a[0]), u.position.setY(-a[1]), this.group.add(u), u.updateMatrixWorld(!0) } } } } }, ju.prototype.setColor = function (A, e) { if (A) { var t = new LA(A); this._lineMaterial.color = t, e && (this._lineMaterial.opacity = e, this._lineMaterial.transparent = 1 !== e), this._meshMaterial.color = t, e && (this._meshMaterial.opacity = e, this._meshMaterial.transparent = 1 !== e), this._lineMaterial.needsUpdate = !0, this._meshMaterial.needsUpdate = !0 } }, ju.prototype.enableStayInFront = function () { this._lineMaterial.transparent = !0, this._meshMaterial.transparent = !0, this._lineMaterial.depthTest = !1, this._meshMaterial.depthTest = !1 }, ju.prototype.disableStayInFront = function () { this._lineMaterial.transparent = !1, this._meshMaterial.transparent = !1, this._lineMaterial.depthTest = !0, this._meshMaterial.depthTest = !0 }, Hu.prototype.setupColor = function (A, e) { A && this.axisNet.setColor(A, e) }, Hu.prototype.hide = function () { this.axisNet && (this.visibleByUser = !1, this.axisNet.group.visible = !1) }, Hu.prototype.show = function () { this.axisNet && (this.visibleByUser = !0, this.axisNet.group.visible = !0) }, Hu.prototype.privateShow = function () { this.axisNet && (this.axisNet.group.visible = !0) }, Hu.prototype.privateHide = function () { this.axisNet && (this.axisNet.group.visible = !1) }, Hu.prototype.enableStayInFront = function () { this.axisNet.enableStayInFront() }, Hu.prototype.disableStayInFront = function () { this.axisNet.disableStayInFront() }; var Yu = function () { this.name = "", this.componentkeys = [], this.box = void 0, this.center = void 0, this.map = void 0 }, Wu = function () { this.name = "", this.image = void 0, this.width = 0, this.height = 0, this.sceneWidth = 0, this.sceneHeight = 0, this.box = { x1: 0, y1: 0, z1: 0, x2: 0, y2: 0, z2: 0, offsetX: 0, offsetY: 0 }, this.componentKeys = void 0 }; Wu.prototype.clone = function () { var A = new Wu; return A.name = this.name, A.image = this.image, A.width = this.width, A.height = this.height, A.sceneWidth = this.sceneWidth, A.sceneHeight = this.sceneHeight, A.box = Object.assign({}, this.box), A.componentKeys = this.componentKeys ? [].concat(this.componentKeys) : void 0, A }, Yu.parseFloorInfos = function (A) { for (var e = [], t = Object.keys(A), i = 0, o = t.length; o > i; i += 1) { var n = A[t[i]]; if (n.length > 0) { var r = new Yu; r.componentkeys = n, r.name = t[i], e.push(r) } } if (e.length > 0) return e }; var Ju = function () { this.floors = void 0, this.sortedFloors = void 0, this.factor = 1, this.baseFloorIndex = -1, this.averageHeight = 0, this.center = void 0 }, zu = function () { function A() { cc(this, A), this.floors = void 0, this.floorExplosionInfo = void 0, this.modelType = void 0, this.modelKey = void 0, this.revitFilter = { OST_CeilingOpening: !0, OST_FloorOpening: !0, OST_RoofOpening: !0, OST_Walls: !0, OST_StructuralFraming: !0, OST_CurtainWallPanels: !0, OST_CurtainWallMullions: !0, OST_CurtaSystem: !0, OST_ShaftOpening: !0 }, this.ifcFilter = { IfcWallStandardCase: !0, IfcWall: !0, IfcCurtainWall: !0, IfcBeam: !0, IfcMember: !0 } } return dc(A, [{ key: "generateMiniMap", value: function (A) { var e = this; if ((this.modelType === Zc.RVT || this.modelType === Zc.IFC || this.modelType === Zc.MERGE) && this.floors && this.floors.length > 0) { var t = vc.MiniMapSize, i = t, o = A.rendererManager.renderer, n = new s(t, i), r = new g(n.x, n.y, { stencilBuffer: !1 }); o.setRenderTarget(r); var a = new p, l = o.getPixelRatio(); o.getViewport(a), o.setPixelRatio(1), o.setViewport(0, 0, n.width, n.height); var c = A.getScene(), h = new y, d = new y, u = A.getModel(this.modelKey).getBoundingBoxWorld(); u.getCenter(h), u.getSize(d); var f = Math.ceil(Math.max(d.x, d.y)), m = f / 2, C = new y(f, f, d.z); u.setFromCenterAndSize(h, C); var v = new Ka; v.up.set(0, 1, 0), v.position.set(h.x, h.y, u.max.z), v.lookAt(h.x, h.y, u.min.z), v.left = -m, v.right = m, v.top = m, v.bottom = -m, v.near = 1, v.far = d.z, v.updateMatrixWorld(!0), v.updateProjectionMatrix(); var I = document.createElement("canvas"); I.width = n.width, I.height = n.height; var E = I.getContext("2d"), B = new Uint8Array(n.width * n.height * 4), x = A.getFilter(); this.floors.forEach((function (a) { var s = e.findSpecificKeys(a.componentkeys, A); 0 === s.length && (s = a.componentkeys); var l = A.getBoundingBoxByIds(s); l.getCenter(h), l.getSize(d); var p = new Wu; p.box.x1 = l.min.x, p.box.y1 = l.min.y, p.box.z1 = l.min.z, p.box.x2 = l.max.x, p.box.y2 = l.max.y, p.box.z2 = l.max.z, p.box.offsetX = l.min.x - u.min.x, p.box.offsetY = l.min.y - u.min.y, p.width = t, p.height = i, p.sceneWidth = f, p.sceneHeight = f, p.name = a.name, p.componentKeys = s, a.map = p, x.setIsolateList(s, !0), A.modelManager.applyFilter(), o.render(c, v), o.readRenderTargetPixels(r, 0, 0, n.width, n.height, B); for (var g = i / 2, m = 4 * t, C = new Uint8Array(4 * t), y = 0; g > y; y += 1) { var S = y * m, w = (i - y - 1) * m; C.set(B.subarray(S, S + m)), B.copyWithin(S, w, w + m), B.set(C, w) } var M = new Uint8ClampedArray(B.buffer), b = new ImageData(M, n.width, n.height); E.putImageData(b, 0, 0), p.image = I.toDataURL() })), x.clearIsolation(), o.setRenderTarget(null), o.setPixelRatio(l), o.setViewport(a.x, a.y, a.width, a.height) } } }, { key: "findSpecificKeys", value: function (A, e) { for (var t = [], i = 0, o = A.length; o > i; i += 1) { var n = e.modelManager.getComponent(A[i]); if (n && n.length > 0) { var r = n[0], a = r.buildInCategory, s = r.type; (a && this.revitFilter[a] || s && this.ifcFilter[s]) && t.push(A[i]) } } return t } }, { key: "getMimiMaps", value: function () { if (this.serverMapData) return { msg: "success", data: this.serverMapData.data }; if (this.floors && this.floors.length > 0) { for (var A = [], e = 0, t = this.floors.length; t > e; e += 1) { var i = this.floors[e].map; i && A.push(i.clone()) } if (A.length > 0) return { msg: "success", data: A } } return { msg: "该模型不支持小地图" } } }, { key: "getServerMimiMaps", value: function (A) { var e = this.model.dataUrl.floorMapUrl(), t = this.model.accessToken, i = this; if (this.floors && this.floors.length > 0) if (this.serverMapData) A({ msg: "success", data: i.serverMapData.data }); else { var o = { url: e, success: function (e) { var t; "SUCCESS" === (t = "string" == typeof e ? JSON.parse(e) : e).code ? (i.serverMapData = t, A({ msg: "success", data: t.data })) : "FAILURE" === t.code ? setTimeout((function () { i.getServerMimiMaps(A) }), 3e3) : A({ msg: "获取模型小地图出错" }) }, error: function () { A({ msg: "该模型不支持小地图" }) } }; t && (o.headers = { Authorization: t }), _d(o) } } }]), A }(), Zu = function () { this.leftChild = null, this.rightChild = null, this.boundingBox = null, this.level = -1, this.components = [] }; Zu.prototype.init = function (A) { if (A && (void 0 !== A.axis && (this.level = A.axis), A.left && (this.leftChild = new Zu, this.leftChild.init(A.left[0] ? A.left[0] : A.left)), A.right && (this.rightChild = new Zu, this.rightChild.init(A.right[0] ? A.right[0] : A.right)), A.box && !A.items && (this.boundingBox = new aA((new y).fromArray(A.box.min), (new y).fromArray(A.box.max))), A.items)) for (var e = 0; A.items.length > e; e += 1) this.components.push(A.items[e].key) }, Zu.prototype.intersect = function (A, e) { if (this.boundingBox) { if (!1 === A.intersectsBox(this.boundingBox)) return; this.leftChild && this.leftChild.intersect(A, e), this.rightChild && this.rightChild.intersect(A, e); for (var t = 0; this.components.length > t; t += 1) e.push(this.components[t]) } else for (var i = 0; this.components.length > i; i += 1) e.push(this.components[i]) }, Zu.prototype.frustumIntersect = function (A, e, t) { if (this.boundingBox) { var i = this.boundingBox; if (t && !t.equals(Bc) && (i = this.boundingBox.clone()).applyMatrix4(t), !1 === A.intersectsBox(i)) return; this.leftChild && this.leftChild.frustumIntersect(A, e, t), this.rightChild && this.rightChild.frustumIntersect(A, e, t); for (var o = 0; this.components.length > o; o += 1) e.push(this.components[o]) } else for (var n = 0; this.components.length > n; n += 1) e.push(this.components[n]) }, Zu.prototype.destroy = function () { this.leftChild && this.leftChild.destroy(), this.rightChild && this.rightChild.destroy(), this.leftChild = null, this.rightChild = null, this.boundingBox = null, this.level = -1, this.components = [] }; var Xu = function (A) { jr.call(this), this.handler = A, this.model = A.model, this.dataVersion = this.model.dataVersion, this.storage = this.model.getStorage(), this.url = A.model.dataUrl, this.offLine = A.model.offLine, this.fileLoader = A.model.fileLoader, this.descriptor = null, this.loader = new bu(this), this.Textureloader = new bu(this), this.jsonLoader = new bu(this), this.loadTaskCount = 0, this.maxLoadTaskCount = 0, this.loadTextureCount = 0, this.maxLoadTextureCount = 0, this.textruesLoaded = !1, this.dataLoaded = !1, this.taskComponentManager = new Ou(this, "component"), this.taskReuseNodeManager = new Ou(this, "component"), this.taskGeometrieManager = new Ou(this, "geometrie"), this.taskComponentNodeManager = new Ou(this, "nodes"), this.taskMaterialManager = new Ou(this, "material"), this.taskTexturesManager = new Ou(this, "textures"), this.fileKeyFromModelKey = {}, this.enableCompressedTexture = !1, this.enableSmallTexture = !1, this.startCallback = null, this.progressCallback = null, this.finishCallback = null, this.progress = { total: 0, loaded: 0, failed: 0 }, this.requests = {} }; Xu.prototype.destroy = function () { for (var A in this.requests) this.requests.hasOwnProperty(A) && (this.requests[A].abort && this.requests[A].abort(), delete this.requests[A]); this.taskComponentManager.stop(), this.taskComponentManager = null, this.taskGeometrieManager.stop(), this.taskGeometrieManager = null, this.taskMaterialManager.stop(), this.taskMaterialManager = null, this.taskTexturesManager.stop(), this.taskTexturesManager = null, this.url = null, this.model = null, this.fileLoader = null, this.descriptor = null, this.handler = null, this.startCallback = null, this.progressCallback = null, this.finishCallback = null, this.descriptor && this.descriptor.destroy() }, Xu.prototype.getStorage = function () { return this.storage }, Xu.prototype.getDescriptor = function () { return this.descriptor }, Xu.prototype.setNotifyProgress = function (A) { this.notifyProgress = A }, Xu.prototype.load = function (A, e, t) { this.startCallback = A, this.progressCallback = e, this.finishCallback = t, this.loadData() }, Xu.prototype.loadData = function () { var A = this.model, e = A.getConfig(), t = e.scene, i = e.animation; if (!t || !t.components || !t.geometries && (!t.batchedGeometries && !t.instancedGeometries || 1 > t.batchedGeometries.length && 1 > t.instancedGeometries.length) || !t.materials || !t.textures) return A.setEmptyScene(!0), Bh.error("scene is null,modelKey is ", A.modelKey), void A.dispatchEventEx({ type: Rc.ON_LOAD_EMPTY_SCENE, modelKey: A.modelKey }); var o = 0, n = 0, r = 0, a = t.components.length || 0, s = t.materials.length || 0, l = t.textures.length || 0, c = t.lights && t.lights.length || 0, h = t.reuseNodes && t.reuseNodes.length || 0, d = [], p = [], g = [], u = [], f = [], m = [], C = [], y = t.textures, v = [], I = []; if (this.map = {}, ap(this.dataVersion, "2.0.0")) { for (var E = 0; a > E; E += 1) t.components[E].fileKey ? d.push(t.components[E].fileKey) : A.dispatchEventEx({ type: Tc.SCENE_NOT_CLOSE, modelKey: A.modelKey }); for (var B = 0; s > B; B += 1) t.materials[B].fileKey ? p.push(t.materials[B].fileKey) : A.dispatchEventEx({ type: Tc.SCENE_NOT_CLOSE, modelKey: A.modelKey }) } else d = t.components, t.geometries, p = t.materials, Array.isArray(t.nodes) && (C = t.nodes), I = t.reuseNodes || []; if (t.map && (this.map = t.map), t.lights && t.lights.length > 0 && (m = t.lights), t.trees.length > 0) for (var x = 0; t.trees.length > x; x += 1) { var S = t.trees[x]; "partition" === S.type && v.push(S.fileKey) } if (i && (o = i.bones.length, n = 1, r = 1, g = i.bones, u.push(i.clips), f.push(i.nodes)), this.maxLoadTaskCount = 0, this.maxLoadTaskCount += a, this.maxLoadTaskCount += s, this.maxLoadTaskCount += o, this.maxLoadTaskCount += n, this.maxLoadTaskCount += r, this.maxLoadTaskCount += c, this.maxLoadTaskCount += v.length, this.maxLoadTaskCount += h, this.maxLoadTaskCount += C.length, 1 > this.maxLoadTaskCount) return Bh.info("Nothing to load ", A.modelKey), void A.dispatchEventEx({ type: Tc.SCENE_NOTHING_TO_LOAD, modelKey: A.modelKey }); this.progress.total += this.maxLoadTaskCount, this.startCallback && this.startCallback(), Bh.time("数据加载时间"), this._loadComponent(d), this._loadMaterial(p), this._loadComponentNode(C), this._loadReuseNode(I), vc.EnableTextureLoading && l > 0 ? (this.maxLoadTextureCount += l, this._loadTextures(y)) : this._onLoadTexture(), this._loadKDTree(v), this._loadClips(u), this._loadBones(g), this._loadNodes(f), c && this._loadLights(m), this.offLine && this.loadAttribute(), e.axis && this._loadAxisNet(e.axis), this.loadFloorInfo(this.model.modelKey), this.loadSceneAndGeos(e) }, Xu.prototype.loadSceneAndGeos = function (A) {}, Xu.prototype.getSceneTaskCount = function (A) { return 0 }, Xu.prototype._loadLightmapConfig = function (A, e) { var t = this.model, i = this.descriptor; i && this.fileLoader.load(A, (function (A) { var o; try { o = JSON.parse(A) } catch (A) { return void console.log("Lightmap config data exceptions!") } void 0 !== o.count.lightmapNum && o.count.lightmapNum > 0 && (t.lightmapNum = o.count.lightmapNum, t.lightmap = !0, i.lightmap = !0, vc.Instance = !1, vc.EnableLightmap = !0), e && e() })) }, Xu.prototype._onTaskFinished = function () { var A = this.model; this.loadTaskCount += 1; var e = this.dealProgressSegment(A, this.loadTaskCount); this.notifyProgress && (this.progressCallback && this.progressCallback({ total: this.maxLoadTaskCount, loaded: e, modelKey: this.model.modelKey })); this.maxLoadTaskCount > this.loadTaskCount || (this.dataLoaded = !0, this.textruesLoaded && (Bh.timeEnd("数据加载时间"), this.finishCallback && this.finishCallback())) }, Xu.prototype._onLoadTexture = function () { this.loadTextureCount += 1, this.maxLoadTextureCount > this.loadTextureCount || (this.textruesLoaded = !0, this.dataLoaded && (Bh.timeEnd("数据加载时间"), this.finishCallback && this.finishCallback())) }, Xu.prototype._loadScene = function (A) { var e = this, t = this.model, i = this.url, o = this.fileLoader; o.setResponseType("arraybuffer"), o.load(i.sceneUrl(A), (function (t) { e._parseScene(t, A), e._onTaskFinished() }), void 0, (function (A) { t.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_SCENE_ERROR, event: A }), e._onTaskFinished() })) }, Xu.prototype._parseScene = function (A, e) { var t = new Loader.SceneReader(A); this.descriptor.mapSceneReader[e] = t, t = null }, Xu.prototype._loadLine = function () { var A = this, e = this.model, t = this.url, i = this.fileLoader; i.setResponseType("arraybuffer"), i.load(t.lineUrl(), (function (e) { A._parseLine(e), A._onTaskFinished() }), void 0, (function (t) { e.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_MATERIAL_ERROR, event: t }), A._onTaskFinished() })) }, Xu.prototype._parseLine = function (A) { for (var e = new Loader.LineReader(A), t = 0, i = e.header.lineCount; i > t; ++t) { var o = e.getPtBuffer(t), n = e.getIdxBuffer(t); if (void 0 !== o && void 0 !== n) { var r = e.getLineData(t); if (0 === r.lineType) { for (var a = [], s = 1, l = n.length; l > s; s++) a.push(n[s - 1]), a.push(n[s]); a.length && (n = a) } this.descriptor.cacheReferencedMeshBufferData("line-" + r.line_id, { P: o, I: n }) } else Bh.log("Error Geometry!") } e = null }, Xu.prototype._parseMaterialBinary = function (A) { var e, t = this.url, i = this.model.materialManager, o = i.materials, n = i.textures, r = new Loader.MaterialReader(A), a = r.materialCount, s = this, l = []; if (a >= 0) { var c = this.model.manager.scene; for (e = 0; a > e; ++e) { var h, d = {}, p = r.getMaterial(e); if (void 0 !== p.color && (d.color = p.color), void 0 !== p.opacity && (d.opacity = p.opacity, 1 > p.opacity && (d.transparent = !0)), void 0 !== p.side && p.side && (d.side = 2), void 0 !== p.emissive && (d.emissive = p.emissive), void 0 !== p.environment && (d.envMapIntensity = p.environment), void 0 !== p.roughness && (d.roughness = p.roughness, d.originRoughness = p.roughness), void 0 !== p.metalness && (d.metalness = p.metalness, d.originMetalness = p.metalness), vc.IBL ? (d.iblProbe = c.iblProbe, (h = new ImageBasedLighting.IBLMaterial(d)).type = "IBL") : h = Kd.createStandardMaterial(d), h.name = e, o[e] = h, d = null, vc.EnableTextureLoading) { var g = null; p.texture_n > 0 && (g = r.getTexture(p.texture_id[0])), g && l.push({ id: e, data: g }) } } if (l.length > 0) { for (a = this.maxLoadTextureCount = l.length, e = 0; a > e; e += 1) this._parseTexture(t, l[e], n); l = null } else s._onLoadTexture(); if (this.model.lightmap) { var u = this.model.lightmapNum; for (this.maxLoadTextureCount += u, e = 0; u > e; e += 1) { var f = this._loadTexture(t.textureUrl("lightmap-rgbm" + e + ".png"), (function () { s._onLoadTexture() }), void 0, (function () { s._onLoadTexture() })); i.lightmaps[e] = f } } r = null } }, Xu.prototype._parseMaterialJson = function (A) { var e, t = this.url, i = this.model.materialManager, o = i.materials, n = i.textures, r = new Loader.MaterialReaderJson(A), a = r.count, s = this, l = []; if (a >= 0) { var c = this.model.manager.scene; for (e = 0; a > e; ++e) { var h, d = {}, p = r.getMaterial(e), g = p.parameters; if (void 0 !== g.color && (d.color = g.color), void 0 !== g.opacity && (d.opacity = g.opacity, 1 > g.opacity && (d.transparent = !0)), void 0 !== g.side && "double" === g.side && (d.side = 2), void 0 !== g.emissive && (d.emissive = g.emissive), void 0 !== g.environment && (d.envMapIntensity = g.environment), void 0 !== g.roughness && (d.roughness = g.roughness, d.originRoughness = g.roughness), void 0 !== g.metalness && (d.metalness = g.metalness, d.originMetalness = g.metalness), void 0 !== g.refractionRatio && (d.refractionRatio = g.refractionRatio), void 0 !== g.imageFade && (d.imageFade = g.imageFade), this.model.lightmap && (d.lights = !1), vc.IBL ? (d.iblProbe = c.iblProbe, (h = new ImageBasedLighting.IBLMaterial(d)).type = "IBL") : (h = Kd.createStandardMaterial(d)).refreshUniforms(), h.name = e, o[e] = h, d = null, vc.EnableTextureLoading) { var u = [], f = p.textures; for (var m in f) { "reliefMap" == m && f.bumpMap || u.push({ type: m, data: f[m] }) } u.length > 0 && l.push({ id: e, dataArray: u }) } } if (l.length > 0) { for (a = l.length, e = 0; a > e; e += 1) { this.maxLoadTextureCount += (u = l[e].dataArray).length } for (e = 0; a > e; e += 1) { for (var C = l[e].id, y = [], v = 0, I = (u = l[e].dataArray).length; I > v; v++) this._parseTextureJson(t, u[v], y); n[C] = y } l = null } else s._onLoadTexture(); if (this.model.lightmap) { var E = this.model.lightmapNum; for (this.maxLoadTextureCount += E, e = 0; E > e; e += 1) { var B = this._loadTexture(t.lightmapTexUrl("lightmap-rgbm" + e + ".png"), (function () { s._onLoadTexture() }), void 0, (function () { s._onLoadTexture() })); i.lightmaps[e] = B } } r = null } }, Xu.prototype._loadTexture = function (A, e, t, i) { var o, n = Yr.Handlers.get(A), r = this; return null !== n ? o = n.load(A, e) : (o = new d, (n = new _r).setCrossOrigin("anonymous"), n.load(A, (function (A) { o.image = Kd.ensurePowerOfTwo(A), o.needsUpdate = !0, e && e(o) }), t, (function (A) { void 0 !== i && i(A), r.model.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_TEXTURE_ERROR, event: A }) }))), o }, Xu.prototype._loadCompressedTexture = function (A, e, t, i) {}, Xu.prototype._loadTextureByCrypto = function (A, e, t, i) { var o, n = Yr.Handlers.get(A), r = this; return null !== n ? o = n.load(A, e) : (o = new d, (n = new TEST.CryptoResourceLoader).loadURL(A, (function (A) { var t = new Blob([A], { type: "jpeg" }), n = new Image; n.onload = function () { o.image = Kd.ensurePowerOfTwo(n), o.needsUpdate = !0, e && e(o) }, n.onerror = function (A) { i && i(A), r.model.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_TEXTURE_ERROR, event: A }) }, n.src = URL.createObjectURL(t) }), (function (A) { void 0 !== i && i(A), r.model.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_TEXTURE_ERROR, event: A }) }))), o }, Xu.prototype._parseTexture = function (A, e, t) { var i = window.TEST || {}, o = e.id, n = e.data, r = n.id + n.file_name_ext; this.textureLoader = this.enableCompressedTexture && n.dds ? this._loadCompressedTexture : i.CryptoResourceLoader ? this._loadTextureByCrypto : this._loadTexture; var a = this; this.textureLoader(A.textureUrl(r), (function (A) { A.repeat.fromArray([n.scale_u, n.scale_v]), A.offset.fromArray([n.offset_u, n.offset_v]), A.setRotateAngle && A.setRotateAngle(n.angle), n.repeat_u && (A.wrapS = 1e3), n.repeat_v && (A.wrapT = 1e3), A && (t[o] = A), a._onLoadTexture() }), void 0, (function () { a._onLoadTexture() })) }, Xu.prototype._parseTextureJson = function (A, e, t) { var i = window.TEST || {}, o = e.type, n = e.data, r = A.textureUrl(n.sourceFile), a = this.enableSmallTexture && n.texture_small; if (!a && this.enableCompressedTexture && n.dds) this.textureLoader = this._loadCompressedTexture; else if (this.textureLoader = i.CryptoResourceLoader ? this._loadTextureByCrypto : this._loadTexture, a) { var s = r.lastIndexOf("."); r = r.substring(0, s) + "_s" + r.substring(s) } var l = this; this.textureLoader(r, (function (A) { A.repeat.fromArray([n.scale[0], n.scale[1]]), A.offset.fromArray([n.offset[0], n.offset[1]]), A.setRotateAngle && A.setRotateAngle(n.angle), n.repeatU && (A.wrapS = 1e3), n.repeatV && (A.wrapT = 1e3), A.texturetype = o, "reliefMap" == o && (A.texturetype = "bumpMap"), n.dataType && "NormalMap" == n.dataType && (A.texturetype = "normalMap"), n.alpha && (A.texturetype = "alphaMap"), n.depth && (A.depth = n.depth), A && t.push(A), l._onLoadTexture() }), void 0, (function () { l._onLoadTexture() })) }, Xu.prototype._loadUV2 = function () { var A = this, e = this.url, t = this.fileLoader; t.setResponseType("arraybuffer"), t.load(e.uv2Url(), (function (e) { A.uv2Buffer = new Uint16Array(e), A._onTaskFinished() }), void 0, (function (e) { A._onTaskFinished() })), t.setResponseType(""), t.load(e.uv2MapItemUrl(), (function (e) { A.uv2MapItem = JSON.parse(e), A._onTaskFinished() }), void 0, (function (e) { A._onTaskFinished() })) }, Xu.prototype.getUV2ById = function (A, e) { if (this.uv2MapItem && e) { var t = this.uv2MapItem[A]; if (t) { var i = t.uv1Scale, o = t.uv1Translation, n = t.uv1ByteOffset / 2, r = 2 * e; if (this.uv2Buffer) { for (var a = this.uv2Buffer.slice(n, n + r), s = [], l = 0; r > l; l += 2) s.push(i[0] * (a[l] / 65535) + o[0]), s.push(i[1] * (a[l + 1] / 65535) + o[1]); return { lightmapIdx: t.lightmapIdx, uv2: s } } } } }, Xu.prototype._loadSymbol = function () { var A = this, e = this.url, t = this.fileLoader; t.setResponseType("arraybuffer"), t.load(e.symbolUrl(), (function (e) { A.parseSymbol(e), A._onTaskFinished() }), void 0, (function (e) { A.model.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_SYMBOL_ERROR, event: e }), A._onTaskFinished() })) }, Xu.prototype.parseSymbol = function (A) { this.descriptor.symbolReader = new Loader.SymbolReader(A) }, Xu.prototype._loadOctree = function (A, e) { var t = null, i = this.model.configLoader.transformInfos.transformMatrix; this.model.configLoader.transformInfos.octreeTransformed && (t = new M).getInverse(i), A && this._loadOctreeBy(t, !1), e && this._loadOctreeBy(t, !0) }, Xu.prototype._loadOctreeBy = function (A, e) { var t, i = this, o = this.url, n = this.fileLoader; t = o.octreeUrl(e ? "i" : "o"), n.setResponseType("arraybuffer"), n.load(t, (function (t) { i._parseOctree(t, A, e), i._onTaskFinished() }), void 0, (function (A) { i.model.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_OCTREEINNER_ERROR, event: A }), i._onTaskFinished() })) }, Xu.prototype._parseOctree = function (A, e, t) { this.descriptor.octreeRootNode[t ? "inner" : "outer"] = this._getOctreeRootNode(A, e) }, Xu.prototype._getOctreeRootNode = function (A, e) { function t(A, t) { e && t.boundingBox.applyMatrix4(e), A.boundingBoxWorld = t.boundingBox.clone(), A.min = t.boundingBox.min, A.max = t.boundingBox.max, A.center = t.boundingBox.getCenter(), A.size = t.boundingBox.getSize().lengthSq(), A.childStart = t.child_s, A.childEnd = t.child_e } function i(A, e) { A.octType = 0, e.center.x > A.center.x && (A.octType += 1), e.center.y > A.center.y && (A.octType += 2), e.center.z > A.center.z && (A.octType += 4) } var o = null, n = new Loader.OctreeReader(A); if (n.getCount() > 0) { var r = n.getNode(0); t(o = new Loader.OctreeNode(r.cell_id, 0), r), function A(e, o) { for (var n = e.childEnd, r = e.childStart; n > r; ++r) { var a = o.getNode(r), s = new Loader.OctreeNode(a.cell_id, e.depth); t(s, a), e.add(s), i(s, e), s.updateMaxDepth(), A(s, o) } }(o, n) } return n = null, o }, Xu.prototype._loadUserId = function () { var A = this, e = this.url, t = this.fileLoader; t.setResponseType("arraybuffer"), t.load(e.userIdUrl(), (function (e) { A._parseUserId(e), A._onTaskFinished() }), void 0, (function (e) { A.model.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_USERID_ERROR, event: e }), A._onTaskFinished() })) }, Xu.prototype._parseUserId = function (A) { this.descriptor.userIdReader = new Loader.IdReader(A) }, Xu.prototype._loadUserData = function () { var A = this, e = this.url, t = this.fileLoader; t.setResponseType(""), t.load(e.userDataUrl(), (function (e) { A._parseUserData(e), A._onTaskFinished() }), void 0, (function (e) { A.model.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_USERDATA_ERROR, event: e }), A._onTaskFinished() })) }, Xu.prototype._parseUserData = function (A) { this.descriptor.userDataReader = new Loader.UserDataReader(A) }, Xu.prototype._loadCamera = function () { var A = this, e = this.url, t = this.fileLoader; t.setResponseType(""), t.load(e.cameraUrl(), (function (e) { A._parseCamera(e), A._onTaskFinished() }), void 0, (function (e) { A.model.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_CAMERA_ERROR, event: e }), A._onTaskFinished() })) }, Xu.prototype._parseCamera = function (A) { var e = this.model.configLoader.transformInfos.transformMatrix; new Loader.CameraReader(A).parse(this.model, e) }, Xu.prototype._parseGeo = function (A, e) { for (var t = new Loader.MPKReader(A), i = new M, o = 0, n = t.header.meshCount; n > o; ++o) { var r = t.getPtBuffer(o), a = t.getIdxBuffer(o), s = t.getNormalBuffer(o), l = t.getMeshData(o), c = t.getUVBuffer(o); null != r && null != a ? (0 !== l.baseScale && (r = new Float32Array(r), i.identity(), i.setPosition(new y(l.baseX, l.baseY, l.baseZ)), i.scale(new y(l.baseScale, l.baseScale, l.baseScale)), GeomUtil.applyMatrix4ToBuffer(i, r)), this.descriptor.cacheReferencedMeshBufferData(l.mesh_id, { P: r, I: a, N: s, UV: c }), this.descriptor.cacheReferencedMeshGeoIds(e, l.mesh_id)) : Logger.log("Error Geometry!") } t = null }, Xu.prototype._loadBorderline = function (A) { var e = this, t = this.url, i = this.fileLoader, o = t.borderLineUrl(A ? 1 : 0); i.setResponseType("arraybuffer"), i.load(o, (function (t) { e._parseBorderLine(t, A), e._onTaskFinished() }), void 0, (function (A) { e.model.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_MATERIAL_ERROR, event: A }), e._onTaskFinished() })) }, Xu.prototype._parseBorderLine = function (A, e) { for (var t = new Loader.LineReader(A), i = [], o = 0, n = t.header.lineCount; n > o; ++o) { var r = t.getLineData(o); i.push({ meshId: r.line_id, positionStart: r.ptOffset / 4, positionCount: 3 * r.ptCount, indexStart: r.idxOffset / 4, indexCount: r.idxCount }) } this.descriptor.cacheBorderLine(e, { P: t.ptBuffer, I: t.idxBuffer, IndexInfos: i }), t = null }, Xu.prototype._isLoadGeoBorderlines = function () { var A = this.model.getConfig().metadata; return !(!vc.BorderLineBatched || !A.outline_mpk) }, Xu.prototype.getAllBorderlineCount = function () { var A = this.model.getConfig().metadata; return this._isLoadGeoBorderlines() ? A.outline_mpk : A.outline_0 + A.outline_1 }, Xu.prototype._loadAllBorderlines = function (A) { this._isLoadGeoBorderlines() ? A.outline_mpk && this._loadAllGeoBorderLines(A.outline_mpk) : (A.outline_0 && this._loadBorderline(!1), A.outline_1 && this._loadBorderline(!0)) }, Xu.prototype.delayLoadBorderlines = function (A) { this.model.getConfig(); this._isLoadGeoBorderlines() ? this._delayLoadGeoBorderlines(A) : this._delayLoadTogetherBorderlines(A) }, Xu.prototype._delayLoadGeoBorderlines = function (A) { var e = this.model.getConfig().metadata; this.startCallback = null, this.progressCallback = null, this.finishCallback = A, this.loadTaskCount = 0, this.maxLoadTaskCount = e.outline_mpk, e.outline_mpk && this._loadAllGeoBorderLines(e.outline_mpk) }, Xu.prototype._delayLoadTogetherBorderlines = function (A) { var e = this.model.getConfig().metadata; this.startCallback = null, this.progressCallback = null, this.finishCallback = A, this.loadTaskCount = 0, this.maxLoadTaskCount = e.outline_0 + e.outline_1, e.outline_0 && this._loadBorderline(!1), e.outline_1 && this._loadBorderline(!0) }, Xu.prototype._loadAllGeoBorderLines = function (A) { this.mpkBorderLineTaskManager || (this.mpkBorderLineTaskManager = new Ou); for (var e = 0; A > e; ++e) this.mpkBorderLineTaskManager.addTask(e); this.mpkBorderLineTaskManager.processTasks(this._loadGeoBorderLine.bind(this)) }, Xu.prototype._loadGeoBorderLine = function (A, e) { var t = this, i = this.fileLoader, o = this.url, n = A >= this.model.getConfig().metadata.mpk_shared_index; i.setResponseType("arraybuffer"), i.load(o.mpkBorderLineUrl(A), (function (A) { t._parseGeoBorderLine(A, n), e(), t._onTaskFinished() }), void 0, (function (A) { t._onTaskFinished() })) }, Xu.prototype._parseGeoBorderLine = function (A, e) { for (var t = new Loader.LineReader(A), i = [], o = 0, n = t.header.lineCount; n > o; ++o) { var r = t.getLineData(o); i.push({ meshId: r.line_id, positionStart: r.ptOffset / 4, positionCount: 3 * r.ptCount, indexStart: r.idxOffset / 4, indexCount: r.idxCount }) } this.descriptor.cacheBorderLine(e, { P: t.ptBuffer, I: t.idxBuffer, IndexInfos: i }), t = null }, Xu.prototype.dealProgressSegment = function (A, e) { return vc.MergeComponent ? e * A.progressPercentage.load : e }, Xu.prototype._loadWireframe = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = function (t) { if (A[i[t]]) if (!0 === A[i[t]].split) { var o = A[i[t]].list, s = new Uint8Array(A[i[t]].length); n.getBatch(o, (function (A) { for (var n = !0, r = 0; o.length > r; r += 1) A[o[r]] ? s.set(new Uint8Array(A[o[r]]), 4e7 * r) : (n = !1, Bh.error("获取分割几何失败")); if (n) { var a = i[t].indexOf("fileKey="); e._parseWireframe(s.buffer, i[t].slice(a + 8)), Bh.debug("load geo from local"), e._onTaskFinished() } else { var l = e.taskGeometrieManager; if (-1 === (a = i[t].indexOf("fileKey="))) return void Bh.error("url is not has fileKey"); l.addTask(i[t].slice(a + 8)), Bh.debug("load geo from net"), e.taskGeometrieManager.processTasks(e.loadWireframe.bind(e)) } }), (function () { Bh.error("获取分割几何失败") })) } else a = i[t].indexOf("fileKey="), e._parseWireframe(A[i[t]], i[t].slice(a + 8)), Bh.debug("load geo from local"), e._onTaskFinished(); else { if (r = e.taskGeometrieManager, -1 === (a = i[t].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; r.addTask(i[t].slice(a + 8)), Bh.debug("load geo from net") } }, o = 0; i.length > o; o += 1) { var r, a, s = t(o); if ("object" === lc(s)) return s.v } e.taskGeometrieManager.processTasks(e.loadWireframe.bind(e)) }), (function () { for (var t = e.taskGeometrieManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadWireframe.bind(e)) })) } else { for (var r = this.taskGeometrieManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadWireframe.bind(e)) } }, Xu.prototype._loadGeo = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = function (t) { if (A[i[t]]) if (!0 === A[i[t]].split) { var o = A[i[t]].list, s = new Uint8Array(A[i[t]].length); n.getBatch(o, (function (A) { for (var n = 0; o.length > n; n += 1) A[o[n]] ? s.set(new Uint8Array(A[o[n]]), 4e7 * n) : Bh.error("获取分割几何失败"); var r = i[t].indexOf("fileKey="); e._parseGeometrie(s.buffer, i[t].slice(r + 8)), Bh.debug("load geo from local"), e._onTaskFinished() }), (function () { Bh.error("获取分割几何失败") })) } else a = i[t].indexOf("fileKey="), e._parseGeometrie(A[i[t]], i[t].slice(a + 8)), Bh.debug("load geo from local"), e._onTaskFinished(); else { if (r = e.taskGeometrieManager, -1 === (a = i[t].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; r.addTask(i[t].slice(a + 8)), Bh.debug("load geo from net") } }, o = 0; i.length > o; o += 1) { var r, a, s = t(o); if ("object" === lc(s)) return s.v } e.taskGeometrieManager.processTasks(e.loadGeometrie.bind(e)) }), (function () { for (var t = e.taskGeometrieManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadGeometrie.bind(e)) })) } else { for (var r = this.taskGeometrieManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadGeometrie.bind(e)) } }, Xu.prototype._loadComponentNode = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = function (t) { if (A[i[t]]) if (!0 === A[i[t]].split) { var o = A[i[t]].list, s = new Uint8Array(A[i[t]].length); n.getBatch(o, (function (A) { for (var n = 0; o.length > n; n += 1) A[o[n]] ? s.set(new Uint8Array(A[o[n]]), 4e7 * n) : Bh.error("获取分割node失败"); var r = i[t].indexOf("fileKey="); e._parseComponentNode(s.buffer, i[t].slice(r + 8)), Bh.debug("load geo from local"), e._onTaskFinished() }), (function () { Bh.error("获取分割node失败") })) } else a = i[t].indexOf("fileKey="), e._parseComponentNode(A[i[t]], i[t].slice(a + 8)), Bh.debug("load geo from local"), e._onTaskFinished(); else { if (r = e.taskComponentNodeManager, -1 === (a = i[t].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; r.addTask(i[t].slice(a + 8)), Bh.debug("load component.node from net") } }, o = 0; i.length > o; o += 1) { var r, a, s = t(o); if ("object" === lc(s)) return s.v } e.taskComponentNodeManager.processTasks(e.loadComponentNode.bind(e)) }), (function () { for (var t = e.taskComponentNodeManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadComponentNode.bind(e)) })) } else { for (var r = this.taskComponentNodeManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadComponentNode.bind(e)) } }, Xu.prototype._loadKDTree = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.kdTreeUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) { var o = i[t].indexOf("fileKey="); if (-1 === o) return void Bh.error("url is not has fileKey"); var n = i[t].slice(o + 8); A[i[t]] ? (e._parseKDTree(A[i[t]], n), Bh.debug("load kdTree from local"), e._onTaskFinished()) : (e.loadKDTree(n, (function () {})), Bh.debug("load kdtree from net")) } }), (function () { for (var t = 0; A.length > t; t += 1) e.loadKDTree(A[t], (function () {})) })) } else for (var r = 0; A.length > r; r += 1) e.loadKDTree(A[r], (function () {})) }, Xu.prototype._loadLights = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.lightUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) { var o = i[t].indexOf("fileKey="); if (-1 === o) return void Bh.error("url is not has fileKey"); var n = i[t].slice(o + 8); A[i[t]] ? (e._parseLight(A[i[t]], n), Bh.debug("load light from local"), e._onTaskFinished()) : (e.loadLight(n, (function () {})), Bh.debug("load kdtree from net")) } }), (function () { for (var t = 0; A.length > t; t += 1) e.loadLight(A[t], (function () {})) })) } else for (var r = 0; A.length > r; r += 1) e.loadLight(A[r], (function () {})) }, Xu.prototype._loadBones = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.bonesUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) if (A[i[t]]) e._parseBones(A[i[t]]), Bh.debug("load Bones from local"), e._onTaskFinished(); else { var o = i[t].indexOf("fileKey="); if (-1 === o) return void Bh.error("url is not has fileKey"); e.loadBones(i[t].slice(o + 8), (function () {})), Bh.debug("load Bones from net") } }), (function () { for (var t = 0; A.length > t; t += 1) e.loadBones(A[t], (function () {})) })) } else { for (var r = this.taskComponentManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadBones.bind(e)) } }, Xu.prototype._loadClips = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.clipsUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) if (A[i[t]]) e._parseClips(A[i[t]]), Bh.debug("load Clips from local"), e._onTaskFinished(); else { var o = i[t].indexOf("fileKey="); if (-1 === o) return void Bh.error("url is not has fileKey"); e.loadClips(i[t].slice(o + 8), (function () {})), Bh.debug("load Clips from net") } }), (function () { for (var t = 0; A.length > t; t += 1) e.loadClips(A[t], (function () {})) })) } else { for (var r = this.taskComponentManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadClips.bind(e)) } }, Xu.prototype._loadNodes = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.nodesUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) if (A[i[t]]) e._parseNodes(A[i[t]]), Bh.debug("load Nodes from local"), e._onTaskFinished(); else { var o = i[t].indexOf("fileKey="); if (-1 === o) return void Bh.error("url is not has fileKey"); e.loadNodes(i[t].slice(o + 8), (function () {})), Bh.debug("load Nodes from net") } }), (function () { for (var t = 0; A.length > t; t += 1) e.loadNodes(A[t], (function () {})) })) } else { for (var r = this.taskComponentManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadNodes.bind(e)) } }, Xu.prototype._loadComponent = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) { if (-1 === (r = i[t].indexOf("fileKey=")) && !e.offLine) return void Bh.error("url is not has fileKey"); var o = i[t].slice(r + 8); if (A[i[t]]) e._parseComponent(A[i[t]], o), Bh.debug("load com from local"), e._onTaskFinished(); else { var n = e.taskComponentManager; if (e.offLine) { var r; if (-1 === (r = i[t].indexOf("data/"))) return void Bh.error("url is not has data/"); n.addTask(i[t].slice(r + 5)) } else n.addTask(o); n.processTasks(e.loadComponent.bind(e)), Bh.debug("load com from net") } } }), (function () { for (var t = e.taskComponentManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadComponent.bind(e)) })) } else { for (var r = this.taskComponentManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadComponent.bind(e)) } }, Xu.prototype._loadReuseNode = function (A) { var e = this; if (vc.getDataFromIndexedDB) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) if (A[i[t]]) e._parseReuseNodes(A[i[t]]), Bh.debug("load com from local"), e._onTaskFinished(); else { var o = e.taskReuseNodeManager; if (e.offLine) { if (-1 === (n = i[t].indexOf("data/"))) return void Bh.error("url is not has data/"); o.addTask(i[t].slice(n + 5)) } else { var n; if (-1 === (n = i[t].indexOf("fileKey="))) return void Bh.error("url is not has fileKey"); o.addTask(i[t].slice(n + 8)) } o.processTasks(e.loadReuseNode.bind(e)), Bh.debug("load com from net") } }), (function () { for (var t = e.taskReuseNodeManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadReuseNode.bind(e)) })) } else { for (var r = this.taskReuseNodeManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadReuseNode.bind(e)) } }, Xu.prototype._loadMaterial = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) if (A[i[t]]) e._parseMaterial(A[i[t]]), Bh.debug("load mat from local"), e._onTaskFinished(); else { var o = e.taskMaterialManager, n = i[t].indexOf("fileKey="); if (-1 === n) return void Bh.error("url is not has fileKey"); o.addTask(i[t].slice(n + 8)), o.processTasks(e.loadMaterial.bind(e)), Bh.debug("load mat from net") } }), (function () { for (var t = e.taskMaterialManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadMaterial.bind(e)) })) } else { for (var r = this.taskMaterialManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadMaterial.bind(e)) } }, Xu.prototype._loadTextures = function (A) { var e = this.model.materialManager.textures, t = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var i = this.url, o = [], n = 0; A.length > n; n += 1) o.push(i.mpkUrl(A[n])); var r = this.model.getStorage(); r && r.getBatch(o, (function (A) { for (var i = 0; o.length > i; i += 1) if (A[o[i]]) { var n, r = function () { if (-1 === (n = o[i].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; var r = A[o[i]]; A[o[i]] instanceof Blob || (r = new Blob([A[o[i]]], { type: "text/plain" })); var a = o[i].slice(n + 8), s = new d; Bh.debug("load tex from local"), e[a] = s; var l = document.createElement("img"); s.wrapS = s.wrapT = 1e3, l.onload = function (e) { "string" != typeof A[o[i]] && window.URL.revokeObjectURL(l.src), t.model.textureNeedsUpdate = !0, s.image = Kd.ensurePowerOfTwo(l), t._onLoadTexture() }, l.onerror = function (A) { t.model.dispatchEventEx({ type: Tc.LOAD_TEXTURE_ERROR }) }, l.src = "string" == typeof A[o[i]] ? A[o[i]] : window.URL.createObjectURL(r), s.image = l, s.needsUpdate = !0 }(); if ("object" === lc(r)) return r.v } else { var a = t.taskTexturesManager, s = o[i].indexOf("fileKey="); if (-1 === s) return void Bh.error("url is not has fileKey"); a.addTask(o[i].slice(s + 8)), a.processTasks(t.loadTextures.bind(t)), Bh.debug("load tex from net") } }), (function () { for (var e = t.taskTexturesManager, i = 0; A.length > i; i += 1) e.addTask(A[i]); e.processTasks(t.loadTextures.bind(t)) })) } else { for (var a = this.taskTexturesManager, s = 0; A.length > s; s += 1) a.addTask(A[s]); a.processTasks(t.loadTextures.bind(t)) } }, Xu.prototype._loadAxisNet = function (A) { if (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { var t = this.url.axisNetUrl(A), i = this.model.getStorage(); i && i.getBatch([t], (function (i) { if (i[t]) e._parseAxisNet(i[t]), Bh.debug("load axisnet from local"); else { if (-1 === t.indexOf("fileKey=")) return void Bh.error("url is not has fileKey"); e.loadAxisNet(A), Bh.debug("load axisnet from net") } }), (function () { e.loadAxisNet(A) })) } else e.loadAxisNet(A) } }, Xu.prototype._parseWireframe = function (A, e) { var t = new Lu.GeometryReader(A, this.dataVersion), i = this.descriptor; if (i) { for (var o = t.geoCount, n = 0; o > n; n += 1) { var r = t.geomMap[n]; void 0 !== r.position && void 0 !== r.index ? i.cacheReferencedMeshWireframeData(r.geoId, r) : Bh.error("Error Geometry!") } t = null } }, Xu.prototype._parseGeometrie = function (A, e) { var t = this.fileKeyFromModelKey[e] || "", i = new ku.GeometryReader(A, this.dataVersion), o = this.descriptor; if (o) { for (var n = i.geoCount, r = 0; n > r; r += 1) { var a = i.geomMap[r]; void 0 !== a.position && void 0 !== a.index && void 0 !== a.normal ? (vc.DEBUG && window.geoidToFileKeyMap && (window.geoidToFileKeyMap[a.geoId] = e), o.cacheReferencedMeshBufferData(t + a.geoId, a)) : Bh.error("Error Geometry!") } i = null } }, Xu.prototype._parseComponentNode = function (A, e) { var t = this.fileKeyFromModelKey[e] || "", i = new ku.NodesReader(A, this.dataVersion), o = this.descriptor; if (o) { for (var n = i.nodeCount, r = 0; n > r; r += 1) { var a = i.geomMap[r]; void 0 !== a.matrix && void 0 !== a.material && void 0 !== a.nodeId ? o.cacheReferencedMeshComponentNodeData(t + a.nodeId, a) : Bh.error("Error Node!") } i = null } }, Xu.prototype._parseMaterial = function (A, e) { var t = this.descriptor; if (t) { var i = new Du(A, this.dataVersion); if (Array.isArray(i.materialMap)) { var o = i.materialCount; if (0 > o) return; for (var n = 0; o > n; n += 1) { var r = i.materialMap[n]; t.cacheReferencedMeshMaterialData(r.matId, r) } } else for (var a in i.materialMap) t.cacheReferencedMeshMaterialData(a, i.materialMap[a]); i = null } }, Xu.prototype._parseComponent = function (A, e) { if (A) { var t = new Uu(A), i = t.compArr.length, o = this.descriptor; if (o) { for (var n = 0; i > n; n += 1) { var r = t.compArr[n]; o.cacheReferencedMeshComponentData(r.key, r) } t = null } } else Bh.error("没有数据") }, Xu.prototype._parseKDTree = function (A, e) { var t = {}; t = "string" == typeof A ? JSON.parse(A) : A, !this.model.kdTreeNode && t && (this.model.kdTreeNode = new Zu, this.model.kdTreeNode.init(t)) }, Xu.prototype._parseLight = function (A, e) { var t, i = []; if (t = "string" == typeof A ? JSON.parse(A) : A) for (var o = 0, n = t.length; n > o; o += 1) { var r = t[o], a = void 0, s = r.pos || [0, 0, 0], l = void 0; switch (r.type) { case Fc.DirectionalLight: (a = new Ra((new LA).fromArray(r.diffuse), .5)).position.set(s[0] - r.lookat[0], s[1] - r.lookat[1], s[2] - r.lookat[2]), a.name = r.parent, 0 === r.ambient[0] && 0 === r.ambient[1] && 0 === r.ambient[2] || (l = new Ta((new LA).fromArray(r.ambient), .5)); break; case Fc.PointLight: (a = new Fa((new LA).fromArray(r.diffuse))).position.set(s[0], s[1], s[2]), a.name = r.parent, 0 === r.ambient[0] && 0 === r.ambient[1] && 0 === r.ambient[2] || (l = new Ta((new LA).fromArray(r.ambient), .5)); break; case Fc.SpotLight: (a = new ba((new LA).fromArray(r.diffuse), .5)).position.set(s[0] - r.lookat[0], s[1] - r.lookat[1], s[2] - r.lookat[2]), a.angle = r.cone_inn || Math.PI / 2, a.name = r.parent, 0 === r.ambient[0] && 0 === r.ambient[1] && 0 === r.ambient[2] || (l = new Ta((new LA).fromArray(r.ambient), .5)) } a && i.push(a), l && i.push(l) } this.model.addLights(i) }, Xu.prototype._parseNodes = function (A, e) { var t = this.descriptor; if (t) { var i = {}; i = "string" == typeof A ? JSON.parse(A) : A, Bh.debug("nodes", i), t.cacheReferencedMeshNodesData(i) } }, Xu.prototype._parseClips = function (A, e) { var t = this.descriptor; if (t) { var i = {}; i = "string" == typeof A ? JSON.parse(A) : A, Bh.debug("clips", i), t.cacheReferencedMeshClipsData(i) } }, Xu.prototype._parseBones = function (A, e) { var t = new ku.BoneReader(A), i = this.descriptor; if (i) { for (var o = t.boneCount, n = 0; o > n; n += 1) { var r = t.boneMap[n]; Bh.debug("bones", r), i.cacheReferencedMeshBoneBufferData(r.geoId, r) } t = null } }, Xu.prototype._parseAxisNet = function (A) { var e = this.model.getBoundingBoxWorld(), t = 0; e && (t = e.min.z); var i = this.model._getNodeGroup(gp.AXISNET); i.visible = !1; var o = new ju(i); o.fromJSON(A, t); var n = new Hu; n.axisNet = o, this.model.axisNetManager = n }, Xu.prototype.loadWireframe = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model, r = vc.GeoWorkerUrl; if (vc.UseGeoWorker) i.setResponseType("arraybuffer"), i.load(o.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) })); else { i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine); var a = i.load(o.mpkUrl(A), (function (i) { t._parseWireframe(i, A), Bh.debug("geo load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_GEOMETRY_ERROR, modelKey: n.modelKey }) })); t.requests.loadGeometrie = a } }, Xu.prototype.loadGeometrie = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model; i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine); var r = i.load(o.mpkUrl(A), (function (i) { t._parseGeometrie(i, A), Bh.debug("geo load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_GEOMETRY_ERROR, modelKey: n.modelKey }), e(), t._onTaskFinished() })); t.requests.loadGeometrie = r }, Xu.prototype.loadComponentNode = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model; i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine); var r = i.load(o.mpkUrl(A), (function (i) { t._parseComponentNode(i, A), Bh.debug("geo load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_COMPONENTNODE_ERROR, modelKey: n.modelKey }), e(), t._onTaskFinished() })); t.requests.loadComponentNode = r }, Xu.prototype.loadMaterial = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model, r = vc.GeoWorkerUrl; if (vc.UseGeoWorker) i.setResponseType("arraybuffer"), i.load(o.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) })); else { rp(t.dataVersion, "1") ? i.setResponseType("json") : i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine); var a = i.load(o.mpkUrl(A), (function (A) { t._parseMaterial(A), Bh.debug("met load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_MATERIAL_ERROR, modelKey: n.modelKey }) })); t.requests.loadMaterial = a } }, Xu.prototype.loadTextures = function (A, e) { var t = this.model.materialManager.textures, i = this, o = this.Textureloader, n = this.url, r = this.model, a = vc.GeoWorkerUrl; if (vc.UseGeoWorker) o.load(n.mpkUrl(A), (function (A) { var t = new Worker(a); t.onmessage = function (A) { var t = A.data; for (var o in t) t.hasOwnProperty(o); e(), i._onTaskFinished() }, t.postMessage({ msg: A }) })); else { o.setResponseType("arraybuffer"), o.setCacheViable(!this.offLine); var s = o.load(n.textureUrl(A), (function (o) { var n = o; o instanceof Blob || (n = new Blob([o], { type: "text/plain" })), Bh.debug("tex load from online"); var a = new d; t[A] = a, a.wrapS = a.wrapT = 1e3; var s = document.createElement("img"); s.onload = function (A) { "string" != typeof n && window.URL.revokeObjectURL(s.src), a.image = Kd.ensurePowerOfTwo(s), i._onLoadTexture(), e(), i.model.textureNeedsUpdate = !0 }, s.onerror = function (A) { r.dispatchEventEx({ type: Tc.LOAD_TEXTURE_ERROR, modelKey: r.modelKey }) }, s.src = "string" == typeof n ? n : window.URL.createObjectURL(n), a.image = s, a.needsUpdate = !0 }), void 0, (function (A) { r.dispatchEventEx({ type: Tc.LOAD_TEXTURE_ERROR, modelKey: r.modelKey }) })); i.requests.loadTextures = s } }, Xu.prototype.loadComponent = function (A, e) { var t = this, i = this.jsonLoader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; if (vc.UseGeoWorker) i.setResponseType("json"), i.load(n.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {})); else { i.setResponseType("json"), vc.useGzip && i.setResponseType("arraybuffer"), i.setCacheViable(!0); var a = i.load(n.mpkUrl(A), (function (i) { t._parseComponent(i, A), Bh.debug("component load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) })); t.requests.loadComponent = a } }, Xu.prototype.loadKDTree = function (A, e) { var t = this, i = this.loader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; if (vc.UseGeoWorker) i.setResponseType("json"), i.load(n.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {})); else { i.setResponseType("json"), i.setCacheViable(!this.offLine); var a = i.load(n.kdTreeUrl(A), (function (i) { t._parseKDTree(i, A), Bh.debug("kdtree load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) })); t.requests.loadKDTree = a } }, Xu.prototype.loadLight = function (A, e) { var t = this, i = this.loader, o = this.model, n = this.url; i.setResponseType("json"), i.setCacheViable(!this.offLine); var r = i.load(n.lightUrl(A), (function (i) { t._parseLight(i, A), Bh.debug("light load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) })); t.requests.loadLight = r }, Xu.prototype.loadBones = function (A, e) { var t = this, i = this.loader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; if (vc.UseGeoWorker) i.setResponseType("arraybuffer"), i.load(n.bonesUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {})); else { i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine); var a = i.load(n.bonesUrl(A), (function (A) { t._parseBones(A), Bh.debug("bones load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) })); t.requests.loadBones = a } }, Xu.prototype.loadClips = function (A, e) { var t = this, i = this.loader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; if (vc.UseGeoWorker) i.setResponseType("json"), i.load(n.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {})); else { i.setResponseType("json"), i.setCacheViable(!this.offLine); var a = i.load(n.clipsUrl(A), (function (A) { t._parseClips(A), Bh.debug("Clips load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) })); t.requests.loadClips = a } }, Xu.prototype.loadNodes = function (A, e) { var t = this, i = this.loader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; if (vc.UseGeoWorker) i.setResponseType("json"), i.load(n.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {})); else { i.setResponseType("json"), i.setCacheViable(!this.offLine); var a = i.load(n.nodesUrl(A), (function (A) { t._parseNodes(A), Bh.debug("Nodes load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) })); t.requests.loadNodes = a } }, Xu.prototype.loadAttribute = function (A, e) { var t = this, i = this.loader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; if (vc.UseGeoWorker) i.setResponseType("json"), i.load(n.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {})); else { i.setResponseType("json"), i.setCacheViable(!this.offLine); var a = i.load(n.attributeUrl(), (function (A) { if (A instanceof String) try { A = JSON.parse(A) } catch (A) {} o.attributes = A, Bh.debug("Attribute load from online") }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) })); t.requests.loadAttribute = a } }, Xu.prototype.loadGeopkOnDemand = function (A, e, t) { this.loadTaskCount = 0, this.maxLoadTaskCount = A.length, this._loadingOnDemand = !0, this.finishCallback = t; var i = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var o = this.url, n = [], r = 0; A.length > r; r += 1) n.push(o.mpkUrl(A[r])); var a = this.model.getStorage(); a && a.getBatch(n, (function (A) { for (var t = function (e) { if (A[n[e]]) if (!0 === A[n[e]].split) { var t = A[n[e]].list, o = new Uint8Array(A[n[e]].length); a.getBatch(t, (function (A) { for (var r = 0; t.length > r; r += 1) A[t[r]] ? o.set(new Uint8Array(A[t[r]]), 4e7 * r) : Bh.error("获取分割几何失败"); var a = n[e].indexOf("fileKey="); i._parseGeometrie(o.buffer, n[e].slice(a + 8)), Bh.debug("load geo from local"), i._onTaskFinished() }), (function () { Bh.error("获取分割几何失败") })) } else s = n[e].indexOf("fileKey="), i._parseGeometrie(A[n[e]], n[e].slice(s + 8)), Bh.debug("load geo from local"), i._onTaskFinished(); else { if (r = i.taskGeometrieManager, -1 === (s = n[e].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; r.addTask(n[e].slice(s + 8)), Bh.debug("load geo from net") } }, o = 0; n.length > o; o += 1) { var r, s, l = t(o); if ("object" === lc(l)) return l.v } i.taskGeometrieManager.processTasks(i.loadGeometrie.bind(i), e) }), (function () { for (var t = i.taskGeometrieManager, o = 0; A.length > o; o += 1) t.addTask(A[o]); t.processTasks(i.loadGeometrie.bind(i), e) })) } else { for (var s = this.taskGeometrieManager, l = 0; A.length > l; l += 1) s.addTask(A[l]); s.processTasks(i.loadGeometrie.bind(i), e) } }, Xu.prototype.loadAxisNet = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model; rp(t.dataVersion, "1") ? i.setResponseType("json") : i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine); var r = i.load(o.axisNetUrl(A), (function (A) { t._parseAxisNet(A), Bh.debug("axis net load from online"), e && e() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_AXISNET_ERROR, modelKey: n.modelKey }) })); t.requests.loadAxisNet = r }, Xu.prototype.loadFloorInfo = function (A, e) { var t = this; this._loadFloorInfoFromDB(A, (function (i) { i && i.data ? (t._parseFloorInfo(i), e && e(!0)) : t._loadFloorInfoFromNet(A, (function (A) { A ? (t._parseFloorInfo(A), e && e(!0)) : e && e(!1) })) })) }, Xu.prototype._loadFloorInfoFromDB = function (A, e) { if (vc.getDataFromIndexedDB && !this.offLine) { var t = this.url.floorInfoUrl(A), i = this.model.getStorage(); i && i.getBatch([t], (function (A) { A[t] ? (e(A[t]), Bh.debug("load floorinfo from local")) : e() }), (function () { e() })) } else e() }, Xu.prototype._loadFloorInfoFromNet = function (A, e) { var t = new bu(this), i = this.url, o = this.model; this.model.accessToken && t.setRequestHeader({ Authorization: this.model.accessToken }), rp(this.dataVersion, "1") ? t.setResponseType("json") : t.setResponseType("arraybuffer"), t.setCacheViable(!this.offLine); var n = t.load(i.floorInfoUrl(A), (function (A) { Bh.debug("floor info load from online"), e && e(A) }), void 0, (function (t) { o.dispatchEventEx({ type: Tc.LOAD_FLOORINFO_ERROR, modelKey: A }), e && e() })); this.requests.loadFloorInfo = n }, Xu.prototype._parseReuseNodes = function (A, e) { if (A) { vc.useGzip && (A = JSON.parse(uh.ab2str(pako.ungzip(A)))); var t = this.descriptor; t && (t.referencedMeshCache.reuseNodes = A) } else Bh.error("没有数据") }, Xu.prototype.loadReuseNode = function (A, e) { var t = this, i = this.jsonLoader, o = this.model, n = this.url; i.setResponseType("json"), vc.useGzip && i.setResponseType("arraybuffer"), i.setCacheViable(!0); i.load(n.mpkUrl(A), (function (A) { t._parseReuseNodes(A), Bh.debug("component load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) })) }, Xu.prototype._parseFloorInfo = function (A) { if (A.data && 0 !== Object.keys(A.data).length) { var e = new zu; e.floors = Yu.parseFloorInfos(A.data), e.modelKey = this.model.modelKey; var t = new Ju; t.floors = e.floors, e.floorExplosionInfo = t, e.modelType = this.model.getConfig().type, this.model.floorManager = e, e.model = this.model } }; var _u = { IfcRoof: { color: [.837255, .203922, .270588, 1] }, IfcSlab: { color: [.637255, .603922, .670588, 1] }, IfcWall: { color: [.537255, .337255, .237255, 1] }, IfcWallStandardCase: { color: [.537255, .337255, .237255, 1] }, IfcDoor: { color: [.637255, .603922, .670588, 1] }, IfcWindow: { color: [.137255, .403922, .870588, .4] }, IfcOpeningElement: { color: [.137255, .403922, .870588, .1] }, IfcRailing: { color: [.137255, .403922, .870588, 1] }, IfcColumn: { color: [.137255, .403922, .870588, 1] }, IfcBeam: { color: [.137255, .403922, .870588, 1] }, IfcFurnishingElement: { color: [.137255, .403922, .870588, 1] }, IfcCurtainWall: { color: [.137255, .403922, .870588, 1] }, IfcStair: { color: [.637255, .603922, .670588, 1] }, IfcStairFlight: { color: [.637255, .603922, .670588, 1] }, IfcBuildingElementProxy: { color: [.5, .5, .5, 1] }, IfcFlowSegment: { color: [.137255, .403922, .870588, 1] }, IfcFlowitting: { color: [.137255, .403922, .870588, 1] }, IfcFlowTerminal: { color: [.137255, .403922, .870588, 1] }, IfcProxy: { color: [.137255, .403922, .870588, 1] }, IfcSite: { color: [.137255, .403922, .870588, 1] }, IfcLightFixture: { color: [.8470588235, .8470588235, .870588, 1] }, IfcDuctSegment: { color: [.8470588235, .427450980392, 0, 1] }, IfcDistributionFlowElement: { color: [.8470588235, .427450980392, 0, 1] }, IfcDuctFitting: { color: [.8470588235, .427450980392, 0, 1] }, IfcPlate: { color: [.137255, .403922, .870588, .5] }, IfcAirTerminal: { color: [.8470588235, .427450980392, 0, 1] }, IfcMember: { color: [.8470588235, .427450980392, 0, 1] }, IfcCovering: { color: [.8470588235, .427450980392, 0, 1] }, IfcTransportElement: { color: [.8470588235, .427450980392, 0, 1] }, IfcFlowController: { color: [.8470588235, .427450980392, 0, 1] }, IfcFlowFitting: { color: [.8470588235, .427450980392, 0, 1] }, IfcRamp: { color: [.8470588235, .427450980392, 0, 1] }, IfcFurniture: { color: [.8470588235, .427450980392, 0, 1] }, IfcFooting: { color: [.8470588235, .427450980392, 0, 1] }, IfcSystemFurnitureElement: { color: [.8470588235, .427450980392, 0, 1] }, IfcSpace: { color: [.137255, .303922, .570588, .5] }, DEFAULT: { color: [.8470588235, .427450980392, 0, 1] } }, $u = function (A) { this.symbolReader = null, this.userIdReader = null, this.userDataReader = null, this.mapSceneReader = {}, this.lightmap = !1, this.mapNodeInfoByCategory = {}, this.mapNodeInfoByUserId = {}, this.mapNodeInfoByNodeId = {}, this.mapNodeInfoByComponentKey = {}, this.mapNodeInfoByParameterizedDesc = {}, this.mapNodeInfoByGeometryId = {}, this.referencedMeshCache = {}, this.componentCount = 0, this.borderLines = {}, this.octreeRootNode = { inner: null, outer: null, layer: null }, this.meshCache = {}, this.allBones = {}, this.model = A }; $u.EnumNodeItemType = { SYMBOL: 0, MESH: 1, TUBE: 2, PIPE: 3, BOX: 4, BOX_M: 5, PIPE_M: 6, MESH_REF: 7, LINE: 8 }, $u.NodeInfoCategory = { INSTANCED: 0, STANDARD: 1 }, $u.EnumDataType = { NONE: 0, MERGE_DATA: 1, LAYER: 2, LAYER_SCENE: 3, ANIMATION: 4 }, $u.EnumKeyframeTrackType = { position: "position", scale: "scale", quaternion: "quaternion", weights: "weights" }, $u.prototype.destroy = function () { this.destroyReader(), this.octreeRootNode = null, this.mapNodeInfoByCategory = {}, this.mapNodeInfoByUserId = {}, this.mapNodeInfoByNodeId = {}, this.mapNodeInfoByComponentKey = {}, this.mapNodeInfoByParameterizedDesc = {}, this.mapNodeInfoByGeometryId = {}, this.referencedMeshCache = {}, this.componentCount = 0, this.borderLines = {} }, $u.prototype.destroyReader = function () { this.userIdReader = {}, this.userDataReader = {}, this.symbolReader = {}, this.mapSceneReader = {} }, $u.prototype.getSceneReaderMap = function () { return this.mapSceneReader }, $u.prototype.isValidScene = function () { return !uh.isEmptyObject(this.getSceneReaderMap()) || (Bh.log("model load not started!"), !1) }, $u.prototype.parseItemData = function (A) { var e = this.model; (ap(e.dataVersion, "2.0.0") || void 0 === e.dataVersion) && (Bh.time("升级几何结构"), this._updateV1ToV2(e), e.dataVersion = "2.0.0", Bh.timeEnd("升级几何结构")), this._readMaterialBuffer(e), e.hasAnimation && vc.EnableAnimation ? (this._parseClips(), this._parseBones()) : this._parseGeo(); var t = {}, i = this.referencedMeshCache; for (var o in Bh.time("_readItemData"), i.bufferData && Object.keys(i.bufferData).length > 0 || A && A(), i.components) this._readItemData(t, o, o, void 0, 0); e.hasAnimation && vc.EnableAnimation && this._parseNodes(), Bh.timeEnd("_readItemData"), t = null, A && A() }, $u.prototype.asyncParseItemData = function (A) { for (var e = this.getSceneReaderMap(), t = Object.keys(e), i = t.length, o = 0, n = this, r = 0; i > r; r += 1) { var a = e[t[r]]; uh.asyncProcess(a, a.header.componentCount, 100, (function (A, e) { n._parseItemDataBy(A, e) }), (function () { (o += 1) === i && A && A() })) } }, $u.prototype._parseItemDataBy = function (A, e) { for (var t = A.getComponentInfo(e), i = t.itemIndex; t.itemCount > i; i += 1) this._readItemData(A, i, e) }, $u.prototype.parseItemDataByComponentKey = function (A) { var e = this.getSceneReaderMap(); for (var t in e) this._parseItemDataBy(e[t], A) }, $u.prototype._readItemData = function (A, e, t) { var i = this.referencedMeshCache.components[e]; void 0 !== i && -1 !== i.geoId && this._readMeshInfo(A, t, i, null) }, $u.prototype._readSymbolInfo = function (A, e, t) { var i = this.symbolReader; if (i) { var o = i.header.symbolCount, n = t.toData, r = A.getMatrixInfo(t.matrixId).matrix.clone(), a = { matrix: r, ItemId: t.ItemId, originalId: t.originalId, userDataId: t.userDataId, materialId: t.materialId }; if (n >= 0 && o > n) for (var s = i.getSymbolInfo(n), l = s.itemIndex; s.itemCount > l; l += 1) { var c = i.getItemInfo(l); c.type !== $u.EnumNodeItemType.SYMBOL && this._readMeshInfo(i, e, c, a) } r = null, a = null, i = null } }, $u.prototype._readMeshInfo = function (A, e, t, i) { var o = null, n = null; null === i ? (t.userDataId, o = t.originalId, n = t.materials || t.matId) : (i.userDataId, o = i.originalId, n = i.materialId > -1 ? i.materialId : t.materialId); var r = null; if (r = this._getMeshNodeAttr(A, t, i)) { if (t.buildInCategory && (r.buildInCategory = t.buildInCategory), r.userId = e, r.name = t.name, r.type = t.type, r.componentKey = e, r.originalId = o, r.materialId = n, r.state = Lc.Visible, r.material = null, r.originMId = n, r.userData = null, r.categoryId = 0, r.familyName = t.familyName, r.familySymbol = t.familySymbol, this.lightmap) { var a = t.ItemId; i && (a = i.ItemId + "_" + t.ItemId), r.itemIdUV2 = a } r.instanceOrNot = !1, this._classifyNodeInfo(r), r = null } }, $u.prototype._getMeshNodeAttrOfPipe = function (A, e, t) { var i = A.getMatrixInfo(e.matrixId).matrix.clone(); t && i.multiplyMatrices(t.matrix, i); var o = e.boundingBox.clone(); o.applyMatrix4(i); var n = A.getGeomPipeInfo(e.toData), r = n.startPt, a = n.endPt, s = new y; s.subVectors(a, r); var l = s.length(); s.normalize(); var c = n.radius; c > 1 || (c = 100); var h = new y(0, 1, 0), d = new y(c, l, c), p = (new f).setFromUnitVectors(h, s), g = r.clone().addScaledVector(s, .5 * l), u = (new M).compose(g, p, d); return i.multiply(u), n = null, { nodeId: (t ? t.ItemId + "_" + e.ItemId : e.ItemId) + "_pipe", geometryId: "pipe", boundingBox: o, matrix: i } }, $u.prototype._getMeshNodeAttrOfTube = function (A, e, t) { var i = this._getMeshNodeAttrOfPipe(A, e, t); return i.nodeId += "_tube", i.geometryId = "tube", i }, $u.prototype._getMeshNodeAttrOfBox = function (A, e, t) { var i = A.getMatrixInfo(e.matrixId).matrix.clone(); t && i.multiplyMatrices(t.matrix, i); var o = e.boundingBox.clone(); o.applyMatrix4(i); var n = e.boundingBox, r = n.getSize(), a = n.getCenter(), s = (new M).scale(new y(r.x, r.y, r.z)); return s.setPosition(a), i.multiply(s), { nodeId: (t ? t.ItemId + "_" + e.ItemId : e.ItemId) + "_box", geometryId: "box", boundingBox: o, matrix: i } }, $u.prototype._getMeshNodeAttrOfBoxM = function (A, e, t) { var i = A.getMatrixInfo(e.matrixId).matrix.clone(); t && i.multiplyMatrices(t.matrix, i); var o = e.boundingBox.clone(); return o.applyMatrix4(i), { nodeId: (t ? t.ItemId + "_" + e.ItemId : e.ItemId) + "_boxM", geometryId: "boxM", boundingBox: o, matrix: i, uvArrayBuffer: A.getGeomBoxUvInfo(e.toData) } }, $u.prototype._getMeshNodeAttrOfPipeM = function (A, e, t) { var i = A.getMatrixInfo(e.matrixId).matrix.clone(); t && i.multiplyMatrices(t.matrix, i); var o = e.boundingBox.clone(); return o.applyMatrix4(i), { nodeId: (t ? t.ItemId + "_" + e.ItemId : e.ItemId) + "_pipeM", geometryId: "pipeM", boundingBox: o, matrix: i, uvArrayBuffer: A.getGeomPipeUvInfo(e.toData) } }, $u.prototype._getMeshNodeAttrOfMeshRef = function (A, e, t) { var i = A.getMatrixInfo(e.matrixId).matrix.clone(); t && i.multiplyMatrices(t.matrix, i); var o = e.boundingBox.clone(); return o.applyMatrix4(i), { nodeId: "refMesh|" + (t ? t.ItemId + "_" + e.ItemId : e.ItemId), geometryId: e.toData, boundingBox: o, matrix: i } }, $u.prototype._getMeshNodeAttr = function (A, e, t, i) { var o = new M; o.fromArray(e.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]), vc.DataReduction && o.scale(new y(1e3, 1e3, 1e3)); var n = t ? e.key + "_" + i : e.key, r = t ? e.geoId + "_" + i : e.geoId; if (-1 !== r) { var a = new ph, s = this.getReferencedMeshBufferById(e.geoId); return s && s.position ? (a = Tu.getBoundingBoxByBuffer(s.position)).applyMatrix4(o) : Bh.error("没有找到对应几何"), { nodeId: n, guid: e.guid, geometryId: r, originalGeometryId: e.geoId, matrix: o, boundingBox: a, model: this.model } } }, $u.prototype._getComponentNodeAttr = function (A, e) { var t = new M; t.fromArray(A.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]), vc.DataReduction && t.scale(new y(1e3, 1e3, 1e3)), e && t.multiplyMatrices(e.matrix, t); var i = A.nodeId, o = A.geoId; if (-1 !== o) { var n = A.maxBoundary || e.maxBoundary, r = A.minBoundary || e.minBoundary, a = new ph; return a.set(r, n), { nodeId: i, guid: A.guid, geometryId: o, originalGeometryId: A.geoId, matrix: t, boundingBox: a, model: this.model } } }, $u.prototype._getLineNodeAttr = function (A, e, t) { var i = e.boundingBox.clone(), o = null; return -1 !== e.matrixId ? (o = A.getMatrixInfo(e.matrixId).matrix.clone(), t && o.multiplyMatrices(t.matrix, o), i.applyMatrix4(o)) : (o = new M, t && i.applyMatrix4(t.matrix)), { nodeId: t ? "line-" + t.ItemId + "-" + e.ItemId : "line-" + e.ItemId, geometryId: "line-" + e.toData, boundingBox: i, matrix: o } }, $u.prototype._classifyNodeInfo = function (A) { this._cacheNodeInfoByComponentKey(A), this._cacheNodeInfoByNodeId(A), this._cacheNodeInfoByUserId(A), this._cacheNodeInfoByCategory(A), this._cacheNodeInfoByParameterizedDesc(A) }, $u.prototype._cacheNodeInfoByComponentKey = function (A) { void 0 === this.mapNodeInfoByComponentKey[A.componentKey] && (this.mapNodeInfoByComponentKey[A.componentKey] = []), this.mapNodeInfoByComponentKey[A.componentKey].push(A) }, $u.prototype._cacheNodeInfoByUserId = function (A) { void 0 === this.mapNodeInfoByUserId[A.userId] && (this.mapNodeInfoByUserId[A.userId] = []), this.mapNodeInfoByUserId[A.userId].push(A) }, $u.prototype._cacheNodeInfoByNodeId = function (A) { this.mapNodeInfoByNodeId[A.nodeId] = A }, $u.prototype._cacheNodeInfoByCategory = function (A) { var e = null; void 0 === this.mapNodeInfoByCategory[e = A.instanceOrNot ? $u.NodeInfoCategory.INSTANCED : $u.NodeInfoCategory.STANDARD] && (this.mapNodeInfoByCategory[e] = {}), void 0 === this.mapNodeInfoByCategory[e][A.userId] && (this.mapNodeInfoByCategory[e][A.userId] = []), this.mapNodeInfoByCategory[e][A.userId].push(A) }, $u.prototype._cacheNodeInfoByParameterizedDesc = function (A) { A.parameterizedDesc && (void 0 === this.mapNodeInfoByParameterizedDesc[A.type] && (this.mapNodeInfoByParameterizedDesc[A.type] = []), this.mapNodeInfoByParameterizedDesc[A.type].push(A)) }, $u.prototype._clearNodeInfoCacheWithParameterizedDesc = function (A) { if (A) for (var e = 0, t = A.length; t > e; e += 1) delete this.mapNodeInfoByParameterizedDesc[A[e]]; else this.mapNodeInfoByParameterizedDesc = {} }, $u.prototype._clearNodeInfoCacheWithComponentKey = function (A) { if (A) for (var e = 0, t = A.length; t > e; e += 1) delete this.mapNodeInfoByComponentKey[A[e]]; else this.mapNodeInfoByComponentKey = {} }, $u.prototype._clearNodeInfoCacheWithCategory = function (A) { if (A) for (var e = this.mapNodeInfoByCategory[$u.NodeInfoCategory.INSTANCED], t = this.mapNodeInfoByCategory[$u.NodeInfoCategory.STANDARD], i = 0, o = A.length; o > i; i += 1) e && delete e[A[i]], t && delete t[A[i]]; else this.mapNodeInfoByCategory = {} }, $u.prototype.clearNodeInfoCacheByComponentsKey = function (A) { this._clearNodeInfoCacheWithComponentKey(A), this._clearNodeInfoCacheWithUserId(A), this._clearNodeInfoCacheWithCategory(A) }, $u.prototype._clearNodeInfoCacheWithUserId = function (A) { if (A) for (var e = 0, t = A.length; t > e; e += 1) delete this.mapNodeInfoByUserId[A[e]], delete this.mapNodeInfoByNodeId[A[e]]; else this.mapNodeInfoByUserId = {}; this.mapNodeInfoByUserId = {} }, $u.prototype.clearNodeInfoCache = function () { this._clearNodeInfoCacheWithComponentKey(), this._clearNodeInfoCacheWithUserId(), this._clearNodeInfoCacheWithCategory() }, $u.prototype.getNodeInfosByComponentKey = function (A) { return this.mapNodeInfoByComponentKey[A] }, $u.prototype.getNodeInfosWithComponentKey = function () { return this.mapNodeInfoByComponentKey }, $u.prototype.getAllNodeInfos = function () { return this.mapNodeInfoByUserId }, $u.prototype.getNodeInfosByUserId = function (A) { return this.mapNodeInfoByUserId[A] }, $u.prototype.getNodeInfosByNodeId = function (A) { return this.mapNodeInfoByNodeId[A] }, $u.prototype.getNodeInfosWithUserId = function () { return this.mapNodeInfoByUserId }, $u.prototype.getStandardNodeInfos = function () { return this.mapNodeInfoByCategory[$u.NodeInfoCategory.STANDARD] }, $u.prototype.getInstancedNodeInfos = function () { return this.mapNodeInfoByCategory[$u.NodeInfoCategory.INSTANCED] }, $u.prototype.getStandardUserIds = function () { return this.getStandardNodeInfos() ? Object.keys(this.getStandardNodeInfos()) : [] }, $u.prototype.getInstancedUserIds = function () { return this.getInstancedNodeInfos() ? Object.keys(this.getInstancedNodeInfos()) : [] }, $u.prototype.getStandardNodeInfosById = function (A) { var e = this.getStandardNodeInfos(); return e ? e[A] : null }, $u.prototype.getInstancedNodeInfosById = function (A) { var e = this.getInstancedNodeInfos(); return e ? e[A] : null }, $u.prototype._getUserIdsByCategory = function (A, e) { var t = [], i = null; if (i = e === $u.NodeInfoCategory.INSTANCED ? this.getInstancedNodeInfos() : this.getStandardNodeInfos()) for (var o = 0, n = A.length; n > o; o += 1) i[A[o]] && t.push(A[o]); return t }, $u.prototype.getInstancedUserIdsByCategory = function (A) { return this._getUserIdsByCategory(A, $u.NodeInfoCategory.INSTANCED) }, $u.prototype.getStandardUserIdsByCategory = function (A) { return this._getUserIdsByCategory(A, $u.NodeInfoCategory.STANDARD) }, $u.prototype._traverseNodeInfosByIds = function (A, e, t) { for (var i = 0, o = e.length; o > i; i += 1) { var n = e[i]; t(n, A[n]) } }, $u.prototype.traverseStandardNodeInfos = function (A, e) { var t = this.getStandardNodeInfos(); t && (A = A || this.getStandardUserIds(), this._traverseNodeInfosByIds(t, A, e)) }, $u.prototype.traverseInstancedNodeInfos = function (A, e) { var t = this.getInstancedNodeInfos(); t && (A = A || this.getInstancedUserIds(), this._traverseNodeInfosByIds(t, A, e)) }, $u.prototype.traverseNodeInfosByComponent = function (A) { for (var e = Object.keys(this.mapNodeInfoByComponentKey), t = 0, i = e.length; i > t; t += 1) for (var o = e[t], n = this.mapNodeInfoByComponentKey[o], r = 0, a = n.length; a > r; r += 1) A(o, n[r]) }, $u.prototype.clearReferencedMeshCache = function () { if (!vc.DEBUG) { for (var A in this.referencedMeshCache) delete this.referencedMeshCache[A]; this.referencedMeshCache = null } }, $u.prototype.cacheReferencedMeshBufferData = function (A, e) { this.referencedMeshCache.bufferData || (this.referencedMeshCache.bufferData = {}), this.referencedMeshCache.bufferData[A] = e }, $u.prototype.cacheReferencedMeshComponentNodeData = function (A, e) { this.referencedMeshCache.componentNode || (this.referencedMeshCache.componentNode = {}), this.referencedMeshCache.componentNode[A] = e }, $u.prototype.cacheReferencedMeshWireframeData = function (A, e) { this.referencedMeshCache.wireframeData || (this.referencedMeshCache.wireframeData = {}), this.referencedMeshCache.wireframeData[A] = e }, $u.prototype.getReferencedMeshBufferData = function () { return this.referencedMeshCache.bufferData }, $u.prototype.getReferencedMeshBufferById = function (A) { return this.referencedMeshCache && this.referencedMeshCache.bufferData ? this.referencedMeshCache.bufferData[A] : null }, $u.prototype.getReferencedMeshComponentNodeById = function (A) { return this.referencedMeshCache && this.referencedMeshCache.componentNode ? this.referencedMeshCache.componentNode[A] : null }, $u.prototype.getReferencedMeshWireframeDataById = function (A) { return this.referencedMeshCache && this.referencedMeshCache.wireframeData ? this.referencedMeshCache.wireframeData[A] : null }, $u.prototype.cacheReferencedMeshBoneBufferData = function (A, e) { this.referencedMeshCache.bones || (this.referencedMeshCache.bones = {}), this.referencedMeshCache.bones[A] = e }, $u.prototype.cacheReferencedMeshClipsData = function (A) { this.referencedMeshCache.clips = A }, $u.prototype.cacheReferencedMeshNodesData = function (A) { this.referencedMeshCache.nodes = A }, $u.prototype.cacheReferencedMeshComponentData = function (A, e) { this.referencedMeshCache.components || (this.referencedMeshCache.components = {}), this.referencedMeshCache.components[A] = e }, $u.prototype.cacheReferencedMeshMaterialData = function (A, e) { this.referencedMeshCache.materials || (this.referencedMeshCache.materials = {}), this.referencedMeshCache.materials[A] = e }, $u.prototype.cacheReferencedMeshGeoIds = function (A, e) { this.referencedMeshCache.mpkIds || (this.referencedMeshCache.mpkIds = {}), this.referencedMeshCache.mpkIds[A] || (this.referencedMeshCache.mpkIds[A] = []), this.referencedMeshCache.mpkIds[A].push(e) }, $u.prototype.clearReferencedMeshCacheByGeopkIdxs = function (A, e) { if (this.referencedMeshCache.mpkIds) for (var t = 0, i = A.length; i > t; t += 1) { var o = A[t], n = this.referencedMeshCache.mpkIds[o]; if (n) { for (var r = 0, a = n.length; a > r; r += 1) e && e(n[r]), delete this.referencedMeshCache[n[r]]; delete this.referencedMeshCache.mpkIds[o] } } }, $u.prototype.cacheBorderLine = function (A, e) { var t = A ? "shared" : "unique"; this.borderLines[t] || (this.borderLines[t] = []), this.borderLines[t].push(e) }, $u.prototype.getSharedBorderLineCache = function () { return this.borderLines.shared }, $u.prototype.getUniqueBorderLineCache = function () { return this.borderLines.unique }, $u.prototype._isRegularShape = function (A) { return A.type === $u.EnumNodeItemType.TUBE || A.type === $u.EnumNodeItemType.PIPE || A.type === $u.EnumNodeItemType.BOX || A.type === $u.EnumNodeItemType.BOX_M || A.type === $u.EnumNodeItemType.PIPE_M }, $u.prototype._isInstancedNode = function (A) { return !!vc.Instance && (A.type === $u.EnumNodeItemType.MESH_REF ? !!vc.SharedMeshInstanceEnable : !!A.parameterizedDesc) }, $u.prototype.getComponentCount = function () { return this.componentCount }, $u.prototype.getOctreeRootNode = function () { return this.octreeRootNode }, $u.prototype.isUseInnerAndOuterOctree = function () { return !0 }, $u.prototype.isOctreeOuter = function (A) { var e = this.octreeRootNode.inner || this.octreeRootNode.outer; return !(e.min.x > A.x || A.x > e.max.x || e.min.y > A.y || A.y > e.max.y || e.min.z > A.z || A.z > e.max.z) }, $u.prototype.getOctreeRoots = function (A) { this.octreeRootNode.outer && A.push(this.octreeRootNode.outer), this.octreeRootNode.inner && A.push(this.octreeRootNode.inner) }, $u.prototype.updateOctreeNodeBy = function (A, e) { var t = new aA; function i(A, e) { t.copy(A.boundingBoxWorld), t.applyMatrix4(e), A.min.copy(t.min), A.max.copy(t.max), A.center = t.getCenter(), A.size = t.getSize().lengthSq() } i(A, e), function A(e, t) { for (var o = 0, n = e.childOctants.length; n > o; o += 1) { var r = e.childOctants[o]; i(r, t), A(r, t) } }(A, e) }, $u.prototype.updateOctreeNode = function (A) { var e = this.getOctreeRootNode(); e.outer && this.updateOctreeNodeBy(e.outer, A), e.inner && this.updateOctreeNodeBy(e.inner, A) }, $u.prototype.removeFromSceneReaderMap = function (A) { for (var e = 0, t = A.length; t > e; e += 1) this.mapSceneReader[A[e]] && delete this.mapSceneReader[A[e]] }, $u.prototype.isUserIdExist = function (A) { return !!this.getNodeInfosByUserId(A) }, $u.prototype.addToNodeInfoMap = function (A) { for (var e = 0, t = A.length; t > e; e += 1) this._cacheNodeInfoByUserId(A[e]) }, $u.prototype.removeFromNodeInfoMap = function (A) { for (var e = this.getAllNodeInfos(), t = 0, i = A.length; i > t; t += 1) { var o = A[t].userId; e[o] && delete e[o] } }, $u.prototype.cacheNodeInfosOnGeometryId = function () { var A = this.getStandardNodeInfos(); for (var e in this.mapNodeInfoByGeometryId = {}, A) for (var t = A[e], i = 0, o = t.length; o > i; i += 1) t[i].geometryId = this.convertGeometryId(t[i].geometryId), this.mapNodeInfoByGeometryId[t[i].geometryId] || (this.mapNodeInfoByGeometryId[t[i].geometryId] = []), this.mapNodeInfoByGeometryId[t[i].geometryId].push(t[i]) }, $u.prototype.getNodeInfosOnGeometryId = function () { return this.mapNodeInfoByGeometryId || this.cacheNodeInfosOnGeometryId(), this.mapNodeInfoByGeometryId }, $u.prototype.clearNodeInfosWithGeometryId = function () { this.mapNodeInfoByGeometryId = {} }, $u.prototype.convertGeometryId = function (A) { return A }, $u.prototype._readMaterialBuffer = function (A) { var e = A.materialManager, t = e.materials, i = e.textures, o = this.referencedMeshCache.materials; for (var n in o) { var r = o[n]; if (!r) return null; var a = Kd.createMaterialByMaterialBufferAndTexture(r, i); a.refreshUniforms && a.refreshUniforms(), t[n] = a, vc.EnableShadow && A.manager.viewerImpl.rendererManager.csm && A.manager.viewerImpl.rendererManager.csm.setupMaterial(a) } }, $u.prototype._updateV1ToV2 = function () { var A = this.referencedMeshCache.components, e = this.referencedMeshCache.bufferData, t = this.referencedMeshCache.materials; for (var i in A) if (A.hasOwnProperty(i)) { var o = A[i], n = o.matId, r = e[o.geoId]; if (o.materials) continue; if (o.materials = [], !r) continue; var a = t[n]; if (!a) continue; var s = this._updateMaterialV1ToV2(n, a); if (s) for (var l in r.materialIndex = s.materialIndex, o.materials = s.materialId, s.materials) s.materials.hasOwnProperty(l) && (this.referencedMeshCache.materials[l] = s.materials[l]) } }, $u.prototype._updateMaterialV1ToV2 = function (A, e) { var t = {}, i = [], o = {}; if (!e) return null; for (var n = e.color, r = e.colorIndex, a = e.texture, s = e.textureIndex, l = 0; n.length > l; l += 4) { var c = {}; c.color = [n[l], n[l + 1], n[l + 2]], c.opacity = Math.floor(100 * n[l + 3]) / 100, c.transparent = 1 > n[l + 3]; var h = (255 * c.color[0] << 16 ^ 255 * c.color[1] << 8 ^ 255 * c.color[2] << 0) + "_" + c.opacity; o[h] = c, i.push(h) } if (0 !== a.length && r.length === s.length) for (var d = -1, p = 0; s.length > p; p += 1) if (d !== r[p] && (d = r[p], -1 !== s[p])) { var g = i[r[p]], u = a[s[p]]; if (o[g].map = u, -1 === g.indexOf(u)) { var f = g + "_" + a[s[p]]; o[f] = o[g], i.length > Object.keys(o).length - 1 || delete o[g], i[r[p]] = f } } return t.materials = o, t.materialId = i, t.materialIndex = r, t }, $u.prototype._computeVertexNormalsFromFaceNormals = function (A, e, t) { for (var i = new Float32Array(t), o = 0, n = 0, r = 0, a = 0, s = 0, l = 0, c = 0; A.length > c; c += 3) s = A[c + 1], l = A[c + 2], n = 3 * e[c + 1], r = 3 * e[c + 2], i[o = 3 * e[c]] = a = A[c], i[o + 1] = s, i[o + 2] = l, i[n] = a, i[n + 1] = s, i[n + 2] = l, i[r] = a, i[r + 1] = s, i[r + 2] = l; return i }, $u.prototype._computeVertexNormalsFromIndex = function (A, e, t) { var i = new Float32Array(e.length); if (e) { var o = 0, n = 0, r = 0, a = new y, s = new y, l = new y, c = new y, h = new y; if (A) for (var d = A, p = 0; d.length > p; p += 3) n = 3 * d[p + 1], r = 3 * d[p + 2], a.fromArray(e, o = 3 * d[p]), s.fromArray(e, n), l.fromArray(e, r), c.subVectors(l, s), h.subVectors(a, s), c.cross(h), i[o] += c.x, i[o + 1] += c.y, i[o + 2] += c.z, i[n] += c.x, i[n + 1] += c.y, i[n + 2] += c.z, i[r] += c.x, i[r + 1] += c.y, i[r + 2] += c.z; else for (var g = 0, u = e.length; u > g; g += 9) a.fromArray(e, g), s.fromArray(e, g + 3), l.fromArray(e, g + 6), c.subVectors(l, s), h.subVectors(a, s), c.cross(h), i[g] = c.x, i[g + 1] = c.y, i[g + 2] = c.z, i[g + 3] = c.x, i[g + 4] = c.y, i[g + 5] = c.z, i[g + 6] = c.x, i[g + 7] = c.y, i[g + 8] = c.z } return i }, $u.prototype.addMeshToInfoMap = function (A, e, t, i, o) { var n = this.getNodeInfosByComponentKey(A); Array.isArray(n) && n.forEach((function (A) { A.nodeId === e && (A.mesh = t, A.index = i, A.uv = A.uv || o) })) }, $u.prototype._parseGeo = function () { Bh.time("处理几何:计算法线"); var A = this.referencedMeshCache; for (var e in A.bufferData) { var t = A.bufferData[e]; t.position.length !== t.normal.length && (t.normal = t.normal.length === t.index.length ? this._computeVertexNormalsFromFaceNormals(t.normal, t.index, t.position.length) : this._computeVertexNormalsFromIndex(t.index, t.position)) } Bh.timeEnd("处理几何:计算法线") }, $u.prototype._parseBones = function () { var A = this.referencedMeshCache; for (var e in A._offsetMatrix || (A._offsetMatrix = {}), A.bufferData) { var t = A.bufferData[e]; t.position.length !== t.normal.length && (t.normal = t.normal.length === t.index.length ? this._computeVertexNormalsFromFaceNormals(t.normal, t.index, t.position.length) : this._computeVertexNormalsFromIndex(t.index, t.position)); var i = A.bones[e]; if (i) { t.skinIndex = i.skinIndex, t.skinWeight = i.skinWeight; var o = i.name; i.offsetMatrix.length / 16 !== o.length && Bh.debug("bones的name数量与Matrix数量不符!"); for (var n = 0; o.length > n; n += 1) A._offsetMatrix[o[n]] = (new M).fromArray(i.offsetMatrix, 16 * n) } } }, $u.prototype._parseClips = function () { for (var A = this.referencedMeshCache.clips, e = [], t = 0, i = A.length; i > t; t += 1) { for (var o = [], n = A[t], r = 0, a = n.tracks.length; a > r; r += 1) { var s = n.tracks[r], l = null; switch (s.type) { case $u.EnumKeyframeTrackType.weights: l = Dr; break; case $u.EnumKeyframeTrackType.quaternion: l = Nr; break; case $u.EnumKeyframeTrackType.position: case $u.EnumKeyframeTrackType.scale: default: l = Vr } if (0 === n.ticksPerSec) { n.ticksPerSec = 1e3; for (var c = 0; s.times.length > c; c += 1) s.times[c] /= n.ticksPerSec } var h = new l(Fs.sanitizeNodeName(s.name) + "." + s.type, s.times, s.values, 2301); o.push(h) } var d = new Gr(void 0 !== n.name ? n.name : "animation_" + t, n.duration / n.ticksPerSec, o); e.push(d) } this.model.animations = e }, $u.prototype._parseNodes = function () { var A = this.referencedMeshCache; A.allBones = [], A.offsetMatrix = []; var e = function A(e, t) { var i = null; "node" === e.type ? i = new H : "bone" === e.type && (i = new Uo, t.allBones[e.name] = i), i.name = Fs.sanitizeNodeName(e.name), i.matrix.fromArray(e.transformation || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]), i.matrix.decompose(i.position, i.quaternion, i.scale); for (var o = 0; e.children.length > o; o += 1) { var n = A(e.children[o], t); n && i.add(n) } for (var r = 0; e.meshes.length > r; r += 1) { var a = e.meshes[r]; t.model._getHandler().defaultManager.meshManager._readBufferInfo(t.model, [t.model.modelKey + "_" + e.meshes[r]]); var s = t.model._getHandler().defaultManager.meshManager._makeSkinMesh(t.model, [t.model.modelKey + "_" + e.meshes[r]], (function (A) {})); t.meshCache[a] = s, s.name = e.name, i.add(s) } return i }(A.nodes, this); for (var t in A.bufferData) { var i = this.meshCache[t]; if (i && i.isSkinnedMesh) { for (var o = [], n = [], r = 0; A.bones[t].name.length > r; r += 1) { var a = A.bones[t].name[r], s = A._offsetMatrix[a], l = this.allBones[a]; s && l && (o.push(l), n.push(s)) } var c = new bo(o, n); i.bind(c, i.matrixWorld) } } this.model.nodes = e, this.model.manager.getScene().onBeforeRender = function (A, e, t, i) { e.updateMatrixWorld(!0) }, this.model.group.add(e), (c = new _s(e)).visible = !1, this.model.skeleton = c, this.model.group.add(c), this.model.mixer = new Rs(e), this.model.actions = []; for (var h = 0; this.model.animations.length > h; h += 1) { var d = this.model.mixer.clipAction(this.model.animations[h]); this.model.actions.push(d) } }; var Af = function (A) { $u.call(this, A), this.instancedComponent = {} }; Object.assign(Af.prototype, $u.prototype), Af.prototype.parseItemData = function (A) { var e = this.model; (ap(e.dataVersion, "2.0.0") || void 0 === e.dataVersion) && (Bh.time("升级几何结构"), this._updateV1ToV2(e), e.dataVersion = "2.0.0", Bh.timeEnd("升级几何结构")), this._readMaterialBuffer(e), e.hasAnimation && vc.EnableAnimation ? (this._parseClips(), this._parseBones()) : (this._parseGeo(), vc.Instance && sp(e.dataVersion, "2.0.0") && this._parseInstanced()); var t = {}, i = this.referencedMeshCache; if (Bh.time("_readItemData"), !i.bufferData || 0 >= Object.keys(i.bufferData).length) return Bh.warn("缺少几何数据"), !0; for (var o in i.components) this._readItemData(t, o, o, void 0, 0); Bh.timeEnd("_readItemData"), t = null, A && A() }, Af.prototype._readMeshInfo = function (A, e, t, i) { var o = this.model.materialManager.materials, n = null, r = null, a = null, s = this.referencedMeshCache; if (t.nodes || t.nodeIds) { r = t.originalId; var l = t, c = (new M).fromArray(l.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]); l.matrix = c; var h = []; h = l.nodes ? l.nodes : l.nodeIds; for (var d = 0; h.length > d; d += 1) { var p = h[d]; if ("object" !== lc(p) && (p = this.getReferencedMeshComponentNodeById(p)), p) { var g, u = null; if (a = "", -1 !== p.geoId) if (u = this._getComponentNodeAttr(p, l, d)) { if (l.buildInCategory && (u.buildInCategory = l.buildInCategory), !o[a = p.material]) { var f = _u[l.type] ? _u[l.type].color : void 0; f || (Bh.log("Material not found for type: ", l.type), f = _u.DEFAULT.color), f || (Bh.log("Default material not found for type: ", l.type), f = [1, 1, 1, 1]); var m = new LA(f[0], f[1], f[2]), C = a || m.getHexString() + "_" + f[3], y = o[C]; y || (Bh.warn("缺少材质 " + a), y = Kd.createStandardMaterial({ color: m }), 1 > f[3] && (y.transparent = !0, y.opacity = f[3]), y.side = 2, o[C] = y), u.material = a = C } if (o[a].aoMap) { var v = this.getReferencedMeshBufferById(u.geometryId); v && (v.uv2 = v.uv) } g = u.nodeId; var I = (K = this.userDataReader) ? K.getUserData(n) : null; u.type = l.type, u.userId = e, u.name = l.name, u.userDataId = n, u.originalId = r, u.materialId = a, u.originMId = a, u.userData = I, u.categoryId = 0, u.componentKey = e, u.familyName = l.familyName, u.familySymbol = l.familySymbol; var E = vc.Instance, B = s.reuseNodes.hasOwnProperty(g); u.instanceOrNot = !(!E || !B), u.isBatched = !0, u.state = Lc.Visible, u.material = null, this._classifyNodeInfo(u), u = null } else Bh.debug("非法node") } } } else if (null === i ? (n = t.userDataId, r = t.originalId, a = t.materialId || t.matId) : (n = i.userDataId, r = i.originalId, a = i.materialId > -1 ? i.materialId : t.materialId), t.materials || (t.materials = []), t.materials.length > 0) for (d = 0; t.materials.length > d; d += 1) { var x = null; if (x = this._getMeshNodeAttr(A, t, t.materials.length > 1, d), !o[a = t.materials[d]]) { var S = _u[t.type] ? _u[t.type].color : void 0; S || (Bh.log("Material not found for type: ", t.type), S = _u.DEFAULT.color), S || (Bh.log("Default material not found for type: ", t.type), S = [1, 1, 1, 1]); var w = new LA(S[0], S[1], S[2]), b = a || w.getHexString() + "_" + S[3], U = o[b]; U || (Bh.warn("缺少材质 " + a), U = Kd.createStandardMaterial({ color: w }), 1 > S[3] && (U.transparent = !0, U.opacity = S[3]), U.side = 2, o[b] = U) } if (o[a].aoMap) { var F = this.getReferencedMeshBufferById(x.geometryId); F && (F.uv2 = F.uv) } if (!x) return; var K; I = (K = this.userDataReader) ? K.getUserData(n) : null; x.type = t.type, x.userId = e, x.name = t.name, x.userDataId = n, x.originalId = r, x.materialId = a, x.originMId = a, x.userData = I, x.categoryId = 0, x.componentKey = e, x.familyName = t.familyName, x.familySymbol = t.familySymbol, vc.Instance && this.instancedComponent[e] ? x.instanceOrNot = !0 : (x.instanceOrNot = !1, this.instancedGeo[x.originalGeometryId].length > 1 && (x.originalGeometryId = "")), x.state = Lc.Visible, x.material = null, x.isBatched = !0, this._classifyNodeInfo(x), x = null } else { var Q = null, R = _u[t.type] ? _u[t.type].color : void 0; R || (Bh.log("Material not found for type: ", t.type), R = _u.DEFAULT.color), R || (Bh.log("Default material not found for type: ", t.type), R = [1, 1, 1, 1]); var T = new LA(R[0], R[1], R[2]), k = T.getHexString() + "_" + R[3], D = o[k]; if (D || (D = Kd.createStandardMaterial({ color: T }), 1 > R[3] && (D.transparent = !0, D.opacity = R[3]), D.side = 2, o[k] = D), t.materials.push(k), Q = this._getMeshNodeAttr(A, t, !1, 0), a = t.materials[0], !Q) return; t.buildInCategory && (Q.buildInCategory = t.buildInCategory); e = t.key; Q.type = t.type, Q.userId = e, Q.name = t.name, Q.originalId = r, Q.materialId = a, Q.originMId = a, Q.userData = {}, Q.categoryId = 0, Q.componentKey = e, Q.familyName = t.familyName, Q.familySymbol = t.familySymbol, Q.instanceOrNot = !(!vc.Instance || !this.instancedComponent[e]), Q.isBatched = !0, Q.state = Lc.Visible, Q.material = null, this._classifyNodeInfo(Q), Q = null } }, Af.prototype._parseGeo = function () { Bh.time("处理几何:按材质拆分构件"); var A = this.referencedMeshCache; for (var e in A.bufferData) { var t = A.bufferData[e]; if (t.position.length !== t.normal.length && (t.normal = t.normal.length === t.index.length ? this._computeVertexNormalsFromFaceNormals(t.normal, t.index, t.position.length) : this._computeVertexNormalsFromIndex(t.index, t.position)), void 0 !== t.materialIndex) { for (var i = void 0, o = [], n = null, r = 0; t.materialIndex.length > r; r += 1) { var a = t.materialIndex[r]; a !== n && (n = a, void 0 !== i && (i.count = 3 * r - i.start, o.push(i)), i = { start: 3 * r, materialIndex: n }) } if (void 0 !== i && (i.count = 3 * t.materialIndex.length - i.start, o.push(i)), 1 === o.length) { A.bufferData[e + "_" + o[0].materialIndex] = t } else { for (var s = {}, l = 0; o.length > l; l += 1) { var c = o[l]; void 0 === s[c.materialIndex] && (s[c.materialIndex] = { index: [], count: 0 }), s[c.materialIndex].index.push({ start: c.start, count: c.count }), s[c.materialIndex].count += c.count } var h = function () { p = {}, g = s[d]; for (var i = 0, o = new Uint32Array(g.count), n = 0; g.index.length > n; n += 1) { var r = g.index[n], a = t.index.slice(r.start, r.start + r.count); o.set(a, i), i += r.count } u = {}, o.forEach((function (A, e) { u[A] || (u[A] = []), u[A].push(e) })); var l = Object.keys(u).length; f = new Float32Array(3 * l), m = new Float32Array(3 * l), C = new Float32Array(2 * l), y = 0, v = 0; var c = 0; for (var h in u) if (u.hasOwnProperty(h)) { h = Number(h); var I = t.position.slice(3 * h, 3 * h + 3), E = t.normal.slice(3 * h, 3 * h + 3); if (t.uv.length > 0) { var B = t.uv.slice(2 * h, 2 * h + 2); C.set(B, v), v += 2 } f.set(I, y), m.set(E, y), y += 3, u[h].forEach((function (A) { o[A] = c })), c += 1 } p.index = o, p.position = f, p.normal = m, t.uv && t.uv.length > 0 && (p.uv = C), A.bufferData[e + "_" + d] = p }; for (var d in s) { var p, g, u, f, m, C, y, v; h() } } } } Bh.timeEnd("处理几何:按材质拆分构件") }, Af.prototype._parseInstanced = function () { Bh.time("_parseInstanced"), this.instancedComponent = {}; var A = {}, e = {}, t = this.referencedMeshCache, i = this.model.materialManager.materials; for (var o in t.components) if (t.components.hasOwnProperty(o)) { var n = t.components[o]; if (n.nodeIds || n.nodes) continue; var r = n.geoId; if (-1 === r) { Bh.debug("实体没有几何"); continue } if (void 0 === A[r] && (A[r] = []), A[r].push(1), !n.materials || 1 > n.materials.length) { n.materials = []; var a = _u[n.type] ? _u[n.type].color : void 0; a || (Bh.log("Material not found for type: ", n.type), a = _u.DEFAULT.color), a || (Bh.log("Default material not found for type: ", n.type), a = [1, 1, 1, 1]); var s = new LA(a[0], a[1], a[2]), l = s.getHexString() + "_" + a[3], c = i[l]; c || (Bh.warn("缺少材质 " + l), c = Kd.createStandardMaterial({ color: s }), 1 > a[3] && (c.transparent = !0, c.opacity = a[3]), c.side = 2, i[l] = c), n.materials.push(l) } for (var h = 0, d = n.materials.length; d > h; h += 1) { var p = n.materials[h] + "&" + r; void 0 === e[p] && (e[p] = []), e[p].push({ componentKey: o }) } } for (var g in this.instancedGeo = A, e) if (e.hasOwnProperty(g)) if (1 < e[g].length) for (var u = 0; e[g].length > u; u += 1) this.instancedComponent[e[g][u].componentKey] = !0; else delete e[g]; Bh.timeEnd("_parseInstanced") }; var ef = function (A) { Xu.call(this, A), this.descriptor = new Af(A.model) }; (ef.prototype = Object.assign(ef.prototype, Xu.prototype)).loadSceneAndGeos = function (A) { var e = A.scene, t = this.model, i = e.geometries.length || 0, o = []; if (this.map = {}, ap(this.dataVersion, "2.0.0")) for (var n = 0; i > n; n += 1) e.geometries[n].fileKey ? o.push(e.geometries[n].fileKey) : t.dispatchEventEx({ type: Tc.SCENE_NOT_CLOSE, modelKey: t.modelKey }); else o = e.geometries; this.maxLoadTaskCount += i, this._loadGeo(o) }, ef.prototype.getSceneTaskCount = function (A) { var e = A.scenes; return e += A.lines, e += A.mpks, vc.BorderLineDelayLoaded || (e += this.getAllBorderlineCount()), e }; var tf = function (A) { this.model = A, this.defaultManager = null, this.instancedManager = null, this.model = A, this.loader = null, this.loaded = !1, this.dataReady = !1, this.borderlinesLoaded = !1, this.borderlinesGenerated = !1 }; tf.prototype.destroy = function () { this.model = null, this.defaultManager.destroy(), this.defaultManager = null, this.instancedManager.destroy(), this.instancedManager = null, this.loader && (this.loader.destroy(), this.loader = null) }, tf.prototype.load = function (A) { var e = this, t = this.model; this.loader.setNotifyProgress(A), this.loader.load((function () { t.manager.dispatchEvent({ type: Rc.ON_LOAD_START, modelKey: t.modelKey }) }), (function (A) { t.manager.dispatchEvent({ type: Rc.ON_LOAD_PROGRESS, progress: A, modelKey: t.modelKey }) }), (function () { e.prepareData((function () { e.processLoadCompleted((function () { t.manager.dispatchEvent({ type: Rc.ON_LOAD_COMPLETE, modelKey: t.modelKey }) })) })) })) }, tf.prototype.processLoadCompleted = function (A) { var e = this.model; e.materialManager._updateTextureMapping(), e.materialManager._updateIBL(e), e.setLoaded(!0); var t = e.manager.filter, i = e.manager.getNodeInfos(); t.initFilterManager(i), requestAnimationFrame((function () { A && A(), e.hasAnimation && vc.EnableAnimation && e.createPanel(), e.updateMeshNodes(), e.applyFilter(), e.debut(e) })) }, tf.prototype.prepareData = function (A) { if (!this.dataReady) { var e = this; this.loader.getDescriptor().parseItemData((function () { e.dataReady = !0, e.settleData(A) })) } }, tf.prototype.prepareWireframe = function (A, e) { if (A.isActivateWireframe()) if (vc.BorderLineDelayLoaded && this.loader.getAllBorderlineCount()) if (this.borderlinesLoaded) this.borderlinesGenerated && (this.defaultManager.asyncGenerateWireframe(A), this.instancedManager.generateWireframe(A)); else { this.borderlinesLoaded = !0; var t = this; this.loader.delayLoadBorderlines((function () { t.instancedManager.generateWireframe(A), t.defaultManager.asyncGenerateWireframe(A, (function () { t.borderlinesGenerated = !0, e && e() })) })) } else this.defaultManager.generateWireframe(A), this.instancedManager.generateWireframe(A) }, tf.prototype.prepare = function (A) {}, tf.prototype.needUpdate = function () { return !0 }, tf.prototype.updateNodes = function () { this.defaultManager.updateNodes(this.model), vc.Instance && this.instancedManager.updateNodes(this.model) }, tf.prototype.isLoaded = function () { return this.loaded }, tf.prototype.isDataReady = function () { return this.loaded }, tf.prototype.isAllReady = function () { return !0 }, tf.prototype.isHidden = function () { var A = this.model; return !A.visible && (A.manager.scene.removeGroupByName(A._getWireframeGroupName()), !0) }, tf.prototype.settleData = function (A) {}, tf.prototype.addNodeInfoToOctantMap = function () {}, tf.prototype.applyFilter = function () { console.log('applyFilter :>dfdfdf> '); this.isLoaded() && (this.defaultManager.applyFilter(this.model), vc.Instance && this.instancedManager.applyFilter(this.model)) }, tf.prototype.applySelection = function () { console.log('applySelection14') // debugger; this.isLoaded() && (this.defaultManager.applySelection(this.model), vc.Instance && this.instancedManager.applySelection(this.model)) }, tf.prototype.clearSelection = function () { this.isLoaded() && (this.defaultManager.clearSelection(this.model), vc.Instance && this.instancedManager.clearSelection(this.model)) }, tf.prototype.applyHover = function () { this.isLoaded() && (this.defaultManager.applyHover(this.model), vc.Instance && this.instancedManager.applyHover(this.model)) }, tf.prototype.clearHover = function () { this.isLoaded() && (this.defaultManager.clearHover(this.model), vc.Instance && this.instancedManager.clearHover(this.model)) }, tf.prototype.applyBlink = function () { this.isLoaded() && (this.defaultManager.applyBlink(this.model), vc.Instance && this.instancedManager.applyBlink(this.model)) }, tf.prototype.clearBlink = function () { this.isLoaded() && (this.defaultManager.clearBlink(this.model), vc.Instance && this.instancedManager.clearBlink(this.model)) }, tf.prototype.applyReplacement = function () { this.isLoaded() && (this.defaultManager.applyReplacement(this.model), vc.Instance && this.instancedManager.applyReplacement(this.model)) }, tf.prototype.getMeshesByUserIds = function (A) { if (this.isLoaded()) { var e = this.defaultManager.getMeshesByUserIds(this.model, A), t = []; return vc.Instance && (t = this.instancedManager.getMeshesByUserId(this.model, A)), [].concat(e).concat(t) } }, tf.prototype.rebuildIndicesforLightmap = function () { this.defaultManager.rebuildIndices(this.model) }, tf.prototype.adjustVisibility = function (A) { this.defaultManager.adjustVisibility(this.model, A) }, tf.prototype.changeVisibilityOfSelectedObjects = function (A) { this.defaultManager.changeVisibilityOfSelectedObjects(this.model, A) }, tf.prototype.changeVisibilityOfNonSelectedObjects = function (A) { this.defaultManager.changeVisibilityOfNonSelectedObjects(this.model, A) }, tf.prototype.adjustInstanceVisibility = function (A) { this.instancedManager.adjustVisibility(this.model, A) }, tf.prototype.changeInstanceVisibilityOfSelectedObjects = function (A) { this.instancedManager.changeVisibilityOfSelectedObjects(this.model, A) }, tf.prototype.changeInstanceVisibilityOfNonSelectedObjects = function (A) { this.instancedManager.changeVisibilityOfNonSelectedObjects(this.model, A) }, tf.prototype.restoreVisibilityOfObjects = function () { this.defaultManager.restoreVisibilityOfObjects(), this.instancedManager.restoreVisibilityOfObjects() }, tf.prototype.getBlinkMaterials = function () { var A = [], e = this.model.materialManager.instanceMaterials; for (var t in e) for (var i = e[t], o = 0, n = i.length; n > o; o += 1) A.push(i[o]); return A = A.concat(this.defaultManager.meshManager.getBlinkMaterials()) }, tf.prototype.disposeBufferAfterVbo = function () { this.isLoaded() && (this.defaultManager.disposeBufferAfterVbo(), this.instancedManager.disposeBufferAfterVbo()) }, tf.prototype.getGeometryBuffersByUserId = function (A) { if (!this.isLoaded()) return []; var e = []; return e = (e = e.concat(this.defaultManager.getGeometryBuffersByUserId(this.model, A))).concat(this.instancedManager.getGeometryBuffersByUserId(this.model, A)) }, tf.prototype.unloadComponents = function (A) {}, tf.prototype.explosion = function (A) { this.isLoaded() && (this.defaultManager.explosion(this.model, A), vc.Instance && this.instancedManager.explosion(this.model, A)) }, tf.prototype.closeExplosion = function () { this.isLoaded() && (this.defaultManager.closeExplosion(this.model), vc.Instance && this.instancedManager.closeExplosion(this.model)) }, tf.prototype.componentsExplosion = function (A) { this.isLoaded() && (this.defaultManager.componentsExplosion(this.model, A), vc.Instance && this.instancedManager.componentsExplosion(this.model, A)) }, tf.prototype.closeComponentsExplosion = function (A) { this.isLoaded() && (this.defaultManager.closeComponentsExplosion(this.model, A), vc.Instance && this.instancedManager.closeComponentsExplosion(this.model, A)) }, tf.prototype.isHiddenNode = function (A) { return this.defaultManager.isHiddenNode(A) || this.instancedManager.isHiddenNode(A) }, tf.prototype.moveMeshfromInstancedToDefault = function (A) {}; var of = function (A) { this.manager = A, this.pickingNodeMap = null, this.pickingNodeGroup = null, this.nodeGroupName = "PickingNodeGroup" }; of .prototype.destroy = function () { this.clearData(), this.pickingNodeGroup = null, this.manager = null }, of .prototype.clearData = function () { this.clearAllFromPickingNodeGroup(), this.clearAllFromPickingNodeMap() }, of .prototype.addToPickingNodeMap = function (A, e) { this.pickingNodeMap || (this.pickingNodeMap = {}), this.pickingNodeMap[A] = e, this.addToPickingNodeGroup(e) }, of .prototype.removeFromPickingNodeMap = function (A) { this.pickingNodeMap && this.pickingNodeMap[A] && (this.removeFormPickingNodeGroup(A), this.disposePickingNodeById(A), delete this.pickingNodeMap[A]) }, of .prototype.addToPickingNodeGroup = function (A) { this.pickingNodeGroup || (this.pickingNodeGroup = new Xi, this.pickingNodeGroup.name = this.nodeGroupName); for (var e = 0, t = A.length; t > e; e += 1) this.pickingNodeGroup.add(A[e]) }, of .prototype.removeFormPickingNodeGroup = function (A) { if (this.pickingNodeGroup) for (var e = this.pickingNodeMap[A], t = 0, i = e.length; i > t; t += 1) this.pickingNodeGroup.remove(e[t]) }, of .prototype.disposePickingNodeById = function (A) { for (var e = this.pickingNodeMap[A], t = 0, i = e.length; i > t; t += 1) e[t].material = null, e[t].geometry.dispose(), e[t] = null }, of .prototype.clearAllFromPickingNodeMap = function () { if (this.pickingNodeMap) { for (var A = Object.keys(this.pickingNodeMap), e = 0, t = A.length; t > e; e += 1) this.disposePickingNodeById(A[e]); this.pickingNodeMap = null } }, of .prototype.clearAllFromPickingNodeGroup = function () { this.pickingNodeGroup && (this.pickingNodeGroup.children.length = 0) }, of .prototype.isPickingMeshesGenerated = function () { return !!this.pickingNodeMap }, of .prototype.generatePickingMeshes = function () {}, of .prototype.updatePickingMeshesState = function (A, e, t) {}, of .prototype.resetPickingMeshesState = function () {}, of .prototype.updatePickingMeshes = function (A, e, t) { return this.isPickingMeshesGenerated() || (this.generatePickingMeshes(), this.isPickingMeshesGenerated()) ? (this.resetPickingMeshesState(), this.updatePickingMeshesState(A, e, t), this.getPickingNodeGroup()) : null }, of .prototype.getPickingNodeGroup = function () { return this.pickingNodeGroup }; var nf = function (A) { of .call(this, A), this.nodeGroupName = "PickingBatchedMeshGroup" }; Object.assign(nf.prototype, of .prototype), eu(nf, [{ key: "disposePickingNodeById", value: function (A) { for (var e = this.pickingNodeMap[A], t = 0, i = e.length; i > t; t += 1) e[t]._indicesGroup = null, e[t].material = null, e[t].geometry.dispose(), e[t] = null } }, { key: "generatePickingMeshes", value: function () { for (var A = this.manager, e = Object.keys(A.mapMaterialIdToMergedNode), t = 0, i = e.length; i > t; t += 1) { for (var o = e[t], n = A.getPropertyValueByMaterialKey(o), r = A.mapMaterialIdToMergedNode[o], a = [], s = 0, l = r.length; l > s; s += 1) { var c = r[s], h = c.geometry, d = c.indices, p = c.mesh, g = new he; g.setAttribute("position", h.getAttribute("position")), g.setIndex(h.getIndex()); var u = new("lines" === n.type ? jo : Ue)(g, Kd.DefaultMaterial); p.matrixWorld.decompose(u.position, u.quaternion, u.scale), u.name = o, u.frustumCulled = !1, u.renderOrder = 0, u._indicesGroup = d, a.push(u) } this.addToPickingNodeMap(o, a) } } }, { key: "_rebuildGeometryGroup", value: function (A, e, t) { var i, o = this.manager.manager, n = 0, r = 0, a = 0, s = A._indicesGroup, l = Object.keys(s), c = [], h = {}; e.length > l.length ? (c = l, h = t) : (c = e, h = s); var d = []; for (a = 0, i = c.length; i > a; a += 1) { var p = c[a]; if (o.isPickableNode(p) && h[p]) { var g = s[p]; if (g && g.length > 0) for (n = 0, r = g.length; r > n; n += 1) d.push({ indexStart: g[n].indexStart, indexCount: g[n].indexCount }) } } A.visible = !0; var u = A.geometry; if (u.clearGroups(), 0 !== d.length) for (d.sort((function (A, e) { return A.indexStart - e.indexStart })), n = 0, r = d.length; r > n; n += 1) { var f = d[n].indexStart, m = d[n].indexCount; if (0 === n) u.addGroup(f, m, 0); else f === d[n - 1].indexStart + d[n - 1].indexCount ? u.groups[u.groups.length - 1].count += m : u.addGroup(f, m, 0) } else A.visible = !1 } }, { key: "updatePickingMeshesState", value: function (A, e, t) { for (var i = this.pickingNodeMap, o = Object.keys(i), n = 0, r = o.length; r > n; n += 1) for (var a = i[o[n]], s = 0, l = a.length; l > s; s += 1) a[s].material = [A], a[s].visible = !1, this._rebuildGeometryGroup(a[s], e, t) } }]); var rf = new aA, af = new M, sf = new CA, lf = new cA, cf = function () { jo.call(this), this.type = "LineSegmentsEx" }; cf.prototype.init = function (A) {}, cf.prototype.destroy = function () {}, cf.prototype.intersectBoxWithDistance = function (A, e) { var t = this.geometry, i = this.matrixWorld; return e && (i = this.matrixWorld.clone()).multiplyMatrices(this.matrixWorld, e), t.boundingBox || t.computeBoundingBox(), rf.copy(t.boundingBox), rf.applyMatrix4(i), A.ray.intersectBoxWithDistance(rf) }, cf.prototype.intersectBoxWithDistanceByIndices = function (A, e) { var t = this.geometry.attributes.position.array, i = 0, o = t.length; e && e.indexCount > 0 && (i = e.positionStart, o = e.positionStart + e.positionCount); var n = uh.box3FromArrayRange(t, i, o); return n.applyMatrix4(this.matrixWorld), A.ray.intersectBoxWithDistance(n) }, cf.prototype.raycastByIndices = function (A, e, t, i) { var o = A.linePrecision; A.linePrecision = vc.LineSelectRange || 5; var n = A.linePrecision, r = n * n, a = null; i ? (a = this.matrixWorld.clone()).multiplyMatrices(this.matrixWorld, i) : a = this.matrixWorld; var s = this.geometry; if (null === s.boundingSphere && s.computeBoundingSphere(), lf.copy(s.boundingSphere), lf.applyMatrix4(a), !1 !== A.ray.intersectsSphere(lf)) { af.getInverse(a), sf.copy(A.ray).applyMatrix4(af); var l = new y, c = new y, h = new y, d = new y, p = s.attributes.position.array, g = s.index.array, u = 0, f = g.length; t && t.indexCount > 0 && (u = t.indexStart, f = t.indexStart + t.indexCount); for (var m = u; f - 1 > m; m += 2) { var C = g[m + 1]; if (l.fromArray(p, 3 * g[m]), c.fromArray(p, 3 * C), r >= sf.distanceSqToSegment(l, c, d, h)) { d.applyMatrix4(a); var v = A.ray.origin.distanceTo(d); A.near > v || v > A.far || e.push({ distance: v, point: h.clone().applyMatrix4(a), index: m, face: null, faceIndex: null, object: this }) } } A.linePrecision = o } }; var hf = new M, df = new CA, pf = new cA, gf = new y, uf = new y, ff = new y, mf = new y, Cf = new y, yf = new y, vf = new y, If = new y, Ef = new y, Bf = new s, xf = new s, Sf = new s, wf = new y, Mf = new y; function bf(A, e, t, i, o, n, r, a) { if (null === (Array.isArray(e) ? i.intersectTriangle(o, n, r, !1, a) : 1 === e.side ? i.intersectTriangle(r, n, o, !0, a) : i.intersectTriangle(o, n, r, 2 !== e.side, a))) return null; Mf.copy(a), Mf.applyMatrix4(A.matrixWorld); var s = t.ray.origin.distanceTo(Mf); return t.near > s || s > t.far ? null : { distance: s, point: Mf.clone(), object: A } } function Uf(A, e, t, i, o, n, r, a, l, c, h, d) { gf.fromBufferAttribute(o, c), uf.fromBufferAttribute(o, h), ff.fromBufferAttribute(o, d); var p = A.morphTargetInfluences; if (e.morphTargets && n && p) { vf.set(0, 0, 0), If.set(0, 0, 0), Ef.set(0, 0, 0); for (var g = 0, u = n.length; u > g; g += 1) { var f = p[g], m = n[g]; 0 !== f && (mf.fromBufferAttribute(m, c), Cf.fromBufferAttribute(m, h), yf.fromBufferAttribute(m, d), r ? (vf.addScaledVector(mf, f), If.addScaledVector(Cf, f), Ef.addScaledVector(yf, f)) : (vf.addScaledVector(mf.sub(gf), f), If.addScaledVector(Cf.sub(uf), f), Ef.addScaledVector(yf.sub(ff), f))) } gf.add(vf), uf.add(If), ff.add(Ef) } var C = bf(A, e, t, i, gf, uf, ff, wf); if (C) { a && (Bf.fromBufferAttribute(a, c), xf.fromBufferAttribute(a, h), Sf.fromBufferAttribute(a, d), C.uv = RA.getUV(wf, gf, uf, ff, Bf, xf, Sf, new s)), l && (Bf.fromBufferAttribute(l, c), xf.fromBufferAttribute(l, h), Sf.fromBufferAttribute(l, d), C.uv2 = RA.getUV(wf, gf, uf, ff, Bf, xf, Sf, new s)); var y = new GA(c, h, d); RA.getNormal(gf, uf, ff, y.normal), C.face = y } return C } var Ff, Kf = function (A, e) { Ue.call(this), this.type = "MeshEx", this.matrixAutoUpdate = !1, this.active = !1, this.guid = "", this.key = "", this.typeEx = "", this.geometry = A || Tu.EmptyGeometry, this.material = e || Kd.DefaultMaterial, this.visible = !1, this.pickable = !0 }; (Kf.prototype = Object.create(Ue.prototype)).constructor = Kf, Kf.prototype.init = function (A) { A && A.parent && A.parent.add(this) }, Kf.prototype.destroy = function () { this.parent && this.parent.remove(this), this.userData && (this.userData = null), this.geometry = null, this.material = null }, Kf.prototype.isVisible = function () { return this.visible && this.active }, Kf.prototype.spawn = function (A) { void 0 !== A.guid && (this.guid = A.guid), void 0 !== A.key && (this.key = A.key), void 0 !== A.name && (this.name = A.name), void 0 !== A.typeEx && (this.typeEx = A.typeEx), A.geometry && (this.geometry = A.geometry), A.material && (this.material = A.material), A.matrix ? (this.matrix.copy(A.matrix), this.updateMatrixWorld(!0)) : (this.matrix.identity(), this.updateMatrixWorld(!0)), this.modelKey = A.modelKey ? A.modelKey : "", A.userData ? this.userData = A.userData : this.userData && (this.userData = null), void 0 !== A.visible && (this.visible = A.visible), void 0 !== A.isMesh && (this.isMesh = A.isMesh), void 0 !== A.isLine && (this.isLine = A.isLine), void 0 !== A.isLineSegments && (this.isLineSegments = A.isLineSegments), this.pickable = void 0 === A.pickable || A.pickable, this.renderOrder = A.renderOrder || 0, this.active = !0, this.visible = !0, this.frustumCulled = !1, this.matChange = !1 }, Kf.prototype.clear = function () { this.geometry = Tu.EmptyGeometry, this.material = Kd.DefaultMaterial, this.active = !1, this.visible = !0, this.guid = "", this.key = "", this.typeEx = "", this.frustumCulled = !0, this.material.visible = !1 }, Kf.prototype.intersectBoxWithDistance = (Ff = new aA, function (A, e) { var t = this.geometry, i = this.material, o = this.matrixWorld; return e && (o = new M).multiplyMatrices(this.matrixWorld, e), void 0 === i ? -1 : (t.boundingBox || t.computeBoundingBox(), Ff.copy(t.boundingBox), Ff.applyMatrix4(o), A.ray.intersectBoxWithDistance(Ff)) } ), Kf.prototype.intersectBoxWithDistanceByIndices = function (A, e) { var t = this.matrixWorld, i = this.computeBoundingBox(e); return i.applyMatrix4(t), A.ray.intersectBoxWithDistance(i) }, Kf.prototype.intersectBoxWithClipPlane = function (A, e) { var t = this.matrixWorld, i = this.computeBoundingBox(e); return i.applyMatrix4(t), i.intersectsPlane(A) }, Kf.prototype.getIntersectionPoints = function (A, e, t, i) { var o = new M; o.getInverse(this.matrixWorld); var n = A.clone(); n.constant *= -1, n = n.applyMatrix4(o); function r(A, e) { var i = e.intersectLine(A); i && t.push(i.x, i.y, i.z) } for (var a, s, l, c = this.geometry.getIndex().array, h = this.geometry.getAttribute("position").array, d = i ? 0 : e.indexStart, p = i ? c.length : e.indexStart + e.indexCount, g = new y, u = new y, f = new y, m = new Hs, C = new Hs, v = new Hs, I = d, E = p; E > I; I += 3) s = 3 * c[I + 1], l = 3 * c[I + 2], g.set(h[a = 3 * c[I]], h[a + 1], h[a + 2]), u.set(h[s], h[s + 1], h[s + 2]), f.set(h[l], h[l + 1], h[l + 2]), i && (g.applyMatrix4(e.matrix), u.applyMatrix4(e.matrix), f.applyMatrix4(e.matrix)), m.set(g, u), C.set(u, f), v.set(f, g), r(m, n), r(C, n), r(v, n) }, Kf.prototype.raycastByIndices = function () { var A = new M, e = new CA, t = new cA, i = new y, o = new y, n = new y, r = new s, a = new s, l = new s, c = new y, h = new y, d = new y, p = new M; function g(A, e, t, s, g, u, f, m) { i.fromBufferAttribute(s, u), o.fromBufferAttribute(s, f), n.fromBufferAttribute(s, m); var C = function (A, e, t, i, o, n, r) { var a = A.material; if (null === (Array.isArray(a) ? t.intersectTriangle(i, o, n, !1, r) : 1 === a.side ? t.intersectTriangle(n, o, i, !0, r) : t.intersectTriangle(i, o, n, 2 !== a.side, r))) return null; d.copy(r), d.applyMatrix4(p); var s = e.ray.origin.distanceTo(d); return e.near > s || s > e.far ? null : { distance: s, point: d.clone(), object: A } }(A, e, t, i, o, n, h); if (C) { if (g && g.array && g.array.length && (r.fromBufferAttribute(g, u), a.fromBufferAttribute(g, f), l.fromBufferAttribute(g, m), C.uv = function (A, e, t, i, o, n, r) { return RA.getBarycoord(A, e, t, i, c), o.multiplyScalar(c.x), n.multiplyScalar(c.y), r.multiplyScalar(c.z), o.add(n).add(r), o.clone() }(h, i, o, n, r, a, l)), s.instanceMatrix) { var v = i.clone().applyMatrix4(s.instanceMatrix), I = o.clone().applyMatrix4(s.instanceMatrix), E = n.clone().applyMatrix4(s.instanceMatrix); C.face = new GA(u, f, m, RA.getNormal(v, I, E, new y)) } else C.face = new GA(u, f, m, RA.getNormal(i, o, n, new y)); C.faceIndex = u } return C } return function (i, o, n, r) { var a = this.geometry, s = this.material; if (r) { a = this.geometry, s = this.material; if ((p = new M).multiplyMatrices(this.matrixWorld, r), void 0 === s) return; if (null === a.boundingSphere && a.computeBoundingSphere(), t.copy(a.boundingSphere), t.applyMatrix4(p), !1 === i.ray.intersectsSphere(t)) return; if (A.getInverse(p), e.copy(i.ray).applyMatrix4(A), null !== a.boundingBox && !1 === e.intersectsBox(a.boundingBox)) return; var l = null, c = null, h = null, d = null, u = a.index; (I = a.attributes.position).instanceMatrix = r; var f = a.attributes.uv, m = null, C = null; if (null !== u) for (m = 0, C = u.count; C > m; m += 3) c = u.getX(m), h = u.getX(m + 1), d = u.getX(m + 2), (l = g(this, i, e, I, f, c, h, d)) && (l.faceIndex = Math.floor(m / 3), o.push(l)); else for (m = 0, C = I.count; C > m; m += 3) (l = g(this, i, e, I, f, c = m, h = m + 1, d = m + 2)) && (l.index = c, o.push(l)) } else { if (p = this.matrixWorld, void 0 === s) return; if (t.copy(this.computeBoundingSphere(n)), t.applyMatrix4(p), !1 === i.ray.intersectsSphere(t)) return; A.getInverse(p), e.copy(i.ray).applyMatrix4(A); var y = this.computeBoundingBox(n); if (!1 === e.intersectsBox(y)) return; l = null, c = null, h = null, d = null; var v, I = a.attributes.position, E = (f = a.attributes.uv, m = null, n.indexStart), B = n.indexStart + n.indexCount, x = a.getIndex().array; for (m = E, v = B; v > m; m += 3) (l = g(this, i, e, I, f, c = x[m], h = x[m + 1], d = x[m + 2])) && (l.faceIndex = Math.floor(m / 3), o.push(l)) } } }(), Kf.prototype.raycastByIndices2 = function () { var A = new M, e = new CA, t = new cA, i = new y, o = new y, n = new y, r = new s, a = new s, l = new s, c = new y, h = new y, d = new y, p = new M; function g(A, e, t, s, g, u, f, m) { i.fromBufferAttribute(s, u), o.fromBufferAttribute(s, f), n.fromBufferAttribute(s, m); var C = function (A, e, t, i, o, n, r) { var a = A.material; if (null === (a instanceof Array ? t.intersectTriangle(i, o, n, !1, r) : 1 === a.side ? t.intersectTriangle(n, o, i, !0, r) : t.intersectTriangle(i, o, n, 2 !== a.side, r))) return null; d.copy(r), d.applyMatrix4(p); var s = e.ray.origin.distanceTo(d); return e.near > s || s > e.far ? null : { distance: s, point: d.clone(), object: A } }(A, e, t, i, o, n, h); if (C) { if (g && g.array && g.array.length && (r.fromBufferAttribute(g, u), a.fromBufferAttribute(g, f), l.fromBufferAttribute(g, m), C.uv = function (A, e, t, i, o, n, r) { return RA.barycoordFromPoint(A, e, t, i, c), o.multiplyScalar(c.x), n.multiplyScalar(c.y), r.multiplyScalar(c.z), o.add(n).add(r), o.clone() }(h, i, o, n, r, a, l)), s.instanceMatrix) { var y = i.clone().applyMatrix4(s.instanceMatrix), v = o.clone().applyMatrix4(s.instanceMatrix), I = n.clone().applyMatrix4(s.instanceMatrix); C.face = new GA(u, f, m, RA.normal(y, v, I)) } else C.face = new GA(u, f, m, RA.normal(i, o, n)); C.faceIndex = u } return C } return function (i, o, n, r) { var a = this.geometry, s = this.material; if (r = !!r, n.isInstanced) { if (void 0 === n.matrix) return; if (p.multiplyMatrices(this.matrixWorld, n.matrix), void 0 === s) return; if (r && (null === a.boundingSphere && a.computeBoundingSphere(), t.copy(a.boundingSphere), t.applyMatrix4(p), !1 === i.ray.intersectsSphere(t))) return; if (A.getInverse(p), e.copy(i.ray).applyMatrix4(A), r && null !== a.boundingBox && !1 === e.intersectsBox(a.boundingBox)) return; var l = a.index; (I = a.attributes.position).instanceMatrix = n.matrix; var c, h = a.attributes.uv; if (null !== l) for (y = 0, c = l.count; c > y; y += 3) f = l.getX(y), m = l.getX(y + 1), C = l.getX(y + 2), (u = g(this, i, e, I, h, f, m, C)) && (u.faceIndex = Math.floor(y / 3), o.push(u)); else for (y = 0, c = I.count; c > y; y += 3) (u = g(this, i, e, I, h, f = y, m = y + 1, C = y + 2)) && (u.index = f, o.push(u)) } else if (n.matrix ? p.multiplyMatrices(this.matrixWorld, n.matrix) : p = this.matrixWorld, void 0 !== s && (!r || (t.copy(this.computeBoundingSphere(n)), t.applyMatrix4(p), !1 !== i.ray.intersectsSphere(t)))) { if (A.getInverse(p), e.copy(i.ray).applyMatrix4(A), r) { var d = this.computeBoundingBox(n); if (!1 === e.intersectsBox(d)) return } var u, f, m, C, y, v, I = a.attributes.position, E = (h = a.attributes.uv, n.indexStart), B = n.indexStart + n.indexCount, x = a.getIndex().array; for (y = E, v = B; v > y; y += 3) (u = g(this, i, e, I, h, f = x[y], m = x[y + 1], C = x[y + 2])) && (u.faceIndex = Math.floor(y / 3), o.push(u)) } } }(), Kf.prototype.computeBoundingBox = function (A) { var e = new aA, t = this.geometry.attributes.position.array, i = null, o = null; return A ? (i = A.positionStart, o = A.positionStart + A.positionCount) : (i = 0, o = t.length), this.setBoundingBoxFromArray(e, t, i, o), e }, Kf.prototype.computeBoundingSphere = function (A) { var e = new aA, t = new y, i = this.geometry.attributes.position.array, o = null, n = null; A ? (o = A.positionStart, n = A.positionStart + A.positionCount) : (o = 0, n = i.length); var r = new cA, a = r.center; this.setBoundingBoxFromArray(e, i, o, n), e.getCenter(a); for (var s = 0, l = o, c = n; c > l; l += 3) t.x = i[l], t.y = i[l + 1], t.z = i[l + 2], s = Math.max(s, a.distanceToSquared(t)); return r.radius = Math.sqrt(s), r }, Kf.prototype.setBoundingBoxFromArray = function (A, e, t, i) { for (var o = Number(1 / 0), n = Number(1 / 0), r = Number(1 / 0), a = -1 / 0, s = -1 / 0, l = -1 / 0, c = t, h = i; h > c; c += 3) { var d = e[c], p = e[c + 1], g = e[c + 2]; o > d && (o = d), n > p && (n = p), r > g && (r = g), d > a && (a = d), p > s && (s = p), g > l && (l = g) } A.min.set(o, n, r), A.max.set(a, s, l) }, Kf.prototype.raycast = function (A, e) { var t = this.geometry, i = this.material, o = this.matrixWorld; if (void 0 !== i && (null === t.boundingSphere && t.computeBoundingSphere(), pf.copy(t.boundingSphere), pf.applyMatrix4(o), !1 !== A.ray.intersectsSphere(pf) && (hf.getInverse(o), df.copy(A.ray).applyMatrix4(hf), null === t.boundingBox || !1 !== df.intersectsBox(t.boundingBox)))) { var n = null; if (t.isBufferGeometry) { var r = null, a = null, l = null, c = t.index, h = t.attributes.position, d = t.morphAttributes.position, p = t.morphTargetsRelative, g = t.attributes.uv, u = t.attributes.uv2, f = t.groups, m = t.drawRange, C = null, y = null, v = null, I = null, E = null, B = null; if (null !== c) if (Array.isArray(i)) { for (C = 0, v = f.length; v > C; C += 1) if (B = i[(E = f[C]).materialIndex]) for (y = Math.max(E.start, m.start), I = Math.min(E.start + E.count, m.start + m.count); I > y; y += 3) r = c.getX(y), a = c.getX(y + 1), l = c.getX(y + 2), (n = Uf(this, B, A, df, h, d, p, g, u, r, a, l)) && (n.faceIndex = Math.floor(y / 3), n.face.materialIndex = E.materialIndex, e.push(n)) } else for (C = Math.max(0, m.start), v = Math.min(c.count, m.start + m.count); v > C; C += 3) r = c.getX(C), a = c.getX(C + 1), l = c.getX(C + 2), (n = Uf(this, i, A, df, h, d, p, g, u, r, a, l)) && (n.faceIndex = Math.floor(C / 3), e.push(n)); else if (void 0 !== h) if (Array.isArray(i)) { for (C = 0, v = f.length; v > C; C += 1) if (B = i[(E = f[C]).materialIndex]) for (y = Math.max(E.start, m.start), I = Math.min(E.start + E.count, m.start + m.count); I > y; y += 3) (n = Uf(this, B, A, df, h, d, p, g, u, r = y, a = y + 1, l = y + 2)) && (n.faceIndex = Math.floor(y / 3), n.face.materialIndex = E.materialIndex, e.push(n)) } else for (C = Math.max(0, m.start), v = Math.min(h.count, m.start + m.count); v > C; C += 3) (n = Uf(this, i, A, df, h, d, p, g, u, r = C, a = C + 1, l = C + 2)) && (n.faceIndex = Math.floor(C / 3), e.push(n)) } else if (t.isGeometry) { var x = null, S = null, w = null, M = Array.isArray(i), b = t.vertices, U = t.faces, F = null, K = t.faceVertexUvs[0]; K.length > 0 && (F = K); for (var Q = 0, R = U.length; R > Q; Q += 1) { var T = U[Q], k = M ? i[T.materialIndex] : i; if (void 0 !== k && (n = bf(this, k, A, df, x = b[T.a], S = b[T.b], w = b[T.c], wf))) { if (F && F[Q]) { var D = F[Q]; Bf.copy(D[0]), xf.copy(D[1]), Sf.copy(D[2]), n.uv = RA.getUV(wf, x, S, w, Bf, xf, Sf, new s) } n.face = T, n.faceIndex = Q, e.push(n) } } } } }; var Qf = function (A, e) { this.model = e, this.loader = A, this.mapNodeInfoByCategory = {}, this.mapNodeInfoByUserId = {}, this.mapNodeInfoByComponentId = {}, this.referencedMeshCache = {}, this.nodeInfosOnGeometryId = null, this.componentCount = 0, this.meshCache = {}, this.allBones = {} }; Qf.EnumNodeItemType = { SYMBOL: 0, MESH: 1, TUBE: 2, PIPE: 3, BOX: 4, BOX_M: 5, PIPE_M: 6, MESH_REF: 7, LINE: 8 }, Qf.NodeInfoCategory = { INSTANCED: 0, STANDARD: 1 }, Qf.EnumDataType = { NONE: 0, MERGE_DATA: 1, LAYER: 2, LAYER_SCENE: 3, ANIMATION: 4 }, Qf.EnumKeyframeTrackType = { position: "position", scale: "scale", quaternion: "quaternion", weights: "weights" }, Qf.prototype.destroy = function () { this.mapNodeInfoByCategory = null, this.mapNodeInfoByUserId = null, this.mapNodeInfoByComponentId = null, this.referencedMeshCache = null, this.nodeInfosOnGeometryId = null }, Qf.prototype.clearReferencedMeshCache = function () { if (!vc.DEBUG) { for (var A in this.referencedMeshCache) delete this.referencedMeshCache[A]; this.referencedMeshCache = null } }, Qf.prototype.cacheReferencedMeshBufferData = function (A, e) { this.referencedMeshCache.geometries || (this.referencedMeshCache.geometries = {}), this.referencedMeshCache.geometries[A] = e }, Qf.prototype.cacheReferencedMeshBoneBufferData = function (A, e) { this.referencedMeshCache.bones || (this.referencedMeshCache.bones = {}), this.referencedMeshCache.bones[A] = e }, Qf.prototype.cacheReferencedMeshClipsData = function (A) { this.referencedMeshCache.clips = A }, Qf.prototype.cacheReferencedMeshNodesData = function (A) { this.referencedMeshCache.nodes = A }, Qf.prototype.cacheReferencedMeshComponentData = function (A, e) { this.referencedMeshCache.components || (this.referencedMeshCache.components = {}), this.referencedMeshCache.components[A] = e }, Qf.prototype.cacheReferencedMeshMaterialData = function (A, e) { this.referencedMeshCache.materials || (this.referencedMeshCache.materials = {}), this.referencedMeshCache.materials[A] = e }, Qf.prototype.getReferencedMeshBufferData = function () { return this.referencedMeshCache.geometries }, Qf.prototype.getReferencedMeshBufferById = function (A) { return this.referencedMeshCache.geometries ? this.referencedMeshCache.geometries[A] : null }, Qf.prototype.cacheReferencedMeshMpkIds = function (A, e) { this.referencedMeshCache.mpkIds || (this.referencedMeshCache.mpkIds = {}), this.referencedMeshCache.mpkIds[A] || (this.referencedMeshCache.mpkIds[A] = []), this.referencedMeshCache.mpkIds[A].push(e) }, Qf.prototype.clearReferencedMeshCacheByMpkIdxs = function (A, e) { if (this.referencedMeshCache.mpkIds) for (var t = 0, i = A.length; i > t; t += 1) { var o = A[t], n = this.referencedMeshCache.mpkIds[o]; if (n) { for (var r = 0, a = n.length; a > r; r += 1) e && e(n[r]), delete this.referencedMeshCache[n[r]]; delete this.referencedMeshCache.mpkIds[o] } } }, Qf.prototype.parseItemData = function (A, e) { (op(A.dataVersion, "1.0") || void 0 === A.dataVersion) && (Bh.time("升级几何结构"), this._updateV1ToV2(A), A.dataVersion = "2.0", Bh.timeEnd("升级几何结构")), this._readMaterialBuffer222(A), A.hasAnimation && vc.EnableAnimation ? (this._parseClips(), this._parseBones()) : (this._parseGeo(), this._parseInstanced()); var t = this.loader.getSceneReaderArray(); if (!t) return Bh.log("Empty scene"), !1; var i = this.referencedMeshCache; if (Bh.time("_readItemData"), !i.geometries || 0 >= Object.keys(i.geometries).length) return !0; if (e) for (var o = 0, n = e.length; n > o; o += 1) i.components[e[o]] && this._readItemData(t, e[o], e[o], void 0, 0); else for (var r in i.components) this._readItemData(t, r, r, void 0, 0); return A.hasAnimation && vc.EnableAnimation && this._parseNodes(), Bh.timeEnd("_readItemData"), t = null, !0 }, Qf.prototype._readItemData = function (A, e, t) { var i = this.referencedMeshCache.components[e]; void 0 !== i && -1 !== i.geoId && (this.model.merged ? this._readMeshInfo(A, t, i, null) : this._readMeshInfo2(A, t, i, null)) }, Qf.prototype._readSymbolInfo = function (A, e, t) { var i = this.loader.getSymbolReader(); if (i) { var o = i.header.symbolCount, n = t.toData, r = A.getMatrixInfo(t.matrixId).matrix.clone(), a = { matrix: r, ItemId: t.ItemId, originalId: t.originalId, userDataId: t.userDataId, materialId: t.materialId }; if (n >= 0 && o > n) for (var s = i.getSymbolInfo(n), l = s.itemIndex; s.itemCount > l; l += 1) { var c = i.getItemInfo(l); c.type !== Qf.EnumNodeItemType.SYMBOL && this._readMeshInfo(i, e, c, a) } r = null, a = null, i = null } }, Qf.prototype._readMeshInfo = function (A, e, t, i) { var o = this.loader, n = this.model.materialManager.materials, r = null, a = null, s = null; if (null === i ? (r = t.userDataId, a = t.originalId, s = t.materialId || t.matId) : (r = i.userDataId, a = i.originalId, s = i.materialId > -1 ? i.materialId : t.materialId), t.materials || (t.materials = []), t.materials.length > 0) for (var l = 0; t.materials.length > l; l += 1) { var c = null; if (c = this._getMeshNodeAttr(A, t, t.materials.length > 1, l), !n[s = t.materials[l]]) { var h = _u[t.type] ? _u[t.type].color : void 0; h || (Bh.log("Material not found for type: ", t.type), h = _u.DEFAULT.color), h || (Bh.log("Default material not found for type: ", t.type), h = [1, 1, 1, 1]); var d = new LA(h[0], h[1], h[2]), p = s || d.getHexString() + "_" + h[3], g = n[p]; g || (Bh.warn("缺少材质 " + s), g = new xr({ color: d }), 1 > h[3] && (g.transparent = !0, g.opacity = h[3]), g.side = 2, n[p] = g) } if (n[s].aoMap) { var u = this.getReferencedMeshBufferById(c.geometryId); u && (u.uv2 = u.uv) } if (!c) return; var f = o.getUserDataReader(), m = f ? f.getUserData(r) : null, C = t.key; c.type = t.type, c.userId = C, c.name = t.name, c.userDataId = r, c.originalId = a, c.materialId = s, c.originMId = s, c.userData = m, c.categoryId = 0, c.componentId = C, c.familyName = t.familyName, c.familySymbol = t.familySymbol, c.instanceOrNot = !(!vc.Instance || !this.instancedComponent[C]), c.state = Lc.Visible, c.material = null, this._classifyNodeInfo(c), c = null } else { var y = null, v = _u[t.type] ? _u[t.type].color : void 0; v || (Bh.log("Material not found for type: ", t.type), v = _u.DEFAULT.color), v || (Bh.log("Default material not found for type: ", t.type), v = [1, 1, 1, 1]); var I = new LA(v[0], v[1], v[2]), E = I.getHexString() + "_" + v[3], B = n[E]; if (B || (B = new xr({ color: I }), 1 > v[3] && (B.transparent = !0, B.opacity = v[3]), B.side = 2, n[E] = B), t.materials.push(E), y = this._getMeshNodeAttr(A, t, !1, 0), s = t.materials[0], !y) return; var x = t.key; y.type = t.type, y.userId = x, y.name = t.name, y.originalId = a, y.materialId = s, y.originMId = s, y.userData = {}, y.categoryId = 0, y.componentId = x, y.familyName = t.familyName, y.familySymbol = t.familySymbol, y.instanceOrNot = !(!vc.Instance || !this.instancedComponent[x]), y.state = Lc.Visible, y.material = null, this._classifyNodeInfo(y), y = null } }, Qf.prototype._readMeshInfo2 = function (A, e, t, i) { var o = this.loader, n = null, r = null, a = null; null === i ? (n = t.userDataId, r = t.originalId, a = t.materials || t.matId) : (n = i.userDataId, r = i.originalId, a = i.materialId > -1 ? i.materialId : t.materialId); var s = null; if (s = this._getMeshNodeAttr(A, t, !1)) { var l = o.getUserDataReader(), c = l ? l.getUserData(n) : null, h = t.key; s.type = t.type, s.userId = h, s.name = t.name, s.originalId = r, s.materialId = a, s.originMId = a, s.userData = c, s.categoryId = 0, s.componentId = h, s.familyName = t.familyName, s.familySymbol = t.familySymbol, s.state = Lc.Visible, s.material = null, this._classifyNodeInfo(s), s = null } }, Qf.prototype._getMeshNodeAttrOfPipe = function (A, e, t) { var i = A.getMatrixInfo(e.matrixId).matrix.clone(), o = uh.TemporaryMatrix; o.copy(i); var n = A.getGeomPipeInfo(e.toData), r = n.startPt, a = n.endPt, s = new y; s.subVectors(a, r); var l = s.length(); s.normalize(); var c = n.radius; c > 1 || (c = 100); var h = new y(0, 1, 0), d = new y(c, l, c), p = (new f).setFromUnitVectors(h, s), g = r.clone().addScaledVector(s, .5 * l), u = (new M).compose(g, p, d); return i.multiply(u), t && (i.multiplyMatrices(t.matrix, i), o.multiplyMatrices(t.matrix, o)), n = null, { nodeId: (t ? t.ItemId + "_" + e.ItemId : e.ItemId) + "_pipe", geometryId: "pipe", boundingBox: e.boundingBox.clone().applyMatrix4(o), matrix: i, finalState: !0 } }, Qf.prototype._getMeshNodeAttrOfTube = function (A, e, t) { var i = this._getMeshNodeAttrOfPipe(A, e, t); return i.nodeId += "_tube", i.geometryId = "tube", i }, Qf.prototype._getMeshNodeAttrOfBox = function (A, e, t) { var i = A.getMatrixInfo(e.matrixId).matrix.clone(), o = uh.TemporaryMatrix; o.copy(i); var n = e.boundingBox, r = n.getSize(), a = n.getCenter(), s = (new M).scale(new y(r.x, r.y, r.z)); return s.setPosition(a), i.multiply(s), t && (i.multiplyMatrices(t.matrix, i), o.multiplyMatrices(t.matrix, o)), { nodeId: (t ? t.ItemId + "_" + e.ItemId : e.ItemId) + "_box", geometryId: "box", boundingBox: e.boundingBox.clone().applyMatrix4(o), matrix: i, finalState: !0 } }, Qf.prototype._getMeshNodeAttrOfBoxM = function (A, e, t) { var i = A.getMatrixInfo(e.matrixId).matrix.clone(); return t && i.multiplyMatrices(t.matrix, i), { nodeId: (t ? t.ItemId + "_" + e.ItemId : e.ItemId) + "_boxM", geometryId: "boxM", boundingBox: e.boundingBox.clone().applyMatrix4(i), matrix: i, uvArrayBuffer: A.getGeomBoxUvInfo(e.toData), finalState: !0 } }, Qf.prototype._getMeshNodeAttrOfPipeM = function (A, e, t) { var i = A.getMatrixInfo(e.matrixId).matrix.clone(); return t && i.multiplyMatrices(t.matrix, i), { nodeId: (t ? t.ItemId + "_" + e.ItemId : e.ItemId) + "_pipeM", geometryId: "pipeM", boundingBox: e.boundingBox.clone().applyMatrix4(i), matrix: i, uvArrayBuffer: A.getGeomPipeUvInfo(e.toData), finalState: !0 } }, Qf.prototype._getMeshNodeAttrOfMeshRef = function (A, e, t) { return { nodeId: "refMesh|" + (t ? t.ItemId + "_" + e.ItemId : e.ItemId), geometryId: e.toData, boundingBox: e.boundingBox.clone(), matrix: A.getMatrixInfo(e.matrixId).matrix.clone(), matrixParent: t ? t.matrix : null, finalState: !1, transformed: !1, shared: !0 } }, Qf.prototype._getMeshNodeAttr = function (A, e, t, i) { var o = new M; o.fromArray(e.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]); var n = t ? e.key + "_" + i : e.key, r = t ? e.geoId + "_" + i : e.geoId; if (-1 !== r) { var a = new aA, s = this.getReferencedMeshBufferById(e.geoId); return s && s.position ? (a = Tu.getBoundingBoxByBuffer(s.position)).applyMatrix4(o) : Bh.warn("no position "), { nodeId: n, guid: e.guid, geometryId: r, originalGeometryId: e.geoId, matrix: o, boundingBox: a, model: this.model } } }, Qf.prototype._getLineNodeAttr = function (A, e, t) { var i = null, o = null; return -1 !== e.matrixId ? (o = !1, i = A.getMatrixInfo(e.matrixId).matrix.clone()) : (o = !0, i = new M), { nodeId: t ? "line-" + t.ItemId + "-" + e.ItemId : "line-" + e.ItemId, geometryId: "line-" + e.toData, boundingBox: e.boundingBox.clone(), matrix: i, matrixParent: t ? t.matrix : null, finalState: !1, transformed: o } }, Qf.prototype._classifyNodeInfo = function (A) { this._cacheNodeInfoByComponentId(A), this._cacheNodeInfoByUserId(A), this._cacheNodeInfoByCategory(A) }, Qf.prototype._cacheNodeInfoByComponentId = function (A) { void 0 === this.mapNodeInfoByComponentId[A.componentId] && (this.mapNodeInfoByComponentId[A.componentId] = []), this.mapNodeInfoByComponentId[A.componentId].push(A) }, Qf.prototype._clearNodeInfoCacheWithComponentId = function (A) { if (A) for (var e = 0, t = A.length; t > e; e += 1) delete this.mapNodeInfoByComponentId[A[e]]; else this.mapNodeInfoByComponentId = {} }, Qf.prototype._clearNodeInfoCacheWithUserId = function (A) { if (A) for (var e = 0, t = A.length; t > e; e += 1) delete this.mapNodeInfoByUserId[A[e]]; else this.mapNodeInfoByUserId = {} }, Qf.prototype._clearNodeInfoCacheWithCategory = function (A) { if (A) for (var e = this.mapNodeInfoByCategory[Qf.NodeInfoCategory.INSTANCED], t = this.mapNodeInfoByCategory[Qf.NodeInfoCategory.STANDARD], i = 0, o = A.length; o > i; i += 1) e && delete e[A[i]], t && delete t[A[i]]; else this.mapNodeInfoByCategory = {} }, Qf.prototype.clearNodeInfoCache = function () { this._clearNodeInfoCacheWithComponentId(), this._clearNodeInfoCacheWithUserId(), this._clearNodeInfoCacheWithCategory() }, Qf.prototype.clearNodeInfoCacheByComponentsKey = function (A) { this._clearNodeInfoCacheWithComponentId(A), this._clearNodeInfoCacheWithUserId(A), this._clearNodeInfoCacheWithCategory(A) }, Qf.prototype.getNodeInfosWithComponentId = function () { return this.mapNodeInfoByComponentId }, Qf.prototype.getNodeInfosByComponentId = function (A) { return this.mapNodeInfoByComponentId[A] }, Qf.prototype._cacheNodeInfoByUserId = function (A) { void 0 === this.mapNodeInfoByUserId[A.userId] && (this.mapNodeInfoByUserId[A.userId] = []), this.mapNodeInfoByUserId[A.userId].push(A) }, Qf.prototype.getNodeInfosByUserId = function (A) { return this.mapNodeInfoByUserId[A] }, Qf.prototype.getNodeInfosWithUserId = function () { return this.mapNodeInfoByUserId }, Qf.prototype._cacheNodeInfoByCategory = function (A) { var e = null; void 0 === this.mapNodeInfoByCategory[e = A.instanceOrNot ? Qf.NodeInfoCategory.INSTANCED : Qf.NodeInfoCategory.STANDARD] && (this.mapNodeInfoByCategory[e] = {}), void 0 === this.mapNodeInfoByCategory[e][A.userId] && (this.mapNodeInfoByCategory[e][A.userId] = []), this.mapNodeInfoByCategory[e][A.userId].push(A) }, Qf.prototype.getNodeInfosByCategory = function (A) { return this.mapNodeInfoByCategory[A] }, Qf.prototype.getStandardNodeInfos = function () { return this.getNodeInfosByCategory(Qf.NodeInfoCategory.STANDARD) }, Qf.prototype.getInstancedNodeInfos = function () { return this.getNodeInfosByCategory(Qf.NodeInfoCategory.INSTANCED) }, Qf.prototype.getStandardUserIds = function () { return this.getStandardNodeInfos() ? Object.keys(this.getStandardNodeInfos()) : null }, Qf.prototype.getInstancedUserIds = function () { return this.getInstancedNodeInfos() ? Object.keys(this.getInstancedNodeInfos()) : null }, Qf.prototype.traverseNodeInfos = function (A) { if (A) for (var e in this.mapNodeInfoByComponentId) for (var t = this.mapNodeInfoByComponentId[e], i = 0, o = t.length; o > i; i += 1) A(e, t[i]) }, Qf.prototype.getUserIdsByCategory = function (A, e) { var t = [], i = null; if (i = e === Qf.NodeInfoCategory.INSTANCED ? this.getInstancedNodeInfos() : this.getStandardNodeInfos()) for (var o = 0, n = A.length; n > o; o += 1) i[A[o]] && t.push(A[o]); return t }, Qf.prototype.getInstancedUserIdsByCategory = function (A) { return this.getUserIdsByCategory(A, Qf.NodeInfoCategory.INSTANCED) }, Qf.prototype.getStandardUserIdsByCategory = function (A) { return this.getUserIdsByCategory(A, Qf.NodeInfoCategory.STANDARD) }, Qf.prototype.getNodeInfosOnBMpkGeometryId = function () { return this.nodeInfosOnGeometryId || this.cacheNodeInfosOnGeometryId(), this.nodeInfosOnGeometryId }, Qf.prototype.cacheNodeInfosOnGeometryId = function () { var A = this.getStandardNodeInfos(); for (var e in this.nodeInfosOnGeometryId = {}, A) for (var t = A[e], i = 0, o = t.length; o > i; i += 1) { var n = this.loader.convertToBMpkGeometryId(t[i].geometryId); void 0 !== n && (t[i].geometryId = n), this.nodeInfosOnGeometryId[t[i].geometryId] || (this.nodeInfosOnGeometryId[t[i].geometryId] = []), this.nodeInfosOnGeometryId[t[i].geometryId].push(t[i]) } }, Qf.prototype.updateNodeInfosByIds = function (A) {}, Qf.prototype._isRegularShape = function (A) { var e = A.type === Qf.EnumNodeItemType.TUBE || A.type === Qf.EnumNodeItemType.PIPE || A.type === Qf.EnumNodeItemType.BOX || A.type === Qf.EnumNodeItemType.BOX_M || A.type === Qf.EnumNodeItemType.PIPE_M; return vc.SharedMeshInstanceEnable && (e = e || A.type === Qf.EnumNodeItemType.MESH_REF), e }, Qf.prototype.getOctreeRoots = function (A) { var e = this.loader, t = e.getOctreeRootNodeOuter(); t && A.push(t); var i = e.getOctreeRootNodeInner(); i && A.push(i) }, Qf.prototype.getComponentCount = function () { return this.componentCount }, Qf.prototype._parseInstanced = function () { this.instancedComponent = {}; var A = {}, e = {}, t = this.referencedMeshCache; for (var i in t.components) if (t.components.hasOwnProperty(i)) { var o = t.components[i], n = o.geoId; if (-1 === n) { Bh.debug("实体没有几何"); continue } if (void 0 === A[n] && (A[n] = [], e[n] = {}), A[n].push({ componentId: i }), !o.materials) { o.materials = []; continue } for (var r = 0; o.materials.length > r; r += 1) { var a = o.materials[r]; e[n][a] || (e[n][a] = []), e[n][a].push({ componentId: i, matrix: o.matrix }) } } for (var s in A) if (A.hasOwnProperty(s)) if (1 < A[s].length) for (r = 0; A[s].length > r; r += 1) this.instancedComponent[A[s][r].componentId] = !0; else delete A[s], delete e[s] }, Qf.prototype._parseBones = function () { var A = this.referencedMeshCache; for (var e in A._offsetMatrix || (A._offsetMatrix = {}), A.geometries) { var t = A.geometries[e]; t.position.length !== t.normal.length && (t.normal = t.normal.length === t.index.length ? this._computeVertexNormalsFromFaceNormals(t.normal, t.index, t.position.length) : this._computeVertexNormalsFromIndex(t.index, t.position)); var i = A.bones[e]; if (i) { t.skinIndex = i.skinIndex, t.skinWeight = i.skinWeight; var o = i.name; i.offsetMatrix.length / 16 !== o.length && Bh.debug("bones的name数量与Matrix数量不符!"); for (var n = 0; o.length > n; n += 1) A._offsetMatrix[o[n]] = (new M).fromArray(i.offsetMatrix, 16 * n) } } }, Qf.prototype._parseClips = function () { for (var A = this.referencedMeshCache.clips, e = [], t = 0, i = A.length; i > t; t += 1) { for (var o = [], n = A[t], r = 0, a = n.tracks.length; a > r; r += 1) { var s = n.tracks[r], l = null; switch (s.type) { case Qf.EnumKeyframeTrackType.weights: l = Dr; break; case Qf.EnumKeyframeTrackType.quaternion: l = Nr; break; case Qf.EnumKeyframeTrackType.position: case Qf.EnumKeyframeTrackType.scale: default: l = Vr } if (0 === n.ticksPerSec) { n.ticksPerSec = 1e3; for (var c = 0; s.times.length > c; c += 1) s.times[c] /= n.ticksPerSec } var h = new l(Fs.sanitizeNodeName(s.name) + "." + s.type, s.times, s.values, 2301); o.push(h) } var d = new Gr(void 0 !== n.name ? n.name : "animation_" + t, n.duration / n.ticksPerSec, o); e.push(d) } this.model.animations = e }, Qf.prototype._parseNodes = function () { var A = this.referencedMeshCache; A.allBones = [], A.offsetMatrix = []; var e = function A(e, t) { var i = null; "node" === e.type ? i = new H : "bone" === e.type && (i = new Uo, t.allBones[e.name] = i), i.name = Fs.sanitizeNodeName(e.name), i.matrix.fromArray(e.transformation || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]), i.matrix.decompose(i.position, i.quaternion, i.scale); for (var o = 0; e.children.length > o; o += 1) { var n = A(e.children[o], t); n && i.add(n) } for (var r = 0; e.meshes.length > r; r += 1) { var a = e.meshes[r]; t.model._getHandler().defaultManager.meshManager._readBufferInfo(t.model, [t.model.modelKey + "_" + e.meshes[r]]); var s = t.model._getHandler().defaultManager.meshManager._makeSkinMesh(t.model, [t.model.modelKey + "_" + e.meshes[r]], (function (A) {})); t.meshCache[a] = s, s.name = e.name, i.add(s) } return i }(A.nodes, this); for (var t in A.geometries) { var i = this.meshCache[t]; if (i && i.isSkinnedMesh) { for (var o = [], n = [], r = 0; A.bones[t].name.length > r; r += 1) { var a = A.bones[t].name[r], s = A._offsetMatrix[a], l = this.allBones[a]; s && l && (o.push(l), n.push(s)) } var c = new bo(o, n); i.bind(c, i.matrixWorld) } } this.model.nodes = e, this.model.manager.getScene().onBeforeRender = function (A, e, t, i) { e.updateMatrixWorld(!0) }, this.model.group.add(e), (c = new _s(e)).visible = !1, this.model.skeleton = c, this.model.group.add(c), this.model.mixer = new Rs(e), this.model.actions = []; for (var h = 0; this.model.animations.length > h; h += 1) { var d = this.model.mixer.clipAction(this.model.animations[h]); this.model.actions.push(d) } }, Qf.prototype._parseGeo = function () { Bh.time("处理几何:按材质拆分构件"); var A = this.referencedMeshCache; for (var e in A.geometries) { var t = A.geometries[e]; if (t.position.length !== t.normal.length && (t.normal = t.normal.length === t.index.length ? this._computeVertexNormalsFromFaceNormals(t.normal, t.index, t.position.length) : this._computeVertexNormalsFromIndex(t.index, t.position)), void 0 !== t.materialIndex) { for (var i = void 0, o = [], n = null, r = 0; t.materialIndex.length > r; r += 1) { var a = t.materialIndex[r]; a !== n && (n = a, void 0 !== i && (i.count = 3 * r - i.start, o.push(i)), i = { start: 3 * r, materialIndex: n }) } if (void 0 !== i && (i.count = 3 * t.materialIndex.length - i.start, o.push(i)), 1 === o.length) { A.geometries[e + "_" + o[0].materialIndex] = t } else { for (var s = {}, l = 0; o.length > l; l += 1) { var c = o[l]; void 0 === s[c.materialIndex] && (s[c.materialIndex] = { index: [], count: 0 }), s[c.materialIndex].index.push({ start: c.start, count: c.count }), s[c.materialIndex].count += c.count } var h = function () { p = {}, g = s[d]; for (var i = 0, o = new Uint32Array(g.count), n = 0; g.index.length > n; n += 1) { var r = g.index[n], a = t.index.slice(r.start, r.start + r.count); o.set(a, i), i += r.count } u = {}, o.forEach((function (A, e) { u[A] || (u[A] = []), u[A].push(e) })); var l = Object.keys(u).length; f = new Float32Array(3 * l), m = new Float32Array(3 * l), C = new Float32Array(2 * l), y = 0, v = 0; var c = 0; for (var h in u) if (u.hasOwnProperty(h)) { h = Number(h); var I = t.position.slice(3 * h, 3 * h + 3), E = t.normal.slice(3 * h, 3 * h + 3); if (t.uv.length > 0) { var B = t.uv.slice(2 * h, 2 * h + 2); C.set(B, v), v += 2 } f.set(I, y), m.set(E, y), y += 3, u[h].forEach((function (A) { o[A] = c })), c += 1 } p.index = o, p.position = f, p.normal = m, t.uv && t.uv.length > 0 && (p.uv = C), A.geometries[e + "_" + d] = p }; for (var d in s) { var p, g, u, f, m, C, y, v; h() } } } } Bh.timeEnd("处理几何:按材质拆分构件") }, Qf.prototype._computeVertexNormalsFromFaceNormals = function (A, e, t) { for (var i = new Float32Array(t), o = 0, n = 0, r = 0, a = 0, s = 0, l = 0, c = 0; A.length > c; c += 3) s = A[c + 1], l = A[c + 2], n = 3 * e[c + 1], r = 3 * e[c + 2], i[o = 3 * e[c]] = a = A[c], i[o + 1] = s, i[o + 2] = l, i[n] = a, i[n + 1] = s, i[n + 2] = l, i[r] = a, i[r + 1] = s, i[r + 2] = l; return i }, Qf.prototype._computeVertexNormalsFromIndex = function (A, e) { var t = new Float32Array(e.length); if (e) { var i = 0, o = 0, n = 0, r = new y, a = new y, s = new y, l = new y, c = new y; if (A) for (var h = A, d = 0; h.length > d; d += 3) o = 3 * h[d + 1], n = 3 * h[d + 2], r.fromArray(e, i = 3 * h[d]), a.fromArray(e, o), s.fromArray(e, n), l.subVectors(s, a), c.subVectors(r, a), l.cross(c), t[i] += l.x, t[i + 1] += l.y, t[i + 2] += l.z, t[o] += l.x, t[o + 1] += l.y, t[o + 2] += l.z, t[n] += l.x, t[n + 1] += l.y, t[n + 2] += l.z; else for (var p = 0, g = e.length; g > p; p += 9) r.fromArray(e, p), a.fromArray(e, p + 3), s.fromArray(e, p + 6), l.subVectors(s, a), c.subVectors(r, a), l.cross(c), t[p] = l.x, t[p + 1] = l.y, t[p + 2] = l.z, t[p + 3] = l.x, t[p + 4] = l.y, t[p + 5] = l.z, t[p + 6] = l.x, t[p + 7] = l.y, t[p + 8] = l.z } return t }, Qf.prototype._readMaterialBuffer222 = function (A) { var e = A.materialManager, t = e.materials, i = e.textures, o = this.referencedMeshCache.materials; for (var n in o) { var r = o[n]; if (!r) return null; var a = new xr; if (a.name = r.name || n, a.key = n, r.emissive && a.emissive && (1 === r.emissive[0] && 1 === r.emissive[1] && 1 === r.emissive[2] || a.emissive.setRGB(r.emissive[0], r.emissive[1], r.emissive[2])), r.color ? a.color.setRGB(r.color[0], r.color[1], r.color[2]) : a.color.setRGB(.72, .72, .72), r.tint && a.color.setRGB(r.tint[0], r.tint[1], r.tint[2]), r.specular && a.specular && a.specular.setRGB(r.specular[0], r.specular[1], r.specular[2]), r.map) if (void 0 !== r.mapOffsetY && 0 !== r.mapOffsetY || void 0 !== r.mapOffsetX && 0 !== r.mapOfsfetX || void 0 !== r.mapScaleX && 1 !== r.mapScaleX || void 0 !== r.mapScaleY && 1 !== r.mapScaleY || void 0 !== r.mapWAngle && 0 !== r.mapWAngle) { var s = r.mapOffsetX + "_" + r.mapOffsetY + "_" + r.mapScaleX + "_" + r.mapScaleY + "_" + r.mapWAngle + "_" + r.map; if (i[s]) a.map = i[s]; else (g = new d).wrapS = g.wrapT = 1e3, g.image = i[r.map].image ? i[r.map].image : null, g.needsUpdate = !0, g.image && (g.offset.x = r.mapOffsetX ? r.mapOffsetX : 0, g.offset.y = r.mapOffsetY ? r.mapOffsetY : 0, g.repeat.x = r.mapScaleX ? r.mapScaleX : 1, g.repeat.y = r.mapScaleY ? r.mapScaleY : 1, g.rotation = r.mapWAngle ? r.mapWAngle : 0, i[s] = g, a.map = g) } else a.map = i[r.map] ? i[r.map] : null; if (r.aoMap) if (void 0 !== r.aoMapOffsetY && 0 !== r.aoMapOffsetY || void 0 !== r.aoMapOffsetX && 0 !== r.aoMapOfsfetX || void 0 !== r.aoMapScaleX && 1 !== r.aoMapScaleX || void 0 !== r.aoMapScaleY && 1 !== r.aoMapScaleY || void 0 !== r.aoMapWAngle && 0 !== r.aoMapWAngle) { var l = r.aoMapOffsetX + "_" + r.aoMapOffsetY + "_" + r.aoMapScaleX + "_" + r.aoMapScaleY + "_" + r.aoMapWAngle + "_" + r.aoMap; if (i[l]) a.aoMap = i[l]; else (g = new d).wrapS = g.wrapT = 1e3, g.image = i[r.aoMap] && i[r.aoMap].image ? i[r.aoMap].image : null, g.needsUpdate = !0, g.image && (g.offset.x = r.aoMapOffsetX ? r.aoMapOffsetX : 0, g.offset.y = r.aoMapOffsetY ? r.aoMapOffsetY : 0, g.repeat.x = r.aoMapScaleX ? r.aoMapScaleX : 1, g.repeat.y = r.aoMapScaleY ? r.aoMapScaleY : 1, g.rotation = r.aoMapWAngle ? r.aoMapWAngle : 0, i[l] = g, a.aoMap = g) } else a.aoMap = i[r.aoMap] ? i[r.aoMap] : null; if (void 0 !== r.aoMapIntensity && (a.aoMapIntensity = r.aoMapIntensity), r.envMap) if (void 0 !== r.envMapOffsetY && 0 !== r.envMapOffsetY || void 0 !== r.envMapOffsetX && 0 !== r.envMapOfsfetX || void 0 !== r.envMapScaleX && 1 !== r.envMapScaleX || void 0 !== r.envMapScaleY && 1 !== r.envMapScaleY || void 0 !== r.envMapWAngle && 0 !== r.envMapWAngle) { var c = r.envMapOffsetX + "_" + r.envMapOffsetY + "_" + r.envMapScaleX + "_" + r.envMapScaleY + "_" + r.envMapWAngle + "_" + r.envMap; if (i[c]) a.envMap = i[c]; else (g = new d).wrapS = g.wrapT = 1e3, g.image = i[r.envMap].image ? i[r.envMap].image : null, g.needsUpdate = !0, g.image && (g.offset.x = r.envMapOffsetX ? r.envMapOffsetX : 0, g.offset.y = r.envMapOffsetY ? r.envMapOffsetY : 0, g.repeat.x = r.envMapScaleX ? r.envMapScaleX : 1, g.repeat.y = r.envMapScaleY ? r.envMapScaleY : 1, g.rotation = r.envMapWAngle ? r.envMapWAngle : 0, i[c] = g, a.envMap = g) } else a.envMap = i[r.envMap] ? i[r.envMap] : null; if (r.lightMap) if (void 0 !== r.lightMapOffsetY && 0 !== r.lightMapOffsetY || void 0 !== r.lightMapOffsetX && 0 !== r.lightMapOfsfetX || void 0 !== r.lightMapScaleX && 1 !== r.lightMapScaleX || void 0 !== r.lightMapScaleY && 1 !== r.lightMapScaleY || void 0 !== r.lightMapWAngle && 0 !== r.lightMapWAngle) { var h = r.lightMapOffsetX + "_" + r.lightMapOffsetY + "_" + r.lightMapScaleX + "_" + r.lightMapScaleY + "_" + r.lightMapWAngle + "_" + r.lightMap; if (i[h]) a.lightMap = i[h]; else (g = new d).wrapS = g.wrapT = 1e3, g.image = i[r.lightMap].image ? i[r.lightMap].image : null, g.needsUpdate = !0, g.image && (g.offset.x = r.lightMapOffsetX ? r.lightMapOffsetX : 0, g.offset.y = r.lightMapOffsetY ? r.lightMapOffsetY : 0, g.repeat.x = r.lightMapScaleX ? r.lightMapScaleX : 1, g.repeat.y = r.lightMapScaleY ? r.lightMapScaleY : 1, g.rotation = r.lightMapWAngle ? r.lightMapWAngle : 0, i[h] = g, a.lightMap = g) } else a.lightMap = i[r.lightMap] ? i[r.lightMap] : null; if (void 0 !== r.lightMapIntensity && (a.lightMapIntensity = r.lightMapIntensity), r.emissiveMap) if (void 0 !== r.emissiveMapOffsetY && 0 !== r.emissiveMapOffsetY || void 0 !== r.emissiveMapOffsetX && 0 !== r.emissiveMapOfsfetX || void 0 !== r.emissiveMapScaleX && 1 !== r.emissiveMapScaleX || void 0 !== r.emissiveMapScaleY && 1 !== r.emissiveMapScaleY || void 0 !== r.emissiveMapWAngle && 0 !== r.emissiveMapWAngle) { var p = r.emissiveMapOffsetX + "_" + r.emissiveMapOffsetY + "_" + r.emissiveMapScaleX + "_" + r.emissiveMapScaleY + "_" + r.emissiveMapWAngle + "_" + r.emissiveMap; if (i[p]) a.emissiveMap = i[p]; else (g = new d).wrapS = g.wrapT = 1e3, g.image = i[r.emissiveMap].image ? i[r.emissiveMap].image : null, g.needsUpdate = !0, g.image && (g.offset.x = r.emissiveMapOffsetX ? r.emissiveMapOffsetX : 0, g.offset.y = r.emissiveMapOffsetY ? r.emissiveMapOffsetY : 0, g.repeat.x = r.emissiveMapScaleX ? r.emissiveMapScaleX : 1, g.repeat.y = r.emissiveMapScaleY ? r.emissiveMapScaleY : 1, g.rotation = r.emissiveMapWAngle ? r.emissiveMapWAngle : 0, i[p] = g, a.emissiveMap = g) } else a.emissiveMap = i[r.emissiveMap] ? i[r.emissiveMap] : null; if (void 0 !== r.emissiveIntensity && (a.emissiveIntensity = r.emissiveIntensity), r.specularMap) if (void 0 !== r.specularMapOffsetY && 0 !== r.specularMapOffsetY || void 0 !== r.specularMapOffsetX && 0 !== r.specularMapOfsfetX || void 0 !== r.specularMapScaleX && 1 !== r.specularMapScaleX || void 0 !== r.specularMapScaleY && 1 !== r.specularMapScaleY || void 0 !== r.specularMapWAngle && 0 !== r.specularMapWAngle) { var g, u = r.specularMapOffsetX + "_" + r.specularMapOffsetY + "_" + r.specularMapScaleX + "_" + r.specularMapScaleY + "_" + r.specularMapWAngle + "_" + r.specularMap; if (i[u]) a.specularMap = i[u]; else (g = new d).wrapS = g.wrapT = 1e3, g.image = i[r.specularMap].image ? i[r.specularMap].image : null, g.needsUpdate = !0, g.image && (g.offset.x = r.specularMapOffsetX ? r.specularMapOffsetX : 0, g.offset.y = r.specularMapOffsetY ? r.specularMapOffsetY : 0, g.repeat.x = r.specularMapScaleX ? r.specularMapScaleX : 1, g.repeat.y = r.specularMapScaleY ? r.specularMapScaleY : 1, g.rotation = r.specularMapWAngle ? r.specularMapWAngle : 0, i[u] = g, a.specularMap = g) } else a.specularMap = i[r.specularMap] ? i[r.specularMap] : null; void 0 !== r.shininess && (a.shininess = r.shininess), void 0 !== r.opacity && (a.opacity = r.opacity, 1 > r.opacity && (a.transparent = !0), r.opacity > 0 || (a.opacity = .1)), a.side = 2, t[n] = a } }, Qf.prototype._updateV1ToV2 = function (A) { var e = this.referencedMeshCache.components, t = this.referencedMeshCache.geometries, i = this.referencedMeshCache.materials; for (var o in e) if (e.hasOwnProperty(o)) { var n = e[o], r = n.matId, a = t[n.geoId]; if (n.materials) continue; if (n.materials = [], !a) continue; var s = i[r]; if (!s) continue; var l = this._updateMaterialV1ToV2(r, s); if (l) for (var c in a.materialIndex = l.materialIndex, n.materials = l.materialId, l.materials) l.materials.hasOwnProperty(c) && (this.referencedMeshCache.materials[c] = l.materials[c]) } }, Qf.prototype._updateMaterialV1ToV2 = function (A, e) { var t = {}, i = [], o = {}; if (!e) return null; for (var n = e.color, r = e.colorIndex, a = e.texture, s = e.textureIndex, l = 0; n.length > l; l += 4) { var c = {}; c.color = [n[l], n[l + 1], n[l + 2]], c.opacity = Math.floor(100 * n[l + 3]) / 100, c.transparent = 1 > n[l + 3]; var h = (255 * c.color[0] << 16 ^ 255 * c.color[1] << 8 ^ 255 * c.color[2] << 0) + "_" + c.opacity; o[h] = c, i.push(h) } if (0 !== a.length && r.length === s.length) for (var d = -1, p = 0; s.length > p; p += 1) { if (d !== r[p]) if (d = r[p], -1 !== s[p]) o[i[r[p]]].map = a[s[p]] } return t.materials = o, t.materialId = i, t.materialIndex = r, t }, Qf.prototype.addMeshToInfoMap = function (A, e, t, i) { var o = this.getNodeInfosByComponentId(A); Array.isArray(o) && o.forEach((function (A) { A.nodeId === e && (A.mesh = t, A.index = i) })) }; var Rf = function () { this.geometries = {} }; Rf.prototype.dispose = function () { this.disposeGeometries(), this.geometries = {} }, Rf.prototype.destory = function () { this.dispose() }, Rf.prototype.disposeGeometries = function () { for (var A in this.geometries) this.disposeGeometry(A) }, Rf.prototype.disposeGeometry = function (A) { var e = this.geometries[A]; if (e) { if (Array.isArray(e)) for (var t = 0, i = e.length; i > t; t += 1) e[t].dispose(); else e.dispose(); delete this.geometries[A] } }, Rf.prototype._hasGeometry = function (A) { return !!this.geometries[A] }, Rf.prototype._cacheGeometry = function (A, e) { void 0 === this.geometries[A] && (this.geometries[A] = e) }, Rf.prototype.getNodeIdxMapByUserId = function (A) {}, Rf.prototype.getGeometryById = function (A) { return this.geometries[A] }, Rf.prototype.getGeometryByNodeInfo = function (A, e) { return this._hasGeometry(e.geometryId) ? this.getGeometryById(e.geometryId) : this._createGeometryByNodeInfo(A, e) }, Rf.prototype._createGeometryByNodeInfo = function (A, e) { return this._createGeometry(e.type, e.geometryId, A.getModelDescriptor().getReferencedMeshBufferById(e.geometryId)) }, Rf.prototype._createGeometry = function (A, e, t) { if (this._hasGeometry(e)) return this.getGeometryById(e); var i = this._createBufferGeometry(A, t); return i ? (i.key = e, this._cacheGeometry(e, i), i) : null }, Rf.prototype._createBufferGeometry = function (A, e) { var t = Qf.EnumNodeItemType, i = null; switch (1) { case t.MESH: case t.MESH_REF: if (!e) return null; if ((i = new he).setIndex(new YA(e.index, 1)), i.setAttribute("position", new YA(e.position, 3)), e.normal && e.normal.length > 0 ? i.setAttribute("normal", new YA(e.normal, 3)) : i.computeVertexNormals(), e.uv && e.uv.length > 0 && i.setAttribute("uv", new YA(e.uv, 2)), e.uv2 && e.uv2.length > 0 && i.setAttribute("uv2", new YA(e.uv2, 2)), e.skinIndex && e.skinIndex.length > 0 ? i.setAttribute("skinIndex", new YA(e.skinIndex, 4)) : Bh.debug("skinIndex 长度为0"), e.skinWeight && e.skinWeight.length > 0 ? i.setAttribute("skinWeight", new YA(e.skinWeight, 4)) : Bh.debug("skinWeight 长度为0"), void 0 !== e.materialIndex) { for (var o = null, n = [], r = void 0, a = 0; e.materialIndex.length > a; a += 1) { var s = e.materialIndex[a]; s !== r && (r = s, null != o && (o.count = 3 * a - o.start, n.push(o)), o = { start: 3 * a, materialIndex: r }) } null != o && (o.count = 3 * e.materialIndex.length - o.start, n.push(o)), i.groups = n } break; case t.TUBE: case t.PIPE: i = Tu.UnitCylinderInstance; break; case t.BOX: i = Tu.UnitBoxInstance; break; case t.BOX_M: i = Tu.getUnitTextureBox(); break; case t.PIPE_M: i = Tu.getUnitTextureCylinder(); break; case t.LINE: if (!e) return null; (i = new he).setIndex(new YA(e.I, 1)), i.setAttribute("position", new YA(e.P, 3)) } return i }, Rf.prototype.createBufferByBufferDataWithUV2 = function (A, e, t) { var i = this.createBufferByBufferData(e, t); if (!i) return null; if (!A.lightmap) return i; var o = [], n = i.index, r = A.getLoader().getUV2ById(e.itemIdUV2, n.length); r && (e.lightmapIdx = r.lightmapIdx, o = r.uv2); for (var a = i.position, s = i.normal, l = i.uv, c = [], h = [], d = [], p = 0; n.length > p; p += 1) { var g = n[p]; c.push(a[3 * g]), c.push(a[3 * g + 1]), c.push(a[3 * g + 2]), s && (h.push(s[3 * g]), h.push(s[3 * g + 1]), h.push(s[3 * g + 2])), l && (d.push(l[2 * g]), d.push(l[2 * g + 1])), n[p] = p } return a = null, s = null, l = null, i.uv2 = o, i.position = c, i.normal = h, i.uv = d, i }, Rf.prototype.createBufferByBufferData = function (A, e) { this.cachedComponentGeoBuffer || (this.cachedComponentGeoBuffer = {}); var t = null, i = null, o = null, n = null, r = null, a = Qf.EnumNodeItemType, s = null; switch (1) { case a.MESH: case a.MESH_REF: if (!e || !e.buffer) return Bh.debug("缺少几何buffer"), null; var c = e.buffer; if (i = c.index, A.geometryId === A.originalGeometryId ? (t = c.position, o = c.normal, n = c.uv ? c.uv : null, r = c.uv2 ? c.uv2 : null) : (t = Float32Array.from(c.position), o = Float32Array.from(c.normal), n = c.uv ? Float32Array.from(c.uv) : null, r = c.uv2 ? Float32Array.from(c.uv2) : null), c = null, e.indexInfo) { i = i.slice(e.indexInfo.indexStart, e.indexInfo.indexStart + e.indexInfo.indexCount), t = t.slice(e.indexInfo.positionStart, e.indexInfo.positionStart + e.indexInfo.positionCount), o = o.slice(e.indexInfo.positionStart, e.indexInfo.positionStart + e.indexInfo.positionCount), n = n ? n.slice(e.indexInfo.uvStart, e.indexInfo.uvStart + e.indexInfo.uvCount) : null, r = r ? r.slice(e.indexInfo.uvStart, e.indexInfo.uvStart + e.indexInfo.uvCount) : null; var h = e.indexInfo.positionStart / 3; i.forEach((function (A, e, t) { t[e] -= h })) } if (uh.isMirror(A.matrix.elements)) for (var d = 0, p = i.length; p > d; d += 3) { var g = i[d + 1]; i[d + 1] = i[d + 2], i[d + 2] = g } break; case a.BOX: case a.PIPE: s = Tu.UnitCylinderInstance, i = Uint32Array.from(s.index.array), t = Float32Array.from(s.attributes.position.array), o = Float32Array.from(s.attributes.normal.array), s = null; break; case a.TUBE: case a.BOX_M: case a.PIPE_M: s = A.type === a.BOX_M || A.type === a.BOX ? Tu.getBoxMBuffer(A.uvArrayBuffer) : Tu.getPipeMBuffer(A.uvArrayBuffer), i = Uint32Array.from(s.index), t = Float32Array.from(s.vertex), o = Float32Array.from(s.normal), s.uv && (n = Float32Array.from(s.uv), delete s.uv), s = null; break; case a.LINE: if (!e || !e.buffer) return null; if (e.isDataView ? (i = Uint32Array.from(e.buffer.I), t = Float32Array.from(e.buffer.P), o = null, n = null) : (i = new Uint32Array(e.buffer.I), t = new Float32Array(e.buffer.P), o = null, n = null), e.indexInfo) { i = i.slice(e.indexInfo.indexStart, e.indexInfo.indexStart + e.indexInfo.indexCount), t = t.slice(e.indexInfo.positionStart, e.indexInfo.positionStart + e.indexInfo.positionCount); h = e.indexInfo.positionStart / 3; i.forEach((function (A, e, t) { t[e] -= h })) } break; default: Bh.log("error data!") } if (!this.cachedComponentGeoBuffer[A.geometryId] || A.geometryId !== A.originalGeometryId) { var u = A.matrix; if (Tu.applyMatrix4ToBuffer(u, t), o) { var f = new l; f.getNormalMatrix(u), Tu.applyMatrix3ToBuffer(f, o), Tu.normalizeBuffer(o) } this.cachedComponentGeoBuffer[A.geometryId] = !0 } return A.uv = !!n, { index: i, position: t, normal: o, uv: n, uv2: r } }; var Tf = function (A) { return Rf.call(this), this.manager = A, this._maxIndiceseNum = 0, this._materialList = [], this.mapMaterialIdToMergedNode = {}, this.selectedMeshes = [], this.nonSelectedMeshes = [], this.selectedObjectIds = [], this.blinkMaterials = [], this.mapDestroyedBufferKey = {}, this }; function kf(A, e, t, i) { for (var o = A.getAttribute("position").array, n = e; t > n; n += 3) o[n] += i.x, o[n + 1] += i.y, o[n + 2] += i.z; A.getAttribute("position").needsUpdate = !0 } (Tf.prototype = Object.create(Rf.prototype)).destroy = function () { this.dispose(), this.clearData(), this.mapMaterialIdToMergedNode = {}, this.manager = null, this._materialList = [], this.selectedMeshes = [], this.nonSelectedMeshes = [], this.selectedObjectIds = [], this.blinkMaterials = [], this.mapDestroyedBufferKey = {} }, Tf.prototype.clearData = function () { this.bufferDestroyed = !1, this.clearAllNodeBuffer(), this._disposeMergedGeometries() }, Tf.prototype.getMeshesByUserIds = function (A, e) { var t = []; for (var i in this.mapMaterialIdToMergedNode) for (var o = this.mapMaterialIdToMergedNode[i], n = 0, r = o.length; r > n; n += 1) { var a = o[n], s = a.indices[e]; if (s) for (var l = 0, c = s.length; c > l; l += 1) { var h = {}; h.mesh = a.mesh, h.indexInfo = s[l], h.matrix = A.getModelMatrix(), t.push(h) } } return t }, Tf.prototype.rebuildIndices = function (A) { this._materialList.length = 0; var e = vc.EnableLightmap && A.lightmap; this.clearSelectedObjectIds(); var t = this.manager.getFilteredUserIds(), i = this.manager.getSelectedUserIds(), o = this.manager.getHoveredUserIds(), n = this.manager.getBlinkedUserIds(), r = (A.hasReplacedUserId(), A.manager.scene.fillClipPlane && vc.ClippingCaps), a = {}; for (var s in this.mapMaterialIdToMergedNode) { var l, c = this.getPropertyValueByMaterialKey(s).materialId, h = null, d = null, p = null, g = null, u = null, f = null, m = null, C = null, y = null; i && i[c] && (g = i[c]), o && o[c] && (u = o[c]), n && n[c] && (f = n[c]), t && t[c] && (h = t[c][zc.HIDDEN], d = t[c][zc.OVERRIDED], p = t[c][zc.TRANSPARENT]); var v = this.mapMaterialIdToMergedNode[s]; for (y = 0, l = v.length; l > y; y += 1) { var I = v[y], E = I.indices, B = I.geometry; if (B.clearGroups(), B._visible = !0, e) for (var x = A.lightmapNum, S = 0; x > S; S += 1) { var w = "lightmap|" + S; - 1 === this._materialList.indexOf(w) && this._materialList.push(w) } if (g || h || d || u || p || vc.EnableLightmap || r || f) { var M = []; for (var b in E) if (E.hasOwnProperty(b)) { if (h && h[b]) continue; var U = E[b]; if (U && U.length > 0) { if (U.sort((function (A, e) { return A.indexStart - e.indexStart })), p && p[b]) { for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.TRANSPARENT }); continue } if (A.manager.isSelectPriority()) { if (g && g[b]) { if (this.cacheSelectedObjectIds(b, s, y), vc.PickingEffect) { if (d && d[b]) { var F = d[b], K = this._materialList.indexOf(F); for (-1 === K && (this._materialList.push(F), K = this._materialList.length - 1), m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.OVERRIDED + K }); continue } for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.NONE }); continue } for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.SELECTED }); continue } if (f && f[b]) { if (d && d[b]) { var Q = "blink|" + d[b], R = this._materialList.indexOf(Q); for (-1 === R && (this._materialList.push(Q), R = this._materialList.length - 1), m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.OVERRIDED + R }); continue } for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.BLINK }); continue } } else { if (f && f[b]) { if (d && d[b]) { var T = "blink|" + d[b], k = this._materialList.indexOf(T); for (-1 === k && (this._materialList.push(T), k = this._materialList.length - 1), m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.OVERRIDED + k }); continue } for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.BLINK }); continue } if (g && g[b]) { if (this.cacheSelectedObjectIds(b, s, y), vc.PickingEffect) { if (d && d[b]) { var D = d[b], L = this._materialList.indexOf(D); for (-1 === L && (this._materialList.push(D), L = this._materialList.length - 1), m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.OVERRIDED + L }); continue } for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.NONE }); continue } for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.SELECTED }); continue } } if (p && p[b]) { for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.TRANSPARENT }); continue } if (u && u[b]) { if (d && d[b]) { var N = this._materialList.indexOf(O = "hover|" + d[b]); for (-1 === N && (this._materialList.push(O), N = this._materialList.length - 1), m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.OVERRIDED + N }); continue } for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.HOVER }); continue } if (d && d[b]) { var O, V = this._materialList.indexOf(O = d[b]); for (-1 === V && (this._materialList.push(O), V = this._materialList.length - 1), m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.OVERRIDED + V }); continue } if (r && a[b]) { for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.CLIPPING }); continue } if (vc.EnableLightmap) for (m = 0, C = U.length; C > m; m += 1) { var G = this._materialList.indexOf("lightmap|" + U[m].lightmapIdx); M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: zc.OVERRIDED + G }) } else for (m = 0, C = U.length; C > m; m += 1) M.push({ indexStart: U[m].indexStart, indexCount: U[m].indexCount, state: 0 }) } } if (M.length > 0) for (M.sort((function (A, e) { return A.state === e.state ? A.indexStart - e.indexStart : A.state - e.state })), m = 0, C = M.length; C > m; m += 1) { var P = M[m].indexStart, q = M[m].indexCount, j = M[m].state; if (0 === m) B.addGroup(P, q, j); else j === M[m - 1].state && P === M[m - 1].indexStart + M[m - 1].indexCount ? B.groups[B.groups.length - 1].count += q : B.addGroup(P, q, j) } else B._visible = !1 } } } }, Tf.prototype.update = function (A, e) { var t = A.manager.filter, i = A.materialManager.materials, o = A.selectedMaterial, n = A.manager.sceneState, r = null, a = null, s = null, l = null, c = null, h = null, d = vc.EnableLightmap && A.lightmap; if (A.isOnlyWireframe()) for (var p in this.mapMaterialIdToMergedNode) { var g = this.mapMaterialIdToMergedNode[p]; for (s = 0, l = g.length; l > s; s += 1) { var u = g[s].mesh; u && (u.visible = !1) } } else { vc.TranslucentDepthDisabled && (o.depthWrite = !o.transparent); var f = t._getMaterialByName("scene"); vc.TranslucentDepthDisabled && (f.depthWrite = !1); var m = []; this.blinkMaterials.length = 0; var C = {}; if (!d) for (r = 0, a = this._materialList.length; a > r; r += 1) { var y = null, v = this._materialList[r], I = v.split("|"); "hover" === I[0] ? (y = t._getMaterialByName(I[1]), y = n.getHoverMaterial(y)) : "blink" === I[0] ? (y = t._getMaterialByName(I[1]), y = n.getBlinkMaterial(y), C[v] || this.blinkMaterials.push(y)) : y = t._getMaterialByName(v) ? t._getMaterialByName(v) : this.manager.model.materialManager.getMaterialById(v), vc.TranslucentDepthDisabled && (y.depthWrite = !y.transparent), m[r] = y } for (var E in this.mapMaterialIdToMergedNode) { var B = this.getPropertyValueByMaterialKey(E).materialId, x = A.manager.getOverrideMaterialByName(B) || i[B] || Kd.getDefaultStandardMaterial(); if (x) { if (d) for (r = 0, a = this._materialList.length; a > r; r += 1) { var S = null, w = this._materialList[r].split("|"); if ("lightmap" === w[0]) if (vc.IBL) S = x.clone(); else { var M = Kd.getMaterialParameters(x); M.lights = !1, (S = Kd.createStandardMaterial(M)).lightMap = A.materialManager.lightmaps[w[1]], S.lightMapIntensity = vc.LightmapIntensity } vc.TranslucentDepthDisabled && S && (S.depthWrite = !S.transparent), m[r] = S } vc.TranslucentDepthDisabled && (x.depthWrite = !x.transparent); var b = n.getHoverMaterial(i[B]); vc.TranslucentDepthDisabled && (b.depthWrite = !b.transparent); var U = this.mapMaterialIdToMergedNode[E]; for (s = 0, l = U.length; l > s; s += 1) { var F = U[s], K = F.geometry; if (null !== K) { var Q = F.mesh; if (Q) if (K._visible) { if (K.groups.length > 0) { var R = C[B]; R || (R = C[B] = n.getBlinkMaterial(x), this.blinkMaterials.push(R)); var T = [x, o, R, b, f]; for (r = 0, a = m.length; a > r; r += 1) { if (!m[r].createByBos) { if (m[r].materialId !== B && !m[r].mapNodeIdToOrigMatId) continue; if (!Object.keys(m[r].mapNodeIdToOrigMatId).find((function (A) { return m[r].mapNodeIdToOrigMatId[A] === B }))) continue } for (var k in K.attributes.uv || (m[r].map = null), U[s].indices) if (this.manager.mapMaterialIdToUserIdsForFilter[B] && this.manager.mapMaterialIdToUserIdsForFilter[B][zc.OVERRIDED]) for (var D = Object.keys(this.manager.mapMaterialIdToUserIdsForFilter[B][zc.OVERRIDED]), L = 0, N = D.length; N > L; L += 1) k === D[L] && (T[5 + r] = m[r]) } if (e) { var O = []; for (c = 0, h = T.length; h > c; c += 1) O.push(e); T = O } Q.material = T } else Q.material = e || x; Q.visible = !0 } else Q.visible = !1; else Bh.error("没有mesh对象") } } x = null } } } }, Tf.prototype.explode = function (A, e, t) { for (var i in this.mapMaterialIdToMergedNode) for (var o = this.mapMaterialIdToMergedNode[i], n = 0, r = o.length; r > n; n += 1) { var a = o[n], s = a.geometry; if (null !== s) { var l = a.indices; for (var c in l) { var h = A.manager.getComponentInfoByUserId(c).boundingBox, d = uh.computeExplodeTranslation(e, h, t), p = l[c]; if (p) for (var g = 0, u = p.length; u > g; g += 1) { var f = p[g].positionStart; kf(s, f, f + p[g].positionCount, d) } } } } }, Tf.prototype.explosion = function (A, e) { var t = A.getModelDescriptor().getStandardUserIds(); e.componentKey = t, this.componentsExplosion(A, e) }, Tf.prototype.closeExplosion = function (A) { this.explosion(A, {}) }, Tf.prototype.componentsExplosion = function (A, e) { var t = e.coefficientX || 1, i = e.coefficientY || 1, o = e.coefficientZ || 1, n = e.offsetX || 0, r = e.offsetY || 0, a = e.offsetZ || 0, s = null; if (e.center) s = (new y).fromArray(e.center); else if (1 !== t || 1 !== i || 1 !== o || 0 !== n || 0 !== r || 0 !== a) return; var l = Array.isArray(e.componentKey) ? e.componentKey : [e.componentKey], c = new y, h = new aA, d = new y(0, 0, 0), p = new y(0, 0, 0), g = new y, u = new M, m = A.getModelMatrix(); m && s && (u.getInverse(m), s.applyMatrix4(u)); var C = A.manager, v = !1, I = new y, E = new f, B = new y(1, 1, 1); uh.isEmptyObject(A.subModel) || (v = !0); for (var x = 0, S = l.length; S > x; x += 1) { var w = l[x]; if (w) { var b = A.getModelDescriptor().getStandardNodeInfosById(w); if (b) for (var U = 0, F = b.length; F > U; U += 1) { var K = b[U]; if (K) { var Q = this._getMaterialKeyByNodeInfo(K), R = this.mapMaterialIdToMergedNode[Q]; if (R) for (var T = 0, k = R.length; k > T; T += 1) { var D = R[T], L = D.geometry, N = D.mesh; if (L && N) { var O = D.indices; if (O) { var V = O[w]; if (V) { h.copy(K.boundingBox), h.getCenter(c), K.userData || (K.userData = {}), d.set(0, 0, 0), p.set(0, 0, 0); var G = new y(1, 1, 1); if (v && (N.matrix.decompose(I, E, B), G.divide(B)), 1 !== t || 1 !== i || 1 !== o || K.userData.explosionFactor) { K.userData.explosionFactor || (K.userData.explosionFactor = new y(1, 1, 1), K.userData.explosionBaseDifference = c.sub(s).clone().multiply(G)); var P = K.userData.explosionFactor, q = K.userData.explosionBaseDifference; d.set((t - P.x) * q.x, (i - P.y) * q.y, (o - P.z) * q.z), 1 === t && 1 === i && 1 === o ? (K.userData.explosionFactor = void 0, K.userData.explosionBaseDifference = void 0) : P.set(t, i, o) } if (0 !== n || 0 !== r || 0 !== a || K.userData.explosionOffset) { K.userData.explosionOffset || (K.userData.explosionOffset = new y(0, 0, 0)); var j = K.userData.explosionOffset; p.set(n * G.x - j.x, r * G.y - j.y, a * G.z - j.z), 0 === n && 0 === r && 0 === a ? K.userData.explosionOffset = void 0 : j.set(n * G.x, r * G.y, a * G.z) } if (g.set(d.x + p.x, d.y + p.y, d.z + p.z), 0 !== g.x || 0 !== g.y || 0 !== g.z) { K.userData.explosionFactor || K.userData.explosionOffset ? C.explosionList[w] || (C.explosionList[w] = !0) : delete C.explosionList[w]; var H = g.clone().multiply(B); u.makeTranslation(H.x, H.y, H.z), K.userData.changeOffset = g.clone(), K.transformation || (K.transformation = !0, K.transformationOriginalMatrix = K.matrix.clone(), K.applyMatrix = new M, K.transformationOriginalBoundingBox = K.boundingBox.clone()), K.matrix.premultiply(u), K.applyMatrix.premultiply(u), K.boundingBox.copy(K.transformationOriginalBoundingBox).applyMatrix4(K.applyMatrix); for (var Y = 0, W = V.length; W > Y; Y += 1) { var J = V[Y].positionStart; kf(L, J, J + V[Y].positionCount, g) } L.attributes.position.needsUpdate = !0 } } } } } } } } } }, Tf.prototype.closeComponentsExplosion = function (A, e) { e = Array.isArray(e) ? e : [e]; this.componentsExplosion(A, { componentKey: e }) }, Tf.prototype._getNodeGroup = function (A) { return A._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }) }, Tf.prototype._hasNodeGroup = function (A) { return A._hasNodeGroup(gp.GEOMETRY) }, Tf.prototype._resetMaxIndicesNumberPerBathSegment = function (A) { vc.SegmentedBatchMergeEnable && this._maxIndiceseNum > vc.maxIndicesNumberPerBathSegment && (Bh.log("adjust maxIndicesNumberPerBathSegment value from " + vc.maxIndicesNumberPerBathSegment + " to " + this._maxIndiceseNum + "!"), vc.maxIndicesNumberPerBathSegment = A) }, Tf.prototype.asyncCreateMeshNodes = function (A, e, t) { var i = this; e && e.length ? this._asyncMergeData(A, e, (function () { Bh.timeEnd("MergeData"), i._makeMeshNodes(A), t && t() })) : t && t() }, Tf.prototype.createBatchedMeshNodes = function (A, e) { var t = this.mapMaterialIdToMergedNode, i = A.manager, o = A.modelKey, n = A._encodedDatabagId, r = this._getNodeGroup(A), a = A.materialManager, s = e.materialKey, l = this.getPropertyValueByMaterialKey(s), c = a.getMaterialById(l.materialId); if (!c) { var h = Object.keys(e.componentInfo)[0], d = e.componentInfo[h][0].nodeId, p = A.getModelDescriptor().getNodeInfosByNodeId(d); if (!p) return; p.uv = "1" === l.uvProp, s = this._getMaterialKeyByNodeInfo(p, A), l = this.getPropertyValueByMaterialKey(s), c = a.getMaterialById(l.materialId) } var g = new he; if (g._visible = !0, g.setIndex(new YA(e.index, 1)), e.position && e.position.length > 0) { g.setAttribute("position", new YA(e.position, 3)), e.normal && e.normal.length === e.position.length && g.setAttribute("normal", new YA(e.normal, 3)); var u = !1; e.uv && e.uv.length > 0 > 0 && (g.setAttribute("uv", new YA(e.uv, 2)), u = !0), c.aoMap && g.setAttribute("uv2", new YA(e.uv, 2)), g.getAttribute("normal") || g.computeVertexNormals(); var f = e.componentInfo; t[s] || (t[s] = []); var m = null; if ("lines" === l.type) (m = new cf(g)).modelKey = o; else { var C = { modelKey: o }; (m = new Kf(g, c)).spawn(C) } if (t[s].push({ geometry: g, indices: f, mesh: m }), m._indicesGroup = f, !uh.isEmptyObject(A.subModel)) { var y = Object.keys(f)[0]; if (y) { var v = uh.getModelKeyFromComponentKey(y); A.subModel[v] && m.matrix.copy(A.subModel[v]) } } r.add(m), i.addMeshToOctantMap(n, s, new Eu(s, m)); var I = function (e) { f.hasOwnProperty(e) && f[e].forEach((function (t) { A.addMeshToInfoMap(e, t.nodeId, m, t, u) })) }; for (var E in f) I(E); r.updateMatrixWorld(!0), f = null, m = null } }, Tf.prototype._asyncMergeData = function (A, e, t) { Bh.time("MergeData"); var i = {}, o = this, n = A.getLoader().maxLoadTaskCount, r = A.progressPercentage.load, a = A.progressPercentage.collect, s = e.length, l = Math.ceil(s / A.progressFrequency), c = A.getModelDescriptor().getStandardNodeInfos(); requestAnimationFrame(function h(d) { var p = d; return function () { var d = null, g = null; for (g = p + l > s ? s : p + l, d = p; g > d; d += 1) { if (o._collectMergedNodeInfosById(A, e[d], c, i), d === g - 1) if (g !== s) A.dispatchEventEx({ type: Rc.ON_LOAD_PROGRESS, progress: { total: n, loaded: (d / s * a + r) * n, modelKey: A.modelKey } }), requestAnimationFrame(h(d + 1)); else A.dispatchEventEx({ type: Rc.ON_LOAD_PROGRESS, progress: { total: n, loaded: (a + r) * n, modelKey: A.modelKey } }), o._asyncMergeGeometry(i, A, t) } } }(0)) }, Tf.prototype._asyncMergeGeometry = function (A, e, t) { var i = []; for (var o in A) i.push(o); if (0 !== i.length) { this._resetMaxIndicesNumberPerBathSegment(this._maxIndiceseNum); var n = this, r = e.getLoader().maxLoadTaskCount, a = e.progressPercentage.load, s = e.progressPercentage.collect, l = e.progressPercentage.merge, c = i.length, h = Math.ceil(c / e.progressFrequency), d = this.mapMaterialIdToMergedNode; requestAnimationFrame(function o(p) { var g = p; return function () { var p, u = null; for (u = g + h > c ? c : g + h, p = g; u > p; p += 1) { if (n._collectMergedGeometriesById(i[p], A, d), p === u - 1) if (u !== i.length) e.dispatchEventEx({ type: Rc.ON_LOAD_PROGRESS, progress: { total: r, loaded: (p / c * l + a + s) * r, modelKey: e.modelKey }, modelKey: e.modelKey }), requestAnimationFrame(o(p + 1)); else t() } } }(0)) } else t() }, Tf.prototype._collectMergedNodeInfosById = function (A, e, t, i) { for (var o = t[e], n = 0, r = o.length; r > n; n += 1) { var a = o[n]; this._createNodeBuffer(A, a); var s = this._getNodeBufferBy(a.nodeId); if (s) { var l = s.index; l && l.length > this._maxIndiceseNum && (this._maxIndiceseNum = l.length); var c = this._getMaterialKeyByNodeInfo(a, A); void 0 === i[c] && (i[c] = []), i[c].push(a) } } }, Tf.prototype._collectMergedGeometriesById = function (A, e, t) { var i = e[A]; void 0 === t[A] && (t[A] = []); for (var o = [], n = Math.max(i.length / 800, 500), r = Math.floor(i.length / n), a = i.length, s = 0; r >= s; s += 1) { for (var l = 0, c = 0, h = 0, d = 0, p = 0, g = null, u = !1, f = 0, m = 0, C = a > n ? n : a; C > m; m += 1) { var y = s * n, v = i[y + m]; if (!v) break; (g = this._getNodeBufferBy(v.nodeId)) ? (c += g.index.length, l += g.position.length, g.normal && (h += g.normal.length), g.uv && g.uv.length > 0 ? (u = !0, d += g.uv.length) : d += g.position.length / 3 * 2, g.uv2 && (p += g.uv2.length), vc.SegmentedBatchMergeEnable && c > vc.maxIndicesNumberPerBathSegment ? (g.normal && (h -= g.normal.length), g.uv && (d -= g.uv.length), g.uv2 && (p -= g.uv2.length), o.push({ start: f, end: m, steps: y, arrayPositionLength: l -= g.position.length, arrayIndexLength: c -= g.index.length, arrayNormalLength: h, arrayUVLength: d, arrayUV2Length: p }), l = 0, c = 0, h = 0, d = 0, p = 0, f = m, m -= 1) : m === C - 1 && o.push({ start: f, end: C, steps: y, arrayPositionLength: l, arrayIndexLength: c, arrayNormalLength: h, arrayUVLength: d, arrayUV2Length: p }), g = null) : m === C - 1 && o.push({ start: f, end: C, steps: y, arrayPositionLength: l, arrayIndexLength: c, arrayNormalLength: h, arrayUVLength: d, arrayUV2Length: p }) } a -= n } for (var I = 0, E = o.length; E > I; I += 1) { for (var B = o[I], x = new he, S = {}, w = new Float32Array(B.arrayPositionLength), M = new Uint32Array(B.arrayIndexLength), b = new Float32Array(B.arrayNormalLength), U = new Float32Array(B.arrayUVLength), F = new Float32Array(B.arrayUV2Length), K = 0, Q = 0, R = 0, T = 0, k = 0, D = [], L = B.start, N = B.end; N > L; L += 1) { var O = i[B.steps + L]; if (g = this._getNodeBufferBy(O.nodeId)) { D.push(O.nodeId); var V = g.index, G = g.position, P = g.normal, q = g.uv, j = g.uv2; w.set(G, K); for (var H = new Uint32Array(V), Y = 0, W = H.length; W > Y; Y += 1) H[Y] += K / 3; M.set(H, Q), void 0 === S[O.userId] && (S[O.userId] = []), S[O.userId].push({ userId: O.userId, nodeId: O.nodeId, positionStart: K, positionCount: G.length, indexStart: Q, indexCount: V.length, lightmapIdx: O.lightmapIdx, boundingBox: O.boundingBox }), Q += V.length, K += G.length, P && (b.set(P, R), R += P.length), u && (q ? (U.set(q, T), T += q.length) : (U.set(new Float32Array(G.length / 3 * 2), T), T += q.length)), j && (F.set(j, k), k += j.length), V = null, G = null, P = null, q = null, j = null, g = null } } this.clearNodeBufferByNodeIds(D), x._visible = !0, x.setIndex(new YA(M, 1)), x.setAttribute("position", new YA(w, 3)), R > 0 && x.setAttribute("normal", new YA(b, 3)), T > 0 && x.setAttribute("uv", new YA(U, 2)), k > 0 && x.setAttribute("uv2", new YA(F, 2)), t[A].push({ geometry: x, indices: S }) } }, Tf.prototype.clearAllNodeBuffer = function () { this.cachedNodeBuffer && (this.cachedNodeBuffer = {}) }, Tf.prototype.clearNodeBufferByNodeIds = function (A) { if (this.cachedNodeBuffer) for (var e = 0, t = A.length; t > e; e += 1) this.cachedNodeBuffer[A[e]] = null }, Tf.prototype._getNodeBufferByNodeInfo = function (A, e) { return this.cachedNodeBuffer || this._createNodeBuffer(A, e), this.cachedNodeBuffer[e.nodeId] }, Tf.prototype._getNodeBufferBy = function (A) { return this.cachedNodeBuffer ? this.cachedNodeBuffer[A] : null }, Tf.prototype._createNodeBufferForMergedBuffer = function (A, e, t) { this.cachedNodeBuffer || (this.cachedNodeBuffer = {}), this.cachedNodeBuffer[e.nodeId] || (this.cachedNodeBuffer[e.nodeId] = this.createBufferByBufferDataWithUV2(A, e, t)) }, Tf.prototype._createNodeBuffer = function (A, e) { this._createNodeBufferForMergedBuffer(A, e, { buffer: A.getModelDescriptor().getReferencedMeshBufferById(e.geometryId), isDataView: !0 }) }, Tf.prototype._createGeometries = function (A, e) { var t = this, i = A.getModelDescriptor().getNodeInfosOnGeometryId(), o = A.getModelDescriptor().getReferencedMeshBufferData(), n = this._getClassifiedMeshes(i, o); this._dealDataMergedMeshs(A, n, o, i, (function () { t._dealDataMergeableMeshs(A, n, o, i, e) })) }, Tf.prototype._getClassifiedMeshes = function (A, e) { var t = [], i = []; for (var o in e) { var n = e[o].IndexInfos, r = void 0; if (n) { if (1 > n.length) continue; for (var a = 0, s = n.length; s > a; a += 1) { if ((l = A[n[a].meshId]) && l.length) { r = n[a].meshId; break } } } else { var l; (l = A[o]) && l.length && (r = o) } if (void 0 !== r) (l = A[r]) && l.length && (l[0].type === $u.EnumNodeItemType.LINE || !l[0].instanceOrNot && l[0].shared ? t.push(o) : i.push(o)) } if (!vc.Instance) for (var o in A) i[o] || t[o] || t.push(o); return { mergeableIdxs: t, mergedIdxs: i } }, Tf.prototype._collectMergeableMeshesByIdxId = function (A, e, t, i, o) { t[e] && t[e].IndexInfos ? this._collectSharedMeshesByIdxId(A, e, t, i, o) : this._collectLineOrIntanceMeshesByIdxId(A, e, t, i, o) }, Tf.prototype._collectLineOrIntanceMeshesByIdxId = function (A, e, t, i, o) { for (var n = i[e], r = { buffer: A.getModelDescriptor().getReferencedMeshBufferById(e) }, a = 0, s = n.length; s > a; a += 1) { var l = n[a]; this._createNodeBufferByGeoBufferData(A, l, r); var c = this._getMaterialKeyByNodeInfo(l); o[c] || (o[c] = []), o[c].push(l) } }, Tf.prototype._collectSharedMeshesByIdxId = function (A, e, t, i, o) { for (var n = t[e].IndexInfos, r = 0, a = n.length; a > r; r += 1) { var s = i[n[r].meshId]; if (s) for (var l = { buffer: A.getModelDescriptor().getReferencedMeshBufferById(e), indexInfo: n[r] }, c = 0, h = s.length; h > c; c += 1) { var d = s[c]; this._createNodeBufferByGeoBufferData(A, d, l); var p = this._getMaterialKeyByNodeInfo(d); o[p] || (o[p] = []), o[p].push(d) } } }, Tf.prototype._mergeMergeableMeshes = function (A, e, t, i) { var o = Object.keys(e); if (0 !== o.length) { var n = this, r = A.getLoader().maxLoadTaskCount, a = o.length, s = A.progressPercentage.load, l = A.progressPercentage.collect, c = A.progressPercentage.merge, h = Math.ceil(a / A.progressFrequency); requestAnimationFrame(function d(p) { var g = p; return function () { var p = null, u = null; for (u = g + h > a ? a : g + h, p = g; u > p; p += 1) n._collectMergedGeometriesById(o[p], e, t), p === u - 1 && (u !== a ? (A.dispatchEvent({ type: Rc.ON_LOAD_PROGRESS, progress: { total: r, loaded: (p / a * c + s + l) * r, modelKey: A.modelKey } }), requestAnimationFrame(d(p + 1))) : n._makeMeshNodes(A, i)) } }(0)) } else this._makeMeshNodes(A, i) }, Tf.prototype._dealDataMergeableMeshs = function (A, e, t, i, o) { if (0 !== e.mergeableIdxs.length) { var n = this, r = this.mapMaterialIdToMergedNode, a = {}, s = e.mergedIdxs.length, l = e.mergeableIdxs.length, c = s + l, h = e.mergeableIdxs, d = A.getLoader().maxLoadTaskCount, p = A.progressPercentage.load, g = A.progressPercentage.collect, u = Math.ceil(l / A.progressFrequency); requestAnimationFrame(function e(f) { var m = f; return function () { var f = null, C = null; for (C = m + u > l ? l : m + u, f = m; C > f; f += 1) n._collectMergeableMeshesByIdxId(A, h[f], t, i, a), f === C - 1 && (C !== l ? (A.dispatchEvent({ type: Rc.ON_LOAD_PROGRESS, progress: { total: d, loaded: ((f + s) / c * g + p) * d, modelKey: A.modelKey } }), requestAnimationFrame(e(f + 1))) : (A.dispatchEvent({ type: Rc.ON_LOAD_PROGRESS, progress: { total: d, loaded: (g + p) * d, modelKey: A.modelKey } }), n._mergeMergeableMeshes(A, a, r, o))) } }(0)) } else this._makeMeshNodes(A, o) }, Tf.prototype._collectDataMergedMeshesByIdxId = function (A, e, t, i, o) { var n = e[A], r = n.IndexInfos; if (r && 0 !== r.length) { var a = !1; n.UV && (n.UV.byteLength || n.UV.length) && (a = !0), o.lightmap && (n = this.getAttributeForLightmapWithDataMerged(n, o, A)); for (var s = void 0, l = 0, c = r.length; c > l; l += 1) { var h = t[r[l].meshId]; if (h && 0 !== h.length) { o.lightmap && (r[l].lightmapIdx = n.lightmapIdx, r[l].positionStart = 3 * r[l].indexStart, r[l].positionCount = 3 * r[l].indexCount), s = r[l].meshId; for (var d = 0, p = h.length; p > d; d += 1) h[d].uv = a } } if (void 0 !== s) { var g = t[s][0], u = {}, f = this._getMaterialKeyByNodeInfo(g); void 0 === i[f] && (i[f] = []); for (var m = 0, C = r.length; C > m; m += 1) t[r[m].meshId] && (void 0 === u[(g = t[r[m].meshId][0]).userId] && (u[g.userId] = []), r[m].userId = g.userId, r[m].nodeId = g.nodeId, r[m].boundingBox = g.boundingBox, u[g.name].push(r[m])); var y = new he; y._visible = !0, y.setIndex(new YA(new Uint32Array(n.I), 1)), y.setAttribute("position", new YA(new Float32Array(n.P), 3)), n.N && (n.N.byteLength || n.N.length) && y.setAttribute("normal", new YA(new Float32Array(n.N), 3)), a && y.setAttribute("uv", new YA(new Float32Array(n.UV), 2)), n.UV2 && (y.setAttribute("uv2", new YA(new Float32Array(n.UV2), 2)), y.lightmapIdx = n.lightmapIdx), i[f].push({ geometry: y, indices: u }) } } }, Tf.prototype.getAttributeForLightmapWithDataMerged = function (A, e, t) { var i = [], o = new Uint32Array(A.I), n = e.getLoader().getUV2ById("bmpk_" + t, o.length); if (n) { var r = n.lightmapIdx; i = n.uv2 } for (var a = new Float32Array(A.P), s = new Float32Array(A.N), l = new Float32Array(A.UV), c = [], h = [], d = [], p = 0; o.length > p; p += 1) { var g = o[p]; c.push(a[3 * g]), c.push(a[3 * g + 1]), c.push(a[3 * g + 2]), s.length > 0 && (h.push(s[3 * g]), h.push(s[3 * g + 1]), h.push(s[3 * g + 2])), l.length > 0 && (d.push(l[2 * g]), d.push(l[2 * g + 1])), o[p] = p } return a = null, s = null, l = null, { I: o, UV2: i, P: c, N: h, UV: d, lightmapIdx: r } }, Tf.prototype._dealDataMergedMeshs = function (A, e, t, i, o) { if (0 !== e.mergedIdxs.length) { var n = this, r = this.mapMaterialIdToMergedNode, a = e.mergedIdxs, s = a.length, l = e.mergedIdxs.length + e.mergeableIdxs.length, c = A.getLoader().maxLoadTaskCount, h = A.progressPercentage.load, d = A.progressPercentage.collect, p = Math.ceil(s / A.progressFrequency); requestAnimationFrame(function e(g) { var u = g; return function () { var g = null, f = null; for (f = u + p > s ? s : u + p, g = u; f > g; g += 1) n._collectDataMergedMeshesByIdxId(a[g], t, i, r), g === f - 1 && (f !== s ? (A.dispatchEvent({ type: Rc.ON_LOAD_PROGRESS, progress: { total: c, loaded: (g / l * d + h) * c, modelKey: A.modelKey } }), requestAnimationFrame(e(g + 1))) : (A.dispatchEvent({ type: Rc.ON_LOAD_PROGRESS, progress: { total: c, loaded: (g / l * d + h) * c, modelKey: A.modelKey } }), o && o())) } }(0)) } else o && o() }, Tf.prototype._dealUnsharedMeshs = function (A, e, t) { for (var i = this.mapMaterialIdToMergedNode, o = 0, n = A.length; n > o; o += 1) { var r = t[A[o]], a = r.IndexInfos, s = e[a[0].meshId][0], l = {}, c = this._getMaterialKeyByNodeInfo(s); void 0 === i[c] && (i[c] = []); for (var h = 0, d = a.length; d > h; h += 1) void 0 === l[(s = e[a[h].meshId][0]).userId] && (l[s.userId] = []), a[h].userId = s.userId, a[h].nodeId = s.nodeId, l[s.userId].push(a[h]); var p = new he; p._visible = !0, p.setIndex(new YA(new Uint32Array(r.index), 1)), p.setAttribute("position", new YA(new Float32Array(r.position), 3)), r.normal && p.setAttribute("normal", new YA(new Float32Array(r.normal), 3)), r.uv && p.setAttribute("uv", new YA(new Float32Array(r.uv), 2)), i[c].push({ geometry: p, indices: l }) } }, Tf.prototype._makeMeshNodes = function (A, e) { Bh.time("makeMesh"); var t = A.manager, i = A.modelKey, o = A._encodedDatabagId, n = this._getNodeGroup(A), r = this.mapMaterialIdToMergedNode; for (var a in r) for (var s = this.getPropertyValueByMaterialKey(a), l = r[a], c = 0, h = l.length; h > c; c += 1) { var d = l[c].geometry, p = l[c].indices; if (!l[c].mesh) { var g = null; if ("lines" === s.type) (g = new cf(d)).modelKey = i; else { var u = { modelKey: i }; (g = new Kf(d)).spawn(u) } if (!uh.isEmptyObject(A.subModel)) { var f = Object.keys(p)[0]; if (f) { var m = uh.getModelKeyFromComponentKey(f); A.subModel[m] && g.matrix.copy(A.subModel[m]) } } g._indicesGroup = p, n.add(g), l[c].mesh = g, t.addMeshToOctantMap(o, a, new Eu(a, g)); var C = function (e) { p.hasOwnProperty(e) && p[e].forEach((function (t) { A.addMeshToInfoMap(e, t.nodeId, g, t) })) }; for (var y in p) C(y); p = null, g = null } } n.updateMatrixWorld(!0), A.dispatchEvent({ type: Rc.ON_LOAD_PROGRESS, progress: { total: A.getLoader().maxLoadTaskCount, loaded: A.getLoader().maxLoadTaskCount, modelKey: A.modelKey } }), e && e(), Bh.timeEnd("makeMesh") }, Tf.prototype.createMeshNodes = function (A, e) { A.getModelDescriptor().getStandardNodeInfos() ? this._createGeometries(A, e) : e && e() }, Tf.prototype.applySelection = function (A) {}, Tf.prototype.clearSelection = function (A) {}, Tf.prototype.applyHover = function (A) {}, Tf.prototype.clearHover = function (A) {}, Tf.prototype.getMeshNode = function () { return this.mapMaterialIdToMergedNode }, Tf.prototype._disposeMergedGeometries = function () { for (var A in this.mapMaterialIdToMergedNode) { for (var e = this.mapMaterialIdToMergedNode[A], t = 0, i = e.length; i > t; t += 1) { e[t].geometry.dispose(), delete e[t].geometry, delete e[t].indices, delete e[t].mesh } delete this.mapMaterialIdToMergedNode[A] } }, Tf.prototype._getMaterialKeyByNodeInfo = function (A, e) { if (e) { var t = e.manager.getOverrideMaterialByNodeInfo(A); A.materialId = t ? t.name : A.originMId } return uh.getCombinedKeyString([A.materialId, A.uv ? "1" : "0", A.type === $u.EnumNodeItemType.LINE ? "lines" : "meshes"]) }, Tf.prototype.getPropertyValueByMaterialKey = function (A) { var e = uh.splitCombinedKeyString(A); return { materialId: e[0], uvProp: e[1], type: e[2] } }, Tf.prototype.clearSelectedObjectIds = function () { this.selectedObjectIds.length = 0 }, Tf.prototype.cacheSelectedObjectIds = function (A, e, t) { this.selectedObjectIds.push({ uid: A, mKey: e, idx: t }) }, Tf.prototype.adjustVisibility = function (A, e) { var t = this._getNodeGroup(A), i = t.visible; e && !t.bVisible || (t.visible = e), t.bVisible = i }, Tf.prototype.changeVisibilityOfSelectedObjects = function (A, e) { if (e) for (var t = 0, i = this.selectedMeshes.length; i > t; t += 1) { var o = this.selectedMeshes[t].object, n = this.selectedMeshes[t].indices; if (o) for (var r = 0, a = n.length; a > r; r += 1) { var s = o.geometry.groups[n[r].idx]; s.start = n[r].start, s.count = n[r].count } } else { this.selectedMeshes.length = 0; for (var l = {}, c = 0, h = this.selectedObjectIds.length; h > c; c += 1) { var d = this.selectedObjectIds[c].mKey, p = this.selectedObjectIds[c].idx, g = uh.getCombinedKeyString([d, p]); if (!l[g]) { l[g] = !0; var u = this.mapMaterialIdToMergedNode[d][p], f = u.mesh; if (f) { for (var m = [], C = u.geometry.groups, y = 0, v = C.length; v > y; y += 1) { var I = C[y]; I.materialIndex === zc.SELECTED && (m.push({ idx: y, start: I.start, count: I.count }), I.start = 0, I.count = 0) } m.length && this.selectedMeshes.push({ object: f, indices: m }) } } } } }, Tf.prototype.changeVisibilityOfNonSelectedObjects = function (A, e) { if (e) for (var t = 0, i = this.nonSelectedMeshes.length; i > t; t += 1) { var o = this.nonSelectedMeshes[t].object, n = this.nonSelectedMeshes[t].indices; if (n) for (var r = 0, a = n.length; a > r; r += 1) { var s = o.geometry.groups[n[r].idx]; s.start = n[r].start, s.count = n[r].count } else o.visible = this.nonSelectedMeshes[t].visibility } else { this.nonSelectedMeshes.length = 0; for (var l = {}, c = 0, h = this.selectedObjectIds.length; h > c; c += 1) { var d = this.selectedObjectIds[c]; l[d.mKey] || (l[d.mKey] = {}), l[d.mKey][d.idx] = !0 } for (var p in this.mapMaterialIdToMergedNode) { var g = this.mapMaterialIdToMergedNode[p]; if (l[p]) for (var u = 0, f = g.length; f > u; u += 1) { var m = g[u].mesh; if (m) { if (!l[p][u]) { this.nonSelectedMeshes.push({ object: m, indices: null, visibility: m.visible }), m.visible = !1; continue } for (var C = [], y = m.geometry.groups, v = 0, I = y.length; I > v; v += 1) { var E = y[v]; E.materialIndex !== zc.SELECTED && (C.push({ idx: v, start: E.start, count: E.count }), E.start = 0, E.count = 0) } C.length > 0 && this.nonSelectedMeshes.push({ object: m, indices: C }) } } else for (var B = 0, x = g.length; x > B; B += 1) { var S = g[B].mesh; S && (this.nonSelectedMeshes.push({ object: S, indices: null, visibility: S.visible }), S.visible = !1) } } } }, Tf.prototype.restoreVisibilityOfObjects = function () { this.selectedMeshes.length = 0, this.nonSelectedMeshes.length = 0 }, Tf.prototype.getBlinkMaterials = function () { return this.blinkMaterials }, Tf.prototype.disposeBufferAfterVbo = function () { if (!this.bufferDestroyed) { var A = 0; for (var e in this.mapMaterialIdToMergedNode) { for (var t = this.mapMaterialIdToMergedNode[e], i = 0, o = t.length; o > i; i += 1) { var n = t[i], r = n.geometry; if (null !== r) { A += 1; var a = e + "-" + i; this.mapDestroyedBufferKey[a] || n.mesh.visible && (this.mapDestroyedBufferKey[a] = !0, Tu.disposeBufferFromGeometry(r, ["normal", "uv", "uv2"])) } } Object.keys(this.mapDestroyedBufferKey).length === A && (this.mapDestroyedBufferKey = {}, this.bufferDestroyed = !0) } } }, Tf.prototype._traverseMeshNodeMap = function (A) { for (var e in this.mapMaterialIdToMergedNode) for (var t = this.mapMaterialIdToMergedNode[e], i = 0, o = t.length; o > i; i += 1) A && A(e, t[i]) }, Tf.prototype.getGeometryBuffersByUserId = function (A, e) { var t = [], i = A.getDatabagId(); return this._traverseMeshNodeMap((function (A, o) { var n = o.indices[e]; if (n) for (var r = o.geometry, a = r.getIndex().array, s = r.getAttribute("position").array, l = 0, c = n.length; c > l; l += 1) { var h = n[l], d = h.indexStart, p = h.indexStart + h.indexCount, g = a.slice(d, p), u = s.slice(d = h.positionStart, p = h.positionStart + h.positionCount); d /= 3, g.forEach((function (A, e, t) { t[e] -= d })), t.push({ databagId: i, nodeId: h.nodeId, position: u, index: g }) } })), t }, Tf.prototype.getPickingNodeGenerator = function () { return this.pickingNodeGenerator || (this.pickingNodeGenerator = new nf(this)), this.pickingNodeGenerator }; var Df = function (A) { of .call(this, A), this.nodeGroupName = "PickingBatchedWireFrameGroup" }; Object.assign(Df.prototype, of .prototype), eu(Df, [{ key: "disposePickingNodeById", value: function (A) { for (var e = this.pickingNodeMap[A], t = 0, i = e.length; i > t; t += 1) e[t]._indicesGroup = null, e[t].material = null, e[t].geometry.dispose(), e[t] = null } }, { key: "generatePickingMeshes", value: function () { var A = this.manager.getWireFrameLineSegments(); A || (this.manager.generateWireframe(), A = this.manager.getWireFrameLineSegments()); for (var e = 0, t = A.length; t > e; e += 1) { var i = A[e].geometry, o = new he; o.setAttribute("position", i.getAttribute("position")), o.setIndex(i.getIndex()); var n = new jo(o, Kd.DefaultMaterial); (new M).copy(A[e].matrix).multiply(this.manager.model.getModelMatrix()).decompose(n.position, n.quaternion, n.scale), n._indicesGroup = A[e]._indicesGroup, n.frustumCulled = !1, n.renderOrder = 1, this.addToPickingNodeMap(e, [n]) } } }, { key: "_rebuildGeometryGroup", value: function (A, e, t) { var i, o = this.manager.manager, n = 0, r = 0, a = 0, s = A._indicesGroup, l = Object.keys(s), c = [], h = {}; e.length > l.length ? (c = l, h = t) : (c = e, h = s); var d = []; for (a = 0, i = c.length; i > a; a += 1) { var p = c[a]; if (o.isPickableNode(p) && h[p]) { var g = s[p]; if (g && g.length > 0) for (n = 0, r = g.length; r > n; n += 1) d.push({ indexStart: g[n].indexStart, indexCount: g[n].indexCount }) } } A.visible = !0; var u = A.geometry; if (u.clearGroups(), 0 !== d.length) for (d.sort((function (A, e) { return A.indexStart - e.indexStart })), n = 0, r = d.length; r > n; n += 1) { var f = d[n].indexStart, m = d[n].indexCount; if (0 === n) u.addGroup(f, m, 0); else f === d[n - 1].indexStart + d[n - 1].indexCount ? u.groups[u.groups.length - 1].count += m : u.addGroup(f, m, 0) } else A.visible = !1 } }, { key: "updatePickingMeshesState", value: function (A, e, t) { for (var i = this.pickingNodeMap, o = Object.keys(i), n = 0, r = o.length; r > n; n += 1) for (var a = i[o[n]], s = 0, l = a.length; l > s; s += 1) a[s].material = [A], a[s].visible = !1, this._rebuildGeometryGroup(a[s], e, t) } }]); var Lf = function (A) { this.manager = A, this.model = A.model, this.generated = !1, this.wireframeLineSegment = null, this.wireframeGeometryMap = null, this.wireframeDataMap = null, this.userIdMapForNoWireFrame = {} }; function Nf(A, e, t, i) { for (var o = A.getAttribute("position").array, n = e; t > n; n += 1) o[3 * n] += i.x, o[3 * n + 1] += i.y, o[3 * n + 2] += i.z; A.getAttribute("position").needsUpdate = !0 } Lf.prototype.destroy = function () { this.clearData(), this.manager = null, this.userIdMapForNoWireFrame = null, this.pickingNodeGenerator && (this.pickingNodeGenerator.destroy(), this.pickingNodeGenerator = null) }, Lf.prototype.clearData = function () { this.generated = !1, this.bufferDestroyed = !1, this.wireframeLineSegment && (this.wireframeLineSegment._indicesGroup = null, this.wireframeLineSegment.geometry.dispose(), this.wireframeLineSegment = null), this.pickingNodeGenerator && this.pickingNodeGenerator.clearData(), this.wireframeGeometryMap = null, this.userIdMapForNoWireFrame = {} }, Lf.prototype._createWireframeGeometry = function (A, e) { if (this.wireframeGeometryMap || (this.wireframeGeometryMap = {}), this.wireframeDataMap || (this.wireframeDataMap = {}), !this.wireframeGeometryMap[e.nodeId]) { var t = this._getWireframeData(A, e), i = new he; i.setIndex(new $A(t.index, 1)), i.setAttribute("position", new YA(t.buffer, 3)), i._userId = e.userId, this.wireframeGeometryMap[e.nodeId] = i } }, Lf.prototype._getWireframeData = function (A, e) { this.wireframeDataMap || (this.wireframeDataMap = {}); var t = {}; if (!this.wireframeDataMap[e.nodeId]) { for (var i = A.attributes.position.array.slice(e.positionStart, e.positionStart + e.positionCount), o = A.getIndex().array.slice(e.indexStart, e.indexStart + e.indexCount), n = 0, r = o.length; r > n; n += 1) o[n] -= e.positionStart / 3; var a = Up(i, o); return t = Tu.reducedGeometry(i, a), this.wireframeDataMap[e.nodeId] = t, t } return this.wireframeDataMap[e.nodeId] }, Lf.prototype._createWireframeGeometries = function (A) { A || (A = this.model); var e = A.manager.filter, t = A.getModelDescriptor().getStandardNodeInfos(); function i(A) { var i = t[A]; return !(i && e._hasRenderWithBoardlineFilter() && !e._isRenderWithBoardline(i[0])) } var o = this.manager.getMeshNode(); for (var n in Bh.time("createWireframeGeometry"), o) { if ("meshes" === this.manager.getPropertyValueByMaterialKey(n).type) for (var r = o[n], a = 0, s = r.length; s > a; a += 1) { var l, c = r[a]; if (c.RenderTypeChange) { for (var h = (l = c.geometry.clone()).attributes.position.array, d = [], p = new y, g = c.mesh.matrixWorld, u = 0, f = h.length; f > u; u += 3) p.set(h[u], h[u + 1], h[u + 2]).applyMatrix4(g), d.push(p.x, p.y, p.z); l.setAttribute("position", new YA(new Float32Array(d), 3)) } else l = c.geometry; if (null !== l) { var m = c.indices; for (var C in m) { i(C) || (this.userIdMapForNoWireFrame[C] = !0); for (var v = m[C], I = 0, E = v.length; E > I; I += 1) this._createWireframeGeometry(l, v[I]) } } } } return Bh.timeEnd("createWireframeGeometry"), !0 }, Lf.prototype._makeWireframe = function (A) { A || (A = this.model); var e = {}, t = A.getWireframeMaterial(); for (var i in this.wireframeGeometryMap) { var o = this.wireframeGeometryMap[i], n = o._userId, r = new jo(o, t); r.userId = n, r.nodeId = i, e[n] || (e[n] = []), e[n].push(r), r = null } var a = []; for (var n in e) for (var s = e[n], l = 0, c = s.length; c > l; l += 1) a.push(s[l]); if (a.length > 0) { var h = {}, d = Tu.mergeBufferGeometriesFromMeshs(a, h); if (d && (this.wireframeLineSegment = new jo(d, A.getWireframeMaterial()), this.wireframeLineSegment.matrixAutoUpdate = !1, this.wireframeLineSegment._indicesGroup = h, !uh.isEmptyObject(A.subModel))) { var p = Object.keys(h)[0]; if (p) { var g = uh.getModelKeyFromComponentKey(p); A.subModel[g] && this.wireframeLineSegment.matrix.copy(A.subModel[g]) } } } for (var n in a = null, e) delete e[n]; e = null, this.wireframeGeometryMap = null }, Lf.prototype.generateWireframe = function (A, e) { A || (A = this.model), this.generated || (this._createWireframeGeometries(A), this._makeWireframe(A), this.generated = !0, e && e()) }, Lf.prototype.update = function (A) { if (this.manager.hasNodeInfo(A)) if (A.isActivateWireframe()) { if (this.generateWireframe(A), this.wireframeLineSegment) { var e = this._getNodeGroup(A); e.clear(), e.add(this.wireframeLineSegment), e.updateMatrixWorld(!0) } } else A._hasNodeGroup(gp.WIREFRAME) && A._removeNodeGroup(gp.WIREFRAME) }, Lf.prototype.rebuildIndices = function (A) { if (this.needDealWireframeLine(A)) { this.wireframeLineSegment.visible = !0; var e = this.wireframeLineSegment._indicesGroup, t = this.wireframeLineSegment.geometry; t.clearGroups(); var i = A.getWireframeMaterial(); this.wireframeLineSegment.material = i; var o = this.manager.getFilteredUserIdsForWireFrame(), n = Boolean(o && Object.keys(o).length); if (this._existHiddenUserId() || n) { var r = [], a = 0, s = 0, l = []; for (var c in e) if (!this._isHiddenUserId(c)) { var h = e[c]; if (h && h.length > 0) { if (o[c]) { var d = o[c], p = l.indexOf(d); for (-1 === p && (l.push(d), p = l.length - 1), a = 0, s = h.length; s > a; a += 1) r.push({ indexStart: h[a].indexStart, indexCount: h[a].indexCount, state: 1 + p }); continue } for (a = 0, s = h.length; s > a; a += 1) r.push({ indexStart: h[a].indexStart, indexCount: h[a].indexCount, state: 0 }) } } if (0 !== r.length) { for (r.sort((function (A, e) { return A.indexStart - e.indexStart })), a = 0, s = r.length; s > a; a += 1) { var g = r[a].indexStart, u = r[a].indexCount, f = r[a].state; if (0 === a) t.addGroup(g, u, f); else f === r[a - 1].state && g === r[a - 1].indexStart + r[a - 1].indexCount ? t.groups[t.groups.length - 1].count += u : t.addGroup(g, u, f) } var m = A.getFilter(), C = [i]; for (a = 0, s = l.length; s > a; a += 1) { var y = m._getMaterialByName(l[a]); C.push(y) } this.wireframeLineSegment.material = C } else this.wireframeLineSegment.visible = !1 } } }, Lf.prototype.explode = function (A, e, t) {}, Lf.prototype.explosion = function (A, e) { if (this.wireframeLineSegment) { var t = Object.keys(this.wireframeLineSegment._indicesGroup); e || (e = {}), e.componentKey = t, this.componentsExplosion(A, e) } }, Lf.prototype.closeExplosion = function (A) { this.explosion(A) }, Lf.prototype.componentsExplosion = function (A, e) { if (this.wireframeLineSegment) for (var t = Array.isArray(e.componentKey) ? e.componentKey : [e.componentKey], i = this.wireframeLineSegment._indicesGroup, o = this.wireframeLineSegment.geometry, n = 0, r = t.length; r > n; n += 1) { var a = t[n]; if (a) { var s = A.getModelDescriptor().getStandardNodeInfosById(a); if (s) { var l = i[a]; if (l) { var c = s[0]; if (!c || !c.userData || !c.userData.changeOffset) continue; for (var h = 0, d = l.length; d > h; h += 1) { var p = l[h].positionStart; Nf(o, p, p + l[h].positionCount, c.userData.changeOffset) } c.userData.changeOffset = void 0 } } } } }, Lf.prototype.closeComponentsExplosion = function (A, e) { this.componentsExplosion(A, { componentKey: e }) }, Lf.prototype._getNodeGroup = function (A) { return A._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 }) }, Lf.prototype.needDealWireframeLine = function (A) { return !(!A.isActivateWireframe() || !this.wireframeLineSegment) }, Lf.prototype.adjustVisibility = function (A, e) { if (this.needDealWireframeLine(A)) { var t = this._getNodeGroup(A), i = t.visible; e && !t.bVisible || (t.visible = e), t.bVisible = i } }, Lf.prototype.changeVisibilityOfSelectedObjects = function (A, e) {}, Lf.prototype.changeVisibilityOfNonSelectedObjects = function (A, e) { this.adjustVisibility(A, e) }, Lf.prototype.restoreVisibilityOfObjects = function () {}, Lf.prototype.disposeBufferAfterVbo = function () { this.generated && !this.bufferDestroyed && this.wireframeLineSegment && this.wireframeLineSegment.visible && (this.bufferDestroyed = !0, Tu.disposeBufferFromGeometry(this.wireframeLineSegment.geometry, ["position", "normal", "uv", "uv2"])) }, Lf.prototype._existHiddenUserId = function () { var A = this.manager.getHiddenUserIds(); return !!(this.userIdMapForNoWireFrame && Object.keys(this.userIdMapForNoWireFrame).length || A && Object.keys(A).length) }, Lf.prototype._isHiddenUserId = function (A) { if (this.userIdMapForNoWireFrame[A]) return !0; var e = this.manager.getHiddenUserIds(); return !(!e || !e[A]) }, Lf.prototype.getWireFrameLineSegments = function () { return this.wireframeLineSegment ? [this.wireframeLineSegment] : null }, Lf.prototype.getPickingNodeGenerator = function () { return this.pickingNodeGenerator || (this.pickingNodeGenerator = new Df(this)), this.pickingNodeGenerator }; var Of = function (A, e) { this.model = e, this.meshManager = new Tf(this), A || (this.wireframeManager = new Lf(this)) }; Of.prototype.destroy = function () { this.meshManager.destroy(), this.meshManager = null, this.wireframeManager.destroy(), this.wireframeManager = null, this._clearFilteredState(), this._clearSelectedState(), this._clearHoveredState(), this._clearBlinkedState() }, Of.prototype.updateNodes = function (A) { var e; e = this._collectModelFiltered(A), this.meshManager.update(A, e), this.wireframeManager.update(A) }, Of.prototype.generateWireframe = function (A, e) { this.wireframeManager.generateWireframe(A, e) }, Of.prototype.asyncGenerateWireframe = function (A, e) { this.wireframeManager.asyncGenerateWireframe(A, e) }, Of.prototype.rebuildIndices = function (A) { this._rebuildIndices(A) }, Of.prototype.clearData = function () { this.meshManager.clearData(), this.wireframeManager.clearData(), this._clearFilteredState(), this._clearSelectedState(), this._clearHoveredState(), this._clearBlinkedState() }, Of.prototype.createMeshNodes = function (A, e) { this.meshManager.createMeshNodes(A, e) }, Of.prototype.createBatchedMeshNodes = function (A, e) { this.meshManager.createBatchedMeshNodes(A, e) }, Of.prototype.asyncCreateMeshNodes = function (A, e, t) { this.meshManager.asyncCreateMeshNodes(A, e, t) }, Of.prototype.hasNodeInfo = function (A) { return Boolean(A.getModelDescriptor().getStandardNodeInfos()) }, Of.prototype.disposeGeometry = function (A) { this.meshManager.disposeGeometry(A) }, Of.prototype.getMeshNode = function () { return this.meshManager.getMeshNode() }, Of.prototype.getPropertyValueByMaterialKey = function (A) { return this.meshManager.getPropertyValueByMaterialKey(A) }, Of.prototype.getFilteredUserIds = function () { return this.mapMaterialIdToUserIdsForFilter }, Of.prototype.getSelectedUserIds = function () { return this.mapMaterialIdToUserIdsForSelection }, Of.prototype.getHoveredUserIds = function () { return this.mapMaterialIdToUserIdsForHover }, Of.prototype.getBlinkedUserIds = function () { return this.mapBlinkUserIds }, Of.prototype.getHiddenUserIds = function () { return this.hiddenUserIdSetObject }, Of.prototype.getTransparentUserIds = function () { return this.transparentUserIdSetObject }, Of.prototype.applyFilter = function (A, e) { console.log('applyFilter :>>dddddddddd '); if (this.hasNodeInfo(A)) { var t = null; t = e || A.getModelDescriptor().getStandardUserIds(); var i = A.getModelDescriptor().getStandardNodeInfos(); this._collectFilteredUserIds(A, t, i), this._collectFilteredUserIdsForWireFrame(A, t, i), this._collectSelectedUserIds(A.manager.sceneState.selectionSet, i), this._collectHoveredUserIds(A.manager.sceneState.hoverId, i), this._rebuildIndices(A), this.updateNodes(A) } }, Of.prototype.applySelection = function (A) { console.log('applySelection16') if (this.hasNodeInfo(A)) { var e = A.getModelDescriptor().getStandardNodeInfos(); this._clearSelectedState(A), this._clearHoveredState(A), this._collectSelectedUserIds(A.manager.sceneState.selectionSet, e), this._collectHoveredUserIds(A.manager.sceneState.hoverId, e), this._rebuildIndices(A), this.updateNodes(A) } }, Of.prototype.clearSelection = function (A) { this._clearSelectedState(A), this.applyHover(A) }, Of.prototype.applyHover = function (A) { if (this.hasNodeInfo(A)) { var e = A.getModelDescriptor().getStandardNodeInfos(); this._clearHoveredState(A), this._collectHoveredUserIds(A.manager.sceneState.hoverId, e), this._rebuildIndices(A), this.updateNodes(A) } }, Of.prototype.clearHover = function (A) { this._clearHoveredState(A), this._rebuildIndices(A), this.updateNodes(A) }, Of.prototype.applyBlink = function (A) { if (this.hasNodeInfo(A)) { var e = A.getModelDescriptor().getStandardNodeInfos(); this._clearBlinkedState(A), this._clearHoveredState(A), this._collectBlinkedUserIds(A.manager.sceneState.getBlinkComponentsIdMap(), e), this._collectHoveredUserIds(A.manager.sceneState.hoverId, e), this._rebuildIndices(A), this.updateNodes(A) } }, Of.prototype.clearBlink = function (A) { this._clearBlinkedState(A), this.applyHover(A) }, Of.prototype.applyReplacement = function (A) { this._rebuildIndices(A), this.updateNodes(A) }, Of.prototype._collectFilteredUserIds = function (A, e, t) { var i = A.manager.filter, o = i._hasHiddenFileIdFilter(), n = i._hasVisibleFilter(), r = i._hasOverrideMaterialFilter(), a = i._hasTransparentFilter(), s = A.hasReplacedUserId(), l = A.hasHiddenSourceObjectUserId(), c = this.mapMaterialIdToUserIdsForFilter = {}; if (this.hiddenUserIdSetObject = {}, this.overrideUserIdSetObject = {}, this.transparentUserIdSetObject = {}, o || n || r || a || s || l) for (var h = 0; e.length > h; h += 1) { var d = e[h], p = t[d]; if (p && p.length) for (var g = 0, u = p.length; u > g; g += 1) { var f = p[g]; if (o && i._isHiddenFileId(f) || n && !1 === i._isVisible(f) || A.isReplacedUserId(d) || A.isHiddenSourceObjectUserId(d)) void 0 === c[f.materialId] && (c[f.materialId] = {}), void 0 === c[f.materialId][zc.HIDDEN] && (c[f.materialId][zc.HIDDEN] = {}), c[f.materialId][zc.HIDDEN][d] = !0, this.hiddenUserIdSetObject[d] = !0; else if (a && i._isTransparent(f)) void 0 === c[f.materialId] && (c[f.materialId] = {}), void 0 === c[f.materialId][zc.TRANSPARENT] && (c[f.materialId][zc.TRANSPARENT] = {}), c[f.materialId][zc.TRANSPARENT][d] = !0, this.transparentUserIdSetObject[d] = !0; else if (r && i._hasOverrideMaterial(f)) { var m = i._getOverrideMaterial(f); if (Array.isArray(m)) { var C = g, y = m.find((function (A) { return !!A.mapNodeIdToOrigMatId && Object.keys(A.mapNodeIdToOrigMatId).includes(f.nodeId) })), v = y ? y.mapNodeIdToOrigMatId[f.nodeId] : m[C].materialId, I = y ? y.materialId : ""; "" !== I && (void 0 === c[v] && (c[v] = {}), void 0 === c[v][zc.OVERRIDED] && (c[v][zc.OVERRIDED] = {})), c[v] || (c[v] = {}, c[v][zc.OVERRIDED] = {}), c[v][zc.OVERRIDED][d] = I, this.overrideUserIdSetObject[d] || (this.overrideUserIdSetObject[d] = []), this.overrideUserIdSetObject[d][C] = I } else { var E = null !== m ? m.name : ""; "" !== E && (void 0 === c[f.materialId] && (c[f.materialId] = {}), void 0 === c[f.materialId][zc.OVERRIDED] && (c[f.materialId][zc.OVERRIDED] = {}), c[f.materialId][zc.OVERRIDED][d] = E, this.overrideUserIdSetObject[d] = E) } } } } }, Of.prototype._collectFilteredUserIdsForWireFrame = function (A, e, t) { var i = A.getFilter(), o = i._hasOverrideMaterialFilterForWireFrame(); if (this.mapFilteredUserIdsForWireFrame = {}, o) for (var n = 0; e.length > n; n += 1) { var r = e[n]; if (!this.hiddenUserIdSetObject[r]) { var a = t[r]; if (a && a.length) for (var s = 0, l = a.length; l > s; s += 1) { var c = a[s]; if (i._hasOverrideMaterialForWireFrame(c)) { var h = i._getOverrideMaterialForWireFrame(c), d = null !== h ? h.name : ""; "" !== d && (this.mapFilteredUserIdsForWireFrame[r] = d) } } } } }, Of.prototype._collectModelFiltered = function (A) { var e = A.manager.filter, t = A.modelKey, i = e._hasModelOverrideMaterialFilter(), o = e._hasModelTransparentFilter(), n = A.manager.modelState.selectionSet; return A.manager.modelState.hoverId === t ? A.manager.modelState.getHoverMaterial() : n.hasOwnProperty(A.modelKey) ? A.manager.modelState.selectionMaterial : o && e._isModelTransparent(t) ? e._getMaterialByName("scene") : i && e._hasModelOverrideMaterial(t) ? e._getModelOverrideMaterial(t) : null }, Of.prototype._clearFilteredState = function () { this.mapMaterialIdToUserIdsForFilter = null }, Of.prototype._collectSelectedUserIds = function (A, e) { var t = this.mapMaterialIdToUserIdsForSelection = {}; for (var i in A) if (this.model.modelKey === i) for (var o in A[i]) { var n = e[o]; if (n && n.length) for (var r = 0, a = n.length; a > r; r += 1) void 0 === t[n[r].materialId] && (t[n[r].materialId] = {}), void 0 === t[n[r].materialId][o] && (t[n[r].materialId][o] = !0) } }, Of.prototype._clearSelectedState = function () { this.mapMaterialIdToUserIdsForSelection && (this.mapMaterialIdToUserIdsForSelection = null) }, Of.prototype._collectHoveredUserIds = function (A, e) { var t = this.mapMaterialIdToUserIdsForHover = {}; if (A && e[A]) for (var i = e[A], o = 0, n = i.length; n > o; o += 1) void 0 === t[i[o].materialId] && (t[i[o].materialId] = {}), void 0 === t[i[o].materialId][A] && (t[i[o].materialId][A] = !0) }, Of.prototype._clearHoveredState = function () { this.mapMaterialIdToUserIdsForHover && (this.mapMaterialIdToUserIdsForHover = null) }, Of.prototype._collectBlinkedUserIds = function (A, e) { var t = this.mapBlinkUserIds = {}; for (var i in A) { var o = e[i]; if (o && o.length) for (var n = 0, r = o.length; r > n; n += 1) void 0 === t[o[n].materialId] && (t[o[n].materialId] = {}), void 0 === t[o[n].materialId][i] && (t[o[n].materialId][i] = !0) } }, Of.prototype.calculateClippingIds = function (A, e) { this.meshManager.calculateClippingIds(A, e) }, Of.prototype._clearBlinkedState = function () { this.mapBlinkUserIds && (this.mapBlinkUserIds = null) }, Of.prototype._rebuildIndices = function (A) { this.meshManager.rebuildIndices(A), this.wireframeManager.rebuildIndices(A) }, Of.prototype.clearCachedData = function () { this.meshManager.clearAllNodeBuffer() }, Of.prototype.getMeshesByUserIds = function (A, e) { return this.meshManager.getMeshesByUserIds(A, e) }, Of.prototype.adjustVisibility = function (A, e) { this.meshManager.adjustVisibility(A, e), this.wireframeManager.adjustVisibility(A, e) }, Of.prototype.changeVisibilityOfSelectedObjects = function (A, e) { this.meshManager.changeVisibilityOfSelectedObjects(A, e), this.wireframeManager.changeVisibilityOfSelectedObjects(A, e) }, Of.prototype.changeVisibilityOfNonSelectedObjects = function (A, e) { this.meshManager.changeVisibilityOfNonSelectedObjects(A, e), this.wireframeManager.changeVisibilityOfNonSelectedObjects(A, e) }, Of.prototype.restoreVisibilityOfObjects = function () { this.meshManager.restoreVisibilityOfObjects(), this.wireframeManager.restoreVisibilityOfObjects() }, Of.prototype.disposeBufferAfterVbo = function () { this.meshManager.disposeBufferAfterVbo(), this.wireframeManager.disposeBufferAfterVbo() }, Of.prototype.getGeometryBuffersByUserId = function (A, e) { return this.meshManager.getGeometryBuffersByUserId(A, e) }, Of.prototype.explosion = function (A, e) { this.meshManager.explosion(A, e), this.wireframeManager.explosion(A, e) }, Of.prototype.closeExplosion = function (A) { this.meshManager.closeExplosion(A), this.wireframeManager.closeExplosion(A) }, Of.prototype.componentsExplosion = function (A, e) { this.meshManager.componentsExplosion(A, e), this.wireframeManager.componentsExplosion(A, e) }, Of.prototype.closeComponentsExplosion = function (A, e) { this.meshManager.closeComponentsExplosion(A, e), this.wireframeManager.closeComponentsExplosion(A, e) }, Of.prototype.isPickableNode = function (A) { var e = this.getHiddenUserIds(); if (e && e[A]) return !1; var t = this.getTransparentUserIds(); return !t || !t[A] }, Of.prototype.isHiddenNode = function (A) { var e = this.getHiddenUserIds(); return !(!e || !e[A]) }, Of.prototype.getMeshManager = function () { return this.meshManager }, Of.prototype.getWireFrameManager = function () { return this.wireframeManager }, Of.prototype.getFilteredUserIdsForWireFrame = function () { return this.mapFilteredUserIdsForWireFrame }; var Vf = function (A) { of .call(this, A), this.nodeGroupName = "PickingInstancedMeshGroup" }; function Gf(A, e, t) { for (var i = A.getAttribute("mcol3").array, o = 0; e.length > o; o += 1) { var n = e[o]; i[3 * n] += t.x, i[3 * n + 1] += t.y, i[3 * n + 2] += t.z } A.getAttribute("mcol3").needsUpdate = !0 } Object.assign(Vf.prototype, of .prototype), eu(Vf, [{ key: "generatePickingMeshes", value: function () { var A = this, e = this.manager, t = e.cachedInstance, i = !vc.BatchMergeEnabled; e.traverseInstanceNodeMap(null, (function (e, o) { for (var n = [], r = 0, a = o.length; a > r; r += 1) { var s = o[r].geometry, l = o[r], c = new Na; c.setAttribute("position", s.getAttribute("position")), c.setAttribute("mcol0", s.getAttribute("mcol0")), c.setAttribute("mcol1", s.getAttribute("mcol1")), c.setAttribute("mcol2", s.getAttribute("mcol2")), c.setAttribute("mcol3", s.getAttribute("mcol3")), c.setAttribute("vState", new Oa(new Float32Array(t.vState[e]), 1, !1, 1)), c.setIndex(s.getIndex()); var h = new Ue(c, Kd.DefaultMaterial); l.matrixWorld.decompose(h.position, h.quaternion, h.scale), h.name = e, h.frustumCulled = !1, h.renderOrder = i ? 1 : 0, n.push(h) } A.addToPickingNodeMap(e, n) })) } }, { key: "updatePickingMeshesState", value: function (A, e, t) { if (this.pickingNodeMap) for (var i = this.manager.manager, o = this.pickingNodeMap, n = 0, r = e.length; r > n; n += 1) { var a = e[n]; if (i.isPickableNode(a)) { var s = i.getMeshManager().getNodeIdxMapByUserId(a); if (s) for (var l = Object.keys(s), c = 0, h = l.length; h > c; c += 1) { var d = l[c], p = o[d]; if (p) for (var g = s[d], u = 0, f = p.length; f > u; u += 1) { var m = p[u]; m.material = A, m.visible = !0; for (var C = m.geometry, y = C.getAttribute("vState").array, v = 0, I = g.length; I > v; v += 1) y[g[v]] = Hc.NONE; C.getAttribute("vState").needsUpdate = !0 } } } } } }, { key: "resetPickingMeshesState", value: function () { if (this.pickingNodeMap) for (var A = this.pickingNodeMap, e = Object.keys(A), t = 0, i = e.length; i > t; t += 1) for (var o = A[e[t]], n = 0, r = o.length; r > n; n += 1) o[n].visible = !1, o[n].geometry.getAttribute("vState").array.fill(Hc.HIDDEN), o[n].geometry.getAttribute("vState").needsUpdate = !0 } }]); var Pf = function (A) { return Rf.call(this), this.manager = A, this.instanceGeometryMap = {}, this.bufferAttributeMap = {}, this.instanceNodeMap = {}, this.nodeIdxMapFromUserId = {}, this.matrixInfoMapFromUserId = {}, this.cachedInstance = { vState: {}, vState2: {}, vColor: {}, vMirror: {}, mcol0: {}, mcol1: {}, mcol2: {}, mcol3: {}, muvCol0: {}, muvCol1: {}, muvCol2: {}, userId: {}, nodeId: {} }, this.selectedMeshes = [], this.nonSelectedMeshes = [], this.selectedObjectIds = [], this }; (Pf.prototype = Object.create(Rf.prototype)).destroy = function () { this.cachedInstance = {}, this.instanceNodeMap = {}, this.bufferAttributeMap = {}, this.nodeIdxMapFromUserId = {}, this.matrixInfoMapFromUserId = {}, this.disposeInstanceGeometries(), this.instanceGeometryMap = {}, this.manager = null, this.selectedMeshes = [], this.nonSelectedMeshes = [], this.selectedObjectIds = [] }, Pf.prototype.clearData = function () { this.bufferDestroyed = !1, this.disposeGeometries(), this.disposeInstanceGeometries(), this.clearInstanceCache(), this.pickingNodeGenerator && this.pickingNodeGenerator.clearData() }, Pf.prototype.clearInstanceCache = function () { this.cachedInstance.vState = {}, this.cachedInstance.vState2 = {}, this.cachedInstance.vColor = {}, this.cachedInstance.vMirror = {}, this.cachedInstance.mcol0 = {}, this.cachedInstance.mcol1 = {}, this.cachedInstance.mcol2 = {}, this.cachedInstance.mcol3 = {}, this.cachedInstance.muvCol0 = {}, this.cachedInstance.muvCol1 = {}, this.cachedInstance.muvCol2 = {}, this.bufferAttributeMap = {}, this.nodeIdxMapFromUserId = {}, this.instanceNodeMap = {}, this.instanceGeometryMap = {}, this.matrixInfoMapFromUserId = {}, this.geometries = {} }, Pf.prototype.updateNodes = function (A) { this._getNodeGroup(A).visible = !A.isOnlyWireframe() }, Pf.prototype.createMeshNodes = function (A, e) { this._createInstanceGeometries(A, e), this._makeInstanceNodes(A) }, Pf.prototype.disposeInstanceGeometries = function () { this.traverseInstanceGeometryMap((function (A, e) { for (var t = 0, i = e.length; i > t; t += 1) e[t].dispose() })) }, Pf.prototype._createInstanceGeometries = function (A, e) { Bh.time("createInstanceGeometries"); var t = this; A.getModelDescriptor().traverseInstancedNodeInfos(e, (function (e, i) { for (var o = 0, n = i.length; n > o; o += 1) { var r = i[o], a = t.getGeometryByNodeInfo(A, r); if (a) { var s = A.manager.getOverrideMaterialByNodeInfo(r); s && (r.materialId = s.name); var l = t.getMeshIdByNodeInfo(r), c = t.cacheInstanceAttributeStateBy(A, l, a, r, s); t.cacheNodeIdxByUserId(r.userId, l, c), t.cacheMatrixInfoByUserId(r.userId, l, { matrix: r.matrix, boundingBox: r.boundingBox }), t.cacheInstanceGeometries(l, a) } } })), Bh.timeEnd("createInstanceGeometries") }, Pf.prototype._createBatchedInstanceGeometries = function (A, e) { var t = A.materialManager.getMaterialById(e.materialKey), i = A.getModelDescriptor(); if (!t) { var o = i.getNodeInfosByNodeId(e.nodeIdInfo[0]); if (!o) return; e.materialKey = o.materialId, t = A.materialManager.getMaterialById(e.materialKey), e.color = []; for (var n = 0, r = e.nodeIdInfo.length; r > n; n += 1) e.color.push(t.color.r, t.color.g, t.color.b, t.opacity) } var a = !1; t.aoMap && (a = !0), e.hasUV2 = a; var s = uh.getCombinedKeyString([e.materialKey, e.geoId]), l = this.cachedInstance; if (e.nodeIdInfo.length < 1) Bh.error("node 数量为 0 "); else if (l.vState[s]) Bh.warn("实例化几何已存在:", s); else { l.vState[s] = new Float32Array(e.nodeIdInfo.length), l.vColor[s] = e.color, l.vMirror[s] = new Float32Array(e.nodeIdInfo.length), l.mcol0[s] = e.mcol0, l.mcol1[s] = e.mcol1, l.mcol2[s] = e.mcol2, l.mcol3[s] = e.mcol3, l.muvCol0[s] = [], l.muvCol1[s] = [], l.muvCol2[s] = [], l.userId[s] = [], l.nodeId[s] = []; for (var c = new M, h = [], d = 0, p = e.nodeIdInfo.length; p > d; d += 1) h = [], l.userId[s].push(e.componentKeyInfo[d]), l.nodeId[s].push(e.nodeIdInfo[d]), h.push(e.mcol0[3 * d]), h.push(e.mcol0[3 * d + 1]), h.push(e.mcol0[3 * d + 2]), h.push(0), h.push(e.mcol1[3 * d]), h.push(e.mcol1[3 * d + 1]), h.push(e.mcol1[3 * d + 2]), h.push(0), h.push(e.mcol2[3 * d]), h.push(e.mcol2[3 * d + 1]), h.push(e.mcol2[3 * d + 2]), h.push(0), h.push(e.mcol3[3 * d]), h.push(e.mcol3[3 * d + 1]), h.push(e.mcol3[3 * d + 2]), h.push(1), c.fromArray(h), 0 > c.determinant() && (l.vMirror[s][d] = -1); this.getBufferAttributesBy(s); this.cacheBatchedInstanceGeometries(s, e); for (var g in e.componentInfo) if (e.componentInfo.hasOwnProperty(g)) for (var u = 0, f = e.componentInfo[g].length; f > u; u += 1) { var m = e.componentInfo[g][u]; this.cacheNodeIdxByUserId(g, s, m); var C = i.getNodeInfosByNodeId(e.nodeIdInfo[m]); C && this.cacheMatrixInfoByUserId(g, s, { matrix: C.matrix, boundingBox: C.boundingBox }) } this._makeInstanceNodeById(A, s, this.instanceGeometryMap[s]) } }, Pf.prototype.getBufferAttributesBy = function (A) { if (this.bufferAttributeMap[A]) return this.bufferAttributeMap[A]; var e = this.cachedInstance, t = new Oa(new Float32Array(e.mcol0[A]), 3, !1, 1), i = new Oa(new Float32Array(e.mcol1[A]), 3, !1, 1), o = new Oa(new Float32Array(e.mcol2[A]), 3, !1, 1), n = new Oa(new Float32Array(e.mcol3[A]), 3, !1, 1), r = [], a = [], s = []; if (e.muvCol0[A]) for (var l = 0, c = e.muvCol0[A].length; c > l; l += 1) r.push(new Oa(new Float32Array(e.muvCol0[A][l]), 2, !1, 1)), a.push(new Oa(new Float32Array(e.muvCol1[A][l]), 2, !1, 1)), s.push(new Oa(new Float32Array(e.muvCol2[A][l]), 2, !1, 1)); return this.bufferAttributeMap[A] = { attributeMcol0: t, attributeMcol1: i, attributeMcol2: o, attributeMcol3: n, attributeMuvCol0Array: r, attributeMuvCol1Array: a, attributeMuvCol2Array: s }, this.bufferAttributeMap[A] }, Pf.prototype._addInstanceNodeToScene = function (A, e, t) { this._getNodeGroup(A).add(t), t.updateMatrixWorld(!0), A.manager.addMeshToOctantMap(A.modelKey, e, new Bu(e, t)) }, Pf.prototype.addAllInstanceNodeToScene = function (A) { this.traverseInstanceNodeMap(null, (function (e, t) { for (var i = 0, o = t.length; o > i; i += 1) A.manager.addMeshToOctantMap(A._encodedDatabagId, e, new Bu(e, t[i])) })) }, Pf.prototype._makeInstanceNodeById = function (A, e, t) { var i = this.cachedInstance, o = A.materialManager, n = this.getMaterialIdByMeshId(e), r = this.getBufferAttributesBy(e), a = o.getInstanceMaterialById(n, A); this.instanceNodeMap[e] || (this.instanceNodeMap[e] = []); for (var s = this.instanceNodeMap[e], l = 0, c = t.length; c > l; l += 1) { t[l].setAttribute("mcol0", r.attributeMcol0), t[l].setAttribute("mcol1", r.attributeMcol1), t[l].setAttribute("mcol2", r.attributeMcol2), t[l].setAttribute("mcol3", r.attributeMcol3), r.attributeMuvCol0Array.length > 0 && (t[l].setAttribute("muvCol0", r.attributeMuvCol0Array[l]), t[l].setAttribute("muvCol1", r.attributeMuvCol1Array[l]), t[l].setAttribute("muvCol2", r.attributeMuvCol2Array[l])), t[l].setAttribute("aColor", new Oa(new Float32Array(i.vColor[e]), 4, !1, 1)), t[l].setAttribute("vState", new Oa(new Float32Array(i.vState[e]), 1, !1, 1)), t[l].setAttribute("vState2", new Oa(new Float32Array(i.vState[e]), 1, !1, 1)), t[l].setAttribute("vMirror", new Oa(new Float32Array(i.vMirror[e]), 1, !1, 1)), t[l].getAttribute("vState2").array.fill(Hc.HIDDEN); var h = t[l].index; t[l].addGroup(0, h.count, 0), t[l].addGroup(0, h.count, 1), a[1].visible = !1; var d = new Kf(t[l], a); if (d.visible = !0, d.modelKey = A.modelKey, d.frustumCulled = !1, s.push(d), !uh.isEmptyObject(A.subModel)) { var p = i.userId[e][0]; if (p) { var g = uh.getModelKeyFromComponentKey(p); A.subModel[g] && d.matrix.copy(A.subModel[g]) } } this._addInstanceNodeToScene(A, e, d) } }, Pf.prototype._makeInstanceNodes = function (A) { Bh.time("makeInstanceNodes"); var e = this; this.traverseInstanceGeometryMap((function (t, i) { e._makeInstanceNodeById(A, t, i) })), Bh.timeEnd("makeInstanceNodes") }, Pf.prototype.resetInstanceMaterial = function (A) { var e = this, t = A.materialManager; this.traverseInstanceGeometryMap((function (i, o) { var n = e.getMaterialIdByMeshId(i), r = t.getInstanceMaterialById(n, A); r[0].visible = !0, r[1].visible = !1, r.splice(2, 1); for (var a = 0, s = o.length; s > a; a += 1) { if (o[a].getAttribute("vState").array.fill(Hc.NONE), o[0].removed) for (var l in o[0].removed) o[a].getAttribute("vState").array[l] = -1; o[a].getAttribute("vState").needsUpdate = !0, o[a].getAttribute("vState2").array.fill(Hc.HIDDEN), o[a].getAttribute("vState2").needsUpdate = !0, o[a].deleteAttribute("vState3"), o[a].groups.splice(2, 1) } })) }, Pf.prototype.clearInstanceStateByUserId = function (A) { function e(A, e, t, i) { for (var o = A.getAttribute("vState").array, n = A.getAttribute("vState2").array, r = 0, a = e.length; a > r; r += 1) { var s = e[r]; o[s] = t, n[s] = i } A.getAttribute("vState").needsUpdate = !0, A.getAttribute("vState2").needsUpdate = !0 } var t = this, i = Hc.NONE, o = Hc.HIDDEN; this.traverseNodeIdxMapByUserId(A, (function (A, n) { var r = t.getInstanceGeometries(A); if (r) for (var a = 0, s = r.length; s > a; a += 1) e(r[a], n, i, o) })) }, Pf.prototype.updateInstanceStateByUserId = function (A, e, t, i) { function o(A, e, t, i, o, n, r) { var a = A.getAttribute("vState").array, s = A.getAttribute("vState2").array, l = A.getAttribute("aColor"), c = A.getAttribute("vState3"), h = null; null !== r && (c ? h = c.array : ((h = (c = A.getAttribute("vState").clone()).array).fill(Hc.HIDDEN), A.setAttribute("vState3", c))); for (var d = l ? l.array : null, p = 0; e.length > p; p += 1) { var g = e[p]; a[g] = t, s[g] = i, h && (h[g] = r), null !== d && null !== o && (d[4 * g] = o[0], d[4 * g + 1] = o[1], d[4 * g + 2] = o[2], d[4 * g + 3] = o[3]) } if (A.getAttribute("vState").needsUpdate = !0, A.getAttribute("vState2").needsUpdate = !0, c && (c.needsUpdate = !0), l && (l.needsUpdate = !0), n) { var u = !1, f = !1; if (!n[0].visible) if (t !== Hc.HIDDEN) n[0].visible = !0; else { for (var m = 0, C = a.length; C > m; m += 1) if (a[m] !== Hc.HIDDEN) { u = !0; break } n[0].visible = u } if (!n[1].visible) if (i !== Hc.HIDDEN) n[1].visible = !0; else { for (var y = 0, v = s.length; v > y; y += 1) if (s[y] !== Hc.HIDDEN) { f = !0; break } n[1].visible = f } } } var n = A.materialManager, r = this; this.traverseNodeIdxMapByUserId(e, (function (a, s) { var l = r.getInstanceGeometries(a); r.getInstanceNodesById(a); if (l) { var c = null, h = null, d = null; if (t === Hc.HIDDEN) { c = Hc.HIDDEN, h = Hc.HIDDEN; for (var p = 0, g = l.length; g > p; p += 1) o(l[p], s, c, h, null, null) } else { var u = r.getMaterialIdByMeshId(a), f = r.getUsableMaterialColorParamsBy(A, u, t, i), m = f.rgbaColor, C = t; t === Hc.TRANSPARENT && (C = Hc.OVERRIDED), t === Hc.SELECTED && r.cacheSelectedObjectIds(e, a); var y = n.getInstanceMaterialById(u, A), v = y[0]; if (v.transparent === f.transparent ? (c = C, h = Hc.HIDDEN) : (c = Hc.HIDDEN, h = C), !0 === f.wireframe) { var I = y[2] || Kd.createInstanceMaterial(Kd.getMaterialParameters(v)); I.wireframe = !0, I.defines.INSTANCE_STATE_TERTIARY = "", 3 > y.length && y.push(I), c = Hc.HIDDEN, h = Hc.HIDDEN, d = C } C === Hc.BLINK && v.setBlinkColor(A.manager.getBlinkColor()); for (p = 0, g = l.length; g > p; p += 1) { if (!0 === f.wireframe) { var E = l[p].groups[0]; l[p].groups[2] = { start: E.start, count: E.count, materialIndex: 2 } } o(l[p], s, c, h, m, y, d) } } } })) }, Pf.prototype.getUsableMaterialColorParamsBy = function (A, e, t, i) { var o = A.selectedMaterial, n = A.manager.filter._getMaterialByName("scene"), r = A.materialManager, a = A.manager.getOverrideMaterialByName(e) || r.getMaterialById(e), s = null, l = null; switch (t) { case Hc.HOVER: i ? (s = A.manager.filter._getMaterialByName(i), l = A.manager.sceneState.getHoverColorByMaterial(s)) : l = A.manager.sceneState.getHoverColorByMaterial(a); break; case Hc.SELECTED: l = Kd.getColorParamsByMaterial(o); break; case Hc.TRANSPARENT: l = Kd.getColorParamsByMaterial(n); break; case Hc.OVERRIDED: case Hc.BLINK: i ? (s = A.manager.filter._getMaterialByName(i), l = Kd.getColorParamsByMaterial(s)) : l = Kd.getColorParamsByMaterial(a) } return l }, Pf.prototype.getInstanceNodesById = function (A) { return this.instanceNodeMap[A] }, Pf.prototype.traverseInstanceNodeMap = function (A, e) { for (var t = this.instanceNodeMap, i = 0, o = (A = A || Object.keys(this.instanceNodeMap)).length; o > i; i += 1) { var n = A[i]; e(n, t[n]) } }, Pf.prototype.getInstanceGeometries = function (A) { return this.instanceGeometryMap[A] }, Pf.prototype.cacheInstanceGeometries = function (A, e) { if (!this.instanceGeometryMap[A]) { var t = this.instanceGeometryMap[A] = []; e instanceof Array || (e = [e]); for (var i = 0, o = e.length; o > i; i += 1) t[i] = new Na, t[i].setIndex(e[i].index), e[i].attributes.position && t[i].setAttribute("position", e[i].attributes.position), e[i].attributes.normal && t[i].setAttribute("normal", e[i].attributes.normal), e[i].attributes.uv && t[i].setAttribute("uv", e[i].attributes.uv), e[i].attributes.uv2 && t[i].setAttribute("uv2", e[i].attributes.uv2) } }, Pf.prototype.cacheBatchedInstanceGeometries = function (A, e) { if (this.instanceGeometryMap[A]) return this.instanceGeometryMap[A][0]; var t = this.instanceGeometryMap[A] = [], i = new Na; return t[0] = i, i.setIndex(new YA(e.index, 1)), e.position && e.position.length > 0 && i.setAttribute("position", new YA(e.position, 3)), e.normal && e.normal.length === e.position.length && i.setAttribute("normal", new YA(e.normal, 3)), e.uv && e.uv.length > 0 && i.setAttribute("uv", new YA(e.uv, 2)), e.hasUV2 && i.getAttribute("uv") && i.setAttribute("uv2", i.getAttribute("uv")), i.getAttribute("normal") || i.computeVertexNormals(), i }, Pf.prototype.traverseInstanceGeometryMap = function (A) { var e = this.instanceGeometryMap; for (var t in e) A(t, e[t]) }, Pf.prototype.disposeInstanceGeometries = function () { this.traverseInstanceGeometryMap((function (A, e) { for (var t = 0, i = e.length; i > t; t += 1) e[t].dispose() })) }, Pf.prototype.cacheInstanceAttributeStateBy = function (A, e, t, i, o) { var n = i.materialId; t instanceof Array || (t = [t]); var r = t.length, a = this.cachedInstance; if (!a.vState[e]) { a.vState[e] = [], a.vColor[e] = [], a.vMirror[e] = [], a.mcol0[e] = [], a.mcol1[e] = [], a.mcol2[e] = [], a.mcol3[e] = [], a.muvCol0[e] = [], a.muvCol1[e] = [], a.muvCol2[e] = [], a.userId[e] = [], a.nodeId[e] = []; for (var s = 0; r > s; s += 1) a.muvCol0[e][s] = [], a.muvCol1[e][s] = [], a.muvCol2[e][s] = [] } var l = o || A.materialManager.getMaterialById(n); a.userId[e].push(i.userId), a.nodeId[e].push(i.nodeId), a.vColor[e].push(l.color.r, l.color.g, l.color.b, l.opacity), a.vState[e].push(0); var c = i.matrix.elements; return a.mcol0[e].push(c[0], c[1], c[2]), a.mcol1[e].push(c[4], c[5], c[6]), a.mcol2[e].push(c[8], c[9], c[10]), a.mcol3[e].push(c[12], c[13], c[14]), 0 > i.matrix.determinant() ? a.vMirror[e].push(-1) : a.vMirror[e].push(0), a.vState[e].length - 1 }, Pf.prototype.cacheNodeIdxByUserId = function (A, e, t) { var i = this.nodeIdxMapFromUserId; i[A] || (i[A] = {}), i[A][e] || (i[A][e] = []), i[A][e].push(t) }, Pf.prototype.getNodeIdxMapByUserId = function (A) { return this.nodeIdxMapFromUserId[A] }, Pf.prototype.traverseNodeIdxMapByUserId = function (A, e) { var t = this.nodeIdxMapFromUserId[A]; for (var i in t) e(i, t[i]) }, Pf.prototype.traverseNodeIdxMap = function (A, e) { for (var t = Object.keys(this.nodeIdxMapFromUserId), i = 0, o = t.length; o > i; i += 1) { var n = t[i], r = this.nodeIdxMapFromUserId[n]; if (!e || !e(n)) for (var a in r) A(a, r[a]) } }, Pf.prototype.cacheMatrixInfoByUserId = function (A, e, t) { var i = this.matrixInfoMapFromUserId; i[A] || (i[A] = {}), i[A][e] || (i[A][e] = []), i[A][e].push(t) }, Pf.prototype.traverseMatrixInfoMapByUserId = function (A, e) { var t = this.matrixInfoMapFromUserId[A]; for (var i in t) e(i, t[i]) }, Pf.prototype.getMeshesByUserId = function (A, e) { var t = this, i = []; return this.traverseMatrixInfoMapByUserId(e, (function (e, o) { for (var n = t.getInstanceNodesById(e), r = 0, a = o.length; a > r; r += 1) for (var s = 0, l = n.length; l > s; s += 1) { var c = {}; if (c.matrix = A.getModelMatrix().clone().multiply(o[r].matrix), c.mesh = n[s], 1 === l) c.boundingBox = o[r].boundingBox; else { var h = c.mesh.geometry.boundingBox; h ? h = h.clone() : (c.mesh.geometry.computeBoundingBox(), h = c.mesh.geometry.boundingBox.clone()), h.applyMatrix4(c.matrix), c.boundingBox = h } i.push(c) } })), i }, Pf.prototype._getNodeGroup = function (A) { return A._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 }) }, Pf.prototype._hasNodeGroup = function (A) { return A._hasNodeGroup(gp.INSTANCEGEOMETRY) }, Pf.prototype.clearSelectedObjectIds = function () { this.selectedObjectIds.length = 0 }, Pf.prototype.cacheSelectedObjectIds = function (A, e) { this.selectedObjectIds.push({ uid: A, mgId: e }) }, Pf.prototype.adjustVisibility = function (A, e) { var t = this._getNodeGroup(A), i = t.visible; e && !t.bVisible || (t.visible = e), t.bVisible = i }, Pf.prototype.changeVisibilityOfSelectedObjects = function (A, e) { var t = null; if (e) for (var i = 0, o = (t = this.selectedMeshes).length; o > i; i += 1) { var n = t[i].object, r = t[i].indices; if (r) { if (r.length) { for (var a = n.geometry.getAttribute("vState").array, s = n.geometry.getAttribute("vState2").array, l = 0, c = r.length; c > l; l += 1) r[l].state ? a[r[l].idx] = r[l].state : r[l].state2 && (s[r[l].idx] = r[l].state2); n.geometry.getAttribute("vState").needsUpdate = !0, n.geometry.getAttribute("vState2").needsUpdate = !0 } } else n.visible = t[i].visibility } else { this.selectedMeshes.length = 0, t = this.selectedMeshes; for (var h = {}, d = 0, p = this.selectedObjectIds.length; p > d; d += 1) h[this.selectedObjectIds[d].mgId] = !0; var g = Object.keys(h); this.traverseInstanceNodeMap(g, (function (A, e) { for (var i = 0, o = e.length; o > i; i += 1) { for (var n = e[i], r = [], a = n.geometry.getAttribute("vState").array, s = n.geometry.getAttribute("vState2").array, l = 0, c = a.length; c > l; l += 1) a[l] === Hc.SELECTED ? (r.push({ idx: l, state: a[l] }), a[l] = Hc.HIDDEN) : s[l] === Hc.SELECTED && (r.push({ idx: l, state2: s[l] }), s[l] = Hc.HIDDEN); r.length ? (n.geometry.getAttribute("vState").needsUpdate = !0, n.geometry.getAttribute("vState2").needsUpdate = !0, t.push({ object: n, indices: r })) : (t.push({ object: n, indices: null, visibility: n.visible }), n.visible = !1) } })) } }, Pf.prototype.changeVisibilityOfNonSelectedObjects = function (A, e) { var t = null; if (e) for (var i = 0, o = (t = this.nonSelectedMeshes).length; o > i; i += 1) { var n = t[i].object, r = t[i].indices; if (r) { if (r.length) { for (var a = n.geometry.getAttribute("vState").array, s = n.geometry.getAttribute("vState2").array, l = 0, c = r.length; c > l; l += 1) void 0 !== r[l].state ? a[r[l].idx] = r[l].state : void 0 !== r[l].state2 && (s[r[l].idx] = r[l].state2); n.geometry.getAttribute("vState").needsUpdate = !0 } } else n.visible = t[i].visibility } else { this.nonSelectedMeshes.length = 0, t = this.nonSelectedMeshes; for (var h = {}, d = 0, p = this.selectedObjectIds.length; p > d; d += 1) h[this.selectedObjectIds[d].mgId] = !0; this.traverseInstanceNodeMap(null, (function (A, e) { if (h[A]) for (var i = 0, o = e.length; o > i; i += 1) { for (var n = [], r = (p = e[i]).geometry.getAttribute("vState").array, a = p.geometry.getAttribute("vState2").array, s = 0, l = r.length; l > s; s += 1) r[s] !== Hc.SELECTED && r[s] !== Hc.HIDDEN ? (n.push({ idx: s, state: r[s] }), r[s] = Hc.HIDDEN) : a[s] !== Hc.SELECTED && a[s] !== Hc.HIDDEN && (n.push({ idx: s, state2: a[s] }), a[s] = Hc.HIDDEN); n.length && (p.geometry.getAttribute("vState").needsUpdate = !0, p.geometry.getAttribute("vState2").needsUpdate = !0, t.push({ object: p, indices: n })) } else for (var c = 0, d = e.length; d > c; c += 1) { var p; t.push({ object: p = e[c], indices: null, visibility: p.visible }), p.visible = !1 } })) } }, Pf.prototype.restoreVisibilityOfObjects = function () { this.selectedMeshes.length = 0, this.nonSelectedMeshes.length = 0 }, Pf.prototype.getMeshIdByNodeInfo = function (A) { return uh.getCombinedKeyString([A.materialId, A.geometryId]) }, Pf.prototype.getMaterialIdByMeshId = function (A) { return uh.splitCombinedKeyString(A)[0] }, Pf.prototype.getOriginalMaterialIdByMeshId = function (A) { var e = uh.splitCombinedKeyString(A); return uh.splitCombinedKeyString(e[0], "_")[0] }, Pf.prototype.disposeBufferAfterVbo = function () { if (!this.bufferDestroyed) { this.bufferDestroyed = !0; var A = ["muvCol0", "muvCol1", "muvCol2", "mcol0", "mcol1", "mcol2", "mcol3"]; vc.EnableExplosion && A.pop(), this.traverseInstanceGeometryMap((function (e, t) { for (var i = 0, o = t.length; o > i; i += 1) Tu.disposeBufferFromGeometry(t[i], A) })) } }, Pf.prototype.getGeometryBuffersByUserId = function (A, e) { var t = A.getModelDescriptor().getInstancedNodeInfosById(e); if (!t) return []; for (var i = [], o = A.getDatabagId(), n = 0, r = t.length; r > n; n += 1) { var a = t[n], s = this.getGeometryByNodeInfo(A, a), l = this._isLines(a); if (s instanceof Array) for (var c = 0, h = s.length; h > c; c += 1) i.push({ isLines: l, databagId: o, nodeId: a.nodeId, position: s[c].getAttribute("position").array, index: s[c].getIndex().array, matrix: a.matrix }); else i.push({ databagId: o, nodeId: a.nodeId, position: s.getAttribute("position").array, index: s.getIndex().array, matrix: a.matrix }) } return i }, Pf.prototype.explode = function (A, e, t) { var i = this; for (var o in i.nodeIdxMapFromUserId) i.traverseNodeIdxMapByUserId(o, (function (n, r) { var a = A.manager.getComponentInfoByUserId(o).boundingBox, s = uh.computeExplodeTranslation(e, a, t), l = i.getInstanceGeometries(n); l && Gf(l[0], r, s) })) }, Pf.prototype.explosion = function (A, e) { var t = Object.keys(this.nodeIdxMapFromUserId); e.componentKey = t, this.componentsExplosion(A, e) }, Pf.prototype.closeExplosion = function (A) { this.explosion(A, {}) }, Pf.prototype.componentsExplosion = function (A, e) { var t = e.coefficientX || 1, i = e.coefficientY || 1, o = e.coefficientZ || 1, n = e.offsetX || 0, r = e.offsetY || 0, a = e.offsetZ || 0, s = null; if (e.center) s = (new y).fromArray(e.center); else if (1 !== t || 1 !== i || 1 !== o || 0 !== n || 0 !== r || 0 !== a) return; var l = Array.isArray(e.componentKey) ? e.componentKey : [e.componentKey], c = new y, h = new aA, d = new y(0, 0, 0), p = new y(0, 0, 0), g = new y, u = new M, m = A.getModelMatrix(); m && s && (u.getInverse(m), s.applyMatrix4(u)); var C = A.manager, v = !1, I = new y, E = new f, B = new y(1, 1, 1); uh.isEmptyObject(A.subModel) || (v = !0); for (var x = 0, S = l.length; S > x; x += 1) { var w = l[x]; if (w) { var b = A.getModelDescriptor().getInstancedNodeInfosById(w); if (b) for (var U = this.nodeIdxMapFromUserId[w], F = 0, K = b.length; K > F; F += 1) { var Q = b[F]; if (Q) { var R = Q.materialId + "&" + Q.geometryId, T = new y(1, 1, 1); if (v) this.getInstanceNodesById(R)[0].matrix.decompose(I, E, B), T.divide(B); if (h.copy(Q.boundingBox), h.getCenter(c), Q.userData || (Q.userData = {}), d.set(0, 0, 0), p.set(0, 0, 0), 1 !== t || 1 !== i || 1 !== o || Q.userData.explosionFactor) { Q.userData.explosionFactor || (Q.userData.explosionFactor = new y(1, 1, 1), Q.userData.explosionBaseDifference = c.sub(s).clone().multiply(T)); var k = Q.userData.explosionFactor, D = Q.userData.explosionBaseDifference; d.set((t - k.x) * D.x, (i - k.y) * D.y, (o - k.z) * D.z), 1 === t && 1 === i && 1 === o ? (Q.userData.explosionFactor = void 0, Q.userData.explosionBaseDifference = void 0) : k.set(t, i, o) } if (0 !== n || 0 !== r || 0 !== a || Q.userData.explosionOffset) { Q.userData.explosionOffset || (Q.userData.explosionOffset = new y(0, 0, 0)); var L = Q.userData.explosionOffset; p.set(n * T.x - L.x, r * T.y - L.y, a * T.z - L.z), 0 === n && 0 === r && 0 === a ? Q.userData.explosionOffset = void 0 : L.set(n * T.x, r * T.y, a * T.z) } if (g.set(d.x + p.x, d.y + p.y, d.z + p.z), 0 !== g.x || 0 !== g.y || 0 !== g.z) { Q.userData.explosionFactor || Q.userData.explosionOffset ? C.explosionList[w] || (C.explosionList[w] = !0) : delete C.explosionList[w]; var N = g.clone().multiply(B), O = u; v && (O = u.clone()).makeTranslation(g.x, g.y, g.z), u.makeTranslation(N.x, N.y, N.z), Q.transformation || (Q.transformation = !0, Q.transformationOriginalMatrix = Q.matrix.clone(), Q.applyMatrix = new M, Q.transformationOriginalBoundingBox = Q.boundingBox.clone()), Q.matrix.premultiply(O), Q.applyMatrix.premultiply(u), Q.boundingBox.copy(Q.transformationOriginalBoundingBox).applyMatrix4(Q.applyMatrix); var V = Q.matrix, G = U[R], P = this.getInstanceGeometries(R); if (P) { var q = P[0], j = q.getAttribute("mcol0"), H = q.getAttribute("mcol1"), Y = q.getAttribute("mcol2"), W = q.getAttribute("mcol3"), J = G[0]; j.array[3 * J] = V.elements[0], j.array[3 * J + 1] = V.elements[1], j.array[3 * J + 2] = V.elements[2], j.needsUpdate = !0, H.array[3 * J] = V.elements[4], H.array[3 * J + 1] = V.elements[5], H.array[3 * J + 2] = V.elements[6], H.needsUpdate = !0, Y.array[3 * J] = V.elements[8], Y.array[3 * J + 1] = V.elements[9], Y.array[3 * J + 2] = V.elements[10], Y.needsUpdate = !0, W.array[3 * J] = V.elements[12], W.array[3 * J + 1] = V.elements[13], W.array[3 * J + 2] = V.elements[14], W.needsUpdate = !0 } } } } } } }, Pf.prototype.closeComponentsExplosion = function (A, e) { e = Array.isArray(e) ? e : [e]; this.componentsExplosion(A, { componentKey: e }) }, Pf.prototype._isLines = function (A) { return A.type === $u.EnumNodeItemType.LINE }, Pf.prototype.getPickingNodeGenerator = function () { return this.pickingNodeGenerator || (this.pickingNodeGenerator = new Vf(this)), this.pickingNodeGenerator }, Pf.prototype.calculateClippingIds = function (A, e) { var t = this; for (var i in t.nodeIdxMapFromUserId) this.traverseMatrixInfoMapByUserId(i, (function (i, o) { for (var n = t.getInstanceNodesById(i), r = 0, a = o.length; a > r; r += 1) for (var s = 0, l = n.length; l > s; s += 1) n[s].intersectBoxWithClipPlane(A, o[r]) && n[s].getIntersectionPoints(A, o[r], e, !0) })) }; var qf = function (A) { of .call(this, A), this.nodeGroupName = "PickingInstancedWireFrameGroup" }; Object.assign(qf.prototype, of .prototype), eu(qf, [{ key: "generatePickingMeshes", value: function () { this.manager.generateWireframe(), this.manager.updateNodes(); var A = this, e = this.manager, t = e.manager.getCachedInstanceData(), i = !vc.BatchMergeEnabled; e._traverseWireframeGeometryMap((function (o, n) { for (var r = [], a = e._getWireframeMeshById(o), s = 0, l = n.length; l > s; s += 1) { var c = n[s], h = new Na, d = a[s]; h.setAttribute("position", c.getAttribute("position")), h.setAttribute("mcol0", c.getAttribute("mcol0")), h.setAttribute("mcol1", c.getAttribute("mcol1")), h.setAttribute("mcol2", c.getAttribute("mcol2")), h.setAttribute("mcol3", c.getAttribute("mcol3")), h.setAttribute("vState", new Oa(new Float32Array(t.vState[o]), 1, !1, 1)), h.setIndex(c.getIndex()); var p = new jo(h, Kd.DefaultMaterial); d.matrixWorld.decompose(p.position, p.quaternion, p.scale), p.name = o, p.frustumCulled = !1, p.renderOrder = i ? 0 : 1, r.push(p) } A.addToPickingNodeMap(o, r) })) } }, { key: "updatePickingMeshesState", value: function (A, e, t) { if (this.pickingNodeMap) for (var i = this.manager.manager, o = this.pickingNodeMap, n = 0, r = e.length; r > n; n += 1) { var a = e[n]; if (i.isPickableNode(a)) { var s = i.getMeshManager().getNodeIdxMapByUserId(a); if (s) for (var l = Object.keys(s), c = 0, h = l.length; h > c; c += 1) { var d = l[c], p = o[d]; if (p) for (var g = s[d], u = 0, f = p.length; f > u; u += 1) { var m = p[u]; m.material = A, m.visible = !0; for (var C = m.geometry, y = C.getAttribute("vState").array, v = 0, I = g.length; I > v; v += 1) y[g[v]] = Hc.NONE; C.getAttribute("vState").needsUpdate = !0 } } } } } }, { key: "resetPickingMeshesState", value: function () { if (this.pickingNodeMap) for (var A = this.pickingNodeMap, e = Object.keys(A), t = 0, i = e.length; i > t; t += 1) for (var o = A[e[t]], n = 0, r = o.length; r > n; n += 1) o[n].visible = !1, o[n].geometry.getAttribute("vState").array.fill(Hc.HIDDEN), o[n].geometry.getAttribute("vState").needsUpdate = !0 } }]); var jf = function (A) { this.manager = A, this.model = A.model, this.wireframeGeometryMap = {}, this.wireframeMeshMap = {}, this.noNeedWireframingIdMap = {}, this.generated = !1 }; jf.prototype.destroy = function () { this.disposeGeometries(), this.wireframeGeometryMap = null, this.noNeedWireframingIdMap = null, this.manager = null }, jf.prototype.clearData = function () { this.generated = !1, this.bufferDestroyed = !1, this.wireframeMesh = {}, this.disposeGeometries(), this.wireframeGeometryMap = {}, this.noNeedWireframingIdMap = {} }, jf.prototype.disposeGeometries = function () { this._traverseWireframeGeometryMap((function (A, e) { for (var t = 0, i = e.length; i > t; t += 1) e[t].dispose() })) }, jf.prototype.updateNodes = function (A) { A || (A = this.model); var e = null; A.isActivateWireframe() ? (this.generateWireframe(A), (e = this._getNodeGroup(A)).updateMatrixWorld(!0), e.visible = !0) : this._hasNodeGroup(A) && ((e = this._getNodeGroup(A)).visible = !1) }, jf.prototype.resetInstanceMaterial = function () { var A = Hc.NONE; this._traverseWireframeGeometryMap((function (e, t) { for (var i = 0, o = t.length; o > i; i += 1) { for (var n = t[i].getAttribute("vState").array, r = 0, a = n.length; a > r; r += 1) n[r] = A; t[i].getAttribute("vState").needsUpdate = !0 } })), this._updateNoWireframingState() }, jf.prototype.updateInstanceWireframeByUserId = function (A, e, t, i) { if (t === Hc.HIDDEN || t === Hc.NONE || t === Hc.OVERRIDED) { var o = null; if (i) { var n = A.getFilter()._getMaterialByName(i), r = Kd.getColorParamsByMaterial(n); o = r.rgbaColor } var a = this; this.manager.traverseNodeIdxMapByUserId(e, (function (A, e) { a._setInstanceWireframeState(A, e, t, o) })) } }, jf.prototype._updateNoWireframingState = function () { var A = this, e = Hc.HIDDEN; this.manager.traverseNodeIdxMap((function (t, i) { A._setInstanceWireframeState(t, i, e) }), (function (e) { return A._isNeedWireframing(e) })) }, jf.prototype._setInstanceWireframeState = function (A, e, t, i) { var o = this._getWireframeGeometryById(A); if (o) for (var n = 0, r = o.length; r > n; n += 1) { var a = o[n].getAttribute("vState").array, s = null, l = null; i && (l = (s = o[n].getAttribute("aColor")) ? s.array : null); for (var c = 0, h = e.length; h > c; c += 1) { var d = e[c]; a[d] = t, null !== l && (l[4 * d] = i[0], l[4 * d + 1] = i[1], l[4 * d + 2] = i[2], l[4 * d + 3] = i[3]) } o[n].getAttribute("vState").needsUpdate = !0, s && (s.needsUpdate = !0) } }, jf.prototype._generateInstanceWireframe = function (A) { A || (A = this.model), this._collectNoWireframingIds(A), this._createInstanceWireframeGeometries(A), this._makeInstanceWireframe(A), this._updateNoWireframingState() }, jf.prototype.generateWireframe = function (A) { A || (A = this.model), this.generated || (Bh.time("createInstancedWireframeGeometry"), this._generateInstanceWireframe(A), Bh.timeEnd("createInstancedWireframeGeometry"), this.generated = !0) }, jf.prototype._collectNoWireframingIds = function (A) { var e = this, t = A.manager.filter; A.getModelDescriptor().traverseInstancedNodeInfos(null, (function (A, i) { i && t._hasRenderWithBoardlineFilter() && !t._isRenderWithBoardline(i[0]) && (e.noNeedWireframingIdMap[A] = !0) })) }, jf.prototype._createInstanceWireframeGeometries = function (A) { var e = this, t = {}; this.manager.traverseInstanceGeometryMap((function (A, i) { for (var o = e._getWireframeBufferById(A, i, t), n = e.wireframeGeometryMap[A] = [], r = 0, a = o.length; a > r; r += 1) { var s = new Na; s.setIndex(o[r].index), s.setAttribute("position", o[r].position), n.push(s) } })), t = null }, jf.prototype._makeInstanceWireframe = function (A) { var e = this, t = this.manager, i = t.getCachedInstanceData(), o = this._getWireframeMaterial(A); this._traverseWireframeGeometryMap((function (n, r) { for (var a = t.getBufferAttributesBy(n), s = e.wireframeMeshMap[n] = [], l = 0, c = r.length; c > l; l += 1) { r[l].setAttribute("vState", new Oa(new Float32Array(i.vState[n]), 1, !1, 1)), r[l].setAttribute("mcol0", a.attributeMcol0), r[l].setAttribute("mcol1", a.attributeMcol1), r[l].setAttribute("mcol2", a.attributeMcol2), r[l].setAttribute("mcol3", a.attributeMcol3); var h = new jo(r[l], o); if (h.matrixAutoUpdate = !1, h.frustumCulled = !1, !uh.isEmptyObject(A.subModel)) { var d = i.userId[n][0]; if (d) { var p = uh.getModelKeyFromComponentKey(d); A.subModel[p] && h.matrix.copy(A.subModel[p]) } } s.push(h), e._addWireframeNodeToScene(A, h) } })) }, jf.prototype._addWireframeNodeToScene = function (A, e) { this._getNodeGroup(A).add(e), e.updateMatrixWorld(!0) }, jf.prototype._isNeedWireframing = function (A) { return !this.noNeedWireframingIdMap || !this.noNeedWireframingIdMap[A] }, jf.prototype._getWireframeMaterial = function (A) { return A.getInstanceWireframeMaterial() }, jf.prototype._getWireframeBufferById = function (A, e, t) { var i = this.getGeometryIdByMeshId(A); if (t[i]) return t[i]; t[i] = []; for (var o = 0, n = e.length; n > o; o += 1) { var r = e[o]; t[i].push({ index: Up(r.attributes.position.array, r.index.array), position: r.attributes.position }) } return t[i] }, jf.prototype._getWireframeGeometryById = function (A) { return this.wireframeGeometryMap[A] }, jf.prototype._getWireframeMeshById = function (A) { return this.wireframeMeshMap[A] }, jf.prototype._traverseWireframeGeometryMap = function (A) { var e = this.wireframeGeometryMap; for (var t in e) A(t, e[t]) }, jf.prototype._getNodeGroup = function (A) { return A._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 }) }, jf.prototype._hasNodeGroup = function (A) { return A._hasNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY) }, jf.prototype.getGeometryIdByMeshId = function (A) { return uh.splitCombinedKeyString(A)[1] }, jf.prototype.adjustVisibility = function (A, e) { if (A.isActivateWireframe()) { var t = this._getNodeGroup(A), i = t.visible; e && !t.bVisible || (t.visible = e), t.bVisible = i } }, jf.prototype.changeVisibilityOfSelectedObjects = function (A, e) {}, jf.prototype.changeVisibilityOfNonSelectedObjects = function (A, e) { this.adjustVisibility(A, e) }, jf.prototype.restoreVisibilityOfObjects = function () {}, jf.prototype.disposeBufferAfterVbo = function () { if (this.generated && !this.bufferDestroyed) { this.bufferDestroyed = !0; var A = ["mcol0", "mcol1", "mcol2", "mcol3"]; vc.EnableExplosion && A.pop(), this._traverseWireframeGeometryMap((function (e, t) { for (var i = 0, o = t.length; o > i; i += 1) Tu.disposeBufferFromGeometry(t[i], A) })) } }, jf.prototype.getPickingNodeGenerator = function () { return this.pickingNodeGenerator || (this.pickingNodeGenerator = new qf(this)), this.pickingNodeGenerator }; var Hf = function (A) { this.model = A, this.meshManager = new Pf(this), this.wireframeManager = new jf(this) }; Hf.prototype.destroy = function () { this.meshManager.destroy(), this.meshManager = null, this.wireframeManager.destroy(), this.wireframeManager = null }, Hf.prototype.clearData = function () { this.meshManager.clearData(), this.wireframeManager.clearData() }, Hf.prototype.getGeometryByNodeInfo = function (A, e) { return this.meshManager.getGeometryByNodeInfo(A, e) }, Hf.prototype.getInstanceGeometries = function () { return this.meshManager.instanceGeometryMap }, Hf.prototype.traverseInstanceGeometryMap = function (A) { this.meshManager.traverseInstanceGeometryMap(A) }, Hf.prototype.getCachedInstanceData = function () { return this.meshManager.cachedInstance }, Hf.prototype.getBufferAttributesBy = function (A) { return this.meshManager.getBufferAttributesBy(A) }, Hf.prototype.traverseNodeIdxMapByUserId = function (A, e) { this.meshManager.traverseNodeIdxMapByUserId(A, e) }, Hf.prototype.traverseNodeIdxMap = function (A, e) { this.meshManager.traverseNodeIdxMap(A, e) }, Hf.prototype.getMeshesByUserId = function (A, e) { return this.meshManager.getMeshesByUserId(A, e) }, Hf.prototype._updateInstanceMaterialByUserId = function (A, e, t, i) { this.meshManager.updateInstanceStateByUserId(A, e, t, i) }, Hf.prototype._updateInstanceMaterialForWireFrameByUserId = function (A, e, t, i) { this.wireframeManager.updateInstanceWireframeByUserId(A, e, t, i) }, Hf.prototype._updateInstanceMaterial = function (A) { Bh.time("update instance material"); var e = zc; for (var t in this.clearSelectedObjectIds(), this.filteredIds) { var i = this.filteredIds[t]; if (i[e.HIDDEN]) this._updateInstanceMaterialByUserId(A, t, Hc.HIDDEN), this._updateInstanceMaterialForWireFrameByUserId(A, t, Hc.HIDDEN); else if (i[e.TRANSPARENT]) this._updateInstanceMaterialByUserId(A, t, Hc.TRANSPARENT); else { if (A.manager.isSelectPriority()) { if (i[e.SELECTED]) { this._updateInstanceMaterialByUserId(A, t, Hc.SELECTED); continue } if (i[e.BLINK]) { i[e.OVERRIDED] ? this._updateInstanceMaterialByUserId(A, t, Hc.BLINK, i[e.OVERRIDED]) : this._updateInstanceMaterialByUserId(A, t, Hc.BLINK); continue } } else { if (i[e.BLINK]) { i[e.OVERRIDED] ? this._updateInstanceMaterialByUserId(A, t, Hc.BLINK, i[e.OVERRIDED]) : this._updateInstanceMaterialByUserId(A, t, Hc.BLINK); continue } if (i[e.SELECTED]) { this._updateInstanceMaterialByUserId(A, t, Hc.SELECTED); continue } } i[e.HOVER] ? i[e.OVERRIDED] ? this._updateInstanceMaterialByUserId(A, t, Hc.HOVER, i[e.OVERRIDED]) : this._updateInstanceMaterialByUserId(A, t, Hc.HOVER) : i[e.OVERRIDED] && this._updateInstanceMaterialByUserId(A, t, Hc.OVERRIDED, i[e.OVERRIDED]) } } this._updateInstanceMaterialForWireFrame(A), Bh.timeEnd("update instance material") }, Hf.prototype._updateInstanceMaterialForWireFrame = function (A) { var e = this.mapFilteredUserIdsForWireFrame; if (e) for (var t = Object.keys(e), i = 0, o = t.length; o > i; i += 1) { var n = t[i]; this.filteredIds && this.filteredIds[n] && this.filteredIds[n][zc.HIDDEN] || this._updateInstanceMaterialForWireFrameByUserId(A, n, Hc.OVERRIDED, e[n]) } }, Hf.prototype._resetInstanceMaterial = function (A) { this.meshManager.resetInstanceMaterial(A), this.wireframeManager.resetInstanceMaterial() }, Hf.prototype._collectFilteredUserIds = function (A, e, t) { var i = A.manager.filter, o = i._hasHiddenFileIdFilter(), n = i._hasVisibleFilter(), r = i._hasOverrideMaterialFilter(), a = i._hasTransparentFilter(), s = A.hasReplacedUserId(), l = A.hasHiddenUserId(), c = this.filteredIds = {}; if (this.transparentUserIdSetObject = {}, o || n || r || a || s || l) for (var h = zc, d = 0; e.length > d; d += 1) { var p = e[d], g = t[p]; if (g && g.length) { var u = g[0]; if (o && i._isHiddenFileId(u) || n && !1 === i._isVisible(u) || A.isReplacedUserId(p) || A.isHiddenSourceObjectUserId(p)) c[p] || (c[p] = {}), c[p][h.HIDDEN] = !0; else if (a && i._isTransparent(u)) c[p] || (c[p] = {}), c[p][h.TRANSPARENT] = !0, this.transparentUserIdSetObject[p] = !0; else if (r && i._hasOverrideMaterial(u)) { var f = i._getOverrideMaterial(u), m = null; if (Array.isArray(f)) { var C = u.nodeId.replace(u.componentKey + "_", ""), y = parseInt(C, 10); "" === (m = null !== f[y] ? f[y].name : "") && (m = u.materialId), c[p] || (c[p] = {}), c[p][h.OVERRIDED] || (c[p][h.OVERRIDED] = []), c[p][h.OVERRIDED][y] = m } else "" !== (m = null !== f ? f.name : "") && (c[p] || (c[p] = {}), c[p][h.OVERRIDED] = m) } } } }, Hf.prototype._collectModelFiltered = function (A) { var e = A.manager.filter, t = A.modelKey, i = e._hasModelOverrideMaterialFilter(), o = e._hasModelTransparentFilter(), n = A.manager.modelState.selectionSet; return A.manager.modelState.hoverId === t ? A.manager.modelState.getHoverMaterial() : n.hasOwnProperty(A.modelKey) ? A.manager.modelState.selectionMaterial : o && e._isModelTransparent(t) ? e._getMaterialByName("scene") : i && e._hasModelOverrideMaterial(t) ? e._getModelOverrideMaterial(t) : null }, Hf.prototype._collectFilteredUserIdsForWireFrame = function (A, e, t) { var i = A.getFilter(), o = i._hasOverrideMaterialFilterForWireFrame(); if (this.mapFilteredUserIdsForWireFrame = {}, o) for (var n = zc, r = 0; e.length > r; r += 1) { var a = e[r]; if (!(this.filteredIds && this.filteredIds[a] && this.filteredIds[a][n.HIDDEN])) { var s = t[a]; if (s && s.length) { var l = s[0]; if (i._hasOverrideMaterialForWireFrame(l)) { var c = i._getOverrideMaterialForWireFrame(l), h = null !== c ? c.name : ""; "" !== h && (this.mapFilteredUserIdsForWireFrame[a] = h) } } } } }, Hf.prototype._collectSelectedUserIds = function (A, e) { var t = this.filteredIds = this.filteredIds || {}, i = zc, o = {}; for (var n in A) if (this.model.modelKey === n) for (var r in A[n]) e[r] && (t[r] || (t[r] = {}), t[r][i.SELECTED] = !0, o[r] = !0); this.selectedUserIds = Object.keys(o) }, Hf.prototype._clearSelectedState = function (A) { if (this.filteredIds && this.selectedUserIds && this.selectedUserIds.length) { for (var e = 0, t = this.selectedUserIds.length; t > e; e += 1) { var i = this.selectedUserIds[e]; this.filteredIds[i] && (this.meshManager.clearInstanceStateByUserId(i), delete this.filteredIds[i][zc.SELECTED]) } this.selectedUserIds = null } }, Hf.prototype._collectHoveredUserIds = function (A, e) { var t = this.filteredIds = this.filteredIds || {}; this.hoverdUserId = void 0, A && e[A] && (t[A] || (t[A] = {}), t[A][zc.HOVER] = !0, this.hoverdUserId = A) }, Hf.prototype._clearHoveredState = function (A) { this.filteredIds && this.hoverdUserId && this.filteredIds[this.hoverdUserId] && (this.meshManager.clearInstanceStateByUserId(this.hoverdUserId), delete this.filteredIds[this.hoverdUserId][zc.HOVER], this.hoverdUserId = void 0) }, Hf.prototype._collectBlinkedUserIds = function (A, e) { var t = this.filteredIds = this.filteredIds || {}, i = zc, o = {}; for (var n in A) e[n] && (t[n] || (t[n] = {}), t[n][i.BLINK] = !0, o[n] = !0); this.blinkUserIds = Object.keys(o) }, Hf.prototype._clearBlinkedState = function (A) { if (this.filteredIds && this.blinkUserIds && this.blinkUserIds.length) { for (var e = 0, t = this.blinkUserIds.length; t > e; e += 1) { var i = this.blinkUserIds[e]; this.filteredIds[i] && (this.meshManager.clearInstanceStateByUserId(i), delete this.filteredIds[i][zc.BLINK]) } this.blinkUserIds = null } }, Hf.prototype.applyFilter = function (A, e) { console.log('applyFilter :>dfdf> '); if (this.hasNodeInfo(A)) { this.updateNodes(A), this._resetInstanceMaterial(A); var t = null; t = e || A.getModelDescriptor().getInstancedUserIds(); var i = A.getModelDescriptor().getInstancedNodeInfos(); this._collectFilteredUserIds(A, t, i), this._collectFilteredUserIdsForWireFrame(A, t, i), this._collectSelectedUserIds(A.manager.sceneState.selectionSet, i), this._collectBlinkedUserIds(A.manager.sceneState.getBlinkComponentsIdMap(), i), this._collectHoveredUserIds(A.manager.sceneState.hoverId, i), this._updateInstanceMaterial(A), this.updateNodes(A) } }, Hf.prototype.applySelection = function (A) { console.log('applySelection17') if (this.hasNodeInfo(A)) { var e = A.getModelDescriptor().getInstancedNodeInfos(); this._clearSelectedState(A), this._clearHoveredState(A), this._collectSelectedUserIds(A.manager.sceneState.selectionSet, e), this._collectHoveredUserIds(A.manager.sceneState.hoverId, e), this._updateInstanceMaterial(A), this.updateNodes(A) } }, Hf.prototype.clearSelection = function (A) { this._clearSelectedState(A), this.applyHover(A) }, Hf.prototype.applyHover = function (A) { if (this.hasNodeInfo(A)) { var e = A.getModelDescriptor().getInstancedNodeInfos(); this._clearHoveredState(A), this._collectHoveredUserIds(A.manager.sceneState.hoverId, e), this._updateInstanceMaterial(A), this.updateNodes(A) } }, Hf.prototype.clearHover = function (A) { this._clearHoveredState(A), this._updateInstanceMaterial(A), this.updateNodes(A) }, Hf.prototype.applyBlink = function (A) { if (this.hasNodeInfo(A)) { var e = A.getModelDescriptor().getInstancedNodeInfos(); this._clearBlinkedState(A), this._clearHoveredState(A), this._collectBlinkedUserIds(A.manager.sceneState.getBlinkComponentsIdMap(), e), this._collectHoveredUserIds(A.manager.sceneState.hoverId, e), this._updateInstanceMaterial(A), this.updateNodes(A) } }, Hf.prototype.clearBlink = function (A) { this._clearBlinkedState(A), this.applyHover(A) }, Hf.prototype.applyReplacement = function (A) { this._updateInstanceMaterial(A), this.updateNodes(A) }, Hf.prototype.hasNodeInfo = function (A) { return Boolean(A.getModelDescriptor().getInstancedNodeInfos()) }, Hf.prototype.updateNodes = function (A) { if (this.hasNodeInfo(A)) { var e; if (e = this._collectModelFiltered(A)) for (var t = A.getModelDescriptor().getInstancedUserIds(), i = 0; t.length > i; i += 1) this._updateInstanceMaterialByUserId(A, t[i], Hc.OVERRIDED, e); this.meshManager.updateNodes(A), this.wireframeManager.updateNodes(A) } }, Hf.prototype.generateWireframe = function (A, e) { this.wireframeManager.generateWireframe(A, e) }, Hf.prototype.createMeshNodes = function (A, e) { this.meshManager.createMeshNodes(A, e) }, Hf.prototype.createInstancedMeshNodes = function (A, e) { this.meshManager._createBatchedInstanceGeometries(A, e) }, Hf.prototype.clearCachedData = function () { this.meshManager.disposeGeometries() }, Hf.prototype.getMeshesByUserIds = function (A, e) { this.meshManager.getMeshesByUserId(A, e) }, Hf.prototype.clearSelectedObjectIds = function () { this.meshManager.clearSelectedObjectIds() }, Hf.prototype.adjustVisibility = function (A, e) { this.meshManager.adjustVisibility(A, e), this.wireframeManager.adjustVisibility(A, e) }, Hf.prototype.changeVisibilityOfSelectedObjects = function (A, e) { this.meshManager.changeVisibilityOfSelectedObjects(A, e), this.wireframeManager.changeVisibilityOfSelectedObjects(A, e) }, Hf.prototype.changeVisibilityOfNonSelectedObjects = function (A, e) { this.meshManager.changeVisibilityOfNonSelectedObjects(A, e), this.wireframeManager.changeVisibilityOfNonSelectedObjects(A, e) }, Hf.prototype.restoreVisibilityOfObjects = function () { this.meshManager.restoreVisibilityOfObjects(), this.wireframeManager.restoreVisibilityOfObjects() }, Hf.prototype.disposeBufferAfterVbo = function () { this.meshManager.disposeBufferAfterVbo(), this.wireframeManager.disposeBufferAfterVbo() }, Hf.prototype.addAllInstanceNodeToScene = function (A) { this.meshManager.addAllInstanceNodeToScene(A) }, Hf.prototype.getGeometryBuffersByUserId = function (A, e) { return this.meshManager.getGeometryBuffersByUserId(A, e) }, Hf.prototype.explode = function (A, e, t) { this.meshManager.explode(A, e, t) }, Hf.prototype.explosion = function (A, e) { this.meshManager.explosion(A, e) }, Hf.prototype.closeExplosion = function (A) { this.meshManager.closeExplosion(A) }, Hf.prototype.componentsExplosion = function (A, e) { this.meshManager.componentsExplosion(A, e) }, Hf.prototype.closeComponentsExplosion = function (A, e) { this.meshManager.closeComponentsExplosion(A, e) }, Hf.prototype.isPickableNode = function (A) { if (!this.filteredIds || !this.filteredIds[A]) return !0; var e = this.filteredIds[A]; return !e[zc.HIDDEN] && !e[zc.TRANSPARENT] }, Hf.prototype.isHiddenNode = function (A) { return !!(this.filteredIds && this.filteredIds[A] && this.filteredIds[A][zc.HIDDEN]) }, Hf.prototype.getMeshManager = function () { return this.meshManager }, Hf.prototype.getWireFrameManager = function () { return this.wireframeManager }, Hf.prototype.getTransparentUserIds = function () { return this.transparentUserIdSetObject }; var Yf = function (A, e) { tf.call(this, A), this.defaultManager = new Of(e, A), this.instancedManager = new Hf(A), this.loader = new ef(this) }; function Wf(A, e) { var t = A.__state.conversionName.toString(), i = Math.round(A.r), o = Math.round(A.g), n = Math.round(A.b), r = A.a, a = Math.round(A.h), s = A.s.toFixed(1), l = A.v.toFixed(1); if (e || "THREE_CHAR_HEX" === t || "SIX_CHAR_HEX" === t) { for (var c = A.hex.toString(16); 6 > c.length;) c = "0" + c; return "#" + c } return "CSS_RGB" === t ? "rgb(" + i + "," + o + "," + n + ")" : "CSS_RGBA" === t ? "rgba(" + i + "," + o + "," + n + "," + r + ")" : "HEX" === t ? "0x" + A.hex.toString(16) : "RGB_ARRAY" === t ? "[" + i + "," + o + "," + n + "]" : "RGBA_ARRAY" === t ? "[" + i + "," + o + "," + n + "," + r + "]" : "RGB_OBJ" === t ? "{r:" + i + ",g:" + o + ",b:" + n + "}" : "RGBA_OBJ" === t ? "{r:" + i + ",g:" + o + ",b:" + n + ",a:" + r + "}" : "HSV_OBJ" === t ? "{h:" + a + ",s:" + s + ",v:" + l + "}" : "HSVA_OBJ" === t ? "{h:" + a + ",s:" + s + ",v:" + l + ",a:" + r + "}" : "unknown format" } (Yf.prototype = Object.create(tf.prototype)).prepare = function (A, e) { if (this.isLoaded() && !this.isHidden()) { this.prepareWireframe(this.model, e); this.model.getMaterialManager(); this.model.getMaterialManager()._updateTextureMapping(), !this.model.lightmap || this.model.enableLightmap === vc.EnableLightmap && this.model.lightmapIntensity === vc.LightmapIntensity || (this.model.enableLightmap = vc.EnableLightmap, this.model.lightmapIntensity = vc.LightmapIntensity, this.rebuildIndicesforLightmap(), this.updateNodes()) } }, Yf.prototype.settleData = function (A) { this.addNodeInfoToOctantMap(), this.createMeshNodes(A) }, Yf.prototype.addNodeInfoToOctantMap = function () { var A = this.model.manager, e = this.model.getEncodedDatabagId(); this.loader.getDescriptor().traverseNodeInfosByComponent((function (t, i) { A.addNodeInfoToOctantMap(e, t, i) })) }, Yf.prototype.createMeshNodes = function (A) { var e = this, t = this.model, i = this.loader.getDescriptor(); this.instancedManager.createMeshNodes(t, i.getInstancedUserIds()), this.defaultManager.asyncCreateMeshNodes(t, i.getStandardUserIds(), (function () { t.getMaterialManager()._updateTextureMapping(), e.clearCachedData(t), e.loaded = !0, A && A() })) }, Yf.prototype.clearCachedData = function (A) { this.loader.getDescriptor().destroyReader(), this.loader.getDescriptor().clearReferencedMeshCache(), this.defaultManager.clearCachedData(), this.instancedManager.clearCachedData() }; var Jf = Array.prototype.forEach, zf = Array.prototype.slice, Zf = { BREAK: {}, extend: function (A) { return this.each(zf.call(arguments, 1), (function (e) { (this.isObject(e) ? Object.keys(e) : []).forEach(function (t) { this.isUndefined(e[t]) || (A[t] = e[t]) } .bind(this)) }), this), A }, defaults: function (A) { return this.each(zf.call(arguments, 1), (function (e) { (this.isObject(e) ? Object.keys(e) : []).forEach(function (t) { this.isUndefined(A[t]) && (A[t] = e[t]) } .bind(this)) }), this), A }, compose: function () { var A = zf.call(arguments); return function () { for (var e = zf.call(arguments), t = A.length - 1; t >= 0; t--) e = [A[t].apply(this, e)]; return e[0] } }, each: function (A, e, t) { if (A) if (Jf && A.forEach && A.forEach === Jf) A.forEach(e, t); else if (A.length === A.length + 0) { var i, o = void 0; for (o = 0, i = A.length; i > o; o++) if (o in A && e.call(t, A[o], o) === this.BREAK) return } else for (var n in A) if (e.call(t, A[n], n) === this.BREAK) return }, defer: function (A) { setTimeout(A, 0) }, debounce: function (A, e, t) { var i = void 0; return function () { var o = this, n = arguments; function r() { i = null, t || A.apply(o, n) } var a = t || !i; clearTimeout(i), i = setTimeout(r, e), a && A.apply(o, n) } }, toArray: function (A) { return A.toArray ? A.toArray() : zf.call(A) }, isUndefined: function (A) { return void 0 === A }, isNull: function (A) { return null === A }, isNaN: function (A) { function e() { return A.apply(this, arguments) } return e.toString = function () { return A.toString() }, e }((function (A) { return isNaN(A) })), isArray: Array.isArray || function (A) { return A.constructor === Array }, isObject: function (A) { return A === Object(A) }, isNumber: function (A) { return A === A + 0 }, isString: function (A) { return A === A + "" }, isBoolean: function (A) { return !1 === A || !0 === A }, isFunction: function (A) { return "[object Function]" === Object.prototype.toString.call(A) } }, Xf = [{ litmus: Zf.isString, conversions: { THREE_CHAR_HEX: { read: function (A) { var e = A.match(/^#([A-F0-9])([A-F0-9])([A-F0-9])$/i); return null !== e && { space: "HEX", hex: parseInt("0x" + e[1].toString() + e[1].toString() + e[2].toString() + e[2].toString() + e[3].toString() + e[3].toString(), 0) } }, write: Wf }, SIX_CHAR_HEX: { read: function (A) { var e = A.match(/^#([A-F0-9]{6})$/i); return null !== e && { space: "HEX", hex: parseInt("0x" + e[1].toString(), 0) } }, write: Wf }, CSS_RGB: { read: function (A) { var e = A.match(/^rgb\(\s*(.+)\s*,\s*(.+)\s*,\s*(.+)\s*\)/); return null !== e && { space: "RGB", r: parseFloat(e[1]), g: parseFloat(e[2]), b: parseFloat(e[3]) } }, write: Wf }, CSS_RGBA: { read: function (A) { var e = A.match(/^rgba\(\s*(.+)\s*,\s*(.+)\s*,\s*(.+)\s*,\s*(.+)\s*\)/); return null !== e && { space: "RGB", r: parseFloat(e[1]), g: parseFloat(e[2]), b: parseFloat(e[3]), a: parseFloat(e[4]) } }, write: Wf } } }, { litmus: Zf.isNumber, conversions: { HEX: { read: function (A) { return { space: "HEX", hex: A, conversionName: "HEX" } }, write: function (A) { return A.hex } } } }, { litmus: Zf.isArray, conversions: { RGB_ARRAY: { read: function (A) { return 3 === A.length && { space: "RGB", r: A[0], g: A[1], b: A[2] } }, write: function (A) { return [A.r, A.g, A.b] } }, RGBA_ARRAY: { read: function (A) { return 4 === A.length && { space: "RGB", r: A[0], g: A[1], b: A[2], a: A[3] } }, write: function (A) { return [A.r, A.g, A.b, A.a] } } } }, { litmus: Zf.isObject, conversions: { RGBA_OBJ: { read: function (A) { return !!(Zf.isNumber(A.r) && Zf.isNumber(A.g) && Zf.isNumber(A.b) && Zf.isNumber(A.a)) && { space: "RGB", r: A.r, g: A.g, b: A.b, a: A.a } }, write: function (A) { return { r: A.r, g: A.g, b: A.b, a: A.a } } }, RGB_OBJ: { read: function (A) { return !!(Zf.isNumber(A.r) && Zf.isNumber(A.g) && Zf.isNumber(A.b)) && { space: "RGB", r: A.r, g: A.g, b: A.b } }, write: function (A) { return { r: A.r, g: A.g, b: A.b } } }, HSVA_OBJ: { read: function (A) { return !!(Zf.isNumber(A.h) && Zf.isNumber(A.s) && Zf.isNumber(A.v) && Zf.isNumber(A.a)) && { space: "HSV", h: A.h, s: A.s, v: A.v, a: A.a } }, write: function (A) { return { h: A.h, s: A.s, v: A.v, a: A.a } } }, HSV_OBJ: { read: function (A) { return !!(Zf.isNumber(A.h) && Zf.isNumber(A.s) && Zf.isNumber(A.v)) && { space: "HSV", h: A.h, s: A.s, v: A.v } }, write: function (A) { return { h: A.h, s: A.s, v: A.v } } } } }], _f = void 0, $f = void 0, Am = function () { $f = !1; var A = arguments.length > 1 ? Zf.toArray(arguments) : arguments[0]; return Zf.each(Xf, (function (e) { if (e.litmus(A)) return Zf.each(e.conversions, (function (e, t) { if (_f = e.read(A), !1 === $f && !1 !== _f) return $f = _f, _f.conversionName = t, _f.conversion = e, Zf.BREAK })), Zf.BREAK })), $f }, em = void 0, tm = { hsv_to_rgb: function (A, e, t) { var i = Math.floor(A / 60) % 6, o = A / 60 - Math.floor(A / 60), n = t * (1 - e), r = t * (1 - o * e), a = t * (1 - (1 - o) * e), s = [ [t, a, n], [r, t, n], [n, t, a], [n, r, t], [a, n, t], [t, n, r] ][i]; return { r: 255 * s[0], g: 255 * s[1], b: 255 * s[2] } }, rgb_to_hsv: function (A, e, t) { var i = Math.min(A, e, t), o = Math.max(A, e, t), n = o - i, r = void 0; return 0 === o ? { h: NaN, s: 0, v: 0 } : (r = A === o ? (e - t) / n : e === o ? 2 + (t - A) / n : 4 + (A - e) / n, 0 > (r /= 6) && (r += 1), { h: 360 * r, s: n / o, v: o / 255 }) }, rgb_to_hex: function (A, e, t) { var i = this.hex_with_component(0, 2, A); return i = this.hex_with_component(i, 1, e), i = this.hex_with_component(i, 0, t) }, component_from_hex: function (A, e) { return A >> 8 * e & 255 }, hex_with_component: function (A, e, t) { return t << (em = 8 * e) | A & ~(255 << em) } }, im = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (A) { return typeof A } : function (A) { return A && "function" == typeof Symbol && A.constructor === Symbol && A !== Symbol.prototype ? "symbol" : typeof A }, om = function (A, e) { if (!(A instanceof e)) throw new TypeError("Cannot call a class as a function") }, nm = function () { function A(A, e) { for (var t = 0; e.length > t; t++) { var i = e[t]; i.enumerable = i.enumerable || !1, i.configurable = !0, "value" in i && (i.writable = !0), Object.defineProperty(A, i.key, i) } } return function (e, t, i) { return t && A(e.prototype, t), i && A(e, i), e } }(), rm = function A(e, t, i) { null === e && (e = Function.prototype); var o = Object.getOwnPropertyDescriptor(e, t); if (void 0 === o) { var n = Object.getPrototypeOf(e); return null === n ? void 0 : A(n, t, i) } if ("value" in o) return o.value; var r = o.get; return void 0 !== r ? r.call(i) : void 0 }, am = function (A, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e); A.prototype = Object.create(e && e.prototype, { constructor: { value: A, enumerable: !1, writable: !0, configurable: !0 } }), e && (Object.setPrototypeOf ? Object.setPrototypeOf(A, e) : A.__proto__ = e) }, sm = function (A, e) { if (!A) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return !e || "object" != typeof e && "function" != typeof e ? A : e }, lm = function () { function A() { if (om(this, A), this.__state = Am.apply(this, arguments), !1 === this.__state) throw new Error("Failed to interpret color arguments"); this.__state.a = this.__state.a || 1 } return nm(A, [{ key: "toString", value: function () { return Wf(this) } }, { key: "toHexString", value: function () { return Wf(this, !0) } }, { key: "toOriginal", value: function () { return this.__state.conversion.write(this) } }]), A }(); function cm(A, e, t) { Object.defineProperty(A, e, { get: function () { return "RGB" === this.__state.space || lm.recalculateRGB(this, e, t), this.__state[e] }, set: function (A) { "RGB" !== this.__state.space && (lm.recalculateRGB(this, e, t), this.__state.space = "RGB"), this.__state[e] = A } }) } function hm(A, e) { Object.defineProperty(A, e, { get: function () { return "HSV" === this.__state.space || lm.recalculateHSV(this), this.__state[e] }, set: function (A) { "HSV" !== this.__state.space && (lm.recalculateHSV(this), this.__state.space = "HSV"), this.__state[e] = A } }) } lm.recalculateRGB = function (A, e, t) { if ("HEX" === A.__state.space) A.__state[e] = tm.component_from_hex(A.__state.hex, t); else { if ("HSV" !== A.__state.space) throw new Error("Corrupted color state"); Zf.extend(A.__state, tm.hsv_to_rgb(A.__state.h, A.__state.s, A.__state.v)) } }, lm.recalculateHSV = function (A) { var e = tm.rgb_to_hsv(A.r, A.g, A.b); Zf.extend(A.__state, { s: e.s, v: e.v }), Zf.isNaN(e.h) ? Zf.isUndefined(A.__state.h) && (A.__state.h = 0) : A.__state.h = e.h }, lm.COMPONENTS = ["r", "g", "b", "h", "s", "v", "hex", "a"], cm(lm.prototype, "r", 2), cm(lm.prototype, "g", 1), cm(lm.prototype, "b", 0), hm(lm.prototype, "h"), hm(lm.prototype, "s"), hm(lm.prototype, "v"), Object.defineProperty(lm.prototype, "a", { get: function () { return this.__state.a }, set: function (A) { this.__state.a = A } }), Object.defineProperty(lm.prototype, "hex", { get: function () { return "HEX" !== !this.__state.space && (this.__state.hex = tm.rgb_to_hex(this.r, this.g, this.b)), this.__state.hex }, set: function (A) { this.__state.space = "HEX", this.__state.hex = A } }); var dm = function () { function A(e, t) { om(this, A), this.initialValue = e[t], this.domElement = document.createElement("div"), this.object = e, this.property = t, this.__onChange = void 0, this.__onFinishChange = void 0 } return nm(A, [{ key: "onChange", value: function (A) { return this.__onChange = A, this } }, { key: "onFinishChange", value: function (A) { return this.__onFinishChange = A, this } }, { key: "setValue", value: function (A) { return this.object[this.property] = A, this.__onChange && this.__onChange.call(this, A), this.updateDisplay(), this } }, { key: "getValue", value: function () { return this.object[this.property] } }, { key: "updateDisplay", value: function () { return this } }, { key: "isModified", value: function () { return this.initialValue !== this.getValue() } }]), A }(), pm = {}; Zf.each({ HTMLEvents: ["change"], MouseEvents: ["click", "mousemove", "mousedown", "mouseup", "mouseover"], KeyboardEvents: ["keydown"] }, (function (A, e) { Zf.each(A, (function (A) { pm[A] = e })) })); var gm = /(\d+(\.\d+)?)px/; function um(A) { if ("0" === A || Zf.isUndefined(A)) return 0; var e = A.match(gm); return Zf.isNull(e) ? 0 : parseFloat(e[1]) } var fm = { makeSelectable: function (A, e) { void 0 !== A && void 0 !== A.style && (A.onselectstart = e ? function () { return !1 } : function () {}, A.style.MozUserSelect = e ? "auto" : "none", A.style.KhtmlUserSelect = e ? "auto" : "none", A.unselectable = e ? "on" : "off") }, makeFullscreen: function (A, e, t) { var i = t, o = e; Zf.isUndefined(o) && (o = !0), Zf.isUndefined(i) && (i = !0), A.style.position = "absolute", o && (A.style.left = 0, A.style.right = 0), i && (A.style.top = 0, A.style.bottom = 0) }, fakeEvent: function (A, e, t, i) { var o = t || {}, n = pm[e]; if (!n) throw new Error("Event type " + e + " not supported."); var r = document.createEvent(n); switch (n) { case "MouseEvents": r.initMouseEvent(e, o.bubbles || !1, o.cancelable || !0, window, o.clickCount || 1, 0, 0, o.x || o.clientX || 0, o.y || o.clientY || 0, !1, !1, !1, !1, 0, null); break; case "KeyboardEvents": var a = r.initKeyboardEvent || r.initKeyEvent; Zf.defaults(o, { cancelable: !0, ctrlKey: !1, altKey: !1, shiftKey: !1, metaKey: !1, keyCode: void 0, charCode: void 0 }), a(e, o.bubbles || !1, o.cancelable, window, o.ctrlKey, o.altKey, o.shiftKey, o.metaKey, o.keyCode, o.charCode); break; default: r.initEvent(e, o.bubbles || !1, o.cancelable || !0) } Zf.defaults(r, i), A.dispatchEvent(r) }, bind: function (A, e, t, i) { return A.addEventListener ? A.addEventListener(e, t, i || !1) : A.attachEvent && A.attachEvent("on" + e, t), fm }, unbind: function (A, e, t, i) { return A.removeEventListener ? A.removeEventListener(e, t, i || !1) : A.detachEvent && A.detachEvent("on" + e, t), fm }, addClass: function (A, e) { if (void 0 === A.className) A.className = e; else if (A.className !== e) { var t = A.className.split(/ +/); - 1 === t.indexOf(e) && (t.push(e), A.className = t.join(" ").replace(/^\s+/, "").replace(/\s+$/, "")) } return fm }, removeClass: function (A, e) { if (e) if (A.className === e) A.removeAttribute("class"); else { var t = A.className.split(/ +/), i = t.indexOf(e); - 1 !== i && (t.splice(i, 1), A.className = t.join(" ")) } else A.className = void 0; return fm }, hasClass: function (A, e) { return new RegExp("(?:^|\\s+)" + e + "(?:\\s+|$)").test(A.className) || !1 }, getWidth: function (A) { var e = getComputedStyle(A); return um(e["border-left-width"]) + um(e["border-right-width"]) + um(e["padding-left"]) + um(e["padding-right"]) + um(e.width) }, getHeight: function (A) { var e = getComputedStyle(A); return um(e["border-top-width"]) + um(e["border-bottom-width"]) + um(e["padding-top"]) + um(e["padding-bottom"]) + um(e.height) }, getOffset: function (A) { var e = A, t = { left: 0, top: 0 }; if (e.offsetParent) do { t.left += e.offsetLeft, t.top += e.offsetTop, e = e.offsetParent } while (e); return t }, isActive: function (A) { return A === document.activeElement && (A.type || A.href) } }, mm = function (A) { function e(A, t) { om(this, e); var i = sm(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this, A, t)), o = i; return i.__prev = i.getValue(), i.__checkbox = document.createElement("input"), i.__checkbox.setAttribute("type", "checkbox"), fm.bind(i.__checkbox, "change", (function () { o.setValue(!o.__prev) }), !1), i.domElement.appendChild(i.__checkbox), i.updateDisplay(), i } return am(e, A), nm(e, [{ key: "setValue", value: function (A) { var t = rm(e.prototype.__proto__ || Object.getPrototypeOf(e.prototype), "setValue", this).call(this, A); return this.__onFinishChange && this.__onFinishChange.call(this, this.getValue()), this.__prev = this.getValue(), t } }, { key: "updateDisplay", value: function () { return !0 === this.getValue() ? (this.__checkbox.setAttribute("checked", "checked"), this.__checkbox.checked = !0, this.__prev = !0) : (this.__checkbox.checked = !1, this.__prev = !1), rm(e.prototype.__proto__ || Object.getPrototypeOf(e.prototype), "updateDisplay", this).call(this) } }]), e }(dm), Cm = function (A) { function e(A, t, i) { om(this, e); var o = sm(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this, A, t)), n = i, r = o; if (o.__select = document.createElement("select"), Zf.isArray(n)) { var a = {}; Zf.each(n, (function (A) { a[A] = A })), n = a } return Zf.each(n, (function (A, e) { var t = document.createElement("option"); t.innerHTML = e, t.setAttribute("value", A), r.__select.appendChild(t) })), o.updateDisplay(), fm.bind(o.__select, "change", (function () { r.setValue(this.options[this.selectedIndex].value) })), o.domElement.appendChild(o.__select), o } return am(e, A), nm(e, [{ key: "setValue", value: function (A) { var t = rm(e.prototype.__proto__ || Object.getPrototypeOf(e.prototype), "setValue", this).call(this, A); return this.__onFinishChange && this.__onFinishChange.call(this, this.getValue()), t } }, { key: "updateDisplay", value: function () { return fm.isActive(this.__select) ? this : (this.__select.value = this.getValue(), rm(e.prototype.__proto__ || Object.getPrototypeOf(e.prototype), "updateDisplay", this).call(this)) } }]), e }(dm), ym = function (A) { function e(A, t) { om(this, e); var i = sm(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this, A, t)), o = i; function n() { o.setValue(o.__input.value) } return i.__input = document.createElement("input"), i.__input.setAttribute("type", "text"), fm.bind(i.__input, "keyup", n), fm.bind(i.__input, "change", n), fm.bind(i.__input, "blur", (function () { o.__onFinishChange && o.__onFinishChange.call(o, o.getValue()) })), fm.bind(i.__input, "keydown", (function (A) { 13 === A.keyCode && this.blur() })), i.updateDisplay(), i.domElement.appendChild(i.__input), i } return am(e, A), nm(e, [{ key: "updateDisplay", value: function () { return fm.isActive(this.__input) || (this.__input.value = this.getValue()), rm(e.prototype.__proto__ || Object.getPrototypeOf(e.prototype), "updateDisplay", this).call(this) } }]), e }(dm); function vm(A) { var e = A.toString(); return e.indexOf(".") > -1 ? e.length - e.indexOf(".") - 1 : 0 } var Im = function (A) { function e(A, t, i) { om(this, e); var o = sm(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this, A, t)), n = i || {}; return o.__min = n.min, o.__max = n.max, o.__step = n.step, o.__impliedStep = Zf.isUndefined(o.__step) ? 0 === o.initialValue ? 1 : Math.pow(10, Math.floor(Math.log(Math.abs(o.initialValue)) / Math.LN10)) / 10 : o.__step, o.__precision = vm(o.__impliedStep), o } return am(e, A), nm(e, [{ key: "setValue", value: function (A) { var t = A; return void 0 !== this.__min && this.__min > t ? t = this.__min : void 0 !== this.__max && t > this.__max && (t = this.__max), void 0 !== this.__step && t % this.__step != 0 && (t = Math.round(t / this.__step) * this.__step), rm(e.prototype.__proto__ || Object.getPrototypeOf(e.prototype), "setValue", this).call(this, t) } }, { key: "min", value: function (A) { return this.__min = A, this } }, { key: "max", value: function (A) { return this.__max = A, this } }, { key: "step", value: function (A) { return this.__step = A, this.__impliedStep = A, this.__precision = vm(A), this } }]), e }(dm); var Em = function (A) { function e(A, t, i) { om(this, e); var o = sm(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this, A, t, i)); o.__truncationSuspended = !1; var n = o, r = void 0; function a() { n.__onFinishChange && n.__onFinishChange.call(n, n.getValue()) } function s(A) { var e = r - A.clientY; n.setValue(n.getValue() + e * n.__impliedStep), r = A.clientY } function l() { fm.unbind(window, "mousemove", s), fm.unbind(window, "mouseup", l), a() } return o.__input = document.createElement("input"), o.__input.setAttribute("type", "text"), fm.bind(o.__input, "change", (function () { var A = parseFloat(n.__input.value); Zf.isNaN(A) || n.setValue(A) })), fm.bind(o.__input, "blur", (function () { a() })), fm.bind(o.__input, "mousedown", (function (A) { fm.bind(window, "mousemove", s), fm.bind(window, "mouseup", l), r = A.clientY })), fm.bind(o.__input, "keydown", (function (A) { 13 === A.keyCode && (n.__truncationSuspended = !0, this.blur(), n.__truncationSuspended = !1, a()) })), o.updateDisplay(), o.domElement.appendChild(o.__input), o } return am(e, A), nm(e, [{ key: "updateDisplay", value: function () { var A, t; return this.__input.value = this.__truncationSuspended ? this.getValue() : (A = this.getValue(), t = Math.pow(10, this.__precision), Math.round(A * t) / t), rm(e.prototype.__proto__ || Object.getPrototypeOf(e.prototype), "updateDisplay", this).call(this) } }]), e }(Im); function Bm(A, e, t, i, o) { return i + (A - e) / (t - e) * (o - i) } var xm = function (A) { function e(A, t, i, o, n) { om(this, e); var r = sm(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this, A, t, { min: i, max: o, step: n })), a = r; function s(A) { A.preventDefault(); var e = a.__background.getBoundingClientRect(); return a.setValue(Bm(A.clientX, e.left, e.right, a.__min, a.__max)), !1 } function l() { fm.unbind(window, "mousemove", s), fm.unbind(window, "mouseup", l), a.__onFinishChange && a.__onFinishChange.call(a, a.getValue()) } function c(A) { var e = A.touches[0].clientX, t = a.__background.getBoundingClientRect(); a.setValue(Bm(e, t.left, t.right, a.__min, a.__max)) } function h() { fm.unbind(window, "touchmove", c), fm.unbind(window, "touchend", h), a.__onFinishChange && a.__onFinishChange.call(a, a.getValue()) } return r.__background = document.createElement("div"), r.__foreground = document.createElement("div"), fm.bind(r.__background, "mousedown", (function (A) { document.activeElement.blur(), fm.bind(window, "mousemove", s), fm.bind(window, "mouseup", l), s(A) })), fm.bind(r.__background, "touchstart", (function (A) { if (1 !== A.touches.length) return; fm.bind(window, "touchmove", c), fm.bind(window, "touchend", h), c(A) })), fm.addClass(r.__background, "slider"), fm.addClass(r.__foreground, "slider-fg"), r.updateDisplay(), r.__background.appendChild(r.__foreground), r.domElement.appendChild(r.__background), r } return am(e, A), nm(e, [{ key: "updateDisplay", value: function () { var A = (this.getValue() - this.__min) / (this.__max - this.__min); return this.__foreground.style.width = 100 * A + "%", rm(e.prototype.__proto__ || Object.getPrototypeOf(e.prototype), "updateDisplay", this).call(this) } }]), e }(Im), Sm = function (A) { function e(A, t, i) { om(this, e); var o = sm(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this, A, t)), n = o; return o.__button = document.createElement("div"), o.__button.innerHTML = void 0 === i ? "Fire" : i, fm.bind(o.__button, "click", (function (A) { return A.preventDefault(), n.fire(), !1 })), fm.addClass(o.__button, "button"), o.domElement.appendChild(o.__button), o } return am(e, A), nm(e, [{ key: "fire", value: function () { this.__onChange && this.__onChange.call(this), this.getValue().call(this.object), this.__onFinishChange && this.__onFinishChange.call(this, this.getValue()) } }]), e }(dm), wm = function (A) { function e(A, t) { om(this, e); var i = sm(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this, A, t)); i.__color = new lm(i.getValue()), i.__temp = new lm(0); var o = i; i.domElement = document.createElement("div"), fm.makeSelectable(i.domElement, !1), i.__selector = document.createElement("div"), i.__selector.className = "selector", i.__saturation_field = document.createElement("div"), i.__saturation_field.className = "saturation-field", i.__field_knob = document.createElement("div"), i.__field_knob.className = "field-knob", i.__field_knob_border = "2px solid ", i.__hue_knob = document.createElement("div"), i.__hue_knob.className = "hue-knob", i.__hue_field = document.createElement("div"), i.__hue_field.className = "hue-field", i.__input = document.createElement("input"), i.__input.type = "text", i.__input_textShadow = "0 1px 1px ", fm.bind(i.__input, "keydown", (function (A) { 13 === A.keyCode && h.call(this) })), fm.bind(i.__input, "blur", h), fm.bind(i.__selector, "mousedown", (function () { fm.addClass(this, "drag").bind(window, "mouseup", (function () { fm.removeClass(o.__selector, "drag") })) })), fm.bind(i.__selector, "touchstart", (function () { fm.addClass(this, "drag").bind(window, "touchend", (function () { fm.removeClass(o.__selector, "drag") })) })); var n, r = document.createElement("div"); function a(A) { p(A), fm.bind(window, "mousemove", p), fm.bind(window, "touchmove", p), fm.bind(window, "mouseup", l), fm.bind(window, "touchend", l) } function s(A) { g(A), fm.bind(window, "mousemove", g), fm.bind(window, "touchmove", g), fm.bind(window, "mouseup", c), fm.bind(window, "touchend", c) } function l() { fm.unbind(window, "mousemove", p), fm.unbind(window, "touchmove", p), fm.unbind(window, "mouseup", l), fm.unbind(window, "touchend", l), d() } function c() { fm.unbind(window, "mousemove", g), fm.unbind(window, "touchmove", g), fm.unbind(window, "mouseup", c), fm.unbind(window, "touchend", c), d() } function h() { var A = Am(this.value); !1 !== A ? (o.__color.__state = A, o.setValue(o.__color.toOriginal())) : this.value = o.__color.toString() } function d() { o.__onFinishChange && o.__onFinishChange.call(o, o.__color.toOriginal()) } function p(A) { -1 === A.type.indexOf("touch") && A.preventDefault(); var e = o.__saturation_field.getBoundingClientRect(), t = A.touches && A.touches[0] || A, i = (t.clientX - e.left) / (e.right - e.left), n = 1 - (t.clientY - e.top) / (e.bottom - e.top); return n > 1 ? n = 1 : 0 > n && (n = 0), i > 1 ? i = 1 : 0 > i && (i = 0), o.__color.v = n, o.__color.s = i, o.setValue(o.__color.toOriginal()), !1 } function g(A) { -1 === A.type.indexOf("touch") && A.preventDefault(); var e = o.__hue_field.getBoundingClientRect(), t = 1 - ((A.touches && A.touches[0] || A).clientY - e.top) / (e.bottom - e.top); return t > 1 ? t = 1 : 0 > t && (t = 0), o.__color.h = 360 * t, o.setValue(o.__color.toOriginal()), !1 } return Zf.extend(i.__selector.style, { width: "122px", height: "102px", padding: "3px", backgroundColor: "#222", boxShadow: "0px 1px 3px rgba(0,0,0,0.3)" }), Zf.extend(i.__field_knob.style, { position: "absolute", width: "12px", height: "12px", border: i.__field_knob_border + (.5 > i.__color.v ? "#fff" : "#000"), boxShadow: "0px 1px 3px rgba(0,0,0,0.5)", borderRadius: "12px", zIndex: 1 }), Zf.extend(i.__hue_knob.style, { position: "absolute", width: "15px", height: "2px", borderRight: "4px solid #fff", zIndex: 1 }), Zf.extend(i.__saturation_field.style, { width: "100px", height: "100px", border: "1px solid #555", marginRight: "3px", display: "inline-block", cursor: "pointer" }), Zf.extend(r.style, { width: "100%", height: "100%", background: "none" }), bm(r, "top", "rgba(0,0,0,0)", "#000"), Zf.extend(i.__hue_field.style, { width: "15px", height: "100px", border: "1px solid #555", cursor: "ns-resize", position: "absolute", top: "3px", right: "3px" }), (n = i.__hue_field).style.background = "", n.style.cssText += "background: -moz-linear-gradient(top, #ff0000 0%, #ff00ff 17%, #0000ff 34%, #00ffff 50%, #00ff00 67%, #ffff00 84%, #ff0000 100%);", n.style.cssText += "background: -webkit-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);", n.style.cssText += "background: -o-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);", n.style.cssText += "background: -ms-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);", n.style.cssText += "background: linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);", Zf.extend(i.__input.style, { outline: "none", textAlign: "center", color: "#fff", border: 0, fontWeight: "bold", textShadow: i.__input_textShadow + "rgba(0,0,0,0.7)" }), fm.bind(i.__saturation_field, "mousedown", a), fm.bind(i.__saturation_field, "touchstart", a), fm.bind(i.__field_knob, "mousedown", a), fm.bind(i.__field_knob, "touchstart", a), fm.bind(i.__hue_field, "mousedown", s), fm.bind(i.__hue_field, "touchstart", s), i.__saturation_field.appendChild(r), i.__selector.appendChild(i.__field_knob), i.__selector.appendChild(i.__saturation_field), i.__selector.appendChild(i.__hue_field), i.__hue_field.appendChild(i.__hue_knob), i.domElement.appendChild(i.__input), i.domElement.appendChild(i.__selector), i.updateDisplay(), i } return am(e, A), nm(e, [{ key: "updateDisplay", value: function () { var A = Am(this.getValue()); if (!1 !== A) { var e = !1; Zf.each(lm.COMPONENTS, (function (t) { if (!Zf.isUndefined(A[t]) && !Zf.isUndefined(this.__color.__state[t]) && A[t] !== this.__color.__state[t]) return e = !0, {} }), this), e && Zf.extend(this.__color.__state, A) } Zf.extend(this.__temp.__state, this.__color.__state), this.__temp.a = 1; var t = .5 > this.__color.v || this.__color.s > .5 ? 255 : 0, i = 255 - t; Zf.extend(this.__field_knob.style, { marginLeft: 100 * this.__color.s - 7 + "px", marginTop: 100 * (1 - this.__color.v) - 7 + "px", backgroundColor: this.__temp.toHexString(), border: this.__field_knob_border + "rgb(" + t + "," + t + "," + t + ")" }), this.__hue_knob.style.marginTop = 100 * (1 - this.__color.h / 360) + "px", this.__temp.s = 1, this.__temp.v = 1, bm(this.__saturation_field, "left", "#fff", this.__temp.toHexString()), this.__input.value = this.__color.toString(), Zf.extend(this.__input.style, { backgroundColor: this.__color.toHexString(), color: "rgb(" + t + "," + t + "," + t + ")", textShadow: this.__input_textShadow + "rgba(" + i + "," + i + "," + i + ",.7)" }) } }]), e }(dm), Mm = ["-moz-", "-o-", "-webkit-", "-ms-", ""]; function bm(A, e, t, i) { A.style.background = "", Zf.each(Mm, (function (o) { A.style.cssText += "background: " + o + "linear-gradient(" + e + ", " + t + " 0%, " + i + " 100%); " })) } var Um = function (A, e) { var t = e || document, i = document.createElement("style"); i.type = "text/css", i.innerHTML = A; var o = t.getElementsByTagName("head")[0]; try { o.appendChild(i) } catch (A) {} }, Fm = '
\n\n Here\'s the new load parameter for your GUI\'s constructor:\n\n \n\n
\n\n Automatically save\n values to localStorage on exit.\n\n
The values saved to localStorage will\n override those passed to dat.GUI\'s constructor. This makes it\n easier to work incrementally, but localStorage is fragile,\n and your friends may not see the same values you do.\n\n
\n\n
\n\n
', Km = function (A, e) { var t = A[e]; return Zf.isArray(arguments[2]) || Zf.isObject(arguments[2]) ? new Cm(A, e, arguments[2]) : Zf.isNumber(t) ? Zf.isNumber(arguments[2]) && Zf.isNumber(arguments[3]) ? Zf.isNumber(arguments[4]) ? new xm(A, e, arguments[2], arguments[3], arguments[4]) : new xm(A, e, arguments[2], arguments[3]) : Zf.isNumber(arguments[4]) ? new Em(A, e, { min: arguments[2], max: arguments[3], step: arguments[4] }) : new Em(A, e, { min: arguments[2], max: arguments[3] }) : Zf.isString(t) ? new ym(A, e) : Zf.isFunction(t) ? new Sm(A, e, "") : Zf.isBoolean(t) ? new mm(A, e) : null }; var Qm = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function (A) { setTimeout(A, 1e3 / 60) }, Rm = function () { function A() { om(this, A), this.backgroundElement = document.createElement("div"), Zf.extend(this.backgroundElement.style, { backgroundColor: "rgba(0,0,0,0.8)", top: 0, left: 0, display: "none", zIndex: "1000", opacity: 0, WebkitTransition: "opacity 0.2s linear", transition: "opacity 0.2s linear" }), fm.makeFullscreen(this.backgroundElement), this.backgroundElement.style.position = "fixed", this.domElement = document.createElement("div"), Zf.extend(this.domElement.style, { position: "fixed", display: "none", zIndex: "1001", opacity: 0, WebkitTransition: "-webkit-transform 0.2s ease-out, opacity 0.2s linear", transition: "transform 0.2s ease-out, opacity 0.2s linear" }), document.body.appendChild(this.backgroundElement), document.body.appendChild(this.domElement); var e = this; fm.bind(this.backgroundElement, "click", (function () { e.hide() })) } return nm(A, [{ key: "show", value: function () { var A = this; this.backgroundElement.style.display = "block", this.domElement.style.display = "block", this.domElement.style.opacity = 0, this.domElement.style.webkitTransform = "scale(1.1)", this.layout(), Zf.defer((function () { A.backgroundElement.style.opacity = 1, A.domElement.style.opacity = 1, A.domElement.style.webkitTransform = "scale(1)" })) } }, { key: "hide", value: function () { var A = this, e = function e() { A.domElement.style.display = "none", A.backgroundElement.style.display = "none", fm.unbind(A.domElement, "webkitTransitionEnd", e), fm.unbind(A.domElement, "transitionend", e), fm.unbind(A.domElement, "oTransitionEnd", e) }; fm.bind(this.domElement, "webkitTransitionEnd", e), fm.bind(this.domElement, "transitionend", e), fm.bind(this.domElement, "oTransitionEnd", e), this.backgroundElement.style.opacity = 0, this.domElement.style.opacity = 0, this.domElement.style.webkitTransform = "scale(1.1)" } }, { key: "layout", value: function () { this.domElement.style.left = window.innerWidth / 2 - fm.getWidth(this.domElement) / 2 + "px", this.domElement.style.top = window.innerHeight / 2 - fm.getHeight(this.domElement) / 2 + "px" } }]), A }(); Um(function (A) { if (A && "undefined" != typeof window) { var e = document.createElement("style"); return e.setAttribute("type", "text/css"), e.innerHTML = A, document.head.appendChild(e), A } }(".dg ul{list-style:none;margin:0;padding:0;width:100%;clear:both}.dg.ac{position:fixed;top:0;left:0;right:0;height:0;z-index:0}.dg:not(.ac) .main{overflow:hidden}.dg.main{-webkit-transition:opacity .1s linear;-o-transition:opacity .1s linear;-moz-transition:opacity .1s linear;transition:opacity .1s linear}.dg.main.taller-than-window{overflow-y:auto}.dg.main.taller-than-window .close-button{opacity:1;margin-top:-1px;border-top:1px solid #2c2c2c}.dg.main ul.closed .close-button{opacity:1 !important}.dg.main:hover .close-button,.dg.main .close-button.drag{opacity:1}.dg.main .close-button{-webkit-transition:opacity .1s linear;-o-transition:opacity .1s linear;-moz-transition:opacity .1s linear;transition:opacity .1s linear;border:0;line-height:19px;height:20px;cursor:pointer;text-align:center;background-color:#000}.dg.main .close-button.close-top{position:relative}.dg.main .close-button.close-bottom{position:absolute}.dg.main .close-button:hover{background-color:#111}.dg.a{float:right;margin-right:15px;overflow-y:visible}.dg.a.has-save>ul.close-top{margin-top:0}.dg.a.has-save>ul.close-bottom{margin-top:27px}.dg.a.has-save>ul.closed{margin-top:0}.dg.a .save-row{top:0;z-index:1002}.dg.a .save-row.close-top{position:relative}.dg.a .save-row.close-bottom{position:fixed}.dg li{-webkit-transition:height .1s ease-out;-o-transition:height .1s ease-out;-moz-transition:height .1s ease-out;transition:height .1s ease-out;-webkit-transition:overflow .1s linear;-o-transition:overflow .1s linear;-moz-transition:overflow .1s linear;transition:overflow .1s linear}.dg li:not(.folder){cursor:auto;height:27px;line-height:27px;padding:0 4px 0 5px}.dg li.folder{padding:0;border-left:4px solid rgba(0,0,0,0)}.dg li.title{cursor:pointer;margin-left:-4px}.dg .closed li:not(.title),.dg .closed ul li,.dg .closed ul li>*{height:0;overflow:hidden;border:0}.dg .cr{clear:both;padding-left:3px;height:27px;overflow:hidden}.dg .property-name{cursor:default;float:left;clear:left;width:40%;overflow:hidden;text-overflow:ellipsis}.dg .c{float:left;width:60%;position:relative}.dg .c input[type=text]{border:0;margin-top:4px;padding:3px;width:100%;float:right}.dg .has-slider input[type=text]{width:30%;margin-left:0}.dg .slider{float:left;width:66%;margin-left:-5px;margin-right:0;height:19px;margin-top:4px}.dg .slider-fg{height:100%}.dg .c input[type=checkbox]{margin-top:7px}.dg .c select{margin-top:5px}.dg .cr.function,.dg .cr.function .property-name,.dg .cr.function *,.dg .cr.boolean,.dg .cr.boolean *{cursor:pointer}.dg .cr.color{overflow:visible}.dg .selector{display:none;position:absolute;margin-left:-9px;margin-top:23px;z-index:10}.dg .c:hover .selector,.dg .selector.drag{display:block}.dg li.save-row{padding:0}.dg li.save-row .button{display:inline-block;padding:0px 6px}.dg.dialogue{background-color:#222;width:460px;padding:15px;font-size:13px;line-height:15px}#dg-new-constructor{padding:10px;color:#222;font-family:Monaco, monospace;font-size:10px;border:0;resize:none;box-shadow:inset 1px 1px 1px #888;word-wrap:break-word;margin:12px 0;display:block;width:440px;overflow-y:scroll;height:100px;position:relative}#dg-local-explain{display:none;font-size:11px;line-height:17px;border-radius:3px;background-color:#333;padding:8px;margin-top:10px}#dg-local-explain code{font-size:10px}#dat-gui-save-locally{display:none}.dg{color:#eee;font:11px 'Lucida Grande', sans-serif;text-shadow:0 -1px 0 #111}.dg.main::-webkit-scrollbar{width:5px;background:#1a1a1a}.dg.main::-webkit-scrollbar-corner{height:0;display:none}.dg.main::-webkit-scrollbar-thumb{border-radius:5px;background:#676767}.dg li:not(.folder){background:#1a1a1a;border-bottom:1px solid #2c2c2c}.dg li.save-row{line-height:25px;background:#dad5cb;border:0}.dg li.save-row select{margin-left:5px;width:108px}.dg li.save-row .button{margin-left:5px;margin-top:1px;border-radius:2px;font-size:9px;line-height:7px;padding:4px 4px 5px 4px;background:#c5bdad;color:#fff;text-shadow:0 1px 0 #b0a58f;box-shadow:0 -1px 0 #b0a58f;cursor:pointer}.dg li.save-row .button.gears{background:#c5bdad url() 2px 1px no-repeat;height:7px;width:8px}.dg li.save-row .button:hover{background-color:#bab19e;box-shadow:0 -1px 0 #b0a58f}.dg li.folder{border-bottom:0}.dg li.title{padding-left:16px;background:#000 url() 6px 10px no-repeat;cursor:pointer;border-bottom:1px solid rgba(255,255,255,0.2)}.dg .closed li.title{background-image:url()}.dg .cr.boolean{border-left:3px solid #806787}.dg .cr.color{border-left:3px solid}.dg .cr.function{border-left:3px solid #e61d5f}.dg .cr.number{border-left:3px solid #2FA1D6}.dg .cr.number input[type=text]{color:#2FA1D6}.dg .cr.string{border-left:3px solid #1ed36f}.dg .cr.string input[type=text]{color:#1ed36f}.dg .cr.function:hover,.dg .cr.boolean:hover{background:#111}.dg .c input[type=text]{background:#303030;outline:none}.dg .c input[type=text]:hover{background:#3c3c3c}.dg .c input[type=text]:focus{background:#494949;color:#fff}.dg .c .slider{background:#303030;cursor:ew-resize}.dg .c .slider-fg{background:#2FA1D6;max-width:100%}.dg .c .slider:hover{background:#3c3c3c}.dg .c .slider:hover .slider-fg{background:#44abda}\n")); var Tm = function () { try { return !!window.localStorage } catch (A) { return !1 } }(), km = void 0, Dm = !0, Lm = void 0, Nm = !1, Om = [], Vm = function A(e) { var t = this, i = e || {}; this.domElement = document.createElement("div"), this.__ul = document.createElement("ul"), this.domElement.appendChild(this.__ul), fm.addClass(this.domElement, "dg"), this.__folders = {}, this.__controllers = [], this.__rememberedObjects = [], this.__rememberedObjectIndecesToControllers = [], this.__listening = [], i = Zf.defaults(i, { closeOnTop: !1, autoPlace: !0, width: A.DEFAULT_WIDTH }), i = Zf.defaults(i, { resizable: i.autoPlace, hideable: i.autoPlace }), Zf.isUndefined(i.load) ? i.load = { preset: "Default" } : i.preset && (i.load.preset = i.preset), Zf.isUndefined(i.parent) && i.hideable && Om.push(this), i.resizable = Zf.isUndefined(i.parent) && i.resizable, i.autoPlace && Zf.isUndefined(i.scrollable) && (i.scrollable = !0); var o = Tm && "true" === localStorage.getItem(Ym(this, "isLocal")), n = void 0, r = void 0; if (Object.defineProperties(this, { parent: { get: function () { return i.parent } }, scrollable: { get: function () { return i.scrollable } }, autoPlace: { get: function () { return i.autoPlace } }, closeOnTop: { get: function () { return i.closeOnTop } }, preset: { get: function () { return t.parent ? t.getRoot().preset : i.load.preset }, set: function (A) { t.parent ? t.getRoot().preset = A : i.load.preset = A, function (A) { for (var e = 0; A.__preset_select.length > e; e++) A.__preset_select[e].value === A.preset && (A.__preset_select.selectedIndex = e) }(this), t.revert() } }, width: { get: function () { return i.width }, set: function (A) { i.width = A, Xm(t, A) } }, name: { get: function () { return i.name }, set: function (A) { i.name = A, r && (r.innerHTML = i.name) } }, closed: { get: function () { return i.closed }, set: function (e) { i.closed = e, i.closed ? fm.addClass(t.__ul, A.CLASS_CLOSED) : fm.removeClass(t.__ul, A.CLASS_CLOSED), this.onResize(), t.__closeButton && (t.__closeButton.innerHTML = e ? A.TEXT_OPEN : A.TEXT_CLOSED) } }, load: { get: function () { return i.load } }, useLocalStorage: { get: function () { return o }, set: function (A) { Tm && (o = A, A ? fm.bind(window, "unload", n) : fm.unbind(window, "unload", n), localStorage.setItem(Ym(t, "isLocal"), A)) } } }), Zf.isUndefined(i.parent)) { if (this.closed = i.closed || !1, fm.addClass(this.domElement, A.CLASS_MAIN), fm.makeSelectable(this.domElement, !1), Tm && o) { t.useLocalStorage = !0; var a = localStorage.getItem(Ym(this, "gui")); a && (i.load = JSON.parse(a)) } this.__closeButton = document.createElement("div"), this.__closeButton.innerHTML = A.TEXT_CLOSED, fm.addClass(this.__closeButton, A.CLASS_CLOSE_BUTTON), i.closeOnTop ? (fm.addClass(this.__closeButton, A.CLASS_CLOSE_TOP), this.domElement.insertBefore(this.__closeButton, this.domElement.childNodes[0])) : (fm.addClass(this.__closeButton, A.CLASS_CLOSE_BOTTOM), this.domElement.appendChild(this.__closeButton)), fm.bind(this.__closeButton, "click", (function () { t.closed = !t.closed })) } else { void 0 === i.closed && (i.closed = !0); var s = document.createTextNode(i.name); fm.addClass(s, "controller-name"), r = Gm(t, s); fm.addClass(this.__ul, A.CLASS_CLOSED), fm.addClass(r, "title"), fm.bind(r, "click", (function (A) { return A.preventDefault(), t.closed = !t.closed, !1 })), i.closed || (this.closed = !1) } i.autoPlace && (Zf.isUndefined(i.parent) && (Dm && (Lm = document.createElement("div"), fm.addClass(Lm, "dg"), fm.addClass(Lm, A.CLASS_AUTO_PLACE_CONTAINER), document.body.appendChild(Lm), Dm = !1), Lm.appendChild(this.domElement), fm.addClass(this.domElement, A.CLASS_AUTO_PLACE)), this.parent || Xm(t, i.width)), this.__resizeHandler = function () { t.onResizeDebounced() }, fm.bind(window, "resize", this.__resizeHandler), fm.bind(this.__ul, "webkitTransitionEnd", this.__resizeHandler), fm.bind(this.__ul, "transitionend", this.__resizeHandler), fm.bind(this.__ul, "oTransitionEnd", this.__resizeHandler), this.onResize(), i.resizable && Zm(this), this.saveToLocalStorageIfPossible = n = function () { Tm && "true" === localStorage.getItem(Ym(t, "isLocal")) && localStorage.setItem(Ym(t, "gui"), JSON.stringify(t.getSaveObject())) }, i.parent || function () { var A = t.getRoot(); A.width += 1, Zf.defer((function () { A.width -= 1 })) }() }; function Gm(A, e, t) { var i = document.createElement("li"); return e && i.appendChild(e), t ? A.__ul.insertBefore(i, t) : A.__ul.appendChild(i), A.onResize(), i } function Pm(A) { fm.unbind(window, "resize", A.__resizeHandler), A.saveToLocalStorageIfPossible && fm.unbind(window, "unload", A.saveToLocalStorageIfPossible) } function qm(A, e) { var t = A.__preset_select[A.__preset_select.selectedIndex]; t.innerHTML = e ? t.value + "*" : t.value } function jm(A, e) { var t = A.getRoot(), i = t.__rememberedObjects.indexOf(e.object); if (-1 !== i) { var o = t.__rememberedObjectIndecesToControllers[i]; if (void 0 === o && (t.__rememberedObjectIndecesToControllers[i] = o = {}), o[e.property] = e, t.load && t.load.remembered) { var n = t.load.remembered, r = void 0; if (n[A.preset]) r = n[A.preset]; else { if (!n.Default) return; r = n.Default } if (r[i] && void 0 !== r[i][e.property]) { var a = r[i][e.property]; e.initialValue = a, e.setValue(a) } } } } function Hm(A, e, t, i) { if (void 0 === e[t]) throw new Error('Object "' + e + '" has no property "' + t + '"'); var o = void 0; if (i.color) o = new wm(e, t); else { var n = [e, t].concat(i.factoryArgs); o = Km.apply(A, n) } i.before instanceof dm && (i.before = i.before.__li), jm(A, o), fm.addClass(o.domElement, "c"); var r = document.createElement("span"); fm.addClass(r, "property-name"), r.innerHTML = o.property; var a = document.createElement("div"); a.appendChild(r), a.appendChild(o.domElement); var s = Gm(A, a, i.before); return fm.addClass(s, Vm.CLASS_CONTROLLER_ROW), fm.addClass(s, o instanceof wm ? "color" : im(o.getValue())), function (A, e, t) { if (t.__li = e, t.__gui = A, Zf.extend(t, { options: function (e) { if (arguments.length > 1) { var i = t.__li.nextElementSibling; return t.remove(), Hm(A, t.object, t.property, { before: i, factoryArgs: [Zf.toArray(arguments)] }) } if (Zf.isArray(e) || Zf.isObject(e)) { var o = t.__li.nextElementSibling; return t.remove(), Hm(A, t.object, t.property, { before: o, factoryArgs: [e] }) } }, name: function (A) { return t.__li.firstElementChild.firstElementChild.innerHTML = A, t }, listen: function () { return t.__gui.listen(t), t }, remove: function () { return t.__gui.remove(t), t } }), t instanceof xm) { var i = new Em(t.object, t.property, { min: t.__min, max: t.__max, step: t.__step }); Zf.each(["updateDisplay", "onChange", "onFinishChange", "step", "min", "max"], (function (A) { var e = t[A], o = i[A]; t[A] = i[A] = function () { var A = Array.prototype.slice.call(arguments); return o.apply(i, A), e.apply(t, A) } })), fm.addClass(e, "has-slider"), t.domElement.insertBefore(i.domElement, t.domElement.firstElementChild) } else if (t instanceof Em) { var o = function (e) { if (Zf.isNumber(t.__min) && Zf.isNumber(t.__max)) { var i = t.__li.firstElementChild.firstElementChild.innerHTML, o = t.__gui.__listening.indexOf(t) > -1; t.remove(); var n = Hm(A, t.object, t.property, { before: t.__li.nextElementSibling, factoryArgs: [t.__min, t.__max, t.__step] }); return n.name(i), o && n.listen(), n } return e }; t.min = Zf.compose(o, t.min), t.max = Zf.compose(o, t.max) } else t instanceof mm ? (fm.bind(e, "click", (function () { fm.fakeEvent(t.__checkbox, "click") })), fm.bind(t.__checkbox, "click", (function (A) { A.stopPropagation() }))) : t instanceof Sm ? (fm.bind(e, "click", (function () { fm.fakeEvent(t.__button, "click") })), fm.bind(e, "mouseover", (function () { fm.addClass(t.__button, "hover") })), fm.bind(e, "mouseout", (function () { fm.removeClass(t.__button, "hover") }))) : t instanceof wm && (fm.addClass(e, "color"), t.updateDisplay = Zf.compose((function (A) { return e.style.borderLeftColor = t.__color.toString(), A }), t.updateDisplay), t.updateDisplay()); t.setValue = Zf.compose((function (e) { return A.getRoot().__preset_select && t.isModified() && qm(A.getRoot(), !0), e }), t.setValue) }(A, s, o), A.__controllers.push(o), o } function Ym(A, e) { return document.location.href + "." + e } function Wm(A, e, t) { var i = document.createElement("option"); i.innerHTML = e, i.value = e, A.__preset_select.appendChild(i), t && (A.__preset_select.selectedIndex = A.__preset_select.length - 1) } function Jm(A, e) { e.style.display = A.useLocalStorage ? "block" : "none" } function zm(A) { var e = A.__save_row = document.createElement("li"); fm.addClass(A.domElement, "has-save"), A.__ul.insertBefore(e, A.__ul.firstChild), fm.addClass(e, "save-row"); var t = document.createElement("span"); t.innerHTML = " ", fm.addClass(t, "button gears"); var i = document.createElement("span"); i.innerHTML = "Save", fm.addClass(i, "button"), fm.addClass(i, "save"); var o = document.createElement("span"); o.innerHTML = "New", fm.addClass(o, "button"), fm.addClass(o, "save-as"); var n = document.createElement("span"); n.innerHTML = "Revert", fm.addClass(n, "button"), fm.addClass(n, "revert"); var r = A.__preset_select = document.createElement("select"); if (A.load && A.load.remembered ? Zf.each(A.load.remembered, (function (e, t) { Wm(A, t, t === A.preset) })) : Wm(A, "Default", !1), fm.bind(r, "change", (function () { for (var e = 0; A.__preset_select.length > e; e++) A.__preset_select[e].innerHTML = A.__preset_select[e].value; A.preset = this.value })), e.appendChild(r), e.appendChild(t), e.appendChild(i), e.appendChild(o), e.appendChild(n), Tm) { var a = document.getElementById("dg-local-explain"), s = document.getElementById("dg-local-storage"); document.getElementById("dg-save-locally").style.display = "block", "true" === localStorage.getItem(Ym(0, "isLocal")) && s.setAttribute("checked", "checked"), Jm(A, a), fm.bind(s, "change", (function () { A.useLocalStorage = !A.useLocalStorage, Jm(A, a) })) } var l = document.getElementById("dg-new-constructor"); fm.bind(l, "keydown", (function (A) { !A.metaKey || 67 !== A.which && 67 !== A.keyCode || km.hide() })), fm.bind(t, "click", (function () { l.innerHTML = JSON.stringify(A.getSaveObject(), void 0, 2), km.show(), l.focus(), l.select() })), fm.bind(i, "click", (function () { A.save() })), fm.bind(o, "click", (function () { var e = prompt("Enter a new preset name."); e && A.saveAs(e) })), fm.bind(n, "click", (function () { A.revert() })) } function Zm(A) { var e = void 0; function t(t) { return t.preventDefault(), A.width += e - t.clientX, A.onResize(), e = t.clientX, !1 } function i() { fm.removeClass(A.__closeButton, Vm.CLASS_DRAG), fm.unbind(window, "mousemove", t), fm.unbind(window, "mouseup", i) } function o(o) { return o.preventDefault(), e = o.clientX, fm.addClass(A.__closeButton, Vm.CLASS_DRAG), fm.bind(window, "mousemove", t), fm.bind(window, "mouseup", i), !1 } A.__resize_handle = document.createElement("div"), Zf.extend(A.__resize_handle.style, { width: "6px", marginLeft: "-3px", height: "200px", cursor: "ew-resize", position: "absolute" }), fm.bind(A.__resize_handle, "mousedown", o), fm.bind(A.__closeButton, "mousedown", o), A.domElement.insertBefore(A.__resize_handle, A.domElement.firstElementChild) } function Xm(A, e) { A.domElement.style.width = e + "px", A.__save_row && A.autoPlace && (A.__save_row.style.width = e + "px"), A.__closeButton && (A.__closeButton.style.width = e + "px") } function _m(A, e) { var t = {}; return Zf.each(A.__rememberedObjects, (function (i, o) { var n = {}; Zf.each(A.__rememberedObjectIndecesToControllers[o], (function (A, t) { n[t] = e ? A.initialValue : A.getValue() })), t[o] = n })), t } Vm.toggleHide = function () { Nm = !Nm, Zf.each(Om, (function (A) { A.domElement.style.display = Nm ? "none" : "" })) }, Vm.CLASS_AUTO_PLACE = "a", Vm.CLASS_AUTO_PLACE_CONTAINER = "ac", Vm.CLASS_MAIN = "main", Vm.CLASS_CONTROLLER_ROW = "cr", Vm.CLASS_TOO_TALL = "taller-than-window", Vm.CLASS_CLOSED = "closed", Vm.CLASS_CLOSE_BUTTON = "close-button", Vm.CLASS_CLOSE_TOP = "close-top", Vm.CLASS_CLOSE_BOTTOM = "close-bottom", Vm.CLASS_DRAG = "drag", Vm.DEFAULT_WIDTH = 245, Vm.TEXT_CLOSED = "关闭控制器", Vm.TEXT_OPEN = "打开控制器", Vm._keydownHandler = function (A) { "text" === document.activeElement.type || 72 !== A.which && 72 !== A.keyCode || Vm.toggleHide() }, fm.bind(window, "keydown", Vm._keydownHandler, !1), Zf.extend(Vm.prototype, { add: function (A, e) { return Hm(this, A, e, { factoryArgs: Array.prototype.slice.call(arguments, 2) }) }, addColor: function (A, e) { return Hm(this, A, e, { color: !0 }) }, remove: function (A) { this.__ul.removeChild(A.__li), this.__controllers.splice(this.__controllers.indexOf(A), 1); var e = this; Zf.defer((function () { e.onResize() })) }, destroy: function () { if (this.parent) throw new Error("Only the root GUI should be removed with .destroy(). For subfolders, use gui.removeFolder(folder) instead."); this.autoPlace && Lm.removeChild(this.domElement); var A = this; Zf.each(this.__folders, (function (e) { A.removeFolder(e) })), fm.unbind(window, "keydown", Vm._keydownHandler, !1), Pm(this) }, addFolder: function (A) { if (void 0 !== this.__folders[A]) throw new Error('You already have a folder in this GUI by the name "' + A + '"'); var e = { name: A, parent: this }; e.autoPlace = this.autoPlace, this.load && this.load.folders && this.load.folders[A] && (e.closed = this.load.folders[A].closed, e.load = this.load.folders[A]); var t = new Vm(e); this.__folders[A] = t; var i = Gm(this, t.domElement); return fm.addClass(i, "folder"), t }, removeFolder: function (A) { this.__ul.removeChild(A.domElement.parentElement), delete this.__folders[A.name], this.load && this.load.folders && this.load.folders[A.name] && delete this.load.folders[A.name], Pm(A); var e = this; Zf.each(A.__folders, (function (e) { A.removeFolder(e) })), Zf.defer((function () { e.onResize() })) }, open: function () { this.closed = !1 }, close: function () { this.closed = !0 }, hide: function () { this.domElement.style.display = "none" }, show: function () { this.domElement.style.display = "" }, onResize: function () { var A = this.getRoot(); if (A.scrollable) { var e = fm.getOffset(A.__ul).top, t = 0; Zf.each(A.__ul.childNodes, (function (e) { A.autoPlace && e === A.__save_row || (t += fm.getHeight(e)) })), window.innerHeight - e - 20 < t ? (fm.addClass(A.domElement, Vm.CLASS_TOO_TALL), A.__ul.style.height = window.innerHeight - e - 20 + "px") : (fm.removeClass(A.domElement, Vm.CLASS_TOO_TALL), A.__ul.style.height = "auto") } A.__resize_handle && Zf.defer((function () { A.__resize_handle.style.height = A.__ul.offsetHeight + "px" })), A.__closeButton && (A.__closeButton.style.width = A.width + "px") }, onResizeDebounced: Zf.debounce((function () { this.onResize() }), 50), remember: function () { if (Zf.isUndefined(km) && ((km = new Rm).domElement.innerHTML = Fm), this.parent) throw new Error("You can only call remember on a top level GUI."); var A = this; Zf.each(Array.prototype.slice.call(arguments), (function (e) { 0 === A.__rememberedObjects.length && zm(A), -1 === A.__rememberedObjects.indexOf(e) && A.__rememberedObjects.push(e) })), this.autoPlace && Xm(this, this.width) }, getRoot: function () { for (var A = this; A.parent;) A = A.parent; return A }, getSaveObject: function () { var A = this.load; return A.closed = this.closed, this.__rememberedObjects.length > 0 && (A.preset = this.preset, A.remembered || (A.remembered = {}), A.remembered[this.preset] = _m(this)), A.folders = {}, Zf.each(this.__folders, (function (e, t) { A.folders[t] = e.getSaveObject() })), A }, save: function () { this.load.remembered || (this.load.remembered = {}), this.load.remembered[this.preset] = _m(this), qm(this, !1), this.saveToLocalStorageIfPossible() }, saveAs: function (A) { this.load.remembered || (this.load.remembered = {}, this.load.remembered.Default = _m(this, !0)), this.load.remembered[A] = _m(this), this.preset = A, Wm(this, A, !0), this.saveToLocalStorageIfPossible() }, revert: function (A) { Zf.each(this.__controllers, (function (e) { this.getRoot().load.remembered ? jm(A || this.getRoot(), e) : e.setValue(e.initialValue), e.__onFinishChange && e.__onFinishChange.call(e, e.getValue()) }), this), Zf.each(this.__folders, (function (A) { A.revert(A) })), A || qm(this.getRoot(), !1) }, listen: function (A) { var e = 0 === this.__listening.length; this.__listening.push(A), e && function A(e) { 0 !== e.length && Qm.call(window, (function () { A(e) })); Zf.each(e, (function (A) { A.updateDisplay() })) }(this.__listening) }, updateDisplay: function () { Zf.each(this.__controllers, (function (A) { A.updateDisplay() })), Zf.each(this.__folders, (function (A) { A.updateDisplay() })) } }); var $m = Vm, AC = function (A) { var e = this; this.indexedDB = window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB; window.IDBKeyRange || window; var t = uh.extend({}, { dbName: "bos3d", store: "default", version: 1, indexes: ["id"], keyPath: "id" }, A); this.IDBOpenDBRequest = null, this.dbName = t.dbName; var i = this.version = t.version; this.storeName = t.store; var o = t.keyPath, n = this.indexedDB.open(this.dbName, i); n.onupgradeneeded = function (A) { Bh.log("DB version changed to " + i); var n = A.target.result, r = null; if (!1 === n.objectStoreNames.contains(e.storeName)) { r = n.createObjectStore(e.storeName, { keyPath: o }); for (var a = 0; t.indexes.length > a; a += 1) { var s = t.indexes[a]; r.createIndex(s, s, { unique: !1 }) } } }, n.onsuccess = function (A) { e.IDBOpenDBRequest = A.target.result, Bh.log("成功建立并打开数据库:" + e.IDBOpenDBRequest.name + " version " + i), e.dispatchEvent({ type: Rc.ON_DATABASE_OPEN }) }, n.onerror = function (A) { Bh.error("IndexedDB", A), e.dispatchEvent({ type: Rc.ON_DATABASE_EEEOR }) }, n.onblocked = function (A) { Bh.warn("Please close all other tabs with this site open!", A) } }; Object.assign(AC.prototype, Ld.prototype), Object.assign(AC.prototype, { constructor: AC, get: function (A, e, t) { if (this.IDBOpenDBRequest) { var i = this.IDBOpenDBRequest.transaction([this.storeName]).objectStore(this.storeName).get(A); i.onsuccess = function (A) { "function" == typeof e && e(A.target.result ? A.target.result.data : null) }, i.onerror = function (A) { Bh.error("getDataByKey error"), "function" == typeof t && t(A) } } }, getBatch: function (A, e, t) { if (this.IDBOpenDBRequest) { for (var i = this.IDBOpenDBRequest.transaction([this.storeName]).objectStore(this.storeName), o = {}, n = [], r = 0; A.length > r; r += 1) n.push(new Promise((function (e, t) { var o = A[r], n = i.index("id").get(o); n.onsuccess = function (A) { e(A.target.result) }, n.onerror = function (A) { Bh.error(o, "failed", A), t(A) } }))); Promise.all(n).then((function (A) { for (var t = 0; A.length > t; t += 1) A[t] && (o[A[t].id] = A[t].data); e(o) })).catch((function (A) { Bh.debug(A), A instanceof TypeError ? Bh.error(A) : e(o) })) } }, setBatch: function (A, e, t) { if (this.IDBOpenDBRequest) for (var i = this.IDBOpenDBRequest.transaction([this.storeName], "readwrite").objectStore(this.storeName), o = 0; A.length > o; o += 1) { i.put({ id: A[o].key, data: A[o] }).onsuccess = function (A) {} } }, set: function (A, e, t, i) { var o = performance.now(); if (this.IDBOpenDBRequest) { var n = this.IDBOpenDBRequest.transaction([this.storeName], "readwrite").objectStore(this.storeName).add([{ id: A, data: e }]); n.onsuccess = function (A) { "function" == typeof t && t(A.target.result), Bh.debug("Saved state to IndexedDB. " + (performance.now() - o).toFixed(2) + "ms") }, n.onerror = function (A) { "function" == typeof i && i(A) } } }, put: function (A, e, t, i, o) { if (this.IDBOpenDBRequest) { var n = performance.now(), r = this.IDBOpenDBRequest.transaction([t], "readwrite").objectStore(t).put({ id: A, data: e }); r.onsuccess = function (A) { "function" == typeof i && i(A.target.result), Bh.debug("Saved state to IndexedDB. " + (performance.now() - n).toFixed(2) + "ms") }, r.onerror = function (A) { Bh.error("离线存储出错:", A.target.error.name, ":", A.target.error.message), "function" == typeof o && o(A) } } }, delete: function (A, e, t) { if (this.IDBOpenDBRequest) { var i = this.IDBOpenDBRequest.transaction(this.storeName, "readwrite").objectStore(this.storeName).delete(A); i.onsuccess = function (A) { Bh.debug("delete data form IndexedDB."), "function" == typeof e && e(A.target.result) }, i.onerror = function (A) { Bh.error("IndexedDB", A), "function" == typeof t && t(A) } } }, clear: function (A, e) { if (this.IDBOpenDBRequest) { var t = this.IDBOpenDBRequest.transaction(this.storeName, "readwrite").objectStore(this.storeName).clear(); t.onsuccess = function (e) { Bh.debug("Cleared IndexedDB."), "function" == typeof A && A(e.target.result) }, t.onerror = function (A) { Bh.error("IndexedDB", A), "function" == typeof e && e(A) } } }, deleteDatabase: function (A) { indexedDB.deleteDatabase(this.dbName), Bh.debug(this.dbName + "数据库已删除"), "function" == typeof A && A() }, close: function (A) { this.IDBOpenDBRequest && (this.IDBOpenDBRequest.close(), Bh.debug("数据库已关闭"), "function" == typeof A && A()) }, getIndex: function (A, e, t, i) { var o = A.transaction(e, "readwrite").objectStore(e).index("id"); o.openCursor().onsuccess = function () { var A = this.result; A && (Bh.debug(A.value), A.continue()) }; var n = IDBKeyRange.only(2), r = o.openCursor(n); r.onsuccess = function () { var A = r.result; A && Bh.info(A.value) } }, destroy: function () { this.close(), this.IDBOpenDBRequest = null, this.dbName = null, this.storeName = null } }); var eC = function (A) { this.serverUrl = A.serverUrl, this.modelKey = A.modelKey, this.dbName = A.dbName, this.offLine = A.offLine, this.shareParameter = "" !== A.share ? "&share=" + A.share : "" }; eC.prototype.projectUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/scene/scene.json" : this.serverUrl + "/api/" + this.dbName + "/models?modelKey=" + (A || this.modelKey) + this.shareParameter }, eC.prototype.sceneUrl = function (A) { return this.serverUrl + this.modelKey + "/scene/scene_" + (A = A || 0) + vc.ZipResourcePostfix }, eC.prototype.sceneIdUrl = function () { return this.serverUrl + this.modelKey + "/scene/scene_id" + vc.ZipResourcePostfix }, eC.prototype.userIdUrl = function () { return this.serverUrl + this.modelKey + "/scene/user_id" + vc.ZipResourcePostfix }, eC.prototype.octreeUrl = function (A) { return this.serverUrl + this.modelKey + "/scene/octree_" + A + vc.ZipResourcePostfix }, eC.prototype.symbolUrl = function () { return this.serverUrl + this.modelKey + "/symbol/symbol" + vc.ZipResourcePostfix }, eC.prototype.mpkUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/data/" + A : np(this.apiVersion, "1.6.0") ? this.serverUrl + "/data?fileKey=" + A : this.serverUrl + "/api/" + this.dbName + "/files?fileKey=" + A }, eC.prototype.texUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/data/Texture/" + A : np(this.apiVersion, "1.6.0") ? this.serverUrl + "/data?fileKey=" + A : this.serverUrl + "/api/" + this.dbName + "/files?fileKey=" + A }, eC.prototype.bonesUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/data/" + A : np(this.apiVersion, "1.6.0") ? this.serverUrl + "/data?fileKey=" + A : this.serverUrl + "/api/" + this.dbName + "/files?fileKey=" + A }, eC.prototype.nodesUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/data/" + A : np(this.apiVersion, "1.6.0") ? this.serverUrl + "/data?fileKey=" + A : this.serverUrl + "/api/" + this.dbName + "/files?fileKey=" + A }, eC.prototype.clipsUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/data/" + A : np(this.apiVersion, "1.6.0") ? this.serverUrl + "/data?fileKey=" + A : this.serverUrl + "/api/" + this.dbName + "/files?fileKey=" + A }, eC.prototype.kdTreeUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/data/" + A : np(this.apiVersion, "1.6.0") ? this.serverUrl + "/data?fileKey=" + A : this.serverUrl + "/api/" + this.dbName + "/files?fileKey=" + A }, eC.prototype.lightUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/data/" + A : np(this.apiVersion, "1.6.0") ? this.serverUrl + "/data?fileKey=" + A : this.serverUrl + "/api/" + this.dbName + "/files?fileKey=" + A }, eC.prototype.rootTilesUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/tileset.json" : this.serverUrl + "/api/" + this.dbName + "/geomodels/" + this.modelKey + "/data/tileset.json" }, eC.prototype.tilesUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/" + A : this.serverUrl + "/api/" + this.dbName + "/geomodels/" + this.modelKey + "/data/" + A }, eC.prototype.b3dmUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/" + A : this.serverUrl + "/api/" + this.dbName + "/geomodels/" + this.modelKey + "/data/" + A }, eC.prototype.attributeUrl = function () { if (this.offLine) return this.serverUrl + "/" + this.modelKey + "/resource/attribute/attribute.json" }, eC.prototype.meshIdUrl = function () { return this.serverUrl + this.modelKey + "/mpk/mesh_id" + vc.ZipResourcePostfix }, eC.prototype.materialUrl = function () { return this.serverUrl + this.modelKey + "/material/material" + vc.ZipResourcePostfix }, eC.prototype.materialIdUrl = function () { return this.serverUrl + this.modelKey + "/material/material_id" + vc.ZipResourcePostfix }, eC.prototype.userDataUrl = function () { return this.serverUrl + this.modelKey + "/userdata/userdata" + vc.ZipResourcePostfix }, eC.prototype.textureUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/data/" + A : np(this.apiVersion, "1.6.0") ? this.serverUrl + "/data?fileKey=" + A : this.serverUrl + "/api/" + this.dbName + "/files?fileKey=" + A + this.shareParameter }, eC.prototype.axisNetUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/data/" + A : np(this.apiVersion, "1.6.0") ? this.serverUrl + "/data?fileKey=" + A : this.serverUrl + "/api/" + this.dbName + "/files?fileKey=" + A }, eC.prototype.floorInfoUrl = function (A) { return this.offLine ? this.serverUrl + "/" + A + "/resource/floor/floorKey.json" : this.serverUrl + "/api/" + this.dbName + "/components/floorkeys?modelKey=" + A + this.shareParameter }, eC.prototype.floorMapUrl = function (A) { return this.offLine ? this.serverUrl + "/" + this.modelKey + "/resource/floor/map.json" : this.serverUrl + "/api/" + this.dbName + "/models/maps?modelKey=" + this.modelKey + this.shareParameter }; var tC = function (A) { $u.call(this, A), this.instancedComponent = {} }; Object.assign(tC.prototype, $u.prototype), tC.prototype.parseItemData = function (A) { this._readMaterialBuffer(this.model); var e = {}, t = this.referencedMeshCache; for (var i in Bh.time("_readItemData"), t.components) t.components.hasOwnProperty(i) && this._readItemData(e, i, i, void 0, 0); Bh.timeEnd("_readItemData"), e = null, A && A() }, tC.prototype._readItemData = function (A, e, t) { var i = this.referencedMeshCache.components[e]; void 0 !== i && this._readMeshInfo(A, t, i, null) }, tC.prototype._readMeshInfo = function (A, e, t, i) { var o = this.referencedMeshCache, n = this.model.materialManager.materials, r = null; if (t.nodes || t.nodeIds) { r = t.originalId; var a = (new M).fromArray(t.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]); t.matrix = a; var s = []; s = t.nodes ? t.nodes : t.nodeIds; for (var l = 0; s.length > l; l += 1) { var c = s[l]; if ("object" !== lc(c) && (c = this.getReferencedMeshComponentNodeById(c)), c) { var h, d = null, p = ""; if (-1 !== c.geoId) if (d = this._getComponentNodeAttr(c, t, l)) { if (t.buildInCategory && (d.buildInCategory = t.buildInCategory), !n[p = c.material]) { var g = _u[t.type] ? _u[t.type].color : void 0; g || (Bh.log("Material not found for type: ", t.type), g = _u.DEFAULT.color), g || (Bh.log("Default material not found for type: ", t.type), g = [1, 1, 1, 1]); var u = new LA(g[0], g[1], g[2]), f = p || u.getHexString() + "_" + g[3], m = n[f]; m || (Bh.warn("缺少材质 " + p), m = Kd.createStandardMaterial({ color: u }), 1 > g[3] && (m.transparent = !0, m.opacity = g[3]), m.side = 2, n[f] = m), d.material = p = f } if (n[p].aoMap) { var C = this.getReferencedMeshBufferById(d.geometryId); C && (C.uv2 = C.uv) } h = d.nodeId; var y = this.userDataReader, v = y ? y.getUserData(null) : null; d.type = t.type, d.userId = e, d.name = t.name, d.userDataId = null, d.originalId = r, d.materialId = p, d.originMId = p, d.userData = v, d.categoryId = 0, d.componentKey = e, d.familyName = t.familyName, d.familySymbol = t.familySymbol; var I = vc.Instance, E = o.reuseNodes.hasOwnProperty(h); d.instanceOrNot = !(!I || !E), d.isBatched = !0, d.state = Lc.Visible, d.material = null, this._classifyNodeInfo(d), d = null } else Bh.debug("非法node") } } } }, tC.prototype._parseInstanced = function () { Bh.time("_parseInstanced"), this.instancedComponent = {}, this.instancedNode = {}; var A = {}, e = this.referencedMeshCache, t = e.componentNodes, i = this.model.materialManager.materials; for (var o in e.components) if (e.components.hasOwnProperty(o)) for (var n = e.components[o], r = 0, a = n.Nodes.length; a > r; r += 1) { var s = n.Nodes[r], l = t[s], c = l.geometry, h = l.material; if (-1 !== c) { if (!h && 0 !== h) { var d = _u[n.type] ? _u[n.type].color : void 0; d || (Bh.log("Material not found for type: ", n.type), d = _u.DEFAULT.color), d || (Bh.log("Default material not found for type: ", n.type), d = [1, 1, 1, 1]); var p = new LA(d[0], d[1], d[2]), g = p.getHexString() + "_" + d[3], u = i[g]; u || (Bh.warn("缺少材质 " + g), u = Kd.createStandardMaterial({ color: p }), 1 > d[3] && (u.transparent = !0, u.opacity = d[3]), u.side = 2, i[g] = u), l.material = g, h = g } var f = h + "&" + c; void 0 === A[f] && (A[f] = []), A[f].push({ nodeId: s }) } else Bh.debug("实体没有几何") } for (var m in A) if (A.hasOwnProperty(m)) if (1 < A[m].length) for (var C = 0; A[m].length > C; C += 1) this.instancedComponent[A[m][C].nodeId] = !0; else delete A[m]; Bh.timeEnd("_parseInstanced") }; var iC = function (A) { Xu.call(this, A), this.maxGeoLoadTaskCount = 0, this.geoLoadTaskCount = 0, this.taskInstancedGeometrieManager = new Ou(this, "geometrie"), this.descriptor = new tC(A.model) }; (iC.prototype = Object.assign(iC.prototype, Xu.prototype))._parseMaterial = function (A, e) { if (A) { var t = this.descriptor; if (t) for (var i in A) t.cacheReferencedMeshMaterialData(i, A[i]) } else Bh.error("没有数据") }, iC.prototype.loadBatchedGeometrie = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model; i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine); var r = i.load(o.mpkUrl(A), (function (i) { t._parseBatchedGeometrie(i, A), Bh.debug("geo load from online"), t._onGeoTaskFinished(), e() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_GEOMETRY_ERROR, modelKey: n.modelKey }), e(), t._onGeoTaskFinished() })); t.requests.loadGeometrie = r }, iC.prototype.loadInstancedGeometrie = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model; i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine); var r = i.load(o.mpkUrl(A), (function (i) { t._parseInstancedGeometrie(i, A), Bh.debug("geo load from online"), t._onGeoTaskFinished(), e() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_GEOMETRY_ERROR, modelKey: n.modelKey }), e(), t._onGeoTaskFinished() })); t.requests.loadGeometrie = r }, iC.prototype._parseGeometrie = function (A, e) { if (A) { var t = this.descriptor; if (t) for (var i in A) A.hasOwnProperty(i) && (A[i].position = new Float32Array(A[i].positions), delete A[i].positions, A[i].index = new Uint32Array(A[i].indices), delete A[i].indices, A[i].normal = new Float32Array(A[i].normals), A[i].uv = new Float32Array(A[i].uv), delete A[i].normals, t.cacheReferencedMeshBufferData(i, A[i])) } else Bh.error("没有数据") }, iC.prototype._parseBatchedGeometrie = function (A, e) { var t = new ku.BatchedGeometryReader(A, this.dataVersion), i = this.descriptor; if (i) { var o = t.geoCount; Bh.time("createBatchedMeshNodes"); for (var n = 0; o > n; n += 1) { var r = t.geomMap[n]; void 0 !== r.position && void 0 !== r.index && void 0 !== r.normal ? (i.cacheReferencedMeshBufferData(r.geoId, r), this.handler.createBatchedMeshNodes(r)) : Bh.error("Error Geometry!") } this.model.manager.viewerImpl.render(), Bh.timeEnd("createBatchedMeshNodes"), t = null } }, iC.prototype._parseInstancedGeometrie = function (A, e) { var t = new ku.InstancedGeometryReader(A, this.dataVersion), i = this.descriptor; if (i) { var o = t.geoCount; Bh.time("createInstancedMeshNodes"); for (var n = 0; o > n; n += 1) { var r = t.geomMap[n]; void 0 !== r.position && void 0 !== r.index && void 0 !== r.normal ? (i.cacheReferencedMeshBufferData(r.geoId, r), this.handler.createInstancedMeshNodes(r)) : Bh.error("Error Geometry!") } this.model.manager.viewerImpl.render(), t = null, Bh.timeEnd("createInstancedMeshNodes") } }, iC.prototype.startLoadSceneAndGeos = function (A) { Bh.time("几何数据加载时间"); var e = A.scene, t = e.instancedGeometries.length || 0, i = e.batchedGeometries, o = e.instancedGeometries; this.maxGeoLoadTaskCount += e.batchedGeometries.length || 0, this.maxGeoLoadTaskCount += t, this._loadBatchedGeo(i), this._loadInstancedGeo(o) }, iC.prototype._loadBatchedGeo = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); if (n) for (var r = function () { var t = i.splice(0, 30); n.getBatch(t, (function (A) { for (var i = function (i) { if (A[t[i]]) if (!0 === A[t[i]].split) { var o = A[t[i]].list, s = new Uint8Array(A[t[i]].length); n.getBatch(o, (function (A) { for (var n = !0, r = 0; o.length > r; r += 1) A[o[r]] ? s.set(new Uint8Array(A[o[r]]), 4e7 * r) : (n = !1, Bh.error("获取分割几何失败")); if (n) { var a = t[i].indexOf("fileKey="); e._parseBatchedGeometrie(s.buffer, t[i].slice(a + 8)), e._onGeoTaskFinished(), Bh.debug("load geo from local") } else { var l = e.taskGeometrieManager, c = t[i].indexOf("fileKey="); if (-1 === c) return void Bh.error("url is not has fileKey"); l.addTask(t[i].slice(c + 8)), Bh.debug("load geo from net"), e.taskGeometrieManager.processTasks(e.loadBatchedGeometrie.bind(e)) } }), (function () { Bh.error("获取分割几何失败") })) } else a = t[i].indexOf("fileKey="), e._parseBatchedGeometrie(A[t[i]], t[i].slice(a + 8)), e._onGeoTaskFinished(), Bh.debug("load geo from local"); else { if (r = e.taskGeometrieManager, -1 === (a = t[i].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; r.addTask(t[i].slice(a + 8)), Bh.debug("load geo from net") } }, o = 0; t.length > o; o += 1) { var r, a, s = i(o); if ("object" === lc(s)) return s.v } e.taskGeometrieManager.processTasks(e.loadBatchedGeometrie.bind(e)) }), (function () { for (var t = e.taskGeometrieManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadBatchedGeometrie.bind(e)) })) }; i.length > 0;) r() } else { for (var a = this.taskGeometrieManager, s = 0; A.length > s; s += 1) a.addTask(A[s]); a.processTasks(e.loadBatchedGeometrie.bind(e)) } }, iC.prototype._loadInstancedGeo = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); if (n) for (var r = function () { var t = i.splice(0, 30); n.getBatch(t, (function (A) { for (var i = function (i) { if (A[t[i]]) if (!0 === A[t[i]].split) { var o = A[t[i]].list, s = new Uint8Array(A[t[i]].length); n.getBatch(o, (function (A) { for (var n = 0; o.length > n; n += 1) A[o[n]] ? s.set(new Uint8Array(A[o[n]]), 4e7 * n) : Bh.error("获取分割几何失败"); var r = t[i].indexOf("fileKey="); e._parseInstancedGeometrie(s.buffer, t[i].slice(r + 8)), e._onGeoTaskFinished(), Bh.debug("load geo from local") }), (function () { Bh.error("获取分割几何失败") })) } else a = t[i].indexOf("fileKey="), e._parseInstancedGeometrie(A[t[i]], t[i].slice(a + 8)), e._onGeoTaskFinished(), Bh.debug("load geo from local"); else { if (r = e.taskInstancedGeometrieManager, -1 === (a = t[i].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; r.addTask(t[i].slice(a + 8)), Bh.debug("load geo from net") } }, o = 0; t.length > o; o += 1) { var r, a, s = i(o); if ("object" === lc(s)) return s.v } e.taskInstancedGeometrieManager.processTasks(e.loadInstancedGeometrie.bind(e)) }), (function () { for (var t = e.taskInstancedGeometrieManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadInstancedGeometrie.bind(e)) })) }; i.length > 0;) r() } else { for (var a = this.taskInstancedGeometrieManager, s = 0; A.length > s; s += 1) a.addTask(A[s]); a.processTasks(e.loadInstancedGeometrie.bind(e)) } }, iC.prototype._onGeoTaskFinished = function () { (this.geoLoadTaskCount += 1, this.notifyProgress) && (this.progressCallback && this.progressCallback({ total: this.maxLoadTaskCount + this.maxGeoLoadTaskCount, loaded: .8 * (this.loadTaskCount + this.geoLoadTaskCount), modelKey: this.model.modelKey })); this.maxGeoLoadTaskCount > this.geoLoadTaskCount || (this.dataLoaded = !0, Bh.timeEnd("几何数据加载时间"), this.geoFinishCallback && this.geoFinishCallback()) }, iC.prototype.getSceneTaskCount = function (A) { var e = A.scenes; return e += A.lines, e += A.mpks, vc.BorderLineDelayLoaded || (e += this.getAllBorderlineCount()), e }; var oC = function (A, e) { tf.call(this, A), this.defaultManager = new Of(e, A), this.instancedManager = new Hf(A), this.loader = new iC(this) }; (oC.prototype = Object.create(tf.prototype)).prepare = function (A, e) { if (this.isLoaded() && !this.isHidden()) { this.prepareWireframe(this.model, e); this.model.getMaterialManager(); this.model.getMaterialManager()._updateTextureMapping(), !this.model.lightmap || this.model.enableLightmap === vc.EnableLightmap && this.model.lightmapIntensity === vc.LightmapIntensity || (this.model.enableLightmap = vc.EnableLightmap, this.model.lightmapIntensity = vc.LightmapIntensity, this.rebuildIndicesforLightmap(), this.updateNodes()) } }, oC.prototype.settleData = function (A) { var e = this; this.addNodeInfoToOctantMap(), e.model.setLoaded(!0); this.loader.geoFinishCallback = function () { e.loaded = !0, e.model.getMaterialManager()._updateTextureMapping(), e.clearCachedData(e.model), A && A() }, this.loader.startLoadSceneAndGeos(this.model.getConfig()) }, oC.prototype.addNodeInfoToOctantMap = function () { var A = this.model.manager, e = this.model.getEncodedDatabagId(); this.loader.getDescriptor().traverseNodeInfosByComponent((function (t, i) { A.addNodeInfoToOctantMap(e, t, i) })) }, oC.prototype.createMeshNodes = function (A) { var e = this, t = this.model; vc.stepLoad && t.setLoaded(!0); var i = this.loader.getDescriptor(); this.instancedManager.createMeshNodes(t, i.getInstancedUserIds()), this.defaultManager.asyncCreateMeshNodes(t, i.getStandardUserIds(), (function () { t.getMaterialManager()._updateTextureMapping(), e.clearCachedData(t), e.loaded = !0, A && A() })) }, oC.prototype.clearCachedData = function (A) { this.loader.getDescriptor().destroyReader(), this.loader.getDescriptor().clearReferencedMeshCache(), this.defaultManager.clearCachedData(), this.instancedManager.clearCachedData() }, oC.prototype.createBatchedMeshNodes = function (A) { this.defaultManager.createBatchedMeshNodes(this.model, A) }, oC.prototype.createInstancedMeshNodes = function (A) { this.instancedManager.createInstancedMeshNodes(this.model, A) }; var nC = function (A) { Xu.call(this, A), this._loadingOnDemand = !1 }; (nC.prototype = Object.assign(nC.prototype, Xu.prototype)).loadGeopkOnDemand = function (A, e, t) { this.loadTaskCount = 0, this.maxLoadTaskCount = A.length, this._loadingOnDemand = !0, this.finishCallback = t; var i = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var o = this.url, n = [], r = 0; A.length > r; r += 1) n.push(o.mpkUrl(A[r])); var a = this.model.getStorage(); a && a.getBatch(n, (function (A) { for (var t = function (e) { if (A[n[e]]) if (!0 === A[n[e]].split) { var t = A[n[e]].list, o = new Uint8Array(A[n[e]].length); a.getBatch(t, (function (A) { for (var r = 0; t.length > r; r += 1) A[t[r]] ? o.set(new Uint8Array(A[t[r]]), 4e7 * r) : Bh.error("获取分割几何失败"); var a = n[e].indexOf("fileKey="); i._parseGeometrie(o.buffer, n[e].slice(a + 8)), Bh.debug("load geo from local"), i._onTaskFinished() }), (function () { Bh.error("获取分割几何失败") })) } else s = n[e].indexOf("fileKey="), i._parseGeometrie(A[n[e]], n[e].slice(s + 8)), Bh.debug("load geo from local"), i._onTaskFinished(); else { if (r = i.taskGeometrieManager, -1 === (s = n[e].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; r.addTask(n[e].slice(s + 8)), Bh.debug("load geo from net") } }, o = 0; n.length > o; o += 1) { var r, s, l = t(o); if ("object" === lc(l)) return l.v } i.taskGeometrieManager.processTasks(i.loadGeometrie.bind(i), e) }), (function () { for (var t = i.taskGeometrieManager, o = 0; A.length > o; o += 1) t.addTask(A[o]); t.processTasks(i.loadGeometrie.bind(i), e) })) } else { for (var s = this.taskGeometrieManager, l = 0; A.length > l; l += 1) s.addTask(A[l]); s.processTasks(i.loadGeometrie.bind(i), e, t) } }, nC.prototype.resetProcessState = function (A) { this.loadTaskCount = 0, this.maxLoadTaskCount = A, this._loadingOnDemand = !0 }, nC.prototype.dealProgressSegment = function (A, e) { return vc.MergeComponent && this._loadingOnDemand ? e * A.progressPercentage.load : e }, nC.prototype._loadLayerKey = function () { var A = this, e = this.fileLoader, t = this.url, i = this.model, o = this.handler.getLayerProvider(); e.setResponseType(""), e.load(t.layerKeyUrl(), (function (e) { var t = new LayerKeyReader(e), i = [], n = t.getData(); o.cacheLayerKeys(n); for (var r = 0, a = t.getCount(); a > r; ++r) { var s = t.getLayerKey(r), l = o.formatLayerIds(s); i.push(l[0]) } A._loadLayer(i) }), void 0, (function (e) { i.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_MPK_ERROR, event: e }), A._onTaskFinished() })) }, nC.prototype._loadLayer = function (A) { var e = this, t = this.fileLoader, i = this.url, o = this.model, n = this.handler.getLayerProvider(); t.setResponseType("arraybuffer"), t.load(i.layerUrl(), (function (t) { for (var i = new LayerReader(t), o = 0, r = i.getLayerCount(); r > o; ++o) if (void 0 !== A[o]) { for (var a = [], s = i.getLayerData(o), l = i.getGeopkList(o), c = 0, h = l.length; h > c; c += 1) a.push(l[c]); n.cacheLayerData(A[o], { layerId: s.layer_id, boundingBox: s.boundingBox, mpkIdxs: a }) } e._onTaskFinished() }), void 0, (function (A) { o.dispatchEvent({ type: Tc.LOAD_ERROR, errorType: Tc.LOAD_MPK_ERROR, event: A }), e._onTaskFinished() })) }, nC.prototype.delayLoadResources = function (A) { var e = this.model.getConfig().metadata; e && 0 !== e.lines ? (this.startCallback = null, this.progressCallback = null, this.finishCallback = A, this.loadTaskCount = 0, this.maxLoadTaskCount = 0, this.maxLoadTaskCount += e.lines, e.lines && this._loadLine()) : A && A() }; var rC = function (A) { Af.call(this, A) }; (rC.prototype = Object.assign(rC.prototype, Af.prototype)).parseItemData = function (A, e) { var t = this.model; (ap(t.dataVersion, "2.0.0") || void 0 === t.dataVersion) && (Bh.time("升级几何结构"), this._updateV1ToV2(t), t.dataVersion = "2.0.0", Bh.timeEnd("升级几何结构")), this._readMaterialBuffer(t), t.hasAnimation && vc.EnableAnimation ? (this._parseClips(), this._parseBones()) : (this._parseGeo(), vc.Instance && sp(t.dataVersion, "2.0.0") && this._parseInstanced()); var i = {}; if (!i) return Bh.log("Empty scene"), !1; var o = this.referencedMeshCache; if (Bh.time("_readItemData"), !o.bufferData || 0 >= Object.keys(o.bufferData).length) return !0; if (A) for (var n = 0, r = A.length; r > n; n += 1) o.components[A[n]] && this._readItemData(i, A[n], A[n], void 0, 0); else for (var a in o.components) this._readItemData(i, a, a, void 0, 0); t.hasAnimation && vc.EnableAnimation && this._parseNodes(), Bh.timeEnd("_readItemData"), i = null, e && e() }; var aC = function (A) { nC.call(this, A), this.descriptor = new rC(A.model) }; (aC.prototype = Object.assign(aC.prototype, nC.prototype)).loadSceneAndMpks = function (A) { this._loadScene(0), this._loadLayerKey(), vc.BorderLineDelayLoaded || this._loadAllBorderlines(A) }, aC.prototype.getSceneTaskCount = function (A) { var e = 2; return vc.BorderLineDelayLoaded || (e += this.getAllBorderlineCount()), e }; var sC = function (A) { tf.call(this, A), this.layerDataLoaded = !1, this.loadedUserIdsObject = null, this.loadedUserIds = null, this.layerProvider = null, this.firstToLoad = !1 }; (sC.prototype = Object.assign(sC.prototype, tf.prototype)).destroy = function () { sC.prototype.destroy.call(this), this.loadedUserIdsObject = null, this.loadedUserIds = null, this.layerProvider.destroy(), this.layerProvider = null }, sC.prototype.getLayerProvider = function () { return this.layerProvider }, sC.prototype.load = function (A) { var e = this, t = this.model; this.loader.setNotifyProgress(A), this.loader.load((function () { t.manager.dispatchEvent({ type: Rc.ON_LOAD_START }) }), (function (A) { t.manager.dispatchEvent({ type: Rc.ON_LOAD_PROGRESS, progress: A }) }), (function () { e.processLoadCompleted((function () { t.manager.dispatchEvent({ type: Rc.ON_LOAD_COMPLETE, modelKey: e.model.modelKey }) })) })) }, sC.prototype.unload = function (A, e) {}, sC.prototype.loadGeopkOnDemand = function (A, e, t, i) { var o = this, n = this.model, r = !A, a = function (A) { n.manager.dispatchEvent({ type: Rc.ON_LOAD_PROGRESS, progress: A }) }; this.firstToLoad ? this.loader.delayLoadResources((function () { o.firstToLoad = !1, o.loader.finishCallback = null, o.prepareData((function () { o.loader.progressCallback = a, o.getLayerProvider().setConditionsOnDemandLoad(A), o._loadGeopkOnDemand(r, e, t, i) })) })) : (o.loader.progressCallback = a, o.getLayerProvider().setConditionsOnDemandLoad(A), o._loadGeopkOnDemand(r, e, t, i)) }, sC.prototype._loadGeopkOnDemand = function (A, e, t, i) { var o = this, n = this.model; this.layerDataLoaded = !1, e && e(), n.manager.dispatchEvent({ type: Rc.ON_LOAD_START }), this.getLayerProvider().loadGeopkOnDemand(A, (function (A) { o.dealData(A) }), (function (A, e) {}), t, (function () { o.layerDataLoaded = !0, n.manager.updateFilterManager(), Bh.log("load finish"), n.dispatchEventEx({ type: Rc.ON_DEMAND_LOAD_COMPLETE, data: { boundingBox: n.manager.getLoadOnDemandDirector().getBoundingBoxForUsedComponent() }, modelKey: o.model.modelKey }), i && i() })) }, sC.prototype.processLoadCompleted = function (A) { var e = this.model; e.materialManager._updateTextureMapping(), e.materialManager._updateIBL(e), e.loaded = !0, e.updateOctreeNode(), requestAnimationFrame((function () { A && A(), e.debut(e) })) }, sC.prototype.isAllReady = function () { return !(!this.isLoaded() || this.isHidden() || !this.isLayerDataLoaded()) }, sC.prototype.applyFilter = function () { console.log('applyFilter :>erqwer> '); if (this.isLoaded() && this.isLayerDataLoaded()) { var A = this.model.getModelDescriptor().getStandardUserIdsByCategory(this.loadedUserIds); if (A.length && this.defaultManager.applyFilter(this.model, A), vc.Instance) { var e = this.model.getModelDescriptor().getInstancedUserIdsByCategory(this.loadedUserIds); e.length && this.instancedManager.applyFilter(this.model, e) } } }, sC.prototype.needUpdate = function () { return !!this.isLayerDataLoaded() }, sC.prototype.clearData = function () {}, sC.prototype.initData = function (A) {}, sC.prototype.dealMeshNodes = function (A) {}, sC.prototype.dealData = function (A) { var e = this; this.initData((function () { e.model.manager.loadOverrideMaterialsByDemand((function () { e.dealMeshNodes(A) }), (function () { e.dealMeshNodes(A) })) })) }, sC.prototype.getLoadedUserIdsObject = function () { return this.loadedUserIdsObject }, sC.prototype.isLayerDataLoaded = function () { return this.layerDataLoaded }, sC.prototype.clearLoadedState = function () { this.layerDataLoaded = !1, this.loadedUserIdsObject = null, this.loadedUserIds = null }; var lC = function (A) { this.model = A, this.conditionsChanged = !0, this.nodeInfosWithLayerKey = {}, this.cachedLayerData = {}, this.cacheAttributes = null, this.cacheSpecialtysLevels = {}, this.mapLayerKeys = {}, this.lastUsedGeopkIdxsObject = null, this.lastUsedLayerIdsObject = null, this.lastUsedLayerData = null, this.mapNeededConditions = null }; lC.prototype.destroy = function () { this.cachedLayerData = null, this.nodeInfosWithLayerKey = null, this.cacheAttributes = null, this.cacheSpecialtysLevels = null, this.mapLayerKeys = null, this.lastUsedLayerData = null, this.lastUsedGeopkIdxsObject = null, this.lastUsedLayerIdsObject = null, this.mapNeededConditions = null }, lC.prototype.clearData = function () {}, lC.prototype.loadLayerDataByIdxs = function (A, e, t, i) {}, lC.prototype.dealLayerDataLoading = function (A, e, t, i, o) {}, lC.prototype.loadGeopkOnDemand = function (A, e, t, i, o) { var n = A ? this.getAllLayerIdxData() : this.getUsedLayerIdxData(); this.dealLayerDataLoading(this.getLayerIdxInfoByLayerData(n), e, t, i, o) }, lC.prototype.getUsedIdxsInfoFrom = function (A, e) { var t = null, i = {}, o = {}, n = {}, r = {}; if (A && A.length) for (var a = 0, s = A.length; s > a; a += 1) i[t = A[a]] = !0; if (e) if (uh.isEmptyObject(i)) n = e; else { for (t in e) i[t] && (r[t] = !0); if (uh.isEmptyObject(r)) o = i, n = e; else { for (t in e) r[t] || (n[t] = !0); for (t in i) r[t] || (o[t] = !0) } } else uh.isEmptyObject(i) || (o = i); return { objCurrUsedIdxs: i, addIdxs: Object.keys(o), removeIdxs: Object.keys(n) } }, lC.prototype.getLayerIdxInfoByLayerData = function (A) { var e = null, t = null; A ? (e = A.layerIds, t = A.mpkIdxs) : (e = null, t = null); var i = this.getUsedIdxsInfoFrom(e, this.lastUsedLayerIdsObject); this.lastUsedLayerIdsObject = i.objCurrUsedIdxs; var o = this.getUsedIdxsInfoFrom(t, this.lastUsedGeopkIdxsObject); return this.lastUsedGeopkIdxsObject = o.objCurrUsedIdxs, { layerScene: i, mpk: o } }, lC.prototype.getUsedLayerIdxData = function () { if (!this.isConditionsChanged() && this.lastUsedLayerData) return this.lastUsedLayerData; this.setConditionsChanged(!1); var A = this.getConditionsOnDemand(); if (!A) return this.lastUsedLayerData = null, null; this.getCachedLayerData(); for (var e = [], t = A, i = this.model.getModelDescriptor().referencedMeshCache.components, o = this.model.getModelDescriptor(), n = 0, r = t.length; r > n; n += 1) { var a = t[n], s = i[a]; if (s) if (s.nodes || s.nodeIds) for (var l = null, c = 0, h = (l = s.nodes ? s.nodes : s.nodeIds).length; h > c; c += 1) { var d = l[c]; if ("object" !== lc(d) && (d = o.getReferencedMeshComponentNodeById(d)), d) { var p = this.getFileKeyByGeoId(d.geoId); p && e.push(p) } } else { var g = this.getFileKeyByGeoId(i[a].geoId); g && e.push(g) } } return this.lastUsedLayerData = { layerIds: [], layerKeys: [], boundingBoxes: [], mpkIdxs: e }, this.lastUsedLayerData }, lC.prototype.getFileKeyByGeoId = function (A) { for (var e in this.cachedLayerData) if (this.cachedLayerData.hasOwnProperty(e)) { var t = this.cachedLayerData[e]; if (A >= t[0] && t[1] >= A) return e } return window.geoidToFileKeyMap ? window.geoidToFileKeyMap[A] : null }, lC.prototype.getAllLayerIdxData = function () { this.setConditionsChanged(!1); var A = this.getCachedLayerData(); if (!A) return null; var e = [], t = [], i = [], o = []; for (var n in A) { for (var r = A[n].mpkIdxs, a = 0, s = r.length; s > a; a += 1) i.push(r[a]); e.push(n), t.push(A[n].layerId), o.push(A[n].boundingBox) } return { layerIds: t, layerKeys: e, boundingBoxes: o, mpkIdxs: i } }, lC.prototype.getUserIdsOnDemand = function () { var A = {}, e = this.getConditionsOnDemand(); if (e) for (var t in e) A[e[t]] = !0; return A }, lC.prototype.cacheLayerData = function (A, e) { this.cachedLayerData[A] = e }, lC.prototype.getCachedLayerData = function () { return this.cachedLayerData }, lC.prototype.clearNodeInfoCacheWithLayerKey = function () { this.nodeInfosWithLayerKey = {} }, lC.prototype.cacheNodeInfoByLayerKey = function (A, e) { this.nodeInfosWithLayerKey[A] || (this.nodeInfosWithLayerKey[A] = []), this.nodeInfosWithLayerKey[A].push(e) }, lC.prototype.cacheNodeInfosWithLayerKey = function () { var A = this.model.getModelDescriptor().getAllNodeInfos(); for (var e in A) for (var t = A[e], i = 0, o = t.length; o > i; i += 1) { var n = t[i], r = this.formatLayerIds(n.userData); this.cacheNodeInfoByLayerKey(r[0], n) } }, lC.prototype.cacheLayerKeys = function (A) { this.mapLayerKeys = A; var e = {}, t = this.getLayerKeyAttributes(); for (var i in A) { var o = A[i], n = o[t[0]], r = o[t[1]]; e.hasOwnProperty(n) || (e[n] = []), e.hasOwnProperty(r) || (e[r] = []), e[n].push(r), e[r].push(n) } this.cacheSpecialtysLevels = e }, lC.prototype.getLayerKeyAttributes = function () { if (this.cacheAttributes) return this.cacheAttributes; var A = [], e = Object.keys(this.mapLayerKeys), t = this.mapLayerKeys[e[0]]; for (var i in t) t.hasOwnProperty(i) && A.push(i); return this.cacheAttributes = A, this.cacheAttributes }, lC.prototype.formatLayerIds = function (A) { var e = []; if (!A) return e.push("unknown"), e; var t = this.getFileKeyByGeoId(A.originalGeometryId); return e.push(t || "unknown"), e }, lC.prototype.getLevelsOrSpecialtys = function (A) { return this.cacheSpecialtysLevels.hasOwnProperty(A) ? this.cacheSpecialtysLevels[A] : (Bh.warn("Attribute " + A + "has no according levels or specialtys."), []) }, lC.prototype.getUnionBoundingBoxOnDemand = function () { var A = this.getBoundingBoxesOnDemand(); if (A && A.length > 0) { for (var e = new aA, t = 0, i = A.length; i > t; t += 1) e.union(A[t]); return e } return null }, lC.prototype.getBoundingBoxesOnDemand = function () { var A = this.getUsedLayerIdxData(); return A ? A.boundingBoxes : null }, lC.prototype.setConditionsOnDemandLoad = function (A) { this.mapNeededConditions = A, this.setConditionsChanged(!0) }, lC.prototype.setConditionsChanged = function (A) { this.conditionsChanged = A }, lC.prototype.getConditionsOnDemand = function () { return this.mapNeededConditions }, lC.prototype.isConditionsChanged = function () { return this.conditionsChanged }; var cC = function (A) { lC.call(this, A) }; (cC.prototype = Object.assign(cC.prototype, lC.prototype)).loadLayerDataByIdxs = function (A, e, t, i) { this.model.getLoader().resetProcessState(e.length), this.model.getLoader().loadGeopkOnDemand(e, (function (A, e) { t && t(e - A, e) }), i) }, cC.prototype.dealLayerDataLoading = function (A, e, t, i, o) { var n = A.mpk; if (0 !== n.addIdxs.length || 0 !== n.removeIdxs.length) { var r = !1; n.removeIdxs.length > 0 && (r = !0, t && t(null, n.removeIdxs)), n.addIdxs.length > 0 ? this.loadLayerDataByIdxs(null, n.addIdxs, i, (function () { e && e(o) })) : r ? e && e(o) : o && o() } else e && e(o) }; var hC = function (A) { return sC.call(this, A), this.layerProvider = new cC(A), this }; (hC.prototype = Object.assign(hC.prototype, sC.prototype)).settleData = function (A) { this.addNodeInfoToOctantMap(), this.getLayerProvider().cacheNodeInfosWithLayerKey(), this.loaded = !0, A && A() }, hC.prototype.clearData = function () { this.model.clearNodeGroup(), this.model.clearMeshFromOctantMap(), this.getLayerProvider().clearData(), this.model.clearWireframeElementCount(), this.defaultManager.clearData(), this.instancedManager.clearData(), this.clearLoadedState() }, hC.prototype.addNodeInfoToOctantMap = function () { var A = this.model.manager, e = this.model.getEncodedDatabagId(); this.model.getModelDescriptor().traverseNodeInfosByComponent((function (t, i) { A.addNodeInfoToOctantMap(e, t, i) })) }, hC.prototype.initData = function (A) { var e = this; e.model.getModelDescriptor().parseItemData(e.layerProvider.getConditionsOnDemand(), (function () { e.settleData(), e.loadedUserIdsObject = e.getLayerProvider().getUserIdsOnDemand(), e.loadedUserIds = Object.keys(e.loadedUserIdsObject), A && A() })) }, hC.prototype.unload = function (A, e) { var t = this; this.model.getModelDescriptor().clearReferencedMeshCacheByGeopkIdxs(e, (function (A) { t.defaultManager.disposeGeometry(A) })) }; var dC = function (A, e) { return hC.call(this, A, e), this.tag = "layer", this.defaultManager = new Of(e, A), this.instancedManager = new Hf(A), this.loader = new aC(this), this }; (dC.prototype = Object.assign(dC.prototype, hC.prototype)).prepare = function (A, e) { this.isAllReady() && (this.prepareWireframe(this.model, e), this.model.getMaterialManager()._updateTextureMapping(this.model)) }, dC.prototype.dealMeshNodes = function (A) { delete this.model.manager.octantToObjectMap[this.model.modelKey], this.addNodeInfoToOctantMap(); var e = this.model.getModelDescriptor().getInstancedUserIdsByCategory(this.loadedUserIds); this.model._removeNodeGroup(gp.INSTANCEGEOMETRY), this.model._removeNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY), this.instancedManager.meshManager.dispose(), this.instancedManager.meshManager.disposeInstanceGeometries(), e.length && this.instancedManager.createMeshNodes(this.model, e); var t = this.model.getModelDescriptor().getStandardUserIdsByCategory(this.loadedUserIds); this.model._removeNodeGroup(gp.GEOMETRY), this.model._removeNodeGroup(gp.WIREFRAME), this.defaultManager.meshManager.dispose(), this.defaultManager.meshManager.clearData(), t.length ? this.defaultManager.asyncCreateMeshNodes(this.model, t, A) : A && A() }, dC.prototype.unloadComponents = function (A, e) { for (var t = this.model.modelKey, i = 0, o = A.length; o > i; i += 1) this.model.manager.removeBatchedMeshFromOctantMap(t, A[i]); this.model.getModelDescriptor().clearNodeInfoCacheByComponentsKey(A), this.dealMeshNodes(e) }; var pC = function (A) { $u.call(this, A) }; (pC.prototype = Object.assign(pC.prototype, $u.prototype)).parseItemData = function (A, e) { var t = this.model; (ap(t.dataVersion, "2.0.0") || void 0 === t.dataVersion) && (Bh.time("升级几何结构"), this._updateV1ToV2(t), t.dataVersion = "2.0.0", Bh.timeEnd("升级几何结构")), this._readMaterialBuffer(t), t.hasAnimation && vc.EnableAnimation ? (this._parseClips(), this._parseBones()) : this._parseGeo(); var i = {}; if (!i) return Bh.log("Empty scene"), !1; var o = this.referencedMeshCache; if (Bh.time("_readItemData"), !o.bufferData || 0 >= Object.keys(o.bufferData).length) return !0; if (A) for (var n = 0, r = A.length; r > n; n += 1) o.components[A[n]] && this._readItemData(i, A[n], A[n], void 0, 0); else for (var a in o.components) this._readItemData(i, a, a, void 0, 0); t.hasAnimation && vc.EnableAnimation && this._parseNodes(), Bh.timeEnd("_readItemData"), i = null, e && e() }; var gC = function (A) { nC.call(this, A), this.descriptor = new pC(A.model) }; (gC.prototype = Object.assign(gC.prototype, nC.prototype)).loadSceneAndMpks = function (A) { this._loadScene(0), this._loadLayerKey(), vc.BorderLineDelayLoaded || this._loadAllBorderlines(A) }, gC.prototype.getSceneTaskCount = function (A) { var e = 2; return vc.BorderLineDelayLoaded || (e += this.getAllBorderlineCount()), e }; var uC = function (A) { of .call(this, A), this.nodeGroupName = "PickingMeshGroup" }; Object.assign(uC.prototype, of .prototype), eu(uC, [{ key: "disposePickingNodeById", value: function (A) { for (var e = Object.keys(this.pickingNodeMap[A]), t = 0, i = e.length; i > t; t += 1) for (var o = this.pickingNodeMap[A][e[t]], n = 0, r = o.length; r > n; n += 1) o[n].material = null, o[n].geometry.dispose(), o[n] = null } }, { key: "removeFormPickingNodeGroup", value: function (A) { if (this.pickingNodeGroup) for (var e = Object.keys(this.pickingNodeMap[A]), t = 0, i = e.length; i > t; t += 1) for (var o = this.pickingNodeMap[A][e[t]], n = 0, r = o.length; r > n; n += 1) this.pickingNodeGroup.remove(o[n]) } }, { key: "addToPickingNodeMap", value: function (A, e, t) { this.pickingNodeMap || (this.pickingNodeMap = {}), this.pickingNodeMap[A] || (this.pickingNodeMap[A] = {}), this.pickingNodeMap[A][e] = t, this.addToPickingNodeGroup(t) } }, { key: "generatePickingMeshes", value: function (A) { var e = this; this.manager.traverseActiveMeshMap(A, (function (A, t, i) { if (!e._isExistNode(A, t)) { for (var o = [], n = 0, r = i.length; r > n; n += 1) { var a = i[n], s = new he; s.setAttribute("position", a.geometry.getAttribute("position")), s.setIndex(a.geometry.getIndex()), s._withDrawRange && s.setDrawRange(a.geometry.drawRange.start, a.geometry.drawRange.count); var l = new(a.isLineSegments ? jo : Ue)(s, Kd.DefaultMaterial); Tu.copyMeshProperties(l, a), l.renderOrder = 1, o.push(l) } e.addToPickingNodeMap(A, t, o) } })) } }, { key: "_isExistNode", value: function (A, e) { return !!(this.pickingNodeMap && this.pickingNodeMap[A] && this.pickingNodeMap[A][e]) } }, { key: "updatePickingMeshesState", value: function (A, e, t) { if (this.pickingNodeMap) for (var i = this.pickingNodeMap, o = this.manager, n = 0, r = e.length; r > n; n += 1) { var a = e[n]; if (i[a] && o.isPickableNode(a)) { var s = o.getActiveMeshMapById(a); if (s) for (var l = Object.keys(i[a]), c = 0, h = l.length; h > c; c += 1) { var d = l[c]; if (s[d]) { var p = i[a][d]; if (p) for (var g = 0, u = p.length; u > g; g += 1) p[g].material = A, p[g].visible = !0 } } } } } }, { key: "resetPickingMeshesState", value: function () { if (this.pickingNodeMap) for (var A = this.pickingNodeMap, e = Object.keys(A), t = 0, i = e.length; i > t; t += 1) for (var o = e[t], n = Object.keys(A[o]), r = 0, a = n.length; a > r; r += 1) for (var s = A[o][n[r]], l = 0, c = s.length; c > l; l += 1) s[l].visible = !1 } }, { key: "updatePickingMeshes", value: function (A, e, t) { return this.generatePickingMeshes(e), this.resetPickingMeshesState(), this.updatePickingMeshesState(A, e, t), this.getPickingNodeGroup() } }]); var fC = function (A, e) { So.call(this), this.type = "SkinnedMeshEx", this.matrixAutoUpdate = !0, this.active = !1, this.guid = "", this.key = "", this.typeEx = "", this.geometry = A || Tu.EmptyGeometry, this.material = e || Kd.DefaultMaterial, this.visible = !1, this.castShadow = vc.EnableShadow, this.receiveShadow = vc.EnableShadow }; (fC.prototype = Object.create(So.prototype)).constructor = fC, fC.prototype.init = function (A) { A && A.parent && A.parent.add(this) }, fC.prototype.destroy = function () { this.parent && this.parent.remove(this), this.userData && (this.userData = null), this.geometry = null, this.material = null }, fC.prototype.isVisible = function () { return this.visible && this.active }, fC.prototype.spawn = function (A) { void 0 !== A.guid && (this.guid = A.guid), void 0 !== A.key && (this.key = A.key), void 0 !== A.name && (this.name = A.name), void 0 !== A.typeEx && (this.typeEx = A.typeEx), A.geometry && (this.geometry = A.geometry), A.material && (this.material = A.material), A.matrix ? (this.matrix.copy(A.matrix), this.updateMatrixWorld(!0)) : (this.matrix.identity(), this.updateMatrixWorld(!0)), this.modelKey = A.modelKey ? A.modelKey : "", A.userData ? this.userData = A.userData : this.userData && (this.userData = null), void 0 !== A.visible && (this.visible = A.visible), this.renderOrder = A.renderOrder || 0, this.active = !0, this.visible = !0, this.frustumCulled = !1, this.matChange = !1 }, fC.prototype.clear = function () { this.geometry = Tu.EmptyGeometry, this.material = Kd.DefaultMaterial, this.active = !1, this.visible = !0, this.guid = "", this.key = "", this.typeEx = "", this.frustumCulled = !0, this.material.visible = !1 }, fC.prototype.intersectBoxWithDistance = function () { var A = new aA; return function (e, t) { var i = this.geometry, o = this.material, n = this.matrixWorld; return t && (n = new M).multiplyMatrices(this.matrixWorld, t), void 0 === o ? -1 : (i.boundingBox || i.computeBoundingBox(), A.copy(i.boundingBox), A.applyMatrix4(n), e.ray.intersectBoxWithDistance(A)) } }(), fC.prototype.intersectBoxWithDistanceByIndices = function (A, e) { var t = this.matrixWorld, i = this.computeBoundingBox(e); return i.applyMatrix4(t), A.ray.intersectBoxWithDistance(i) }, fC.prototype.intersectBoxWithClipPlane = function (A, e) { var t = this.matrixWorld, i = this.computeBoundingBox(e); return i.applyMatrix4(t), i.intersectsPlane(A) }, fC.prototype.raycastByIndices = function () { var A = new M, e = new CA, t = new cA, i = new y, o = new y, n = new y, r = new s, a = new s, l = new s, c = new y, h = new y, d = new y, p = new M; function g(A, e, t, s, g, u, f, m) { i.fromBufferAttribute(s, u), o.fromBufferAttribute(s, f), n.fromBufferAttribute(s, m); var C = function (A, e, t, i, o, n, r) { var a = A.material; if (null === (Array.isArray(a) ? t.intersectTriangle(i, o, n, !1, r) : 1 === a.side ? t.intersectTriangle(n, o, i, !0, r) : t.intersectTriangle(i, o, n, 2 !== a.side, r))) return null; d.copy(r), d.applyMatrix4(p); var s = e.ray.origin.distanceTo(d); return e.near > s || s > e.far ? null : { distance: s, point: d.clone(), object: A } }(A, e, t, i, o, n, h); if (C) { if (g && g.array && g.array.length && (r.fromBufferAttribute(g, u), a.fromBufferAttribute(g, f), l.fromBufferAttribute(g, m), C.uv = function (A, e, t, i, o, n, r) { return RA.getBarycoord(A, e, t, i, c), o.multiplyScalar(c.x), n.multiplyScalar(c.y), r.multiplyScalar(c.z), o.add(n).add(r), o.clone() }(h, i, o, n, r, a, l)), s.instanceMatrix) { var v = i.clone().applyMatrix4(s.instanceMatrix), I = o.clone().applyMatrix4(s.instanceMatrix), E = n.clone().applyMatrix4(s.instanceMatrix); C.face = new GA(u, f, m, RA.getNormal(v, I, E, new y)) } else C.face = new GA(u, f, m, RA.getNormal(i, o, n, new y)); C.faceIndex = u } return C } return function (i, o, n, r) { var a = this.geometry, s = this.material; if (r) { a = this.geometry, s = this.material; if ((p = new M).multiplyMatrices(this.matrixWorld, r), void 0 === s) return; if (null === a.boundingSphere && a.computeBoundingSphere(), t.copy(a.boundingSphere), t.applyMatrix4(p), !1 === i.ray.intersectsSphere(t)) return; if (A.getInverse(p), e.copy(i.ray).applyMatrix4(A), null !== a.boundingBox && !1 === e.intersectsBox(a.boundingBox)) return; var l = null, c = null, h = null, d = null, u = a.index; (I = a.attributes.position).instanceMatrix = r; var f = a.attributes.uv, m = null, C = null; if (null !== u) for (m = 0, C = u.count; C > m; m += 3) c = u.getX(m), h = u.getX(m + 1), d = u.getX(m + 2), (l = g(this, i, e, I, f, c, h, d)) && (l.faceIndex = Math.floor(m / 3), o.push(l)); else for (m = 0, C = I.count; C > m; m += 3) (l = g(this, i, e, I, f, c = m, h = m + 1, d = m + 2)) && (l.index = c, o.push(l)) } else { if (p = this.matrixWorld, void 0 === s) return; if (t.copy(this.computeBoundingSphere(n)), t.applyMatrix4(p), !1 === i.ray.intersectsSphere(t)) return; A.getInverse(p), e.copy(i.ray).applyMatrix4(A); var y = this.computeBoundingBox(n); if (!1 === e.intersectsBox(y)) return; l = null, c = null, h = null, d = null; var v, I = a.attributes.position, E = (f = a.attributes.uv, m = null, n.indexStart), B = n.indexStart + n.indexCount, x = a.getIndex().array; for (m = E, v = B; v > m; m += 3) (l = g(this, i, e, I, f, c = x[m], h = x[m + 1], d = x[m + 2])) && (l.faceIndex = Math.floor(m / 3), o.push(l)) } } }(), fC.prototype.minDistanceToTri = function (A, e, t) { function i(A, e) { return new y(A.x - e.x, A.y - e.y, A.z - e.z) } function o(A, e) { return new y(A.x + e.x, A.y + e.y, A.z + e.z) } function n(A, e, t) { return new y(A.x + e.x * t, A.y + e.y * t, A.z + e.z * t) } function r(A, e) { return A.x * e.x + A.y * e.y + A.z * e.z } function a(A, e) { return new y(A.y * e.z - A.z * e.y, A.z * e.x - A.x * e.z, A.x * e.y - A.y * e.x) } function s(A, e, t, s) { var l, c = r(e, s), h = r(e, e), d = r(s, s), p = i(t, A), g = r(e, p), u = r(s, p), f = null; 0 > (f = (g * d - u * c) / (h * d - c * c)) || isNaN(f) ? f = 0 : f > 1 && (f = 1); var m = null, C = null, y = null, v = null; return 0 >= (l = (f * c - u) / d) || isNaN(l) ? (C = t, 0 >= (f = g / h) || isNaN(f) ? (m = A, y = i(t, A)) : 1 > f ? (m = n(A, e, f), v = a(p, e), y = a(e, v)) : y = i(t, m = o(A, e))) : 1 > l ? (C = n(t, s, l), 0 >= f || isNaN(f) ? (m = A, v = a(p, s), y = a(s, v)) : 1 > f ? (m = n(A, e, f), 0 > r(y = a(e, s), p) && y.multiplyScalar(-1)) : (v = a(p = i(t, m = o(A, e)), s), y = a(s, v))) : (C = o(t, s), 0 >= (f = (c + g) / h) || isNaN(f) ? (m = A, y = i(C, A)) : 1 > f ? (m = n(A, e, f), v = a(p = i(C, A), e), y = a(e, v)) : y = i(C, m = o(A, e))), { vec: y, closestP: m, closestQ: C } } function l(A, e) { var t = null, o = null, l = [], c = [], h = null; l[0] = i(A[1], A[0]), l[1] = i(A[2], A[1]), l[2] = i(A[0], A[2]), c[0] = i(e[1], e[0]), c[1] = i(e[2], e[1]), c[2] = i(e[0], e[2]); for (var d = null, p = null, g = null, u = 0, f = A[0].distanceToSquared(e[0]) + 1, m = 0; 3 > m; m += 1) for (var C = 0; 3 > C; C += 1) { var y = s(A[m], l[m], e[C], c[C]); h = y.vec; var v = r(d = i(o = y.closestQ, t = y.closestP), d); if (f >= v) { p = t.clone(), g = o.clone(), f = v; var I = r(i(A[(m + 2) % 3], t), h), E = r(i(e[(C + 2) % 3], o), h); if (0 >= I && E >= 0) return { start: t.clone(), end: o.clone(), minDistance: Math.sqrt(v) }; 0 > I && (I = 0), E > 0 && (E = 0), r(d, h) - I + E > 0 && (u = 1) } } var B = a(l[0], l[1]), x = r(B, B); if (x > 1e-15) { var S = []; d = i(A[0], e[0]), S[0] = r(d, B), d = i(A[0], e[1]), S[1] = r(d, B), d = i(A[0], e[2]), S[2] = r(d, B); var w = -1; if (S[0] > 0 && S[1] > 0 && S[2] > 0 ? S[w = S[1] > S[0] ? 0 : 1] > S[2] && (w = 2) : 0 > S[0] && 0 > S[1] && 0 > S[2] && S[2] > S[w = S[0] > S[1] ? 0 : 1] && (w = 2), w >= 0 && (u = 1, r(d = i(e[w], A[0]), a(B, l[0])) > 0 && r(d = i(e[w], A[1]), a(B, l[1])) > 0 && r(d = i(e[w], A[2]), a(B, l[2])) > 0)) return t = n(e[w], B, S[w] / x), o = e[w].clone(), t.distanceTo(o) } var M = a(c[0], c[1]), b = r(M, M); if (b > 1e-15) { var U = []; d = i(e[0], A[0]), U[0] = r(d, M), d = i(e[0], A[1]), U[1] = r(d, M), d = i(e[0], A[2]), U[2] = r(d, M); w = -1; if (U[0] > 0 && U[1] > 0 && U[2] > 0 ? U[w = U[1] > U[0] ? 0 : 1] > U[2] && (w = 2) : 0 > U[0] && 0 > U[1] && 0 > U[2] && U[2] > U[w = U[0] > U[1] ? 0 : 1] && (w = 2), w >= 0 && (u = 1, r(d = i(A[w], e[0]), a(M, c[0])) > 0 && r(d = i(A[w], e[1]), a(M, c[1])) > 0 && r(d = i(A[w], e[2]), a(M, c[2])) > 0)) return { start: t = A[w].clone(), end: (o = n(A[w], M, U[w] / b)).clone(), minDistance: t.distanceTo(o) } } return u ? (t = p, o = g, { start: p.clone(), end: g.clone(), minDistance: Math.sqrt(f) }) : { start: p.clone(), end: g.clone(), minDistance: 0 } } var c = new y, h = new y, d = new y; function p(A, e, t, i, o, n) { c.fromBufferAttribute(e, t), h.fromBufferAttribute(e, i), d.fromBufferAttribute(e, o), n && (c.applyMatrix4(n), h.applyMatrix4(n), d.applyMatrix4(n)), A.push(c), A.push(h), A.push(d) } for (var g = { start: null, end: null, minDistance: Number.POSITIVE_INFINITY }, u = this.geometry, f = u.attributes.position, m = e ? e.indexStart : 0, C = u.getIndex().array, v = m, I = e ? e.indexStart + e.indexCount : C.length; I > v; v += 3) { var E = []; p(E, f, C[v], C[v + 1], C[v + 2], t); var B = l(A, E); if (0 >= B.minDistance) return g.minDistance = 0, g; g.minDistance > B.minDistance && (g.minDistance = B.minDistance, g.start = B.start.clone(), g.end = B.end.clone()) } return g }, fC.prototype.computeBoundingBox = function (A) { var e = new aA, t = this.geometry.attributes.position.array, i = null, o = null; return A ? (i = A.positionStart, o = A.positionStart + A.positionCount) : (i = 0, o = t.length), this.setBoundingBoxFromArray(e, t, i, o), e }, fC.prototype.computeBoundingSphere = function (A) { var e = new aA, t = new y, i = this.geometry.attributes.position.array, o = null, n = null; A ? (o = A.positionStart, n = A.positionStart + A.positionCount) : (o = 0, n = i.length); var r = new cA, a = r.center; this.setBoundingBoxFromArray(e, i, o, n), e.getCenter(a); for (var s = 0, l = o, c = n; c > l; l += 3) t.x = i[l], t.y = i[l + 1], t.z = i[l + 2], s = Math.max(s, a.distanceToSquared(t)); return r.radius = Math.sqrt(s), r }, fC.prototype.setBoundingBoxFromArray = function (A, e, t, i) { for (var o = Number(1 / 0), n = Number(1 / 0), r = Number(1 / 0), a = -1 / 0, s = -1 / 0, l = -1 / 0, c = t, h = i; h > c; c += 3) { var d = e[c], p = e[c + 1], g = e[c + 2]; o > d && (o = d), n > p && (n = p), r > g && (r = g), d > a && (a = d), p > s && (s = p), g > l && (l = g) } A.min.set(o, n, r), A.max.set(a, s, l) }; var mC = function (A) { return Rf.call(this), this.manager = A, this.nodePriority = { high: [], medium: [], low: [] }, this.visibleOctant = [], this.occlusionVisibleOctant = [], this.usedNodeInfosObject = {}, this.lineNodes = {}, this.blinkMaterials = [], this.selectedMeshes = [], this.nonSelectedMeshes = [], this.selectedObjectIds = [], this.activeMeshMap = {}, this }; (mC.prototype = Object.create(Rf.prototype)).destroy = function () { this.dispose(), this.clearData(), this.pickingNodeGenerator && (this.pickingNodeGenerator.destroy(), this.pickingNodeGenerator = null), this.activeMeshMap = null, this.manager = null, this.nodePriority = null, this.visibleOctant = null, this.occlusionVisibleOctant = null, this.nodePriority = null, this.lineNodes = null, this.blinkMaterials = null }, mC.prototype.disposeLineNodes = function () { for (var A in this.lineNodes) { var e = this.lineNodes[A]; e.geometry.dispose(), e = null, delete this.lineNodes[A] } }, mC.prototype.clearData = function () { this.pickingNodeGenerator && this.pickingNodeGenerator.clearData(), this._clearActiveMeshMap(), this.disposeGeometries(), this.disposeLineNodes(), this._clearNodePriorityData(!0), this._clearUsedNodeInfosObject(), this.visibleOctant.length = 0, this.occlusionVisibleOctant.length = 0 }, mC.prototype.update = function (A, e, t) { this._updateMeshNodes(A, e, t) }, mC.prototype.cullNodes = function (A, e) { this._clearNodePriorityData(!1), this._adjustLowNodePriorityLength(A); var t = 0; return t = vc.EnableOctant ? this._cullNodesWithOctant(A, e) : this._cullNodesWithFull(A), this._calcPrioritizedNodeCount(A, t) }, mC.prototype.getPriorityNodes = function () { return [this.nodePriority.high, this.nodePriority.medium, this.nodePriority.low] }, mC.prototype._cullNodesWithOctant = function (A, e) { var t = 0, i = 0, o = this.manager.getLoader(A).getOctreeRootNodeInner(), n = this.manager.getLoader(A).getOctreeRootNodeOuter(); if (this.manager.getContainsCamera(A) || !n) return this.visibleOctant.length = 0, o && this._frustumCull(A, e, o), n && this._frustumCull(A, e, n), (i = this.visibleOctant.length) > 0 && (this._sortVisibleOctant(e), t = this._logicCull(A, !0, !0, t, i)), t; n && (this.visibleOctant.length = 0, this._frustumCull(A, e, n), (i = this.visibleOctant.length) > 0 && (this._sortVisibleOctant(e), t = this._logicCull(A, !0, !1, t, i))); var r = this.manager.getFilter(A); (Object.keys(this.nodePriority.low).length + this.nodePriority.high.length + this.nodePriority.medium.length < this.manager.getRenderableCount(A) || r._hasRenderPromotionFilter()) && ((o = this.manager.getLoader(A).getOctreeRootNodeInner()) && (this.visibleOctant.length = 0, this._frustumCull(A, e, o), (i = this.visibleOctant.length) > 0 && (this._sortVisibleOctant(A, e), t = this._logicCull(A, !0, !1, t, i)))); return t }, mC.prototype._cullNodesWithFull = function (A) { var e = A.getModelDescriptor().getComponentCount(); return 0 === e ? 0 : this._logicCullWithFull(A, e) }, mC.prototype._calcPrioritizedNodeCount = function (A, e) { var t = e + this.nodePriority.high.length + this.nodePriority.medium.length; return t > this.manager.getRenderableCount(A) && (t = this.manager.getRenderableCount(A)), t }, mC.prototype._updateMeshNodes = function (A, e, t) { if (this.filter = A.getFilter(), A.isOnlyWireframe()) { A._getNodeGroup(gp.GEOMETRY).visible = !1 } else { var i = A.getModelDescriptor().getStandardNodeInfos(); if (i) { this.clearSelectedObjectIds(), A._getNodeGroup(gp.GEOMETRY).visible = !0; var o = A.manager.filter, n = A.selectedMaterial, r = A.manager.sceneState, a = A.manager; if (a.octantToObjectMap && a.octantToObjectMap[A.modelKey]) { var s = a.octantToObjectMap[A.modelKey].mesh, l = A.materialManager.materials, c = this.manager.hiddenUserIdSetObject, h = this.manager.overrideUserIdSetObject, d = this.manager.transparentUserIdSetObject, p = this.manager.selectedUserIdSetObject, g = this.manager.hoveredUserIdSetObject; this.blinkMaterials.length = 0, e || (e = A.getModelDescriptor().getStandardUserIds()), vc.TranslucentDepthDisabled && (n.depthWrite = !n.transparent); var u = o._getMaterialByName("scene"); vc.TranslucentDepthDisabled && (u.depthWrite = !1); for (var f = 0; e.length > f; f += 1) { var m = e[f]; if (i[m]) { var C = i[m][0]; if (C) if (s[m]) { var y = s[m][0]; if (y instanceof vu && (y = y.object), y) if (c && c[m]) y.visible = !1; else { y.visible = !0; var v = []; if (d && d[m] && !vc.EnableSelectionByTranslucent) { for (var I = 0; C.materialId.length > I; I += 1) v.push(t || u); y.material = v } else if (p && p[m]) if (this.cacheSelectedObjectIds(m), vc.PickingEffect) for (var E = o._getOverrideMaterial(C), B = 0; C.materialId.length > B; B += 1) v.push(t || E); else { for (var x = 0; C.materialId.length > x; x += 1) v.push(t || n); y.material = v } else if (g && g[m]) { for (var S = 0; C.materialId.length > S; S += 1) if (h[m]) { var w = o._getMaterialByName(h[m]), M = r.getHoverMaterial(t || w); v.push(M) } else { var b = r.getHoverMaterial(t || l[C.materialId[S]]); v.push(b) } y.material = v } else if (d && d[m]) { for (var U = 0; C.materialId.length > U; U += 1) v.push(t || u); y.material = v } else if (h && h[m]) { for (var F = 0; C.materialId.length > F; F += 1) if (Array.isArray(h[m])) { (K = l[C.materialId[F]]) || (K = o._getMaterialByName(h[m][F])), v.push(t || K) } else { var K = o._getMaterialByName(h[m]); v.push(t || K) } y.material = v } else { for (var Q = 0; C.materialId.length > Q; Q += 1) { K = l[C.materialId[Q]]; v.push(t || K) } y.material = v } } } else Bh.error(m, "没有创建对应的mesh") } } } } } }, mC.prototype._getUsableMaterial = function (A, e, t, i) { var o = e.materialId, n = e.userId, r = A.materialManager.materials, a = A.manager.sceneState, s = A.manager.filter, l = null, c = a.isSelected(n); !0 !== c || s._isPickable(e) || (c = !1), t ? vc.PickingEffect ? l = s._getOverrideMaterial(e) : (l = s._getOverrideMaterial(e)) && !c || (l = t) : i && (l = s._getOverrideMaterial(e)); var h = A.manager.getOverrideMaterialByNodeInfo(e); return l = l || h || r[o], vc.Hover && !vc.EnableRenderPass && a.hoverId === n && !1 === c && (l = a.getHoverMaterial(l)), l }, mC.prototype._dealMeshes = function (A, e, t, i, o) { var n = this.getGeometryByNodeInfo(A, e), r = A.pool, a = 0; if (Array.isArray(n)) for (var s = 0, l = n.length; l > s; s += 1) { a = r.get({ modelKey: A.modelKey, nodeId: e.nodeId, userId: e.userId, originalId: e.originalId, userData: e.userData, geometry: n[s], matrix: e.matrix, material: i, renderOrder: i.transparent ? 0 : vc.MaximumDepth - e.cellDepth, visible: t }), null } else a = r.get({ modelKey: A.modelKey, nodeId: e.nodeId, userId: e.userId, originalId: e.originalId, userData: e.userData, geometry: n, matrix: e.matrix, material: i, renderOrder: i.transparent ? 0 : vc.MaximumDepth - e.cellDepth, visible: t }); 0 > a || o.curOctantId !== e.octantId && (a > 0 && A.manager.addObjectRangeToOctantMap(o.curOctantId, o.octantStartIndex, a - 1), o.octantStartIndex = a, o.curOctantId = e.octantId) }, mC.prototype._dealLineSegments = function (A, e, t, i) { var o = this.getGeometryByNodeInfo(A, e); if (o) { var n = this._getLineSegmentsNodeGroup(A), r = this.lineNodes[e.nodeId]; r || ((r = new cf(o, i)).nodeId = e.nodeId, r.name = e.name, r.geometryId = e.geometryId, r.modelKey = A.modelKey, this.lineNodes[e.nodeId] = r), r.material = i, r.visible = t, n.add(r), r.updateMatrixWorld(!0), this._cacheActiveMesh(e.userId, e.nodeId, r) } }, mC.prototype._frustumCull = function (A, e, t) { var i = A.manager, o = e.getFrustum(), n = vc.OctantDepth, r = e.projScreenMatrix, a = new aA; function s(A, e, t, i, o) { var n = null; if (e && t > A.depth && (a.set(A.min, A.max), n = e.intersectsBox(a)), n) { if (i) { var l = a.applyMatrix4(r), c = l.getSize().length(), h = l.getCenter().z; A.priority = c / (h = h > 1e-6 ? h : 1e-6), o.push(A) } else o.push(A); for (var d = 0, p = A.childOctants.length; p > d; d += 1) s(A.childOctants[d], e, t, i, o) } } (vc.DEBUG && i.showOctreeBox(t), s(t, o, n, !0, this.visibleOctant), vc.OcclusionTranslucentEnabled) && s(t, this.manager.getFrustumFromOcclusionCamera(), n, !1, this.occlusionVisibleOctant); return !0 }, mC.prototype._logicCull = function (A, e, t, i, o) { var n = A.manager, r = n.filter, a = r._hasHiddenFileIdFilter(), s = r._hasOverrideMaterialFilter(), l = n.sceneState.selectionSet, c = r._hasRenderPromotionFilter(), h = this.nodePriority.high, d = this.nodePriority.medium, p = this.nodePriority.low, g = this.nodePriority.low.length, u = A.getModelDescriptor().getNodeInfosWithComponentKey(); function f(A, e) { if (!(a && r._isHiddenFileId(A) || !1 === r._isVisible(A))) if (l.hasOwnProperty(A.userId) || s && r._hasHighPriorityOverrideMaterial(A)) h.push(A); else { var t = !1; if (c && r._isRenderPromotion(A) && (t = !0), e) { var o = A.userData, n = o ? o.categoryId : void 0; n && e[n] && (t = !0) } t ? d.push(A) : g > i && (p[i] = A, i += 1) } } var m = n.getCategoriesFromHighPriority("outer"); !0 === t && (m = n.getCategoriesFromHighPriority("inner")); for (var C = 0, y = 0, v = 0; o > v; v += 1) { var I = null, E = 0; e ? (I = this.visibleOctant[v].octantId, E = this.visibleOctant[v].depth) : I = v; var B = u[I]; if (B) { var x = this._getUsedNodeInfosByComponentKey(I); if (!x) { for (C = 0, y = B.length; y > C; C += 1) { (w = B[C]).octantId = I, w.cellDepth = E, this._isSatisfied(A, w) && this._cacheUsedNodeInfosByComponentKey(I, w) } x = this._getUsedNodeInfosByComponentKey(I) } if (x) { var S = x.default; for (C = 0, y = S.length; y > C; C += 1) { var w; f(w = S[C], m) } } } } return Bh.timeEnd("collectNodeInfo"), i }, mC.prototype._clearUsedNodeInfosObject = function () { for (var A in this.usedNodeInfosObject) delete this.usedNodeInfosObject[A].default, delete this.usedNodeInfosObject[A].instance, delete this.usedNodeInfosObject[A]; this.usedNodeInfosObject = {} }, mC.prototype._getUsedNodeInfosByComponentKey = function (A) { return this.usedNodeInfosObject[A] }, mC.prototype._cacheUsedNodeInfosByComponentKey = function (A, e) { this.usedNodeInfosObject[A] || (this.usedNodeInfosObject[A] = {}, this.usedNodeInfosObject[A].default = [], this.usedNodeInfosObject[A].instance = []), this.usedNodeInfosObject[A].default.push(e) }, mC.prototype._isSatisfied = function (A, e) { var t = A.getLoadedUserIdsObject(); return !t || Boolean(t[e.userId]) }, mC.prototype._logicCullWithFull = function (A, e) { return this._logicCull(A, !1, !0, 0, e) }, mC.prototype._sortVisibleOctant = function (A, e) {}, mC.prototype._applyOcclusionTranslucent = function (A) { if (vc.OcclusionTranslucentEnabled) { var e = A.pool.getObjects(), t = A.manager.octantToObjectMap, i = this.occlusionVisibleOctant.length; if (i > 0) for (var o = A.manager.getFrustumFromOcclusionCamera(), n = 0; i > n; n += 1) { var r = t[this.occlusionVisibleOctant[n].octantId]; if (r && r.length > 0) for (var a = 0, s = r.length; s > a; a += 2) for (var l = r[a]; r[a + 1] >= l; l += 1) { var c = e[l][0]; Rd.intersectObjectWithFrustum(c, o) && this._overrideOcclusionMaterial(c) } } } }, mC.prototype._overrideOcclusionMaterial = function (A, e) { var t = e.material; if (t && !1 === t.transparent) { var i = A.manager.acquireMaterial(), o = i.material; t.color ? o.color.copy(t.color) : i.resetColor(), o.opacity = vc.OcclusionOpacity, e.material = o, e.material.needsUpdate = !0 } }, mC.prototype._clearNodePriorityData = function (A) { var e = this.nodePriority; e.high.length = 0, e.medium.length = 0, A && (e.low.length = 0) }, mC.prototype._adjustLowNodePriorityLength = function (A) { 0 === this.nodePriority.low.length && (this.nodePriority.low.length = this.manager.getRenderableCount(A)) }, mC.prototype._clearLineSegmentsNodeGroup = function (A) { this._getLineSegmentsNodeGroup(A).clear() }, mC.prototype._getLineSegmentsNodeGroup = function (A) { return A._getNodeGroup(gp.LINESEGMENTS, { globalSpace: !0 }) }, mC.prototype._isLineSegments = function (A) { return A.type === Qf.EnumNodeItemType.LINE }, mC.prototype.getBlinkMaterials = function (A) { return this.blinkMaterials }, mC.prototype._makeMesh = function (A, e, t) { var i = A.modelKey, o = A.manager, n = A.getModelDescriptor().getStandardNodeInfos(); if (n) { e || (e = A.getModelDescriptor().getInstancedUserIds()); for (var r = A.getModelDescriptor(), a = A._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }), s = A.materialManager.materials, l = 0, c = e.length; c > l; l += 1) { var h = A.getModelDescriptor().getNodeInfosByComponentKey(e[l]); if (!h || !h[0].mesh) for (var d = n[e[l]], p = 0, g = d.length; g > p; p += 1) { var u = d[p]; if (u) { var f = u.geometryId, m = this.getGeometryById(f); if (m) { var C = u.materialId || r.referencedMeshCache.components[e[l]].matId, y = null; if (y = [], op(A.dataVersion, "1.0") || void 0 === A.dataVersion) { var v = s[C]; if (u.materialId = [], !v) continue; if (Array.isArray(v)) if (v.length > 1) for (p = 0; v.length > p; p += 1) u.materialId.push(C + "_" + p), s[C + "_" + p] = v[p]; else s[C] = v[0], u.materialId.push(C); else u.materialId.push(C); for (p = 0; u.materialId.length > p; p += 1) y.push(s[u.materialId[p]]) } else for (p = 0; C.length > p; p += 1) { var I = s[C[p]]; I || (I = Kd.DefaultMaterial), y.push(I) } if (1 > y.length) { var E = _u[u.type] ? _u[u.type].color : void 0; E || (Bh.log("Material not found for type: ", u.type), E = _u.DEFAULT.color), E || (Bh.log("Default material not found for type: ", u.type), E = [1, 1, 1, 1]); var B = new LA(E[0], E[1], E[2]), x = B.getHexString() + "_" + E[3], S = s[x]; S || (S = new xr({ color: B }), 1 > E[3] && (S.transparent = !0, S.opacity = E[3]), S.side = 2, s[x] = S), m.groups = [{ start: 0, count: m.index.count, materialIndex: 0 }], u.materialId.push(x), y.push(S) } for (var w = 0; y.length > w; w += 1) y[w].aoMap && m.attributes.uv && (m.attributes.uv2 = m.attributes.uv); var M = new Kf(m, y), b = { matrix: u.matrix, modelKey: i, name: u.name, key: u.componentKey, userData: {}, typeEx: u.type }; M.spawn(b), a.add(M), o.addMeshToOctantMap(i, u.componentKey, new Iu(u.componentKey, M)); var U = { indexCount: m.index.count, indexStart: 0, lightmapIdx: void 0, nodeId: u.componentKey, positionCount: 3 * m.attributes.position.count, positionStart: 0, userId: u.componentKey }; M._indicesGroup = {}, M._indicesGroup[u.componentKey] = [U], A.addMeshToInfoMap(u.componentKey, u.componentKey, M, U), M.geometryId = u.geometryId, this._cacheActiveMesh(u.userId, u.nodeId, M), f = null, C = null, b = null, y = null, m = null, M = null } } } } a.updateMatrixWorld(!0), t && t() } }, mC.prototype._makeSkinMesh = function (A, e, t) { var i = A.modelKey, o = A.manager, n = A.getModelDescriptor().getStandardNodeInfos(); if (n) { e || (e = A.getModelDescriptor().getInstancedUserIds()); for (var r = A.getModelDescriptor(), a = A.materialManager.materials, s = 0, l = e.length; l > s; s += 1) for (var c = n[e[s]], h = 0, d = c.length; d > h; h += 1) { var p = c[h]; if (p) { var g = p.geometryId, u = this.getGeometryById(g); if (u) { var f = p.materialId || r.referencedMeshCache.components[e[s]].matId, m = null; m = []; for (h = 0; f.length > h; h += 1) { var C = a[f[h]]; C || (C = Kd.DefaultMaterial), m.push(C) } if (1 > m.length) { var y = _u[p.type] ? _u[p.type].color : void 0; y || (Bh.log("Material not found for type: ", p.type), y = _u.DEFAULT.color), y || (Bh.log("Default material not found for type: ", p.type), y = [1, 1, 1, 1]); var v = new LA(y[0], y[1], y[2]), I = v.getHexString() + "_" + y[3], E = a[I]; E || (E = new xr({ color: v }), 1 > y[3] && (E.transparent = !0, E.opacity = y[3]), E.side = 2, a[I] = E), u.groups = [{ start: 0, count: u.index.count, materialIndex: 0 }], p.materialId.push(I), m.push(E) } for (var B = 0; m.length > B; B += 1) m[B].aoMap && (u.attributes.uv2 = u.attributes.uv); var x = null; if ("skinIndex" in u.attributes && "skinWeight" in u.attributes) { x = new fC(u, m); for (var S = 0; m.length > S; S += 1) m[S].skinning = !0; console.log("SkinnedMesh 类型mesh") } else x = new Kf(u, m); var w = { matrix: p.matrix, modelKey: i, name: p.name, key: p.componentKey, userData: {}, typeEx: p.type }; x.spawn(w), o.addMeshToOctantMap(i, p.componentKey, new Iu(p.componentKey, x)); var M = { indexCount: u.index.count, indexStart: 0, lightmapIdx: void 0, nodeId: p.componentKey, positionCount: u.attributes.position.count, positionStart: 0, userId: p.componentKey }; return x._indicesGroup = {}, x._indicesGroup[p.componentKey] = [M], A.addMeshToInfoMap(p.componentKey, p.componentKey, x, M), x.geometryId = p.geometryId, this._cacheActiveMesh(p.userId, p.nodeId, x), g = null, f = null, w = null, m = null, u = null, x } } } } }, mC.prototype._readBufferInfo = function (A, e) { var t = A.getModelDescriptor().getStandardNodeInfos(); if (t) { e || (e = A.getModelDescriptor().getInstancedUserIds()); for (var i = A.getModelDescriptor(), o = A.materialManager.materials, n = A.materialManager.textures, r = 0, a = e.length; a > r; r += 1) for (var s = t[e[r]], l = 0, c = s.length; c > l; l += 1) { var h = i.referencedMeshCache.components[s[l].componentKey], d = h.type; if (-1 !== h.geoId) { var p = this.getGeometryById(h.geoId); if (p || (p = this.getGeometryByNodeInfo(A, s[l]))) if (np(A.dataVersion, "2.0.0")) ; else { var g = o[h.matId]; if (g) { if (A.textureNeedsUpdate && void 0 !== A.dataVersion && ap(A.dataVersion, "2.0.0") && (A.textureNeedsUpdate = !1, g.textures.length > 0)) if (g.materials.length > 1) for (l = 0; g.UVgroup.length > l; l += 1) for (m = (f = g.UVgroup[l]).start, C = f.count, y = f.textureIndex, r = 0; g.groups.length > r; r += 1) { E = (v = g.groups[r]).count, B = v.materialIndex; if ((m === (I = v.start) || m + C === I + E || I > m && C > E) && C >= E) { S = g.materials[B]; (x = n[g.textures[y]]) && S && (S.map = x) } } else g.materials[0].map = n[g.textures[0]] } else if (g = this._readMaterialBuffer(h.matId, A)) { if (0 === g.materials.length) { (v = _u[d] ? _u[d].color : void 0) || (Bh.log("Material not found for type: ", d), v = _u.DEFAULT.color), v || Bh.log("Default material not found for type: ", d); var u = new xr({ color: new LA(v[0], v[1], v[2]) }); 1 > v[3] && (u.transparent = !0, u.opacity = v[3]), u.side = 2, g.materials.push(u), g.groups.push({ start: 0, count: c = p.index.count, materialIndex: 0 }) } if (g.textures.length > 0) if (g.materials.length > 1) for (var l = 0; g.UVgroup.length > l; l += 1) for (var f, m = (f = g.UVgroup[l]).start, C = f.count, y = f.textureIndex, r = 0; g.groups.length > r; r += 1) { var v, I, E = (v = g.groups[r]).count, B = v.materialIndex; if ((m === (I = v.start) || m + C === I + E || I > m && C > E) && C >= E) { var x, S = g.materials[B]; (x = n[g.textures[y]]) && S && (S.map = x) } } else g.materials[0].map = n[g.textures[0]]; p && g && (p.groups = g.groups), o[h.matId] = g.materials } } } else Bh.debug("实体没有几何") } } }, mC.prototype.createMeshNodes = function (A, e) { this._readBufferInfo(A, e), A.hasAnimation && vc.EnableAnimation ? this._makeSkinMesh(A) : this._makeMesh(A) }, mC.prototype.asyncCreateMeshNodes = function (A, e, t) { this._readBufferInfo(A, e), A.hasAnimation && vc.EnableAnimation ? t && t() : this._makeMesh(A, e, t) }, mC.prototype._readMaterialBuffer = function (A, e) { var t = e.getModelDescriptor().referencedMeshCache.materials[A]; if (!t) return null; var i = t.color, o = t.colorIndex, n = t.texture, r = t.textureIndex, a = [], s = [], l = []; new Aa; if (i.length > 4) { for (var c = 0; i.length / 4 > c; c += 1) { var h = new xr({ color: new LA(i[4 * c], i[4 * c + 1], i[4 * c + 2]) }); 1 > i[4 * c + 3] && (h.transparent = !0, h.opacity = i[4 * c + 3]), h.side = 2, a.push(h), h = null } for (var d = null, p = void 0, g = 0; o.length > g; g += 1) { var u = o[g]; u !== p && (p = u, null != d && (d.count = 3 * g - d.start, s.push(d)), d = { start: 3 * g, materialIndex: p }) } null != d && (d.count = 3 * o.length - d.start, s.push(d)) } else if (4 === i.length) { var f = new xr({ color: new LA(i[0], i[1], i[2]) }); 1 > i[3] && (f.transparent = !0, f.opacity = i[3]), f.side = 2, a.push(f), s.push({ start: 0, count: 3 * o.length, materialIndex: 0 }) } for (var m = null, C = void 0, y = r, v = 0; y.length > v; v += 1) { var I = y[v]; I !== C && (C = I, null != m && (m.count = 3 * v - m.start, l.push(m)), m = { start: 3 * v, textureIndex: C }) } return null != m && (m.count = 3 * y.length - m.start, l.push(m)), { materials: a, groups: s, textures: n, UVgroup: l } }, mC.prototype.clearSelectedObjectIds = function () { this.selectedObjectIds.length = 0 }, mC.prototype.cacheSelectedObjectIds = function (A) { this.selectedObjectIds.push(A) }, mC.prototype.adjustVisibility = function (A, e) { var t = this._getNodeGroup(A), i = t.visible; e && !t.bVisible || (t.visible = e), t.bVisible = i }, mC.prototype.changeVisibilityOfSelectedObjects = function (A, e) { var t = A.manager, i = t.octantToObjectMap[A.modelKey].mesh; this.selectedMeshes.length = 0; for (var o = 0, n = this.selectedObjectIds.length; n > o; o += 1) { var r = this.selectedObjectIds[o], a = i[r][0]; a && (t.filter._isVisible({ userId: r }) && (a.visible = e)) } }, mC.prototype.changeVisibilityOfNonSelectedObjects = function (A, e) { var t = A.manager, i = t.octantToObjectMap[A.modelKey].mesh; this.selectedMeshes.length = 0; for (var o = {}, n = 0, r = this.selectedObjectIds.length; r > n; n += 1) { o[this.selectedObjectIds[n]] = !0 } for (var a in i) if (i.hasOwnProperty(a) && !o[a]) { var s = i[a][0]; if (!s) continue; if (!t.filter._isVisible({ userId: a })) continue; s.visible = e } }, mC.prototype.restoreVisibilityOfObjects = function () { this.selectedMeshes.length = 0, this.nonSelectedMeshes.length = 0 }, mC.prototype._getNodeGroup = function (A) { return A._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }) }, mC.prototype.getMeshesByUserIds = function (A, e) { var t = e, i = A.getModelDescriptor().getNodeInfosByComponentKey(t); if (i) { for (var o = [], n = 0, r = i.length; r > n; n += 1) for (var a = i[n], s = a.mesh, l = s._indicesGroup[t], c = 0, h = l.length; h > c; c += 1) { var d = {}; d.mesh = s, d.indexInfo = l[c], d.matrix = s.matrix.clone().multiply(A.getModelMatrix()), d.boundingBox = a.boundingBox.clone().applyMatrix4(d.matrix), o.push(d) } return o } return null }, mC.prototype._getUsedGeometry = function (A, e) { var t = null; if (!vc.Instance && e.uvArrayBuffer) { var i = e.geometryId + "|" + e.nodeId; if (t = this.getGeometryById(i)) return t; var o = this._createGeometryByNodeInfo(A, e); o instanceof Array || (o = [o]), t = []; for (var n = new l, r = new y, a = e.uvArrayBuffer, s = 0, c = o.length; c > s; s += 1) { var h = new he; h.setIndex(o[s].index), h.addAttribute("position", o[s].attributes.position), h.addAttribute("normal", o[s].attributes.normal), n.set(a[6 * s], a[6 * s + 2], a[6 * s + 4], a[6 * s + 1], a[6 * s + 3], a[6 * s + 5], 0, 0, 1); for (var d = [], p = o[s].attributes.uv.array, g = 0, u = p.length; u > g; g += 2) r.set(p[g], p[g + 1], 1), r.applyMatrix3(n), d.push(r.x), d.push(r.y); h.addAttribute("uv", new Ae(d, 2)), t.push(h) } this._cacheGeometry(i, t) } else t = this.getGeometryByNodeInfo(A, e); return t }, mC.prototype.getGeometryBuffersByUserId = function (A, e) { var t = A.getModelDescriptor().getStandardNodeInfosById(e); if (!t) return []; for (var i = [], o = A.getDatabagId(), n = 0, r = t.length; r > n; n += 1) { var a = t[n], s = this.getGeometryByNodeInfo(A, a); if (s) { var l = this._isLines(a); if (s instanceof Array) for (var c = 0, h = s.length; h > c; c += 1) i.push({ isLines: l, databagId: o, nodeId: a.nodeId, position: s[c].getAttribute("position").array, index: s[c].getIndex().array, matrix: a.matrix }); else i.push({ isLines: l, databagId: o, nodeId: a.nodeId, position: s.getAttribute("position").array, index: s.getIndex().array, matrix: a.matrix }) } } return i }, mC.prototype.traverseActiveMeshMap = function (A, e) { for (var t = 0, i = (A = A || Object.keys(this.activeMeshMap)).length; i > t; t += 1) { var o = A[t]; if (this.activeMeshMap[o]) for (var n = Object.keys(this.activeMeshMap[o]), r = 0, a = n.length; a > r; r += 1) { var s = n[r]; e(o, s, this.activeMeshMap[o][s]) } } }, mC.prototype.getActiveMeshMapById = function (A) { return this.activeMeshMap[A] }, mC.prototype._clearActiveMeshMap = function () { this.activeMeshMap = {} }, mC.prototype._cacheActiveMesh = function (A, e, t) { this.activeMeshMap[A] || (this.activeMeshMap[A] = {}), this.activeMeshMap[A][e] || (this.activeMeshMap[A][e] = []), this.activeMeshMap[A][e].push(t) }, mC.prototype._isLines = function (A) { return A.type === $u.EnumNodeItemType.LINE }, mC.prototype.getPickingNodeGenerator = function () { return this.pickingNodeGenerator || (this.pickingNodeGenerator = new uC(this)), this.pickingNodeGenerator }, mC.prototype.isPickableNode = function (A) { return !this.filter || this.filter._isPickable({ userId: A }) }; var CC = function (A) { of .call(this, A), this.nodeGroupName = "PickingWireFrameGroup" }; Object.assign(CC.prototype, of .prototype), eu(CC, [{ key: "disposePickingNodeById", value: function (A) { for (var e = Object.keys(this.pickingNodeMap[A]), t = 0, i = e.length; i > t; t += 1) for (var o = this.pickingNodeMap[A][e[t]], n = 0, r = o.length; r > n; n += 1) o[n].material = null, o[n].geometry.dispose(), o[n] = null } }, { key: "addToPickingNodeMap", value: function (A, e, t) { this.pickingNodeMap || (this.pickingNodeMap = {}), this.pickingNodeMap[A] || (this.pickingNodeMap[A] = {}), this.pickingNodeMap[A][e] = t, this.addToPickingNodeGroup(t) } }, { key: "removeFormPickingNodeGroup", value: function (A) { if (this.pickingNodeGroup) for (var e = Object.keys(this.pickingNodeMap[A]), t = 0, i = e.length; i > t; t += 1) for (var o = this.pickingNodeMap[A][e[t]], n = 0, r = o.length; r > n; n += 1) this.pickingNodeGroup.remove(o[n]) } }, { key: "generatePickingMeshes", value: function (A) { var e = this, t = this.manager; this.manager.manager.getMeshManager().traverseActiveMeshMap(A, (function (A, i, o) { if (!(o && o.length && o[0].isLineSegments || e._isExistNode(A, i))) { var n = 0, r = 0, a = o[0].geometryId, s = []; for (n = 0, r = o.length; r > n; n += 1) s.push(o[n].geometry); var l = t._getWireframeGeometryById(a, s), c = []; for (n = 0, r = l.length; r > n; n += 1) { var h = new jo(l[n], Kd.DefaultMaterial); Tu.copyMeshProperties(h, o[n]), h.renderOrder = 0, c.push(h) } e.addToPickingNodeMap(A, i, c) } })) } }, { key: "_isExistNode", value: function (A, e) { return !!(this.pickingNodeMap && this.pickingNodeMap[A] && this.pickingNodeMap[A][e]) } }, { key: "updatePickingMeshesState", value: function (A, e, t) { if (this.pickingNodeMap) for (var i = this.pickingNodeMap, o = this.manager.manager.getMeshManager(), n = 0, r = e.length; r > n; n += 1) { var a = e[n]; if (i[a] && o.isPickableNode(a)) { var s = o.getActiveMeshMapById(a); if (s) for (var l = Object.keys(i[a]), c = 0, h = l.length; h > c; c += 1) { var d = l[c]; if (s[d]) { var p = i[a][d]; if (p) for (var g = 0, u = p.length; u > g; g += 1) p[g].material = A, p[g].visible = !0 } } } } } }, { key: "resetPickingMeshesState", value: function () { if (this.pickingNodeMap) for (var A = this.pickingNodeMap, e = Object.keys(A), t = 0, i = e.length; i > t; t += 1) for (var o = e[t], n = Object.keys(A[o]), r = 0, a = n.length; a > r; r += 1) for (var s = A[o][n[r]], l = 0, c = s.length; c > l; l += 1) s[l].visible = !1 } }, { key: "updatePickingMeshes", value: function (A, e, t) { return this.generatePickingMeshes(e), this.resetPickingMeshesState(), this.updatePickingMeshesState(A, e, t), this.getPickingNodeGroup() } }]); var yC = function (A) { this.manager = A, this.wireframeGeometries = {}, this.wireframeLineMeshes = {} }; yC.prototype._disposeGeometries = function () { for (var A in this.wireframeGeometries) this._disposeGeometry(A) }, yC.prototype.destroy = function () { this.manager = null, this._clearWireframeLineMeshes(), this.wireframeLineMeshes = null, this._disposeGeometries(), this.wireframeGeometries = null }, yC.prototype.clearData = function () { this._clearWireframeLineMeshes(), this._disposeGeometries() }, yC.prototype.update = function (A, e) { this.isActivateWireframe(A) ? (this._clearWireframeGroupNode(A), this._generateWireframeNodes(A, e), this._getWireWireframeGroupNode(A).updateMatrixWorld(!0)) : this._removeWireframeGroupNode(A) }, yC.prototype._disposeGeometry = function (A) { var e = this.wireframeGeometries[A]; if (e) { if (Array.isArray(e)) for (var t = 0, i = e.length; i > t; t += 1) e[t].dispose(); else e.dispose(); delete this.wireframeGeometries[A] } }, yC.prototype._clearWireframeLineMeshes = function () { for (var A in this.wireframeLineMeshes) delete this.wireframeLineMeshes[A]; this.wireframeLineMeshes = {} }, yC.prototype._clearWireframeGroupNode = function (A) { this._getWireWireframeGroupNode(A).clear() }, yC.prototype._removeWireframeGroupNode = function (A) { A._removeNodeGroup(this._getWireframeGroupName(A)) }, yC.prototype.isActivateWireframe = function (A) { return A.isActivateWireframe() }, yC.prototype._getWireWireframeGroupNode = function (A) { return A._getNodeGroup(this._getWireframeGroupName(A), { globalSpace: !0 }) }, yC.prototype._getWireframeGeometryByNodeInfo = function (A, e) { return this._getWireframeGeometryById(e.geometryId, this.manager.getGeometryByNodeInfo(A, e), A) }, yC.prototype._getWireframeGeometryById = function (A, e, t) { if (this.wireframeGeometries[A]) return this.wireframeGeometries[A]; var i = [], o = null, n = null; if (Array.isArray(e)) for (var r = 0, a = e.length; a > r; r += 1) n = Up(e[r].attributes.position.array, e[r].index.array), (o = new he).setIndex(new $A(n, 1)), o.setAttribute("position", e[r].attributes.position, 3), i.push(o); else n = Up(e.attributes.position.array, e.index.array), (o = new he).setIndex(new $A(n, 1)), o.setAttribute("position", e.attributes.position, 3), i.push(o); return this.wireframeGeometries[A] = i, this.wireframeGeometries[A] }, yC.prototype._makeWireframeLineMeshes = function (A, e, t) { var i = this.wireframeLineMeshes[e.nodeId]; if (!i) { i = this.wireframeLineMeshes[e.nodeId] = []; for (var o = this._getWireframeGeometryByNodeInfo(A, e), n = 0, r = o.length; r > n; n += 1) { var a = new jo(o[n], this._getWireframeMaterial(A)); a.name = e.nodeId + "_" + n, a.applyMatrix4(e.matrix), a.matrixAutoUpdate = !1, i.push(a) } e.wireframeMeshs = i } for (var s = 0, l = i.length; l > s; s += 1) t.add(i[s]) }, yC.prototype._generateWireframeNodes = function (A, e) { var t = this._getWireWireframeGroupNode(A), i = A.getModelDescriptor().getStandardNodeInfos(); e || (e = A.getModelDescriptor().getStandardUserIds()); for (var o, n, r = this.manager.getHiddenUserIds(), a = 0; e.length > a; a += 1) { var s = e[a], l = i[s][0]; r[s] || (o = l, n = this._getFilter(A), o.type === Qf.EnumNodeItemType.LINE || vc.Instance && ("box" === o.geometryId || "boxM" === o.geometryId) || n._hasRenderWithBoardlineFilter() && !n._isRenderWithBoardline(o) || this._makeWireframeLineMeshes(A, l, t)) } }, yC.prototype._getWireframeGroupName = function (A) { return A._getWireframeGroupName() }, yC.prototype._getWireframeMaterial = function (A) { return A.getWireframeMaterial() }, yC.prototype._getFilter = function (A) { return A.manager.filter }, yC.prototype.adjustVisibility = function (A, e) { if (A.isActivateWireframe()) { var t = this._getWireWireframeGroupNode(A), i = t.visible; e && !t.bVisible || (t.visible = e), t.bVisible = i } }, yC.prototype.changeVisibilityOfSelectedObjects = function (A, e) {}, yC.prototype.changeVisibilityOfNonSelectedObjects = function (A, e) { this.adjustVisibility(A, e) }, yC.prototype.restoreVisibilityOfObjects = function () {}, yC.prototype.getPickingNodeGenerator = function () { return this.pickingNodeGenerator || (this.pickingNodeGenerator = new CC(this)), this.pickingNodeGenerator }; var vC = function (A) { this.meshManager = new mC(this), this.model = A, this.wireframeManager = new yC(this) }; vC.prototype.destroy = function () { this.meshManager.destroy(), this.meshManager = null, this.wireframeManager.destroy(), this.wireframeManager = null }, vC.prototype.clearData = function () { this.meshManager.clearData(), this.wireframeManager.clearData() }, vC.prototype.disposeGeometry = function (A) { this.meshManager.disposeGeometry(A) }, vC.prototype.cullNodes = function (A, e) { this.hasNodeInfo(A) && this.meshManager.cullNodes(A, e) }, vC.prototype.updateNodes = function (A, e) { if (this.hasNodeInfo(A)) { var t; t = this._collectModelFiltered(A), this.meshManager.update(A, e, t), this.wireframeManager.update(A, e) } }, vC.prototype.applyFilter = function (A, e) { console.log('applyFilter :>dfdfdfdf> '); if (this.hasNodeInfo(A)) { var t = null; t = e || A.getModelDescriptor().getStandardUserIds(); var i = A.getModelDescriptor().getStandardNodeInfos(); this._collectFilteredUserIds(A.manager.filter, t, i), this._collectSelectedUserIds(A.manager.sceneState.selectionSet, i), this._collectHoveredUserIds(A.manager.sceneState.hoverId, i), this.updateNodes(A, e) } }, vC.prototype.applySelection = function (A) { console.log('applySelection18') if (this.hasNodeInfo(A)) { var e = A.getModelDescriptor().getStandardNodeInfos(); this._clearSelectedState(A), this._clearHoveredState(A), this._collectSelectedUserIds(A.manager.sceneState.selectionSet, e), this._collectHoveredUserIds(A.manager.sceneState.hoverId, e), this.updateNodes(A) } }, vC.prototype.clearSelection = function (A) { this._clearSelectedState(A), this.applyHover(A) }, vC.prototype.applyHover = function (A) { if (this.hasNodeInfo(A)) { var e = A.getModelDescriptor().getStandardNodeInfos(); this._clearHoveredState(A), this._collectHoveredUserIds(A.manager.sceneState.hoverId, e), this.updateNodes(A) } }, vC.prototype.clearHover = function (A) { this._clearHoveredState(A), this.updateNodes(A) }, vC.prototype.applyBlink = function (A) {}, vC.prototype.clearBlink = function (A) {}, vC.prototype.getPriorityNodes = function () { return this.meshManager.getPriorityNodes() }, vC.prototype.getGeometryByNodeInfo = function (A, e) { return this.meshManager.getGeometryByNodeInfo(A, e) }, vC.prototype.getRenderableCount = function (A) { return A.renderableCount }, vC.prototype.getLoader = function (A) { return A.loader }, vC.prototype.getContainsCamera = function (A) { return A.containsCamera }, vC.prototype.getFilter = function (A) { return A.manager.filter }, vC.prototype.hasNodeInfo = function (A) { return !!A.getModelDescriptor().getStandardNodeInfos() }, vC.prototype.createMeshNodes = function (A) { this.meshManager.createMeshNodes(A) }, vC.prototype.asyncCreateMeshNodes = function (A, e, t) { this.meshManager.asyncCreateMeshNodes(A, e, t) }, vC.prototype._collectFilteredUserIds = function (A, e, t) { var i = A._hasHiddenFileIdFilter(), o = A._hasVisibleFilter(), n = A._hasOverrideMaterialFilter(), r = A._hasTransparentFilter(); this.mapMaterialIdToUserIdsForFilter = {}; if (this.hiddenUserIdSetObject = {}, this.overrideUserIdSetObject = {}, this.transparentUserIdSetObject = {}, i || o || n || r) for (var a = 0; e.length > a; a += 1) { var s = e[a], l = t[s]; if (l && l.length) for (var c = 0, h = l.length; h > c; c += 1) { var d = l[c]; if (i && A._isHiddenFileId(d) || o && !1 === A._isVisible(d)) this.hiddenUserIdSetObject[s] = !0; else if (r && A._isTransparent(d)) this.transparentUserIdSetObject[s] = !0; else if (n && A._hasOverrideMaterial(d)) { var p = A._getOverrideMaterial(d); if (Array.isArray(p)) { for (var g = [], u = 0, f = p.length; f > u; u++) { var m = null !== p[u] ? p[u].name : ""; "" !== m && g.push(m) } this.overrideUserIdSetObject[s] = g } else { var C = null !== p ? p.name : ""; "" !== C && (this.overrideUserIdSetObject[s] = C) } } } } }, vC.prototype._collectModelFiltered = function (A) { var e = A.manager.filter, t = A.modelKey, i = e._hasModelOverrideMaterialFilter(), o = e._hasModelTransparentFilter(), n = A.manager.modelState.selectionSet; return A.manager.modelState.hoverId === t ? A.manager.modelState.getHoverMaterial() : n.hasOwnProperty(A.modelKey) ? A.manager.modelState.selectionMaterial : o && e._isModelTransparent(t) ? e._getMaterialByName("scene") : i && e._hasModelOverrideMaterial(t) ? e._getModelOverrideMaterial(t) : null }, vC.prototype._clearFilteredState = function () { this.hiddenUserIdSetObject = {}, this.overrideUserIdSetObject = {}, this.transparentUserIdSetObject = {} }, vC.prototype.getFilteredUserIds = function () { return this.mapMaterialIdToUserIdsForFilter }, vC.prototype.getSelectedUserIds = function () { return this.mapMaterialIdToUserIdsForSelection }, vC.prototype.getHoveredUserIds = function () { return this.mapMaterialIdToUserIdsForHover }, vC.prototype.getBlinkedUserIds = function () { return this.mapBlinkUserIds }, vC.prototype.getHiddenUserIds = function () { return this.hiddenUserIdSetObject }, vC.prototype._collectSelectedUserIds = function (A, e) { for (var t in this.selectedUserIdSetObject = {}, A) if (A.hasOwnProperty(t)) { if (!e[t]) continue; this.selectedUserIdSetObject[t] = !0 } }, vC.prototype._clearSelectedState = function () { this.selectedUserIdSetObject = {} }, vC.prototype._collectHoveredUserIds = function (A, e) { if (this.hoveredUserIdSetObject = {}, A && e[A]) { var t = e[A]; this.hoveredUserIdSetObject = {}, t && (this.hoveredUserIdSetObject[A] = !0) } }, vC.prototype._clearHoveredState = function () { this.hoveredUserIdSetObject = {} }, vC.prototype.getMeshesByUserIds = function (A, e) { return this.meshManager.getMeshesByUserIds(A, e) }, vC.prototype.adjustVisibility = function (A, e) { this.meshManager.adjustVisibility(A, e), this.wireframeManager.adjustVisibility(A, e) }, vC.prototype.changeVisibilityOfSelectedObjects = function (A, e) { this.meshManager.changeVisibilityOfSelectedObjects(A, e), this.wireframeManager.changeVisibilityOfSelectedObjects(A, e) }, vC.prototype.changeVisibilityOfNonSelectedObjects = function (A, e) { this.meshManager.changeVisibilityOfNonSelectedObjects(A, e), this.wireframeManager.changeVisibilityOfNonSelectedObjects(A, e) }, vC.prototype.restoreVisibilityOfObjects = function () { this.meshManager.restoreVisibilityOfObjects(), this.wireframeManager.restoreVisibilityOfObjects() }, vC.prototype.isPickableNode = function (A) { var e = this.getHiddenUserIds(); if (e && e[A]) return !1; var t = this.getTransparentUserIds(); return !t || !t[A] }, vC.prototype.isHiddenNode = function (A) { var e = this.getHiddenUserIds(); return !(!e || !e[A]) }, vC.prototype.getMeshManager = function () { return this.meshManager }, vC.prototype.getWireFrameManager = function () { return this.wireframeManager }, vC.prototype.getTransparentUserIds = function () { return this.transparentUserIdSetObject }; var IC = function (A) { return hC.call(this, A), this.tag = "layer", this.defaultManager = new vC, this.instancedManager = new Hf, this.loader = new gC(this), this }; (IC.prototype = Object.assign(IC.prototype, hC.prototype)).destroy = function () { this.defaultManager.destroy(), this.defaultManager = null, this.instancedManager.destroy(), this.instancedManager = null }, IC.prototype.prepareData = function (A) {}, IC.prototype.prepare = function (A) { this.isAllReady() && (this.model.getMaterialManager()._updateTextureMapping(), this.model.clearMeshFromOctantMap()) }, IC.prototype.updateNodes = function () {}, IC.prototype.addNodeInfoToOctantMap = function () {}, IC.prototype.dealMeshNodes = function (A) { A && A() }, IC.prototype.disposeBufferAfterVbo = function () {}, IC.prototype.dealMeshNodes = function (A) { this.model.getModelDescriptor().getInstancedUserIdsByCategory(this._loadedUserIds); var e = this.model, t = this; this.defaultManager.asyncCreateMeshNodes(e, e.getModelDescriptor().getStandardUserIds(), (function () { t.updateNodes(), A && A() })) }, IC.prototype.unloadComponents = function (A, e) { for (var t = this.model.modelKey, i = 0, o = A.length; o > i; i += 1) { var n = this.model.getModelDescriptor().getNodeInfosByComponentKey(A[i]); if (n) { for (var r = 0, a = n.length; a > r; r += 1) { var s = n[r]; if (s.mesh) this.defaultManager.meshManager.disposeGeometry(s.mesh.geometry.key), s.mesh.destroy() } this.model.manager.removeMeshFromOctantMap(t, A[i]) } } this.model.getModelDescriptor().clearNodeInfoCacheByComponentsKey(A), e && e() }; var EC = function (A) { Af.call(this, A), this.instancedComponent = {} }; Object.assign(EC.prototype, Af.prototype), EC.prototype.parseItemData = function (A) { this._readMaterialBuffer(this.model), this._parseGeo(), vc.Instance && this._parseInstanced(); var e = {}, t = this.referencedMeshCache; for (var i in Bh.time("_readItemData"), t.components) t.components.hasOwnProperty(i) && this._readItemData(e, i, i, void 0, 0); Bh.timeEnd("_readItemData"), e = null, A && A() }, EC.prototype._readItemData = function (A, e, t) { var i = this.referencedMeshCache.components[e]; void 0 !== i && this._readMeshInfo(A, t, i, null) }, EC.prototype._readMeshInfo = function (A, e, t, i) { var o = this.referencedMeshCache, n = this.model.materialManager.materials, r = null, a = null, s = this.model.subModel[t.subModel]; if (t.nodes || t.nodeIds) { a = t.originalId; var l = (new M).fromArray(t.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]); t.matrix = l; var c = []; c = t.nodes ? t.nodes : t.nodeIds; for (var h = 0; c.length > h; h += 1) { var d = c[h]; if ("object" !== lc(d) && (d = this.getReferencedMeshComponentNodeById(d)), d) { var p, g = null, u = ""; if (-1 !== d.geoId) if ((g = this._getMeshNodeAttr(d, t, h)).boundingBox.applyMatrix4(s), g) { if (t.buildInCategory && (g.buildInCategory = t.buildInCategory), !n[u = d.material]) { var f = _u[t.type] ? _u[t.type].color : void 0; f || (Bh.log("Material not found for type: ", t.type), f = _u.DEFAULT.color), f || (Bh.log("Default material not found for type: ", t.type), f = [1, 1, 1, 1]); var m = new LA(f[0], f[1], f[2]), C = u || m.getHexString() + "_" + f[3], y = n[C]; y || (Bh.warn("缺少材质 " + u), y = Kd.createStandardMaterial({ color: m }), 1 > f[3] && (y.transparent = !0, y.opacity = f[3]), y.side = 2, n[C] = y), g.material = u = C } if (n[u].aoMap) { var v = this.getReferencedMeshBufferById(g.geometryId); v && (v.uv2 = v.uv) } p = g.nodeId; var I = (R = this.userDataReader) ? R.getUserData(r) : null; g.type = t.type, g.userId = e, g.name = t.name, g.userDataId = r, g.originalId = a, g.materialId = u, g.originMId = u, g.userData = I, g.categoryId = 0, g.componentKey = e, g.familyName = t.familyName, g.familySymbol = t.familySymbol; var E = vc.Instance, B = o.reuseNodes.hasOwnProperty(p); g.instanceOrNot = !(!E || !B), g.isBatched = !0, g.state = Lc.Visible, g.material = null, this._classifyNodeInfo(g), g = null } else Bh.debug("非法node") } } } else { var x = t, S = ""; if (null === i ? (r = x.userDataId, a = x.originalId, S = x.materialId || x.matId) : (r = i.userDataId, a = i.originalId, S = i.materialId > -1 ? i.materialId : x.materialId), x.materials || (x.materials = []), x.materials.length > 0) for (h = 0; x.materials.length > h; h += 1) { var w = null; if (w = this._getOldMeshNodeAttr(A, x, x.materials.length > 1, h)) { if (x.buildInCategory && (w.buildInCategory = x.buildInCategory), w.boundingBox.applyMatrix4(s), !n[S = x.materials[h]]) { var b = _u[x.type] ? _u[x.type].color : void 0; b || (Bh.log("Material not found for type: ", x.type), b = _u.DEFAULT.color), b || (Bh.log("Default material not found for type: ", x.type), b = [1, 1, 1, 1]); var U = new LA(b[0], b[1], b[2]), F = S || U.getHexString() + "_" + b[3], K = n[F]; K || (Bh.warn("缺少材质 " + S), K = Kd.createStandardMaterial({ color: U }), 1 > b[3] && (K.transparent = !0, K.opacity = b[3]), K.side = 2, n[F] = K) } if (n[S].aoMap) { var Q = this.getReferencedMeshBufferById(w.geometryId); Q && (Q.uv2 = Q.uv) } if (!w) return; var R; I = (R = this.userDataReader) ? R.getUserData(r) : null; w.type = x.type, w.userId = x.key, w.name = x.name, w.userDataId = r, w.originalId = a, w.materialId = S, w.originMId = S, w.userData = I, w.categoryId = 0, w.componentKey = x.key, w.familyName = x.familyName, w.familySymbol = x.familySymbol, vc.Instance && this.instancedComponent[x.key] ? w.instanceOrNot = !0 : (w.instanceOrNot = !1, this.instancedGeo[w.originalGeometryId].length > 1 && (w.originalGeometryId = "")), w.state = Lc.Visible, w.material = null, w.isBatched = !0, this._classifyNodeInfo(w), w = null } else Bh.debug("非法node") } else { var T = null, k = _u[x.type] ? _u[x.type].color : void 0; k || (Bh.log("Material not found for type: ", x.type), k = _u.DEFAULT.color), k || (Bh.log("Default material not found for type: ", x.type), k = [1, 1, 1, 1]); var D = new LA(k[0], k[1], k[2]), L = D.getHexString() + "_" + k[3], N = n[L]; if (N || (N = Kd.createStandardMaterial({ color: D }), 1 > k[3] && (N.transparent = !0, N.opacity = k[3]), N.side = 2, n[L] = N), x.materials.push(L), (T = this._getOldMeshNodeAttr(A, x, !1, 0)).boundingBox.applyMatrix4(s), S = x.materials[0], !T) return; e = x.key; T.type = x.type, T.userId = e, T.name = x.name, T.originalId = a, T.materialId = S, T.originMId = S, T.userData = {}, T.categoryId = 0, T.componentKey = e, T.familyName = x.familyName, T.familySymbol = x.familySymbol, T.instanceOrNot = !(!vc.Instance || !this.instancedComponent[e]), T.isBatched = !0, T.state = Lc.Visible, T.material = null, this._classifyNodeInfo(T), T = null } } }, EC.prototype._getMeshNodeAttr = function (A, e, t) { var i = new M; i.fromArray(A.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]), vc.DataReduction && i.scale(new y(1e3, 1e3, 1e3)), e && i.multiplyMatrices(e.matrix, i), A.geoId = e.subModel + A.geoId; var o = A.nodeId, n = A.geoId; if (-1 !== n) { var r = A.maxBoundary || e.maxBoundary, a = A.minBoundary || e.minBoundary, s = new ph; return s.set(a, r), { nodeId: o, guid: A.guid, geometryId: n, originalGeometryId: A.geoId, matrix: i, boundingBox: s, model: this.model } } }, EC.prototype._getOldMeshNodeAttr = function (A, e, t, i) { var o = new M; o.fromArray(e.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]), vc.DataReduction && o.scale(new y(1e3, 1e3, 1e3)); var n = t ? e.key + "_" + i : e.key, r = t ? e.geoId + "_" + i : e.geoId; if (-1 !== r) { var a = new ph, s = this.getReferencedMeshBufferById(e.geoId); return s && s.position ? (a = Tu.getBoundingBoxByBuffer(s.position)).applyMatrix4(o) : Bh.warn("no position "), { nodeId: n, guid: e.guid, geometryId: r, originalGeometryId: e.geoId, matrix: o, boundingBox: a, model: this.model } } }; var BC = function (A) { Xu.call(this, A), this.maxGeoLoadTaskCount = 0, this.geoLoadTaskCount = 0, this.taskInstancedGeometrieManager = new Ou(this, "geometrie"), this.descriptor = new EC(A.model) }; (BC.prototype = Object.assign(BC.prototype, Xu.prototype)).loadData = function () { for (var A = this, e = this, t = this.model, i = t.getConfig(), o = !1, n = 0, r = 0, a = 0, s = 0, l = [], c = [], h = [], d = [], p = [], g = [], u = [], f = [], m = [], C = function (C, y) { var v = i.children[C]; if (E = i.animation, !(I = i.scene[C]) || !I.components || !I.geometries && (!I.batchedGeometries && !I.instancedGeometries || 1 > I.batchedGeometries.length && 1 > I.instancedGeometries.length) || !I.materials || !I.textures) return Bh.error("scene is null,modelKey is ", t.modelKey), t.dispatchEventEx({ type: Rc.ON_LOAD_EMPTY_SCENE, modelKey: t.modelKey }), "continue"; if (o = !0, n += I.components.length || 0, I.components.forEach((function (A) { e.fileKeyFromModelKey[A] = v })), r += I.materials.length || 0, a += I.textures.length || 0, s += I.reuseNodes && I.reuseNodes.length || 0, u = u.concat(I.textures), A.map = A.map || [], 2 > Number(I.geo)) return Bh.error("不支持1.0版本的几何结构和其他版本混合加载。"), { v: void 0 }; if (l = l.concat(I.components), h = h.concat(I.materials), m = m.concat(I.reuseNodes || []), Array.isArray(I.nodes) && (c = c.concat(I.nodes)), u = u.concat(I.textures), I.map && A.map.push(I.map), I.trees.length > 0) for (B = 0; I.trees.length > B; B += 1) "partition" === (x = I.trees[B]).type && (f.push(x.fileKey), e.fileKeyFromModelKey[x.fileKey] = v); I.lights && I.lights.length > 0 && (g = g.concat(I.lights)), E && (E.bones.length, E.bones, d.push(E.clips), p.push(E.nodes)) }, y = 0, v = i.scene.length; v > y; y += 1) { var I, E, B, x, S = C(y); switch (S) { case "continue": continue; default: if ("object" === lc(S)) return S.v } } if (t.setEmptyScene(!o), e.maxLoadTaskCount = 0, e.maxLoadTaskCount += n, e.maxLoadTaskCount += r, e.maxLoadTaskCount += f.length, e.maxLoadTaskCount += s, e.maxLoadTaskCount += c.length, e.maxLoadTaskCount += g.length, 1 > e.maxLoadTaskCount) return Bh.info("Nothing to load ", t.modelKey), void t.dispatchEventEx({ type: Tc.SCENE_NOTHING_TO_LOAD, modelKey: t.modelKey }); e.progress.total += e.maxLoadTaskCount, e.startCallback && e.startCallback(), Bh.time("数据加载时间"), e._loadComponent(l), e._loadMaterial(h), e._loadComponentNode(c), e._loadReuseNode(m), vc.EnableTextureLoading && a > 0 ? (e.maxLoadTextureCount += a, e._loadTextures(u)) : e._onLoadTexture(), e._loadKDTree(f), g.length > 0 && e._loadLights(g), e.offLine && e.loadAttribute(), e.loadFloorInfo(e.model.modelKey), e.loadSceneAndGeos(i) }, BC.prototype.loadReuseNode = function (A, e) { var t = this, i = this.jsonLoader, o = this.model, n = this.url; i.setResponseType("json"), vc.useGzip && i.setResponseType("arraybuffer"), i.setCacheViable(!0); i.load(n.mpkUrl(A), (function (A) { t._parseReuseNodes(A), Bh.debug("component load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) })) }, BC.prototype._parseComponent = function (A, e) { var t = this.fileKeyFromModelKey[e] || ""; if (A) { var i = this.descriptor; if (i) for (var o in vc.useGzip && (A = JSON.parse(uh.ab2str(pako.ungzip(A)))), A) if (A.hasOwnProperty(o)) { var n = A[o]; - 1 !== n.geoId && (n.geoId = t + n.geoId, n.subModel = t), i.cacheReferencedMeshComponentData(A[o].key, A[o]) } } else Bh.error("没有数据") }, BC.prototype._parseMaterial = function (A, e) { if (A) { if (A instanceof ArrayBuffer) try { A = JSON.parse(uh.ab2str(A)) } catch (A) { Bh.error("处理材质出错") } var t = this.descriptor; if (t) for (var i in A) t.cacheReferencedMeshMaterialData(i, A[i]) } else Bh.error("没有数据") }, BC.prototype.loadBatchedGeometrie = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model; i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine); var r = i.load(o.mpkUrl(A), (function (i) { t._parseBatchedGeometrie(i, A), Bh.debug("geo load from online"), t._onGeoTaskFinished(), e() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_GEOMETRY_ERROR, modelKey: n.modelKey }), e(), t._onGeoTaskFinished() })); t.requests.loadGeometrie = r }, BC.prototype.loadInstancedGeometrie = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model; i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine); var r = i.load(o.mpkUrl(A), (function (i) { t._parseInstancedGeometrie(i, A), Bh.debug("geo load from online"), t._onGeoTaskFinished(), e() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_GEOMETRY_ERROR, modelKey: n.modelKey }), e(), t._onGeoTaskFinished() })); t.requests.loadGeometrie = r }, BC.prototype._parseBatchedGeometrie = function (A, e) { var t = this.fileKeyFromModelKey[e] || "", i = new ku.BatchedGeometryReader(A, this.dataVersion), o = this.descriptor; if (o) { for (var n = i.geoCount, r = 0; n > r; r += 1) { var a = i.geomMap[r]; void 0 !== a.position && void 0 !== a.index && void 0 !== a.normal ? (a.geoId = t + a.geoId, o.cacheReferencedMeshBufferData(a.geoId, a), this.handler.createBatchedMeshNodes(a)) : Bh.error("Error Geometry!") } this.model.manager.viewerImpl.render(), i = null } }, BC.prototype._parseInstancedGeometrie = function (A, e) { var t = this.fileKeyFromModelKey[e] || "", i = new ku.InstancedGeometryReader(A, this.dataVersion), o = this.descriptor; if (o) { for (var n = i.geoCount, r = 0; n > r; r += 1) { var a = i.geomMap[r]; void 0 !== a.position && void 0 !== a.index && void 0 !== a.normal ? (a.geoId = t + a.geoId, o.cacheReferencedMeshBufferData(a.geoId, a), this.handler.createInstancedMeshNodes(a)) : Bh.error("Error Geometry!") } this.model.manager.viewerImpl.render(), i = null } }, BC.prototype._parseReuseNodes = function (A, e) { if (A) { vc.useGzip && (A = JSON.parse(uh.ab2str(pako.ungzip(A)))); var t = this.descriptor; if (t) if (t.referencedMeshCache.reuseNodes) for (var i in A) t.referencedMeshCache.reuseNodes[i] = A[i]; else t.referencedMeshCache.reuseNodes = A } else Bh.error("没有数据") }, BC.prototype.startLoadSceneAndGeos = function (A) { Bh.time("几何数据加载时间"); for (var e = A.scene, t = this, i = 0, o = 0, n = [], r = [], a = function (a, s) { var l = e[a], c = A.children[a]; (l.batchedGeometries && l.batchedGeometries.length > 0 || l.instancedGeometries && l.instancedGeometries.length > 0) && (i += l.batchedGeometries.length || 0, o += l.instancedGeometries.length || 0, n = n.concat(l.batchedGeometries), r = r.concat(l.instancedGeometries), l.batchedGeometries.forEach((function (A) { t.fileKeyFromModelKey[A] = c })), l.instancedGeometries.forEach((function (A) { t.fileKeyFromModelKey[A] = c }))) }, s = 0, l = e.length; l > s; s += 1) a(s); t.maxGeoLoadTaskCount += i, t.maxGeoLoadTaskCount += o, t.maxGeoLoadTaskCount > 0 || t._onGeoTaskFinished(), this._loadBatchedGeo(n), this._loadInstancedGeo(r) }, BC.prototype.loadSceneAndGeos = function (A) { for (var e = A.scene, t = this, i = 0, o = [], n = function (n, r) { var a = e[n], s = A.children[n]; a.geometries && a.geometries.length > 0 && !(a.batchedGeometries && a.batchedGeometries.length > 0 || a.instancedGeometries && a.instancedGeometries.length > 0) && (i += a.geometries.length || 0, o = o.concat(a.geometries), a.geometries.forEach((function (A) { t.fileKeyFromModelKey[A] = s }))) }, r = 0, a = e.length; a > r; r += 1) n(r); t.maxLoadTaskCount += i, this._loadGeo(o) }, BC.prototype._loadBatchedGeo = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = function (t) { if (A[i[t]]) if (!0 === A[i[t]].split) { var o = A[i[t]].list, s = new Uint8Array(A[i[t]].length); n.getBatch(o, (function (A) { for (var n = !0, r = 0; o.length > r; r += 1) A[o[r]] ? s.set(new Uint8Array(A[o[r]]), 4e7 * r) : (n = !1, Bh.error("获取分割几何失败")); if (n) { var a = i[t].indexOf("fileKey="); e._parseBatchedGeometrie(s.buffer, i[t].slice(a + 8)), e._onGeoTaskFinished(), Bh.debug("load geo from local") } else { var l = e.taskGeometrieManager, c = i[t].indexOf("fileKey="); if (-1 === c) return void Bh.error("url is not has fileKey"); l.addTask(i[t].slice(c + 8)), Bh.debug("load geo from net"), e.taskGeometrieManager.processTasks(e.loadBatchedGeometrie.bind(e)) } }), (function () { Bh.error("获取分割几何失败") })) } else a = i[t].indexOf("fileKey="), e._parseBatchedGeometrie(A[i[t]], i[t].slice(a + 8)), e._onGeoTaskFinished(), Bh.debug("load geo from local"); else { if (r = e.taskGeometrieManager, -1 === (a = i[t].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; r.addTask(i[t].slice(a + 8)), Bh.debug("load geo from net") } }, o = 0; i.length > o; o += 1) { var r, a, s = t(o); if ("object" === lc(s)) return s.v } e.taskGeometrieManager.processTasks(e.loadBatchedGeometrie.bind(e)) }), (function () { for (var t = e.taskGeometrieManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadBatchedGeometrie.bind(e)) })) } else { for (var r = this.taskGeometrieManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadBatchedGeometrie.bind(e)) } }, BC.prototype._loadInstancedGeo = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = function (t) { if (A[i[t]]) if (!0 === A[i[t]].split) { var o = A[i[t]].list, s = new Uint8Array(A[i[t]].length); n.getBatch(o, (function (A) { for (var n = 0; o.length > n; n += 1) A[o[n]] ? s.set(new Uint8Array(A[o[n]]), 4e7 * n) : Bh.error("获取分割几何失败"); var r = i[t].indexOf("fileKey="); e._parseInstancedGeometrie(s.buffer, i[t].slice(r + 8)), e._onGeoTaskFinished(), Bh.debug("load geo from local") }), (function () { Bh.error("获取分割几何失败") })) } else a = i[t].indexOf("fileKey="), e._parseInstancedGeometrie(A[i[t]], i[t].slice(a + 8)), e._onGeoTaskFinished(), Bh.debug("load geo from local"); else { if (r = e.taskInstancedGeometrieManager, -1 === (a = i[t].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; r.addTask(i[t].slice(a + 8)), Bh.debug("load geo from net") } }, o = 0; i.length > o; o += 1) { var r, a, s = t(o); if ("object" === lc(s)) return s.v } e.taskInstancedGeometrieManager.processTasks(e.loadInstancedGeometrie.bind(e)) }), (function () { for (var t = e.taskInstancedGeometrieManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadInstancedGeometrie.bind(e)) })) } else { for (var r = this.taskInstancedGeometrieManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadInstancedGeometrie.bind(e)) } }, BC.prototype._onGeoTaskFinished = function () { (this.geoLoadTaskCount += 1, this.notifyProgress) && (this.progressCallback && this.progressCallback({ total: this.maxLoadTaskCount + this.maxGeoLoadTaskCount, loaded: .8 * (this.loadTaskCount + this.geoLoadTaskCount), modelKey: this.model.modelKey })); this.maxGeoLoadTaskCount > this.geoLoadTaskCount || (this.dataLoaded = !0, Bh.timeEnd("几何数据加载时间"), this.geoFinishCallback && this.geoFinishCallback()) }, BC.prototype.getSceneTaskCount = function (A) { var e = A.scenes; return e += A.lines, e += A.mpks, vc.BorderLineDelayLoaded || (e += this.getAllBorderlineCount()), e }, BC.prototype._parseKDTree = function (A, e) { var t = {}; t = "string" == typeof A ? JSON.parse(A) : A, this.model.kdTreeNode = this.model.kdTreeNode || []; var i = this.fileKeyFromModelKey[e] || ""; if (t) { var o = new Zu; o.modelKey = i, o.init(t), this.model.kdTreeNode.push(o) } }; var xC = function (A, e) { tf.call(this, A), this.defaultManager = new Of(e, A), this.instancedManager = new Hf(A), this.loader = new BC(this) }; (xC.prototype = Object.create(tf.prototype)).prepare = function (A, e) { if (this.isLoaded() && !this.isHidden()) { this.prepareWireframe(this.model, e); this.model.getMaterialManager(); this.model.getMaterialManager()._updateTextureMapping(), !this.model.lightmap || this.model.enableLightmap === vc.EnableLightmap && this.model.lightmapIntensity === vc.LightmapIntensity || (this.model.enableLightmap = vc.EnableLightmap, this.model.lightmapIntensity = vc.LightmapIntensity, this.rebuildIndicesforLightmap(), this.updateNodes()) } }, xC.prototype.settleData = function (A) { var e = this; this.addNodeInfoToOctantMap(); var t = !1, i = !1; this.createMeshNodes((function () { t = !0, i && (e.loaded = !0, e.model.getMaterialManager()._updateTextureMapping(), e.clearCachedData(e.model), A && A()) })), e.model.setLoaded(!0); this.loader.geoFinishCallback = function () { i = !0, t && (e.loaded = !0, e.model.getMaterialManager()._updateTextureMapping(), e.clearCachedData(e.model), A && A()) }, this.loader.startLoadSceneAndGeos(this.model.getConfig()) }, xC.prototype.addNodeInfoToOctantMap = function () { var A = this.model.manager, e = this.model.getEncodedDatabagId(); this.loader.getDescriptor().traverseNodeInfosByComponent((function (t, i) { A.addNodeInfoToOctantMap(e, t, i) })) }, xC.prototype.createMeshNodes = function (A) { var e = this, t = this.model; vc.stepLoad && t.setLoaded(!0); var i = this.loader.getDescriptor(); this.instancedManager.createMeshNodes(t, i.getInstancedUserIds()), this.defaultManager.asyncCreateMeshNodes(t, i.getStandardUserIds(), (function () { t.getMaterialManager()._updateTextureMapping(), e.loaded = !0, A && A() })) }, xC.prototype.clearCachedData = function (A) { this.loader.getDescriptor().destroyReader(), this.loader.getDescriptor().clearReferencedMeshCache(), this.defaultManager.clearCachedData(), this.instancedManager.clearCachedData() }, xC.prototype.createBatchedMeshNodes = function (A) { this.defaultManager.createBatchedMeshNodes(this.model, A) }, xC.prototype.createInstancedMeshNodes = function (A) { this.instancedManager.createInstancedMeshNodes(this.model, A) }; var SC = function (A) { $u.call(this, A) }; Object.assign(SC.prototype, $u.prototype); var wC = function (A) { Xu.call(this, A), this.descriptor = new SC(A.model) }; (wC.prototype = Object.assign(wC.prototype, Xu.prototype)).loadSceneAndGeos = function (A) { var e = A.scene, t = this.model, i = e.geometries.length || 0, o = []; if (this.map = {}, ap(this.dataVersion, "2.0.0")) for (var n = 0; i > n; n += 1) e.geometries[n].fileKey ? o.push(e.geometries[n].fileKey) : t.dispatchEventEx({ type: Tc.SCENE_NOT_CLOSE, modelKey: t.modelKey }); else o = e.geometries; this.maxLoadTaskCount += i, this._loadGeo(o) }, wC.prototype.getSceneTaskCount = function (A) { var e = A.scenes; return e += A.lines, e += A.mpks, vc.BorderLineDelayLoaded || (e += this.getAllBorderlineCount()), e }; var MC = function (A, e) { tf.call(this, A), this.defaultManager = new vC(e, A), this.instancedManager = new Hf(A), this.loader = new wC(this) }; Object.assign(MC.prototype, tf.prototype), MC.prototype.prepare = function (A) { this.isLoaded() && !this.isHidden() && (this.model.getMaterialManager()._updateTextureMapping(), this.model.clearMeshFromOctantMap(), this.instancedManager.addAllInstanceNodeToScene(this.model), this.defaultManager.cullNodes(this.model, A), this.prepareWireframe(this.model), this.updateNodes()) }, MC.prototype.prepareWireframe = function (A, e) { A.isActivateWireframe() && this.instancedManager.generateWireframe(A) }, MC.prototype.settleData = function (A) { this.addNodeInfoToOctantMap(), this.createMeshNodes(A) }, MC.prototype.addNodeInfoToOctantMap = function () { var A = this.model.manager, e = this.model.getEncodedDatabagId(); this.model.getModelDescriptor().traverseNodeInfosByComponent((function (t, i) { A.addNodeInfoToOctantMap(e, t, i) })) }, MC.prototype.createMeshNodes = function (A) { var e = this.model, t = this; this.instancedManager.createMeshNodes(this.model, this.model.getModelDescriptor().getInstancedUserIds()), this.defaultManager.asyncCreateMeshNodes(e, e.getModelDescriptor().getStandardUserIds(), (function () { e.getMaterialManager()._updateTextureMapping(), t.updateNodes(), e.getModelDescriptor().clearReferencedMeshCache(), t.loaded = !0, A && A() })) }, MC.prototype.disposeBufferAfterVbo = function () {}, MC.prototype.explosion = function (A) { if (this.isLoaded()) { var e = this.model.getComponentlist(); A.componentKey = e, this.componentsExplosion(A) } }, MC.prototype.closeExplosion = function () { this.explosion({}) }, MC.prototype.componentsExplosion = function (A) { if (this.isLoaded()) { var e = A.coefficientX || 1, t = A.coefficientY || 1, i = A.coefficientZ || 1, o = A.offsetX || 0, n = A.offsetY || 0, r = A.offsetZ || 0, a = null; if (A.center) a = (new y).fromArray(A.center); else if (1 !== e || 1 !== t || 1 !== i || 0 !== o || 0 !== n || 0 !== r) return; var s = this.model, l = s.manager, c = Array.isArray(A.componentKey) ? A.componentKey : [A.componentKey], h = new y, d = new aA, p = new y(0, 0, 0), g = new y(0, 0, 0), u = new y, f = s.getModelMatrix(), m = new M; f && a && (m.getInverse(f), a.applyMatrix4(m)); for (var C = 0; c.length > C; C += 1) { var v = c[C], I = s.getComponentInfo(v); if (I && I.length > 0) for (var E = 0, B = I.length; B > E; E += 1) { var x = I[E], S = x.mesh; if (S) { if (d.copy(x.boundingBox), d.getCenter(h), x.userData || (x.userData = {}), p.set(0, 0, 0), g.set(0, 0, 0), 1 !== e || 1 !== t || 1 !== i || x.userData.explosionFactor) { x.userData.explosionFactor || (x.userData.explosionFactor = new y(1, 1, 1), x.userData.explosionBaseDifference = h.sub(a).clone()); var w = x.userData.explosionFactor, b = x.userData.explosionBaseDifference; p.set((e - w.x) * b.x, (t - w.y) * b.y, (i - w.z) * b.z), 1 === e && 1 === t && 1 === i ? (x.userData.explosionFactor = void 0, x.userData.explosionBaseDifference = void 0) : w.set(e, t, i) } if (0 !== o || 0 !== n || 0 !== r || x.userData.explosionOffset) { x.userData.explosionOffset || (x.userData.explosionOffset = new y(0, 0, 0)); var U = x.userData.explosionOffset; g.set(o - U.x, n - U.y, r - U.z), 0 === o && 0 === n && 0 === r ? x.userData.explosionOffset = void 0 : U.set(o, n, r) } if (u.set(p.x + g.x, p.y + g.y, p.z + g.z), 0 !== u.x || 0 !== u.y || 0 !== u.z) { x.userData.explosionFactor || x.userData.explosionOffset ? l.explosionList[v] || (l.explosionList[v] = !0) : delete l.explosionList[v], m.makeTranslation(u.x, u.y, u.z), x.transformation || (x.transformation = !0, x.transformationOriginalMatrix = x.matrix.clone(), x.applyMatrix = new M, x.transformationOriginalBoundingBox = x.boundingBox.clone()), x.matrix.premultiply(m), x.applyMatrix.premultiply(m), x.boundingBox.copy(x.transformationOriginalBoundingBox).applyMatrix4(x.applyMatrix); var F = S.matrixAutoUpdate; S.matrixAutoUpdate = !1, S.applyMatrix4(m), S.updateMatrixWorld(!0), S.matrixAutoUpdate = F; var K = x.wireframeMeshs; if (K) for (var Q = 0, R = K.length; R > Q; Q += 1) { var T = K[Q]; F = T.matrixAutoUpdate, T.matrixAutoUpdate = !1, T.matrix.copy(S.matrix), T.updateMatrixWorld(!0), T.matrixAutoUpdate = F } } } } } } }, MC.prototype.closeComponentsExplosion = function (A) { var e = Array.isArray(A) ? A : [A]; this.componentsExplosion({ componentKey: e }) }; var bC = function (A) { this.model = A, this.config = null, this.statistics = { renderableCount: 0, renderableTotal: vc.maxObjectNumInPool, renderableTotalForPool: vc.maxObjectNumInPool, numOfElements: 0, numOfTriangles: 0, memoeryInfo: null }, this.transformInfos = { octreeTransformed: !0, originalBoundingBox: null, boundingBox: null, position: new y, rotation: new f, scale: new y(1, 1, 1), transformMatrix: new M, originalMatrix: new M } }; bC.prototype.destroy = function () { this.model = null, this.config = null, this.statistics = null, this.transformInfos = null }, bC.prototype.load = function (A) { var e = this, t = this.model, i = t.dataUrl, o = function (o) { var n = {}; if ("string" == typeof o) try { n = JSON.parse(o) } catch (A) { return t.setEmptyScene(!0), void t.dispatchEventEx({ type: Rc.ON_LOAD_INVALID_SCENE, modelKey: t.modelKey }) } else n = o; if (n && "SUCCESS" === n.code) { if (vc.offLine) e.model.getStorage().put(i.projectUrl(), n, e.model.modelKey, (function () {}), (function () {})); if (-1 === Number(n.data.status)) return void t.dispatchEventEx({ type: Tc.PARSEFAILE, modelKey: t.modelKey }); if (3 > Number(n.data.status)) return void t.dispatchEventEx({ type: Tc.PARSING, modelKey: t.modelKey }); if (n.data.type === Zc.DWG) return t.dispatchEventEx({ type: Tc.IS2D, modelKey: t.modelKey }), void Bh.error("模型 ", t.modelKey, " 是图纸文件,请使用EIMDRAWINGS库加载"); !n.data.profiles || n.data.children && n.data.children.length > 1 ? (e.dataVersion = "2.0.0", i.apiVersion = "2.0.0", e.model.dataVersion = e.dataVersion) : (e.dataVersion = n.data.profiles.geo || "1.0.0", i.apiVersion = n.data.profiles.api, e.model.dataVersion = e.dataVersion), e._parse(n.data), t.dispatchEventEx({ type: Rc.ON_LOAD_CONFIG_FINISH, modelKey: t.modelKey }), A && A() } else Bh.log(t.modelKey, "config load error! ", n.message), t.dispatchEventEx({ type: Rc.ON_LOAD_ERROR, modelKey: t.modelKey, code: n.code, message: n.message }), t.manager.unload(t.modelKey) }; if (vc.offLine) { var n = this.model.getStorage(); n && n.getBatch([i.projectUrl()], (function (A) { A[i.projectUrl()] ? o(A[i.projectUrl()]) : _d({ type: "GET", url: i.projectUrl(), headers: { Authorization: t.accessToken }, success: o, error: function (A) { t.dispatchEventEx({ type: Rc.ON_NETWORK_ERROR, modelKey: t.modelKey, data: A }) } }) }), (function () {})) } else _d({ type: "GET", url: i.projectUrl(), headers: { Authorization: t.accessToken }, success: o, error: function (A, e) { switch (A) { case 401: t.dispatchEventEx({ type: Rc.ACCOUNT_NO_EXIST, modelKey: t.modelKey, data: e }); break; case 403: t.dispatchEventEx({ type: Rc.NO_PERMISSION, modelKey: t.modelKey, data: e }); break; default: t.dispatchEventEx({ type: Rc.ON_NETWORK_ERROR, modelKey: t.modelKey, data: A }) } } }) }, bC.prototype._parse = function (A) { this.config = A, A.lengthUnit && (this.model.originalLengthUnit = A.lengthUnit), vc.AutoMergeComponent && A.componentCount > vc.AutoMergeComponentCount && (vc.MergeComponent = !0), this._toStatistics(A), this._setTransformInfos(A), this._chooseRendering(A), this._setHandler(A) }, bC.prototype._getDataProvider = function (A) { if (vc.DataProvider === Wc.MERGED && void 0 !== A.bmpks && A.bmpks > 0) return Bh.debug("data from: merged"), Wc.MERGED; if (vc.LoadComponentOnDemand && A.scene && A.scene.map) { if (vc.DataProvider === Wc.LAYER_SCENE) return A.layers > 1 ? (Bh.debug("data from: layer scene"), Wc.LAYER_SCENE) : (Bh.debug("data from: layer"), Wc.LAYER); if (vc.DataProvider === Wc.LAYER) return Bh.debug("data from: layer"), Wc.LAYER } if (vc.DataProvider === Wc.AUTO) { if (vc.LoadComponentOnDemand && A.scene && A.scene.map) return np(this.dataVersion, "2.0.0") && (vc.MergeComponent = !0), Bh.debug("data from: layer"), Wc.LAYER; if (!vc.loadBatch && A.scene.geometries && A.scene.geometries.length > 0) return rp(this.dataVersion, "2.0.0") && (vc.MergeComponent = !0), Wc.DEFAULT; if (A.scene.batchedGeometries && A.scene.batchedGeometries.length > 0 || A.scene.instancedGeometries && A.scene.instancedGeometries.length > 0) return vc.MergeComponent = !0, Wc.MERGED; if (vc.MergeComponent && void 0 !== A.bmpks && A.bmpks > 0) return Bh.debug("data from: merged"), Wc.MERGED } return Bh.debug("data from: default"), Wc.DEFAULT }, bC.prototype._chooseRendering = function (A) { this.model.manager.chooseRendering(this.statistics.memoeryInfo) }, bC.prototype._setHandler = function (A) { var e = this._getDataProvider(A), t = null, i = this.model; if (Array.isArray(A.scene)) { for (var o = 0, n = A.children.length; n > o; o += 1) { var r = A.scene[o]; r && (i.subModel[A.children[o]] = (new M).fromArray(r.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1])) } t = new xC(i, !1), i.merged = !0, vc.MergeComponent = !0 } else if (i.hasAnimation && vc.EnableAnimation) t = new MC(i); else if (vc.MergeComponent) { switch (e) { case Wc.LAYER: vc.HasLayerData = !0, vc.LoadGeoOnDemand = !0, (t = new dC(i, !1)).layerProvider.cachedLayerData = A.scene.map; break; case Wc.LAYER_SCENE: vc.HasLayerData = !0, vc.LoadGeoOnDemand = !0; break; case Wc.MERGED: t = new oC(i, !1); break; default: t = new Yf(i, !1) } i.merged = !0 } else if (vc.OrganizeNodesByCameraView) switch (e) { case Wc.LAYER: case Wc.LAYER_SCENE: vc.HasLayerData = !0, vc.LoadGeoOnDemand = !0 } else switch (e) { case Wc.LAYER: vc.HasLayerData = !0, vc.LoadGeoOnDemand = !0, (t = new IC(i)).layerProvider.cachedLayerData = A.scene.map; break; case Wc.LAYER_SCENE: vc.HasLayerData = !0, vc.LoadGeoOnDemand = !0; break; case Wc.MERGED: break; default: t = new MC(i) } i._handler = t }, bC.prototype._setTransformInfos = function (A) { if (this.model.hasAnimation = A.hasAnimation, this.transformInfos.octreeTransformed = !1, this.transformInfos.boundingBox && this.transformInfos.boundingBox.isBox3 || (this.transformInfos.boundingBox = new aA), this.transformInfos.boundingBox.expandByPoint(new y(A.minBoundary.x, A.minBoundary.y, A.minBoundary.z)), this.transformInfos.boundingBox.expandByPoint(new y(A.maxBoundary.x, A.maxBoundary.y, A.maxBoundary.z)), this.transformInfos.transformMatrix.compose(this.transformInfos.position, this.transformInfos.rotation, this.transformInfos.scale), this.transformInfos.transformMatrix.fromArray(A.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]), A.transform && Array.isArray(A.transform)) { var e = (new M).fromArray(A.transform || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]); this.transformInfos.transformMatrix.multiplyMatrices(this.transformInfos.transformMatrix, e) } this.transformInfos.originalMatrix.copy(this.transformInfos.transformMatrix), this.model.setModelMatrix(this.transformInfos.transformMatrix), this.model.manager.updateScene() }, bC.prototype._toStatistics = function (A) { A.count = {}, A.count.texture_pixels && A.count.texture_pixels > vc.MaxTexturePixels && (vc.EnableTextureLoading = !1), void 0 !== A.count && (void 0 !== A.count.mesh_face && (this.statistics.numOfTriangles += A.count.mesh_face), this.statistics.renderableTotal = 0, this.statistics.renderableTotalForPool = 0, void 0 !== A.count.geom_box && void 0 !== A.count.geom_pipe && void 0 !== A.count.geom_tube && void 0 !== A.count.mesh ? (this.statistics.renderableTotal += A.count.geom_box, this.statistics.renderableTotal += A.count.geom_pipe, this.statistics.renderableTotal += A.count.geom_tube, this.statistics.renderableTotal += A.count.mesh, this.statistics.renderableTotalForPool += 6 * A.count.geom_box, this.statistics.renderableTotalForPool += 3 * A.count.geom_pipe, this.statistics.renderableTotalForPool += A.count.geom_tube, this.statistics.renderableTotalForPool += A.count.mesh, this.statistics.numOfTriangles += 12 * A.count.geom_box, this.statistics.numOfTriangles += 32 * A.count.geom_pipe, this.statistics.numOfTriangles += 32 * A.count.geom_tube) : void 0 !== A.count.geom && void 0 !== A.count.mesh && (this.statistics.renderableTotal += A.count.geom, this.statistics.renderableTotal += A.count.mesh, this.statistics.numOfTriangles += 12 * A.count.geom, this.statistics.numOfElements = this.statistics.renderableTotal, this.statistics.renderableTotalForPool = this.statistics.renderableTotal), void 0 !== A.count.item && (this.statistics.numOfElements = A.count.item)), this.statistics.memoeryInfo = this._computeApproximateMemoerySize(A) }, bC.prototype._computeApproximateMemoerySize = function (A) { var e = 0, t = 0, i = A.count.mesh_vertex || 0, o = A.count.mesh_face || 0, n = A.count.geom_box || 0, r = A.count.geom_pipe || 0, a = A.count.texture_pixels || 0; t += 8 * i, t += 3 * o, t += 0, t += 0, e += 6 * i, e += 3 * o, e += 0, e += 0; var s = 0; if (s += o, n > 0 && (s += 12 * n), r > 0 && (s += 124 * r), s += 0, vc.Instance) { n > 0 && (t += 192, t += 36, t += 24 * n, e += 144, e += 36, e += 18 * n), r > 0 && (t += 1040, t += 372, t += 24 * r, e += 780, e += 372, e += 18 * r) } else n > 0 && (t += 24 * n * 8, t += 12 * n * 3, e += 24 * n * 6, e += 12 * n * 3), r > 0 && (t += 130 * r * 8, t += 124 * r * 3, e += 130 * r * 6, e += 124 * r * 3); return vc.EnableTextureLoading && (t += 4 * a, e += 4 * a), t *= 4, e *= 4, t *= 1 / 1048576, e *= 1 / 1048576, { maxMemoerySize: t = Math.ceil(t), minMemoerySize: e = Math.ceil(e), triangleNumber: s, instanceEnabled: vc.Instance } }, bC.prototype.getMemoeryInfo = function () { return this.statistics.memoeryInfo }, bC.prototype.getStatistics = function () { return this.statistics }, bC.prototype.getConfig = function () { return this.config }, bC.prototype.getTransforms = function () { return this.transformInfos }, bC.prototype.setRenderableCount = function (A) { this.statistics.renderableCount = A }; var UC = function (A) { ef.call(this, A), this.descriptor = new Af(A.model), this.fileKeyFromModelKey = {} }; (UC.prototype = Object.assign(UC.prototype, ef.prototype)).loadData = function () { var A = this, e = this.model; this.modelDataVersion = e.configLoader.modelDataVersion; e.getConfig(); var t = e.configLoader.scenes, i = [], o = [], n = [], r = [], a = [], s = [], l = [], c = []; A.maxLoadTaskCount = 0, A.maxLoadTextureCount = 0; for (var h = function (h) { var d = t[h].scene, F = t[h].dataVersion, K = t[h].modelKey; if (!(d && d.components && d.geometries && d.materials && d.textures)) return e.setEmptyScene(!0), Bh.error("scene is null,modelKey is ", K), e.dispatchEventEx({ type: Rc.ON_LOAD_EMPTY_SCENE, modelKey: K }), { v: void 0 }; if (p = d.components.length || 0, g = d.geometries.length || 0, u = d.materials.length || 0, f = d.textures.length || 0, m = [], C = [], y = [], v = [], I = [], E = [], B = d.textures, x = [], op(F, "2.0.0")) m = d.components, C = d.geometries, y = d.materials; else { for (S = 0; p > S; S += 1) d.components[S].fileKey ? m.push(d.components[S].fileKey) : e.dispatchEventEx({ type: Tc.SCENE_NOT_CLOSE, modelKey: K }); for (w = 0; g > w; w += 1) d.geometries[w].fileKey ? C.push(d.geometries[w].fileKey) : e.dispatchEventEx({ type: Tc.SCENE_NOT_CLOSE, modelKey: K }); for (M = 0; u > M; M += 1) d.materials[M].fileKey ? y.push(d.materials[M].fileKey) : e.dispatchEventEx({ type: Tc.SCENE_NOT_CLOSE, modelKey: K }) } if (d.trees.length > 0) for (b = 0; d.trees.length > b; b += 1) "partition" === (U = d.trees[b]).type && x.push(U.fileKey); A.maxLoadTaskCount += p, A.maxLoadTaskCount += g, A.maxLoadTaskCount += u, vc.EnableTextureLoading && (A.maxLoadTextureCount += f), A.maxLoadTaskCount += 0, A.maxLoadTaskCount += 0, A.maxLoadTaskCount += 0, A.maxLoadTaskCount += x.length, m.forEach((function (e) { A.fileKeyFromModelKey[e] = K })), C.forEach((function (e) { A.fileKeyFromModelKey[e] = K })), y.forEach((function (e) { A.fileKeyFromModelKey[e] = K })), v.forEach((function (e) { A.fileKeyFromModelKey[e] = K })), I.forEach((function (e) { A.fileKeyFromModelKey[e] = K })), E.forEach((function (e) { A.fileKeyFromModelKey[e] = K })), B.forEach((function (e) { A.fileKeyFromModelKey[e] = K })), x.forEach((function (e) { A.fileKeyFromModelKey[e] = K })), i = i.concat(m), o = o.concat(C), n = n.concat(y), r = r.concat(v), a = a.concat(I), s = s.concat(E), l = l.concat(B), c = c.concat(x) }, d = 0; t.length > d; d += 1) { var p, g, u, f, m, C, y, v, I, E, B, x, S, w, M, b, U, F = h(d); if ("object" === lc(F)) return F.v } if (A.progress.total += A.maxLoadTaskCount, 1 > A.maxLoadTaskCount) return Bh.info("Nothing to load ", e.modelKey), void e.dispatchEventEx({ type: Tc.SCENE_NOTHING_TO_LOAD, modelKey: e.modelKey }); Bh.time("数据加载时间"), A._loadComponent(i), A._loadMaterial(n), vc.EnableTextureLoading && A.maxLoadTextureCount.length > 0 ? A._loadTextures(l) : A._onLoadTexture(), A._loadTextures(l), A._loadKDTree(c), A._loadClips(a), A._loadBones(r), A._loadNodes(s), A.offLine && A.loadAttribute(), A._loadGeo(o) }, UC.prototype.loadSceneAndGeos = function (A) { this._loadGeo(A) }, UC.prototype._loadGeometrie = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { var t = this.url, i = [], o = []; i.push(o); for (var n = 0, r = 0; A.length > r; r += 1) 50 > n || (i.push(o = []), n = 0), n += 1, o.push(t.mpkUrl(A[r])); var a = this.model.getStorage(); if (a) for (var s = function (t, o) { var n = i[o]; a.getBatch(n, (function (A) { for (var t = function (t) { if (-1 === (o = n[t].indexOf("fileKey="))) return Bh.error("url is not has fileKey"), { v: void 0 }; var i = n[t].slice(o + 8); if (A[n[t]]) if (!0 === A[n[t]].split) { var s = A[n[t]].list, l = new Uint8Array(A[n[t]].length); a.getBatch(s, (function (A) { for (var t = 0; s.length > t; t += 1) A[s[t]] ? l.set(new Uint8Array(A[s[t]]), 4e7 * t) : Bh.error("获取分割几何失败"); e._parseGeometrie(l.buffer, i), Bh.debug("load geo from local"), e._onTaskFinished() }), (function () { Bh.error("获取分割几何失败") })) } else e._parseGeometrie(A[n[t]], i), Bh.debug("load geo from local"), e._onTaskFinished(); else { if (r = e.taskGeometrieManager, -1 === n[t].indexOf("fileKey=")) return Bh.error("url is not has fileKey"), { v: void 0 }; r.addTask(i), Bh.debug("load geo from net") } }, i = 0; n.length > i; i += 1) { var o, r, s = t(i); if ("object" === lc(s)) return s.v } e.taskGeometrieManager.processTasks(e.loadGeometrie.bind(e)) }), (function () { for (var t = e.taskGeometrieManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadGeometrie.bind(e)) })) }, l = 0, c = i.length; c > l; l += 1) s(0, l) } else { for (var h = this.taskGeometrieManager, d = 0; A.length > d; d += 1) h.addTask(A[d]); h.processTasks(e.loadGeometrie.bind(e)) } }, UC.prototype._loadKDTree = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { var t = this.url, i = [], o = []; i.push(o); for (var n = 0, r = 0; A.length > r; r += 1) 50 > n || (i.push(o = []), n = 0), n += 1, o.push(t.mpkUrl(A[r])); var a = this.model.getStorage(); if (a) for (var s = function (t, o) { var n = i[o]; a.getBatch(n, (function (A) { for (var t = 0; n.length > t; t += 1) { var i = n[t].indexOf("fileKey="); if (-1 === i) return void Bh.error("url is not has fileKey"); var o = n[t].slice(i + 8); if (A[n[t]]) e._parseKDTree(A[n[t]], o), Bh.debug("load kdtree from local"), e._onTaskFinished(); else { var r = e.taskComponentManager; if (-1 === n[t].indexOf("fileKey=")) return void Bh.error("url is not has fileKey"); r.addTask(o), r.processTasks(e.loadKDTree.bind(e)), Bh.debug("load kdtree from net") } } }), (function () { for (var t = e.taskComponentManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadKDTree.bind(e)) })) }, l = 0, c = i.length; c > l; l += 1) s(0, l) } else { for (var h = this.taskComponentManager, d = 0; A.length > d; d += 1) h.addTask(A[d]); h.processTasks(e.loadKDTree.bind(e)) } }, UC.prototype._loadBones = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.bonesUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) { var o = i[t].indexOf("fileKey="); if (-1 === o) return void Bh.error("url is not has fileKey"); var n = i[t].slice(o + 8); if (A[i[t]]) e._parseBones(A[i[t]], n), Bh.debug("load Bones from local"), e._onTaskFinished(); else { if (-1 === i[t].indexOf("fileKey=")) return void Bh.error("url is not has fileKey"); e.loadBones(i[t].slice(o + 8), (function () {})), Bh.debug("load Bones from net") } } }), (function () { for (var t = 0; A.length > t; t += 1) e.loadBones(A[t], (function () {})) })) } else { for (var r = this.taskComponentManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadBones.bind(e)) } }, UC.prototype._loadClips = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.clipsUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) { var o = i[t].indexOf("fileKey="); if (-1 === o) return void Bh.error("url is not has fileKey"); var n = i[t].slice(o + 8); if (A[i[t]]) e._parseClips(A[i[t]], n), Bh.debug("load Clips from local"), e._onTaskFinished(); else { if (-1 === i[t].indexOf("fileKey=")) return void Bh.error("url is not has fileKey"); e.loadClips(i[t].slice(o + 8), (function () {})), Bh.debug("load Clips from net") } } }), (function () { for (var t = 0; A.length > t; t += 1) e.loadClips(A[t], (function () {})) })) } else { for (var r = this.taskComponentManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadClips.bind(e)) } }, UC.prototype._loadNodes = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.nodesUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) { var o = i[t].indexOf("fileKey="); if (-1 === o) return void Bh.error("url is not has fileKey"); var n = i[t].slice(o + 8); if (A[i[t]]) e._parseNodes(A[i[t]], n), Bh.debug("load Nodes from local"), e._onTaskFinished(); else { if (-1 === i[t].indexOf("fileKey=")) return void Bh.error("url is not has fileKey"); e.loadNodes(i[t].slice(o + 8), (function () {})), Bh.debug("load Nodes from net") } } }), (function () { for (var t = 0; A.length > t; t += 1) e.loadNodes(A[t], (function () {})) })) } else { for (var r = this.taskComponentManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadNodes.bind(e)) } }, UC.prototype._loadComponent = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { var t = this.url, i = [], o = []; i.push(o); for (var n = 0, r = 0; A.length > r; r += 1) 50 > n || (i.push(o = []), n = 0), n += 1, o.push(t.mpkUrl(A[r])); var a = this.model.getStorage(); if (a) for (var s = function (t, o) { var n = i[o]; a.getBatch(n, (function (A) { for (var t = 0; n.length > t; t += 1) { var i = n[t].indexOf("fileKey="); if (-1 === i) return void Bh.error("url is not has fileKey"); var o = n[t].slice(i + 8); if (A[n[t]]) e._parseComponent(A[n[t]], o), Bh.debug("load com from local"), e._onTaskFinished(); else { var r = e.taskComponentManager; if (-1 === n[t].indexOf("fileKey=")) return void Bh.error("url is not has fileKey"); r.addTask(o), r.processTasks(e.loadComponent.bind(e)), Bh.debug("load com from net") } } }), (function () { for (var t = e.taskComponentManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadComponent.bind(e)) })) }, l = 0, c = i.length; c > l; l += 1) s(0, l) } else { for (var h = this.taskComponentManager, d = 0; A.length > d; d += 1) h.addTask(A[d]); h.processTasks(e.loadComponent.bind(e)) } }, UC.prototype._loadMaterial = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var t = this.url, i = [], o = 0; A.length > o; o += 1) i.push(t.mpkUrl(A[o])); var n = this.model.getStorage(); n && n.getBatch(i, (function (A) { for (var t = 0; i.length > t; t += 1) { var o = i[t].indexOf("fileKey="); if (-1 === o) return void Bh.error("url is not has fileKey"); var n = i[t].slice(o + 8); if (A[i[t]]) e._parseMaterial(A[i[t]], n), Bh.debug("load mat from local"), e._onTaskFinished(); else { var r = e.taskMaterialManager; if (-1 === i[t].indexOf("fileKey=")) return void Bh.error("url is not has fileKey"); r.addTask(n), r.processTasks(e.loadMaterial.bind(e)), Bh.debug("load mat from net") } } }), (function () { for (var t = e.taskMaterialManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadMaterial.bind(e)) })) } else { for (var r = this.taskMaterialManager, a = 0; A.length > a; a += 1) r.addTask(A[a]); r.processTasks(e.loadMaterial.bind(e)) } }, UC.prototype._loadTextures = function (A) { var e = this.model.materialManager.textures, t = this; if (vc.getDataFromIndexedDB && !this.offLine) { for (var i = this.url, o = [], n = 0; A.length > n; n += 1) o.push(i.mpkUrl(A[n])); var r = this.model.getStorage(); r && r.getBatch(o, (function (A) { for (var i = 0; o.length > i; i += 1) if (A[o[i]]) { var n = o[i].indexOf("fileKey="); if (-1 === n) return void Bh.error("url is not has fileKey"); var r = o[i].slice(n + 8), a = new d; Bh.debug("load tex from local"), e[r] = a; var s = document.createElement("img"); a.wrapS = a.wrapT = 1e3, s.onload = function (e) { "string" != typeof A[o[i]] && window.URL.revokeObjectURL(s.src), t.model.textureNeedsUpdate = !0, t._onLoadTexture() }, s.onerror = function (A) { t.model.dispatchEventEx({ type: Tc.LOAD_TEXTURE_ERROR }) }, s.src = "string" == typeof A[o[i]] ? A[o[i]] : window.URL.createObjectURL(A[o[i]]), a.image = s, a.needsUpdate = !0 } else { var l = t.taskTexturesManager, c = o[i].indexOf("fileKey="); if (-1 === c) return void Bh.error("url is not has fileKey"); l.addTask(o[i].slice(c + 8)), l.processTasks(t.loadTextures.bind(t)), Bh.debug("load tex from net") } }), (function () { for (var e = t.taskTexturesManager, i = 0; A.length > i; i += 1) e.addTask(A[i]); e.processTasks(t.loadTextures.bind(t)) })) } else { for (var a = this.taskTexturesManager, s = 0; A.length > s; s += 1) a.addTask(A[s]); a.processTasks(t.loadTextures.bind(t)) } }, UC.prototype._parseGeometrie = function (A, e) { var t = this.fileKeyFromModelKey[e] || "", i = new ku.GeometryReader(A, this.modelDataVersion[t]), o = this.descriptor; if (o) { for (var n = i.geoCount, r = 0; n > r; r += 1) { var a = i.geomMap[r]; void 0 !== a.position && void 0 !== a.index && void 0 !== a.normal ? o.cacheReferencedMeshBufferData(t + a.geoId, a) : Bh.error("Error Geometry!") } i = null } }, UC.prototype._parseMaterial = function (A, e) { var t = this.descriptor; if (t) { var i = new Du(A, this.modelDataVersion[this.fileKeyFromModelKey[e] || ""]); if (Array.isArray(i.materialMap)) { var o = i.materialCount; if (0 > o) return; for (var n = 0; o > n; n += 1) { var r = i.materialMap[n]; t.cacheReferencedMeshMaterialData(r.matId, r) } } else for (var a in i.materialMap) t.cacheReferencedMeshMaterialData(a, i.materialMap[a]); i = null } }, UC.prototype._parseComponent = function (A, e) { if (A) { var t = new Uu(A), i = t.compArr.length, o = this.descriptor; if (o) { for (var n = this.fileKeyFromModelKey[e] || "", r = 0; i > r; r += 1) { var a = t.compArr[r]; - 1 !== a.geoId && (a.geoId = n + a.geoId, -1 !== a.matId && (a.matId = n + a.matId), this.model.submodel[n] = this.model.submodel[n] || [], this.model.submodel[n].push(a.key)), o.cacheReferencedMeshComponentData(a.key, a) } t = null } } else Bh.error("没有数据") }, UC.prototype._parseKDTree = function (A, e) { var t = {}; if (t = "string" == typeof A ? JSON.parse(A) : A, this.model.kdTreeNode = this.model.kdTreeNode || [], t) { var i = new Zu; i.init(t), this.model.kdTreeNode.push(i) } }, UC.prototype._parseNodes = function (A, e) { var t = this.descriptor; if (t) { var i = {}; i = "string" == typeof A ? JSON.parse(A) : A, Bh.debug("nodes", i), t.cacheReferencedMeshNodesData(i) } }, UC.prototype._parseClips = function (A, e) { var t = this.descriptor; if (t) { var i = {}; i = "string" == typeof A ? JSON.parse(A) : A, Bh.debug("clips", i), t.cacheReferencedMeshClipsData(i) } }, UC.prototype._parseBones = function (A, e) { var t = new ku.BoneReader(A), i = this.descriptor; if (i) { for (var o = t.boneCount, n = 0; o > n; n += 1) { var r = t.boneMap[n]; Bh.debug("bones", r), i.cacheReferencedMeshBoneBufferData(r.geoId, r) } t = null } }, UC.prototype._loadComponent = function (A) { var e = this; if (vc.getDataFromIndexedDB && !this.offLine) { var t = this.url, i = [], o = []; i.push(o); for (var n = 0, r = 0; A.length > r; r += 1) 50 > n || (i.push(o = []), n = 0), n += 1, o.push(t.mpkUrl(A[r])); var a = this.model.getStorage(); if (a) for (var s = function (t, o) { var n = i[o]; a.getBatch(n, (function (A) { for (var t = 0; n.length > t; t += 1) { var i = n[t].indexOf("fileKey="); if (-1 === i) return void Bh.error("url is not has fileKey"); var o = n[t].slice(i + 8); if (A[n[t]]) e._parseComponent(A[n[t]], o), Bh.debug("load com from local"), e._onTaskFinished(); else { var r = e.taskComponentManager; if (-1 === n[t].indexOf("fileKey=")) return void Bh.error("url is not has fileKey"); r.addTask(o), r.processTasks(e.loadComponent.bind(e)), Bh.debug("load com from net") } } }), (function () { for (var t = e.taskComponentManager, i = 0; A.length > i; i += 1) t.addTask(A[i]); t.processTasks(e.loadComponent.bind(e)) })) }, l = 0, c = i.length; c > l; l += 1) s(0, l) } else { for (var h = this.taskComponentManager, d = 0; A.length > d; d += 1) h.addTask(A[d]); h.processTasks(e.loadComponent.bind(e)) } }, UC.prototype.loadGeometrie = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model, r = vc.GeoWorkerUrl; vc.UseGeoWorker ? (i.setResponseType("arraybuffer"), i.load(o.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }))) : (i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine), i.load(o.mpkUrl(A), (function (i) { t._parseGeometrie(i, A, A), Bh.debug("geo load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_GEOMETRY_ERROR, modelKey: n.modelKey }) }))) }, UC.prototype.loadMaterial = function (A, e) { var t = this, i = this.loader, o = this.url, n = this.model, r = vc.GeoWorkerUrl; vc.UseGeoWorker ? (i.setResponseType("arraybuffer"), i.load(o.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }))) : (i.setResponseType(t.modelDataVersion[t.fileKeyFromModelKey[A] || ""] > 1 ? "json" : "arraybuffer"), i.setCacheViable(!this.offLine), i.load(o.mpkUrl(A), (function (i) { t._parseMaterial(i, A), Bh.debug("met load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { n.dispatchEventEx({ type: Tc.LOAD_MATERIAL_ERROR, modelKey: n.modelKey }) }))) }, UC.prototype.loadTextures = function (A, e) { var t = this.model.materialManager.textures, i = this, o = this.Textureloader, n = this.url, r = this.model, a = vc.GeoWorkerUrl; vc.UseGeoWorker ? o.load(n.mpkUrl(A), (function (A) { var t = new Worker(a); t.onmessage = function (A) { var t = A.data; for (var o in t) t.hasOwnProperty(o); e(), i._onTaskFinished() }, t.postMessage({ msg: A }) })) : (o.setResponseType("blob"), o.setMimeType("text/plain"), o.setCacheViable(!this.offLine), o.load(n.textureUrl(A), (function (o) { Bh.debug("tex load from online"); var n = new d; t[A] = n, n.wrapS = n.wrapT = 1e3; var a = document.createElement("img"); a.onload = function (A) { "string" != typeof o && window.URL.revokeObjectURL(a.src), e(), i.model.textureNeedsUpdate = !0, i._onLoadTexture() }, a.onerror = function (A) { r.dispatchEventEx({ type: Tc.LOAD_TEXTURE_ERROR, modelKey: r.modelKey }) }, a.src = "string" == typeof o ? o : window.URL.createObjectURL(o), n.image = a, n.needsUpdate = !0 }), void 0, (function (A) { r.dispatchEventEx({ type: Tc.LOAD_TEXTURE_ERROR, modelKey: r.modelKey }) }))) }, UC.prototype.loadComponent = function (A, e) { var t = this, i = this.jsonLoader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; vc.UseGeoWorker ? (i.setResponseType("json"), i.load(n.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {}))) : (i.setResponseType("json"), i.setCacheViable(!this.offLine), i.load(n.mpkUrl(A), (function (i) { t._parseComponent(i, A), Bh.debug("component load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) }))) }, UC.prototype.loadKDTree = function (A, e) { var t = this, i = this.loader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; vc.UseGeoWorker ? (i.setResponseType("json"), i.load(n.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {}))) : (i.setResponseType("json"), i.setCacheViable(!this.offLine), i.load(n.kdTreeUrl(A), (function (i) { t._parseKDTree(i, A), Bh.debug("kdtree load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) }))) }, UC.prototype.loadBones = function (A, e) { var t = this, i = this.loader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; vc.UseGeoWorker ? (i.setResponseType("arraybuffer"), i.load(n.bonesUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {}))) : (i.setResponseType("arraybuffer"), i.setCacheViable(!this.offLine), i.load(n.bonesUrl(A), (function (i) { t._parseBones(i, A), Bh.debug("bones load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) }))) }, UC.prototype.loadClips = function (A, e) { var t = this, i = this.loader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; vc.UseGeoWorker ? (i.setResponseType("json"), i.load(n.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {}))) : (i.setResponseType("json"), i.setCacheViable(!this.offLine), i.load(n.clipsUrl(A), (function (i) { t._parseClips(i, A), Bh.debug("Clips load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) }))) }, UC.prototype.loadNodes = function (A, e) { var t = this, i = this.loader, o = this.model, n = this.url, r = vc.GeoWorkerUrl; vc.UseGeoWorker ? (i.setResponseType("json"), i.load(n.mpkUrl(A), (function (A) { var i = new Worker(r); i.onmessage = function (A) { var i = A.data; for (var o in i) i.hasOwnProperty(o); e(), t._onTaskFinished() }, i.postMessage({ msg: A }) }), (function (A) {}))) : (i.setResponseType("json"), i.setCacheViable(!this.offLine), i.load(n.nodesUrl(A), (function (i) { t._parseNodes(i, A), Bh.debug("Nodes load from online"), e(), t._onTaskFinished() }), void 0, (function (A) { o.dispatchEventEx({ type: Tc.LOAD_COMPONENT_ERROR, modelKey: o.modelKey }) }))) }; var FC = function (A, e) { tf.call(this, A), this.defaultManager = new Of(e, A), this.instancedManager = new Hf(A), this.loader = new UC(this) }; FC.prototype = Object.create(Yf.prototype); var KC = function (A) { bC.call(this, A), this.modelDataVersion = {} }; (KC.prototype = Object.assign(KC.prototype, bC.prototype)).load = function (A) { var e = this, t = this.model; this.config = {}; var i = t.dataUrl, o = function (o) { var n = {}; if ("string" == typeof o) try { n = JSON.parse(o) } catch (A) { return t.setEmptyScene(!0), void t.dispatchEventEx({ type: Rc.ON_LOAD_INVALID_SCENE, modelKey: t.modelKey }) } else n = o; if (n && "SUCCESS" === n.code) { if (vc.offLine) e.model.getStorage().put(i.projectUrl(), n, e.model.modelKey, (function () {}), (function () {})); if (-1 === Number(n.data.status)) return void t.dispatchEventEx({ type: Tc.PARSEFAILE, modelKey: t.modelKey }); if (3 > Number(n.data.status)) return void t.dispatchEventEx({ type: Tc.PARSING, modelKey: t.modelKey }); e.dataVersion = n.data.profiles.geo || "1.0.0", i.apiVersion = n.data.profiles.api, e.model.dataVersion = e.dataVersion, e._parse(n.data), t.dispatchEventEx({ type: Rc.ON_LOAD_CONFIG_FINISH, modelKey: t.modelKey }), A && A() } else Bh.log(t.modelKey, "config load error! ", n.message), t.dispatchEventEx({ type: Rc.ON_LOAD_ERROR, modelKey: t.modelKey, code: n.code, message: n.message }) }; if (vc.offLine) { var n = this.model.getStorage(); n && n.getBatch([i.projectUrl()], (function (A) { A[i.projectUrl()] ? o(A[i.projectUrl()]) : _d({ type: "GET", url: i.projectUrl(), headers: { Authorization: t.accessToken }, success: o, error: function (A) { t.dispatchEventEx({ type: Rc.ON_NETWORK_ERROR, modelKey: t.modelKey, data: A }) } }) }), (function () {})) } else { for (var r = [], a = function () { var A = t.modelKeys[s]; r.push(new Promise((function (e, o) { _d({ type: "GET", url: i.projectUrl(A), headers: { Authorization: t.accessToken }, success: function (t) { e({ modelKey: A, data: t }) }, error: function (e, i) { switch (e) { case 401: t.dispatchEventEx({ type: Rc.ACCOUNT_NO_EXIST, modelKey: A, data: i }); break; case 403: t.dispatchEventEx({ type: Rc.NO_PERMISSION, modelKey: A, data: i }); break; default: t.dispatchEventEx({ type: Rc.ON_NETWORK_ERROR, modelKey: A, data: e }) } o(e, i) } }) }))) }, s = 0; t.modelKeys.length > s; s += 1) a(); Promise.all(r).then((function (o) { for (var n = [], r = 0, a = 0; o.length > a; a += 1) if (o[a]) { var s = o[a].data, l = o[a].modelKey, c = {}; if ("string" == typeof s) try { c = JSON.parse(s) } catch (A) { return void t.dispatchEventEx({ type: Rc.ON_LOAD_INVALID_SCENE, modelKey: l }) } else c = s; if (c && "SUCCESS" === c.code) { if (vc.offLine) e.model.getStorage().put(i.projectUrl(), c, e.model.modelKey, (function () {}), (function () {})); var h = c.data.scene || null, d = c.data.profiles.geo || "1.0.0"; if (i.apiVersion = c.data.profiles.api, n.push({ scene: h, modelKey: c.data.key, dataVersion: d }), e.modelDataVersion[c.data.key] = d, r += c.data.componentCount, -1 === Number(c.data.status)) return void t.dispatchEventEx({ type: Tc.PARSEFAILE, modelKey: l }); if (3 > Number(c.data.status)) return void t.dispatchEventEx({ type: Tc.PARSING, modelKey: l }); e.dataVersion = c.data.profiles.geo || "1.0.0", e.sceneReader = e.sceneReader || [], t.setConfig(c.data), e._parse(c.data) } else Bh.log(t.modelKey, "config load error! ", c.message), t.dispatchEventEx({ type: Rc.ON_LOAD_ERROR, modelKey: l, code: c.code, message: c.message }) } var p = new FC(t, !1); t._handler = p, e.model.componentCount = r, t.dispatchEventEx({ type: Rc.ON_LOAD_CONFIG_FINISH, modelKey: t.modelKey }), e.scenes = n, A && A() })).catch((function (A) { console.log(A) })) } }, KC.prototype._parse = function (A) { this.config = A, A.lengthUnit && (this.model.originalLengthUnit = A.lengthUnit), vc.MergeComponent = !0, this._toStatistics(A), this._setTransformInfos(A), this._chooseRendering(A) }; var QC = {}; QC.brdf_vs = ["varying vec2 vUV;", "void main() {", " vUV = uv;", " gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);", "}"].join("\n"), QC.brdf_fs = ["varying vec2 vUV;", "uniform sampler2D HammersleyTable;", "const float PI = 3.14159265358979;", "float GGX(float NdotV, float alpha)", "{", " float alpha2 = pow(alpha, 2.0);", " return 2.0 * NdotV / (NdotV + sqrt(alpha2 + (1.0 - alpha2) * NdotV * NdotV));", "}", "float G_Smith(float NdotV, float NdotL, float roughness)", "{", " float alpha = pow(roughness, 2.0);", " return GGX(NdotV, alpha) * GGX(NdotL, alpha);", "}", "vec3 ImportanceSampleGGX(vec2 Xi, vec3 N, float roughness)", "{", " float a = roughness * roughness;", " float Phi = 2.0 * PI * Xi.x; ", " float CosTheta = sqrt((1.0 - Xi.y) / (1.0 + (a * a - 1.0) * Xi.y)); ", " float SinTheta = sqrt(1.0 - CosTheta * CosTheta);", " vec3 H;", " H.x = SinTheta * cos(Phi); ", " H.y = SinTheta * sin(Phi); ", " H.z = CosTheta;", " vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); ", " vec3 TangentX = normalize(cross(UpVector, N)); ", " vec3 TangentY = cross(N, TangentX);", " return normalize(TangentX * H.x + TangentY * H.y + N * H.z);", "}", "vec2 IntegrateBRDF(float NdotV, float roughness)", "{", " vec3 N = vec3(0.0, 0.0, 1.0);", " vec3 V = vec3(sqrt(1.0 - NdotV * NdotV), 0.0, NdotV);", " vec2 result = vec2(0.0, 0.0);", " const int NumSamples = 1024;", " for (int i = 0; i < NumSamples; i++)", " {", " float u = float(i) / float(NumSamples);", " vec2 Xi = vec2(u, texture2D(HammersleyTable, vec2(u)).r);", " vec3 H = ImportanceSampleGGX(Xi, N, roughness);", " vec3 L = 2.0 * dot(V, H) * H - V;", " float NdotL = saturate(L.z);", " float NdotH = saturate(H.z);", " float VdotH = saturate(dot(V, H));", " float NdotV = saturate(dot(N, V));", " if (NdotL > 0.0)", " {", " float G = G_Smith(NdotV, NdotL, roughness);", " float G_Vis = G * VdotH / (NdotH * NdotV); ", " float F = pow(1.0 - VdotH, 5.0);", " result.x += (1.0 - F) * G_Vis;", " result.y += F * G_Vis;", " }", " }", " return result / float(NumSamples);", "}", "void main()", "{", " vec2 brdf = IntegrateBRDF(vUV.x, vUV.y);", " gl_FragColor = vec4(brdf, 0.0, 1.0);", "}"].join("\n"), QC.BRDFMap = function (A, e) { this.texture = null, this.resolution = e || 512, this.brdfMaterial = new Pe({ vertexShader: QC.brdf_vs, fragmentShader: QC.brdf_fs, uniforms: { HammersleyTable: { value: A } }, lights: !1 }), this.quad = new Ue(new et(window.innerWidth, window.innerHeight), this.brdfMaterial), this.quad.position.z = -100 }, QC.BRDFMap.prototype.constructor = QC.BRDFMap, QC.BRDFMap.prototype.generateMap = function (A) { var e = new Y; e.add(this.quad); var t = new Ka(window.innerWidth / -2, window.innerWidth / 2, window.innerHeight / 2, window.innerHeight / -2, -1e4, 1e4); t.position.z = 100; var i = new g(this.resolution, this.resolution, { minFilter: 1006, magFilter: 1003, format: 1022 }); A.setRenderTarget(i), A.clear(), A.render(e, t), this.texture = i.texture }; var RC = function () { this.instanceMaterials = {}, this.materials = {}, this.textures = {}, this.lightmaps = {}, this.ensureImagePowerOfTwo = !1 }; RC.prototype.changeAllMaterials = function (A, e) {}, RC.prototype.destroy = function () { this.instanceMaterials = {}, this.materials = {}, this.textures = {}, this.lightmaps = {} }, RC.prototype.disposeInstanceMaterials = function (A) { var e = this.instanceMaterials; for (var t in e) { var i = e[t]; if (Array.isArray(i)) for (var o = 0, n = i.length; n > o; o += 1) i[o].dispose(); else i.dispose() } }, RC.prototype.disposeMaterials = function (A) { for (var e in this.materials) this.materials[e].dispose(); this.disposeInstanceMaterials(A) }, RC.prototype.updateMaterialsValue = function (A, e, t) { var i = this.materials, o = this.instanceMaterials, n = null; for (var r in i) for (var r in (n = i[r]) && n[e] && (n[e] = t, "function" == typeof n.refreshUniforms && n.refreshUniforms(), n.needsUpdate = !0), o) if (n = o[r]) if (Array.isArray(n)) for (var a = 0, s = n.length; s > a; a += 1) n[a][e] && (n[a][e] = t, "function" == typeof n[a].refreshUniforms && n[a].refreshUniforms(), n[a].needsUpdate = !0); else n[e] && (n[e] = t, "function" == typeof n.refreshUniforms && n.refreshUniforms(), n.needsUpdate = !0) }, RC.prototype.enableColorWithoutLight = function (A) { var e = this.materials, t = this.instanceMaterials, i = null; if (A) { for (var o in e) (i = e[o]) && (i.defines.USE_COLORWITHOUTLIGHT = "", i.needsUpdate = !0); for (var o in t) if (i = t[o]) if (i instanceof Array) for (var n = 0, r = i.length; r > n; n += 1) i[n].defines.USE_COLORWITHOUTLIGHT = "", i[n].needsUpdate = !0; else i.defines.USE_COLORWITHOUTLIGHT = "", i.needsUpdate = !0 } else { for (var o in e) (i = e[o]) && (delete i.defines.USE_COLORWITHOUTLIGHT, i.needsUpdate = !0); for (var o in t) if (i = t[o]) if (i instanceof Array) for (n = 0, r = i.length; r > n; n += 1) delete i[n].defines.USE_COLORWITHOUTLIGHT, i[n].needsUpdate = !0; else delete i.defines.USE_COLORWITHOUTLIGHT, i.needsUpdate = !0 } }, RC.prototype._updateTextureMapping = function (A) { var e = vc.EnableTextureMapping, t = this.ensureImagePowerOfTwo; function i(A, e) { if (e) { if (void 0 === e.length) A.map = e; else for (var i = 0; e.length > i; i += 1) t || (e[i].image = Kd.ensurePowerOfTwo(e[i].image)), "map" === e[i].texturetype ? A.map = e[i] : "bumpMap" === e[i].texturetype ? e[i].depth && (A.bumpScale = e[i].depth) : "specularMap" === e[i].texturetype ? A.specularMap = e[i] : "alphaMap" === e[i].texturetype ? (A.alphaMap = e[i], A.alphaTest = .01, A.map = e[i], A.transparent = !0) : "emissiveMap" === e[i].texturetype ? A.emissiveMap = e[i] : "environmentMap" === e[i].texturetype ? A.envMap = e[i] : "normalMap" === e[i].texturetype ? (A.normalMap = e[i], e[i].depth && A.normalScale.set(e[i].depth, e[i].depth)) : Bh.warn("This map type is not supported yet:", e[i].texturetype); vc.IBL && A.refreshUniforms(), A.needsUpdate = !0 } else A.textureColor && A.color.setStyle(A.textureColor), A.needsUpdate = !0 } if (this.lastTextureEnabled !== e) { var o = this.textures, n = this.materials; if (A) var r = A.manager.getMaterialOverrideSet(), a = r ? r.materialsByName : null, s = r ? r.textures : null; var l = this.instanceMaterials, c = null, h = null; if (e) { for (c in n) { if (h = n[c]) i(h, d = o[c]) } for (c in l) if (h = l[c]) { var d = o[c]; if (s && s[c] && (d = s[c]), Array.isArray(h)) for (var p = 0, g = h.length; g > p; p += 1) i(h[p], d); else i(h, d) } for (c in a) { if (h = a[c]) i(h, d = s[c.split("#")[0]]) } this.ensureImagePowerOfTwo = !0 } else { if (!r) for (c in n) (h = n[c]) && (h.map = null, h.needsUpdate = !0); for (c in l) if (h = l[c]) if (Array.isArray(h)) for (p = 0, g = h.length; g > p; p += 1) h[p].pureColor && (h[p].color.setStyle(h[p].pureColor), h[p].map = null, h[p].needsUpdate = !0), r || (h[p].map = null, h[p].needsUpdate = !0); else h.pureColor && (h.color.setStyle(h.pureColor), h.map = null, h.needsUpdate = !0), r || (h.map = null, h.needsUpdate = !0); for (c in a) (h = a[c]) && (h.map = null, h.needsUpdate = !0, h.pureColor && h.color.setStyle(h.pureColor)) } this.lastTextureEnabled = e } }, RC.prototype.updateMaterials = function (A) { var e = this.materials; for (var t in e) if (e.hasOwnProperty(t)) { var i = e[t]; i.IBLMaps = A.manager.scene.IBLMaps, i.refreshUniforms() } }, RC.prototype._updateIBL = function (A) { var e = A.manager.scene; if (vc.IBL && null !== e.iblProbe && e.iblProbe.isComputed) { this.materialManager.updateMaterials(A); var t = e.IBLcfg, i = t[Object.keys(t)[e.IBLIndex]]; for (var o in i) this.materialManager.updateMaterialsValue(A, o, i[o]) } }, RC.prototype.changeAllMaterials = function (A, e) { var t = this.materials; for (var i in t) if (t.hasOwnProperty(i)) { var o = Kd.getMaterialParameters(t[i]), n = null; e ? (delete o.textureColor, delete o.pureColor, delete o.imageFade, o.lights = !0, (n = new QC.IBLMaterial(o)).type = "IBL", n.refreshUniforms()) : (delete o.iblProbe, (n = Kd.createStandardMaterial(o)).roughness = o.originRoughness, n.metalness = o.originMetalness, n.refreshUniforms()), n.name = i, t[i] = n, o = null } }, RC.prototype.switchNewStyleMaterial = function (A, e) { var t = this.materials; for (var i in t) if (t.hasOwnProperty(i)) { var o = Kd.getMaterialParameters(t[i]), n = null; (n = e ? Kd.createNewStyleMaterial(o) : Kd.createStandardMaterial(o)).name = i, t[i] = n, o = null } }, RC.prototype.getInstanceMaterialById = function (A, e) { if (this.instanceMaterials[A]) return this.instanceMaterials[A]; var t = Kd.getMaterialParameters(e.manager.getOverrideMaterialByName(A) || this.materials[A]), i = t.transparent, o = Kd.createInstanceMaterial(t, !0); o.transparent = !1; var n = Kd.createInstanceMaterial(t, !0); return n.transparent = !0, vc.TranslucentDepthDisabled && (n.depthWrite = !1), i === o.transparent ? (this.instanceMaterials[A] = [o, n], n.defines.INSTANCE_STATE_SECONDARY = "") : (this.instanceMaterials[A] = [n, o], o.defines.INSTANCE_STATE_SECONDARY = ""), this.instanceMaterials[A] }, RC.prototype.getMaterialById = function (A) { return this.materials[A] }; var TC = function (A, e, t, i) { var o = this; this.manager = A, this.modelKey = e.modelKey, this.projectKey = e.dbName, this.offLine = e.offLine, this.accessToken = e.token || "", this.shareKey = e.share || "", this.dataVersion = null, this.debut = i, this.dataUrl = new eC(e), this.submodel = {}, this.loadingManager = new jr, this.loadingManager.model = this, this.fileLoader = new bu(this.loadingManager), this.configLoader = new bC(this), this.firstOctreeTransform = !0, this.numOfElements = 0, this.numOfTriangles = 0, this.singleStepMode = !1, this.sizeOfNextStep = 0, this.needUpdate = !1, this.boundingBoxWorld = null, this.rotation = new f, this.position = new y, this.scale = new y(1, 1, 1), this.transformMatrix = new M, this.selectedMaterial = this.manager.sceneState.selectionMaterial, this.materialManager = new RC, this.wireframeManager = new au, this.axisNetManager = void 0, this.floorManager = void 0, this.containsCamera = !1, this.loaded = !1, this.visible = !0, this.emptyScene = !1, this.cameraList = [], this.index = 0, this.modelConfig = null, this.kdTreeNode = null, this.parseCfgFinish = void 0, this.progressPercentage = { load: .4, collect: .5, merge: .1 }, this.progressFrequency = 10, this._encodedDatabagId = this.modelKey, this.groupName = gp.MODEL + "|" + this.modelKey, this.group = this.manager.scene.getOrCreateGroup(this.groupName, { pickableType: Qc.Geometry, globalSpace: !0 }), this._handler = null, this.lightmap = !1, this.lightmapNum = 0, this.enableLightmap = !1, this.lightmapIntensity = vc.LightmapIntensity, this.minDistanceObjects = {}, this.prioritizedNodeCount = 0, this.plugins = [], this.merged = !1, e.modelKeys && (this.modelGroup = !0, this.groupKey = e.modelKey, this.modelKeys = e.modelKeys, this.progressFrequency = 100, this.merged = !0, this.configLoader = new KC(this)), this.subModel = {}, mh.isSupportIndexedDB() ? (this.storage = new AC({ store: this.modelKey, version: 1, dbName: this.modelKey }), this.storage.addEventListener(Rc.ON_DATABASE_OPEN, (function (A) { t && t(o, !0) })), this.storage.addEventListener(Rc.ON_DATABASE_EEEOR, (function (A) { o.storage = void 0, t && t(o, !1) }))) : (o.storage = void 0, t && t(this, !1)) }; Object.assign(TC.prototype, Ld.prototype), TC.prototype.getStorage = function () { return this.storage }, TC.prototype.destroy = function () { this.selectedMaterial = null, this.cameraList = null, this.occlusionCamera && (this.occlusionCamera = null), this._removeMeshNodeGroup(), this.removeAllFromOctantMap(), this._handler && (this._handler.destroy(), this._handler = null), this.wireframeManager.destroy(), this.wireframeManager = null, this.materialManager.disposeMaterials(this), this.materialManager.destroy(), this.materialManager = null, this.manager = null, this.plugins = null, this.dataUrl = null, this.fileLoader = null, this.configLoader.destroy(), this.configLoader = null }, TC.prototype._getWireframeGroupName = function () { return gp.WIREFRAME + "|" + this.modelKey }, TC.prototype.load = function (A) { var e = this; this.configLoader.load((function () { e.parseCfgFinish && e.parseCfgFinish(), e.manager.updateScene(), e._getHandler().load(A) })) }, TC.prototype.setCrossOrigin = function (A) { this.fileLoader.setCrossOrigin(A) }, TC.prototype.prepare = function (A, e) { var t = this._getHandler(); t && t.prepare(A, e) }, TC.prototype.dispatchEventEx = function (A) { A.modelKey = this.modelKey, this.manager.dispatchEvent(A) }, TC.prototype.setLoaded = function (A) { this.loaded = A }, TC.prototype.isLoaded = function () { return this.loaded }, TC.prototype.getTransformMatrix = function () { return this.transformMatrix }, TC.prototype.isEmptyScene = function () { return this.emptyScene }, TC.prototype.setEmptyScene = function (A) { this.emptyScene = A }, TC.prototype.isLayerData = function () { return !(!this._handler || "layer" !== this._handler.tag) }, TC.prototype.setConfig = function (A) { this.configLoader.config = A }, TC.prototype.getConfig = function () { return this.configLoader.config }, TC.prototype.isVisible = function () { return this.manager.filter._isModelVisible(this.modelKey) }, TC.prototype.setVisible = function (A) { A ? this.manager.filter.showModelByIds([this.modelKey]) : this.manager.filter.hideModelByIds([this.modelKey]) }, TC.prototype.calculateCameraModelRelation = function (A) { this.containsCamera = this.getModelDescriptor().isOctreeOuter(A) }, TC.prototype.addCamera = function (A) { this.cameraList.push(A) }, TC.prototype.getCameraNameList = function () { for (var A = [], e = this.cameraList.length - 1; e >= 0; e -= 1) A.push(this.cameraList[e].name); return A }, TC.prototype.getCamera = function (A) { for (var e = this.cameraList.length - 1; e >= 0; e -= 1) if (this.cameraList[e].name === A) return this.cameraList[e]; return null }, TC.prototype.updateOctreeNode = function (A) { if (A || this.firstOctreeTransform) { this.firstOctreeTransform && (this.firstOctreeTransform = !1); var e = this.manager.scene.getMatrixGlobal(); this.getModelDescriptor().updateOctreeNode(e) } }, TC.prototype.isDataReady = function () { var A = this._handler; return !!A && A.isDataReady() }, TC.prototype.updateMeshNodes = function (A) { var e = this._getHandler(); if (e) { if ("layer" === e.tag && !e.layerDataLoaded) return; e.updateNodes() } }, TC.prototype._getHandler = function (A) { return this._handler }, TC.prototype.getMeshesByUserIds = function (A) { if (A) { var e = this._getHandler(); return e ? e.getMeshesByUserIds(A) : void 0 } }, TC.prototype.applyFilter = function () { console.log('applyFilter :>dfdfdf> '); if (!1 !== this.manager.filter._isModelVisible(this.modelKey)) { for (var A = 0, e = this.plugins.length; e > A; A += 1) this.plugins[A].applyFilter(); this.group.visible = !0; var t = this._getHandler(); t && t.applyFilter() } else this.group.visible = !1 }, TC.prototype.applySelection = function () { console.log('applySelection11') for (var A = 0, e = this.plugins.length; e > A; A += 1) this.plugins[A].applySelection(); var t = this._getHandler(); t && t.applySelection() }, TC.prototype.clearSelection = function () { for (var A = 0, e = this.plugins.length; e > A; A += 1) this.plugins[A].clearSelection(); var t = this._getHandler(); t && t.clearSelection() }, TC.prototype.applyHover = function () { for (var A = 0, e = this.plugins.length; e > A; A += 1) this.plugins[A].applyHover(); var t = this._getHandler(); t && t.applyHover() }, TC.prototype.clearHover = function () { for (var A = 0, e = this.plugins.length; e > A; A += 1) this.plugins[A].clearHover(); var t = this._getHandler(); t && t.clearHover() }, TC.prototype.applyBlink = function () { var A = this._getHandler(); A && A.applyBlink() }, TC.prototype.clearBlink = function () { var A = this._getHandler(); A && A.clearBlink() }, TC.prototype.applyReplacement = function () { var A = this._getHandler(); A && A.applyReplacement() }, TC.prototype._removeMeshNodeGroup = function () { this._removeNodeGroup(gp.GEOMETRY), this._removeNodeGroup(gp.INSTANCEGEOMETRY), this._removeNodeGroup(gp.WIREFRAME), this._removeNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY), this._removeNodeGroup(gp.AXISNET), this._removeSceneGroup(), this.group = null }, TC.prototype._getNodeGroup = function (A, e) { for (var t = this.group.children, i = 0, o = t.length; o > i; i += 1) if (t[i].name === A) return t[i]; var n = new ep(A, e); return this.group.add(n), n.globalSpace && (n.matrixAutoUpdate = !1, n.updateMatrixWorld(!0)), n }, TC.prototype._removeNodeGroup = function (A) { this.group.removeByName(A) }, TC.prototype._hasNodeGroup = function (A) { return this.group.hasChild(A) }, TC.prototype._removeSceneGroup = function () { this.manager.scene.removeGroupByName(this.groupName), this.manager.scene.removeGroupByName(this._getWireframeGroupName()) }, TC.prototype.removeAllFromOctantMap = function () { this.manager.removeAllFromOctantMap(this.modelKey) }, TC.prototype.clearMeshFromOctantMap = function () { this.manager.removeMeshFromOctantMap(this.modelKey) }, TC.prototype.getDatabagId = function () { return this.modelKey }, TC.prototype.getEncodedDatabagId = function () { return this.modelKey }, TC.prototype.getMaterialManager = function () { return this.materialManager }, TC.prototype.clearWireframeElementCount = function () { this.wireframeElementCount = void 0 }, TC.prototype.getWireframeElementCount = function () { if (void 0 !== this.wireframeElementCount) return this.wireframeElementCount; var A = this.getModelDescriptor().getAllNodeInfos(), e = this.manager.filter, t = 0; for (var i in A) { var o = A[i]; e._hasRenderWithBoardlineFilter() && !e._isRenderWithBoardline(o[0]) || (t += o.length) } return this.wireframeElementCount = t, t }, TC.prototype.isActivateWireframe = function () { return this.manager.isDrawingBoardlineEnabled() }, TC.prototype.isOnlyWireframe = function () { return this.manager.isOnlyWireframe() }, TC.prototype.getLoadedUserIdsObject = function () { return this._handler && this._handler.getLoadedUserIdsObject ? this._handler.getLoadedUserIdsObject() : null }, TC.prototype.clearNodeGroup = function () { var A = this._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); A.clear(), (A = this._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).clear(), (A = this._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).clear(), (A = this._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).clear() }, TC.prototype.getWireframeMaterial = function () { return this.wireframeManager.wireframeMaterial }, TC.prototype.getInstanceWireframeMaterial = function () { return this.wireframeManager.instanceWireframeMaterial }, TC.prototype.getMaterialByMaterialId = function (A) { return this.materialManager.materials[A] }, TC.prototype.adjustProgressPercentage = function (A, e, t) { this.progressPercentage.load = A, this.progressPercentage.collect = e, this.progressPercentage.merge = t }, TC.prototype.setReplacedUserIdMap = function (A) { this.replacedUserIdMap = uh.isOwnEmptyObject(A) ? null : A }, TC.prototype.hasReplacedUserId = function () { return !uh.isEmptyObject(this.replacedUserIdMap) }, TC.prototype.isReplacedUserId = function (A) { return this.replacedUserIdMap && this.replacedUserIdMap[A] }, TC.prototype.registerPlugin = function (A) { this.plugins.push(A) }, TC.prototype.disposeBufferAfterVbo = function () { var A = this._getHandler(); A && A.disposeBufferAfterVbo() }, TC.prototype.isHiddenUserId = function (A) { var e = this._getHandler(); return !!e && e.isHiddenNode(A) }, TC.prototype.hasHiddenUserId = function () { return this.manager.hasHiddenUserId() }, TC.prototype.isHiddenSourceObjectUserId = function (A) { return this.manager.isHiddenSourceObjectUserId(A) }, TC.prototype.hasHiddenSourceObjectUserId = function () { return this.manager.hasHiddenSourceObjectUserId() }, TC.prototype.getModelDescriptor = function () { return this._handler.loader.getDescriptor() }, TC.prototype.getLoader = function () { return this._handler.loader }, TC.prototype.getConfig = function () { return this.configLoader.getConfig() }, TC.prototype.getTransforms = function () { return this.configLoader.getTransforms() }, TC.prototype.getStatistics = function () { return this.configLoader.getStatistics() }, TC.prototype.setRenderableCount = function (A) { this.configLoader.setRenderableCount(A), this._handler && this._handler.clearPriorityNodesSet && this._handler.clearPriorityNodesSet(!0) }, TC.prototype.getRenderableCount = function () { return this.configLoader.getStatistics().renderableCount }, TC.prototype.getBoundingBoxWorld = function () { return this.configLoader.getTransforms().boundingBox }, TC.prototype.calculateBoundingBox = function () { var A = this.getModelDescriptor().getAllNodeInfos(), e = new aA; for (var t in A) for (var i = A[t], o = 0, n = i.length; n > o; o += 1) { var r = i[o]; r.boundingBox && e.union(r.boundingBox) } var a = this.getModelMatrix(); a && e.applyMatrix4(a), this.configLoader.getTransforms().boundingBox.copy(e) }, TC.prototype.calculateClippingIds = function () { var A = this._getHandler(); A && A.calculateClippingIds() }, TC.prototype.explode = function (A) { var e = this.getBoundingBoxWorld().getCenter(), t = this._getHandler(); t && t.explode(e, A) }, TC.prototype.formatLayerIds = function (A) { return this.getLayerProvider().formatLayerIds(A) }, TC.prototype.getBoundingBoxOfGeometries = function (A) { for (var e = !A, t = new aA, i = 0; A.length > i; i += 1) { var o = this.group.getObjectByProperty("guid", A[i]); if (o) { var n = o.geometry; if (n) { if (e || n) { n.boundingBox || n.computeBoundingBox(); var r = n.boundingBox; if (r) { var a = r.clone(); o.matrixWorld && a.applyMatrix4(o.matrixWorld), t.expandByPoint(a.min), t.expandByPoint(a.max) } } } else Bh.log("empty geometry!") } } return t }, TC.prototype.setModelMatrix = function (A) { this.group.matrix.copy(A), this.group.updateMatrixWorld(!0); var e = this.configLoader.transformInfos; e && e.boundingBox && (e.transformMatrix.copy(A), e.originalBoundingBox ? this.calculateBoundingBox() : (e.originalBoundingBox = e.boundingBox.clone(), e.boundingBox.applyMatrix4(A))), this.manager.updateSceneBoundingBox() }, TC.prototype.applyModelMatrix = function (A) { var e = this.configLoader.transformInfos; e && e.boundingBox && (e.transformMatrix.premultiply(A), e.originalBoundingBox || (e.originalBoundingBox = e.boundingBox.clone()), e.boundingBox.applyMatrix4(A)), this.group.matrix.copy(e.transformMatrix), this.group.updateMatrixWorld(!0), this.manager.updateSceneBoundingBox() }, TC.prototype.getModelMatrix = function () { var A = null; return this.group.matrix && (A = this.group.matrix.clone()), A }, TC.prototype.resetModelMatrix = function () { var A = this.configLoader.transformInfos.originalMatrix; A && this.setModelMatrix(A) }, TC.prototype.overturnYAndZaxis = function () { var A = (new M).makeRotationFromEuler(new F(Math.PI / 2, 0, 0)); this.group.matrix && (A.multiply(this.group.matrix), this.setModelMatrix(A)) }, TC.prototype.hasComponent = function (A) { return !!this.getModelDescriptor().getNodeInfosByUserId(A) }, TC.prototype.getComponentInfo = function (A) { return this.getModelDescriptor().getNodeInfosByComponentKey(A) }, TC.prototype.getComponentlist = function () { var A = [], e = this.getModelDescriptor(); for (var t in e.mapNodeInfoByComponentKey) e.mapNodeInfoByComponentKey.hasOwnProperty(t) && A.push(t); return A }, TC.prototype.addMeshToInfoMap = function (A, e, t, i, o) { this.getModelDescriptor().addMeshToInfoMap(A, e, t, i, o) }, TC.prototype.loadGeopkOnDemand = function (A, e, t) { this._handler && "layer" === this._handler.tag && this._handler.loadGeopkOnDemand(A, e, t) }, TC.prototype.unloadGeopkOnDemand = function (A, e) { this._handler && "layer" === this._handler.tag && this._handler.unloadComponents(A, e) }, TC.prototype.loadAllGeosOnDemand = function (A, e, t) { this._handler && "layer" === this._handler.tag && this._handler.loadAllGeosOnDemand(A, e, t) }, TC.prototype.getUnionBoundingBoxOnDemand = function () { return this.getLayerProvider().getUnionBoundingBoxOnDemand() }, TC.prototype.setConditionsChangedOnDemand = function (A) { this.getLayerProvider().setConditionsChanged(A) }, TC.prototype.explosion = function (A) { var e = this._getHandler(); Bh.time("模型离散用时"), e && (this.explosioning = !0, e.explosion(A)), Bh.timeEnd("模型离散用时"), this.calculateBoundingBox() }, TC.prototype.closeExplosion = function () { Bh.time("取消模型离散用时"); var A = this._getHandler(); A && (A.closeExplosion(), this.explosioning = !1), Bh.timeEnd("取消模型离散用时") }, TC.prototype.componentsExplosion = function (A) { var e = this._getHandler(); if (1 === (A.coefficientX || 1) && 1 === (A.coefficientY || 1) && 1 === (A.coefficientZ || 1) && 0 === (A.offsetX || 0) && 0 === (A.offsetY || 0) && 0 === (A.offsetZ || 0)) return this.explosioning = !1, this.closeComponentsExplosion(A.componentKey), void this.calculateBoundingBox(); Bh.time("构件离散用时"), e && (this.explosioning = !0, e.componentsExplosion(A), this.calculateBoundingBox()), Bh.timeEnd("构件离散用时") }, TC.prototype.closeComponentsExplosion = function (A) { Bh.time("取消构件离散用时"); var e = this._getHandler(); e && (e.closeComponentsExplosion(A), this.explosioning = !1), Bh.timeEnd("取消构件离散用时") }, TC.prototype.floorExplosion = function (A) { if (this.floorManager) { var e = this.floorManager.floorExplosionInfo; this.explosioning = !0; var t = this._getHandler(); if (!t) return !1; if (!e.sortedFloors) { for (var i = [], o = 0, n = e.floors.length; n > o; o += 1) { var r = e.floors[o], a = this.manager.getBoundingBoxByIds(r.componentkeys); if (!a.isEmpty()) { r.box = a; var s = new y; r.box.getCenter(s), r.center = s, i.push(r) } } i.sort((function (A, e) { return A.center.z - e.center.z })), e.sortedFloors = i; for (var l = 0, c = 1 / 0, h = 0, d = 0, p = i.length; p > d; d += 1) { var g = Math.abs(i[d].center.z); c > g && (l = d, c = g); var u = new y; i[d].box.getSize(u), h += u.z } e.baseFloorIndex = l, e.averageHeight = h / i.length; var f = i[l].center.toArray(); e.center = f } for (var m = (A - 1) * e.averageHeight, C = 0, v = e.sortedFloors.length; v > C; C += 1) { if (C !== e.baseFloorIndex) t.componentsExplosion({ offsetZ: (C - e.baseFloorIndex) * m, componentKey: e.sortedFloors[C].componentkeys, center: e.center }) } return this.calculateBoundingBox(), !0 } return !1 }, TC.prototype.closeFloorExplosion = function () { if (this.floorManager) { var A = this.floorManager.floorExplosionInfo; if (A && A.sortedFloors) { var e = this._getHandler(); if (e) { for (var t = 0, i = A.sortedFloors.length; i > t; t += 1) { e.closeComponentsExplosion(A.sortedFloors[t].componentkeys) } this.calculateBoundingBox(), this.explosioning = !1 } } } }, TC.prototype.showModel = function (A) { this.nodes.visible = A }, TC.prototype.updateMaterials = function () { var A = this.materials; for (var e in A) if (A.hasOwnProperty(e)) { var t = A[e]; t.IBLMaps = this.manager.scene.IBLMaps, t.refreshUniforms() } }, TC.prototype.updateMaterialsValue = function (A, e) { var t = this.materials; for (var i in t) if (t.hasOwnProperty(i)) { var o = t[i]; o.hasOwnProperty(A) && (o[A] = e, o.refreshUniforms(), o.needsUpdate = !0) } }, TC.prototype.changeAllMaterials = function (A) { var e = this.materials; for (var t in e) if (e.hasOwnProperty(t)) { var i = Kd.getMaterialParameters(e[t]), o = null; A ? (delete i.textureColor, delete i.pureColor, delete i.imageFade, i.lights = !0, (o = new QC.IBLMaterial(i)).type = "IBL", o.refreshUniforms()) : (delete i.iblProbe, (o = Kd.createStandardMaterial(i)).roughness = i.originRoughness, o.metalness = i.originMetalness, o.refreshUniforms()), o.name = t, e[t] = o, i = null } }, TC.prototype.getAllComponents = function () { return this.getComponentlist() }, TC.prototype.getComponentKeysByTypeFromList = function (A, e) { for (var t = this.getModelDescriptor(), i = [], o = 0; A.length > o; o += 1) t.mapNodeInfoByComponentKey.hasOwnProperty(A[o]) && t.mapNodeInfoByComponentKey[A[o]][0].type === e && i.push(A[o]); return i }, TC.prototype.getComponentKeysByType = function (A) { var e = this.getModelDescriptor(), t = []; for (var i in e.mapNodeInfoByComponentKey) e.mapNodeInfoByComponentKey.hasOwnProperty(i) && e.mapNodeInfoByComponentKey[i][0].type === A && t.push(i); return t }, TC.prototype.getAllComponentKeyType = function () { var A = {}, e = [], t = this.getModelDescriptor(); for (var i in t.mapNodeInfoByComponentKey) if (t.mapNodeInfoByComponentKey.hasOwnProperty(i)) { var o = t.mapNodeInfoByComponentKey[i][0].type; A[o] || (A[o] = !0, e.push(o)) } return e }, TC.prototype.getComponentKeysByName = function (A) { var e = this.getModelDescriptor(), t = []; for (var i in e.mapNodeInfoByComponentKey) e.mapNodeInfoByComponentKey.hasOwnProperty(i) && e.mapNodeInfoByComponentKey[i][0].name === A && t.push(i); return t }, TC.prototype.getComponentKeysByProperty = function (A, e) { var t = this.getModelDescriptor(), i = []; for (var o in t.mapNodeInfoByComponentKey) t.mapNodeInfoByComponentKey.hasOwnProperty(o) && t.mapNodeInfoByComponentKey[o][0][A] === e && i.push(o); return i }, TC.prototype._getLayerHandler = function () { return this._layerHandler }, TC.prototype.prepareData = function () { var A = this; this.materialManager._updateTextureMapping(), this.materialManager._updateIBL(this); var e = this._getHandler(); e && e.prepareData((function () { A.loaded = !0, A.hasAnimation && vc.EnableAnimation && A.createPanel(), A.debut(A) })) }, TC.prototype.isUserIdExist = function (A) { return !!this.getModelDescriptor().getNodeInfosByUserId(A) }, TC.prototype.getNodeInfosByUserId = function (A) { return this.getModelDescriptor().getNodeInfosByUserId(A) }, TC.prototype.getNodeInfos = function () { return this.getModelDescriptor().getNodeInfosWithUserId() }, TC.prototype.getFilter = function () { return this.manager.filter }, TC.prototype.getOctreeRoots = function (A) { this.getModelDescriptor().getOctreeRoots(A) }, TC.prototype.getPickingMeshes = function (A, e, t, i) { this._dealNonInstancedNodesForPicking(A, e, t, i), this._dealInstancedNodesForPicking(A, e, t, i), this._dealPluginNodesForPicking(A, e, t, i) }, TC.prototype._dealNonInstancedNodesForPicking = function (A, e, t, i) { if (this._handler) { var o = this._handler.defaultManager; if (o.hasNodeInfo(this)) { var n = o.getMeshManager().getPickingNodeGenerator().updatePickingMeshes(A.selectedMaterial, t, i); n && e.meshes.push(n); var r = o.getWireFrameManager().getPickingNodeGenerator().updatePickingMeshes(A.wireframeMaterial, t, i); r && e.meshes.push(r) } } }, TC.prototype._dealInstancedNodesForPicking = function (A, e, t, i) { if (this._handler) { var o = this._handler.instancedManager; if (o.hasNodeInfo(this)) { var n = o.getMeshManager().getPickingNodeGenerator().updatePickingMeshes(A.instancedSelectedMaterial, t, i); n && e.meshes.push(n); var r = o.getWireFrameManager().getPickingNodeGenerator().updatePickingMeshes(A.instancedWireFrameMaterial, t, i); r && e.meshes.push(r) } } }, TC.prototype._dealPluginNodesForPicking = function (A, e, t, i) { if (this._handler) for (var o = this.plugins, n = 0, r = o.length; r > n; n += 1) { var a = o[n].getPickingNodeGenerator().updatePickingMeshes(A.selectedMaterial, t, i); a && e.meshes.push(a) } }, TC.prototype.onWSWorkerMessage = function () {}, TC.prototype.onPDWorkerMessage = function () {}, TC.prototype._overrideOcclusionMaterial = function (A) { var e = A.material; if (e && !1 === e.transparent) { var t = this.manager.acquireMaterial(), i = t.material; e.color ? i.color.copy(e.color) : t.resetColor(), i.opacity = vc.OcclusionOpacity, A.material = i, A.material.needsUpdate = !0 } }, TC.prototype.showSkeleton = function (A) { this.skeleton.visible = A }, TC.prototype.deactivateAllActions = function () { this.needUpdate = !1, this.actions.forEach((function (A) { A.stop() })) }, TC.prototype.activateAllActions = function () { this.needUpdate = !0; for (var A = 0; this.actions.length > A; A += 1) this.setWeight(this.actions[A], 0 === A ? 1 : 0); this.actions.forEach((function (A) { A.play() })) }, TC.prototype.pauseAllActions = function () { this.needUpdate = !1, this.actions.forEach((function (A) { A.paused = !0 })) }, TC.prototype.toSingleStepMode = function () { this.unPauseAllActions(), this.singleStepMode = !0, this.sizeOfNextStep = this.settings["调整步长"] }, TC.prototype.pauseContinue = function () { this.singleStepMode ? (this.singleStepMode = !1, this.unPauseAllActions()) : this.paused ? (this.paused = !1, this.unPauseAllActions()) : (this.paused = !0, this.pauseAllActions()) }, TC.prototype.unPauseAllActions = function () { this.needUpdate = !0, this.actions.forEach((function (A) { A.paused = !1 })) }, TC.prototype.setWeight = function (A, e) { A.enabled = !0, A.setEffectiveTimeScale(1), A.setEffectiveWeight(e) }, TC.prototype.modifyTimeScale = function (A) { this.mixer.timeScale = A }, TC.prototype.createPanel = function () { var A = this, e = new $m({ width: 300 }).addFolder(this.modelKey), t = e.addFolder("可见性"), i = e.addFolder("激活/失活"), o = e.addFolder("暂停/步进"), n = e.addFolder("混合权重"), r = e.addFolder("综合速度"); this.settings = { "显示模型": !0, "显示骨骼": !1, "关闭全部动画": this.deactivateAllActions.bind(A), "激活所有动画": this.activateAllActions.bind(A), "暂停/继续": this.pauseContinue.bind(A), "单步动画": this.toSingleStepMode.bind(A), "调整步长": .05, "使用默认持续时间": !0, "设置自定义持续时间": 3.5, "modify idle weight": 0, "modify walk weight": 1, "modify run weight": 0, "修改时间尺度": 1 }; var a = this.settings; t.add(a, "显示模型").onChange(this.showModel.bind(A)), t.add(a, "显示骨骼").onChange(this.showSkeleton.bind(A)), i.add(a, "关闭全部动画"), i.add(a, "激活所有动画"), o.add(a, "暂停/继续"), o.add(a, "单步动画"), o.add(a, "调整步长", .01, .1, .001); for (var s = this.actions, l = function (e) { var t = s[e]._clip.name; a[t] = 0 === e ? 1 : 0, n.add(a, t, 0, 1, .01).listen().onChange((function (t) { A.setWeight(s[e], t) })) }, c = 0; s.length > c; c += 1) l(c); r.add(a, "修改时间尺度", 0, 10, .01).onChange(this.modifyTimeScale.bind(A)), t.open(), i.open(), o.open(), n.open(), r.open() }, TC.prototype.getTransformGroup = function () { return this.transformGroup || (this.transformGroup = this.manager.scene.getOrCreateGroup(gp.TRANSFORM), this.group.add(this.transformGroup), this.transformGroup.updateMatrixWorld(!0)), this.transformGroup }, TC.prototype.getComponentKeysBySubmodelKey = function (A) { return this.submodel[A] || [] }, TC.prototype.getTrianglesCount = function () { var A = 0, e = 0, t = 0, i = 0, o = {}; return this.group.traverse((function (n) { if (n.isMesh) { var r = n.geometry, a = r.getAttribute("position").count, s = r.index.count / 3, l = r.getAttribute("vState"); o[r.id] || (t += a, i += s, o[r.id] = !0), l && (a *= l.count, s *= l.count), A += a, e += s } })), o = null, { positionsCount: A, trianglesCount: e, realPositionCount: t, realTrianglesCount: i } }, TC.prototype.addLights = function (A) { this.lightGroup = this.lightGroup || new Xi, this.group.add(this.lightGroup), this.lightGroup.visible = !1; for (var e = 0, t = A.length; t > e; e += 1) this.lightGroup.add(A[e]), A[e].updateMatrixWorld() }, TC.prototype.hasLights = function () { return this.lightGroup && this.lightGroup.children.length > 0 }, TC.prototype.enabledLights = function () { this.lightGroup.visible = !0 }, TC.prototype.disabledLights = function () { this.lightGroup.visible = !1 }, Object.defineProperties(TC.prototype, { modelConfig: { get: function () { return Bh.warn("EIMMODEL.Model: .modelConfig 现在为 .getConfig()"), this.getConfig() }, set: function (A) { this.setConfig(A) } }, loader: { get: function () { return this._getHandler().loader } } }); var kC = { getBoxFromTileBoundingVolumeBox: function (A) { var e = new aA, t = (new y).fromArray(A, 0), i = new y; return i.fromArray(A, 3), i.add(t), e.expandByPoint(i), i.fromArray(A, 6), i.add(t), e.expandByPoint(i), i.fromArray(A, 9), i.add(t), e.expandByPoint(i), e }, getSphereFromTileBoundingVolumeSphere: function (A) { return new cA((new y).fromArray(A, 0), A[3] || 0) }, getTransfrom: function (A) { return Array.isArray(A) ? (new M).fromArray(A) : new M }, getSSE: function (A) { var e = this.getBoxByComponentsKey(A), t = this.viewerImpl.camera, i = e.getCenter(new y), o = e.getSize().length(), n = this.viewerImpl.getRenderer().domElement.width, r = t.fov; return o * n / (2 * t.position.clone().sub(i).length() * Math.tan(r / 2)) } }, DC = function (A) { bC.call(this, A) }; function LC(A, e, t) { if (0 > e) throw new Error("byteOffset cannot be negative."); if (0 > t) throw new Error("byteLength cannot be negative."); if (e + t > A.byteLength) throw new Error("sub-region exceeds array bounds."); return A = A.subarray(e = e || 0, e + (t = t || A.byteLength - e)), LC.decode(A) } function NC(A, e, t) { return A >= e && t >= A } (DC.prototype = Object.create(bC.prototype)).load = function (A) { var e = this, t = this.model, i = t.dataUrl; _d({ type: "GET", url: i.rootTilesUrl(), headers: { Authorization: t.accessToken }, success: function (o) { var n = {}; if ("string" == typeof o) try { n = JSON.parse(o) } catch (A) { return t.setEmptyScene(!0), void t.dispatchEventEx({ type: Rc.ON_LOAD_INVALID_SCENE, modelKey: t.modelKey }) } else n = o; if (n) { if (vc.offLine) e.model.getStorage().put(i.projectUrl(), n, e.model.modelKey, (function () {}), (function () {})); e._parse(n), t.dispatchEventEx({ type: Rc.ON_LOAD_CONFIG_FINISH, modelKey: t.modelKey }), A && A() } else Bh.log(t.modelKey, "config load error! ", n.message), t.dispatchEventEx({ type: Rc.ON_LOAD_ERROR, modelKey: t.modelKey, code: n.code, message: n.message }) }, error: function (A, e) { switch (A) { case 401: t.dispatchEventEx({ type: Rc.ACCOUNT_NO_EXIST, modelKey: t.modelKey, data: e }); break; case 403: t.dispatchEventEx({ type: Rc.NO_PERMISSION, modelKey: t.modelKey, data: e }); break; default: t.dispatchEventEx({ type: Rc.ON_NETWORK_ERROR, modelKey: t.modelKey, data: A }) } } }) }, DC.prototype._parse = function (A) { this.config = A, A.lengthUnit && (this.model.originalLengthUnit = A.lengthUnit || "m"), this._toStatistics(A), this._setTransformInfos(A), this._chooseRendering(A) }, DC.prototype._setTransformInfos = function (A) { this.model.hasAnimation = !1, this.transformInfos.octreeTransformed = !1, this.transformInfos.boundingBox && this.transformInfos.boundingBox.isBox3 || (this.transformInfos.boundingBox = kC.getBoxFromTileBoundingVolumeBox(A.root.boundingVolume.box)), this.transformInfos.transformMatrix.compose(this.transformInfos.position, this.transformInfos.rotation, this.transformInfos.scale), this.transformInfos.transformMatrix.fromArray(A.matrix || [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]), this.model.setModelMatrix(this.transformInfos.transformMatrix), this.model.manager.updateScene() }, LC.decodeWithTextDecoder = function (A) { return new TextDecoder("utf-8").decode(A) }, LC.decodeWithFromCharCode = function (A) { for (var e = "", t = function (A) { for (var e = 0, t = 0, i = 0, o = 128, n = 191, r = [], a = A.length, s = 0; a > s; s += 1) { var l = A[s]; if (0 === i) { if (NC(l, 0, 127)) { r.push(l); continue } if (NC(l, 194, 223)) { i = 1, e = 31 & l; continue } if (NC(l, 224, 239)) { 224 === l && (o = 160), 237 === l && (n = 159), i = 2, e = 15 & l; continue } if (NC(l, 240, 244)) { 240 === l && (o = 144), 244 === l && (n = 143), i = 3, e = 7 & l; continue } throw new Error("String decoding failed.") } NC(l, o, n) ? (o = 128, n = 191, e = e << 6 | 63 & l, (t += 1) === i && (r.push(e), e = i = t = 0)) : (e = i = t = 0, o = 128, n = 191, s -= 1) } return r }(A), i = t.length, o = 0; i > o; o += 1) { var n = t[o]; n > 65535 ? (n -= 65536, e += String.fromCharCode(55296 + (n >> 10), 56320 + (1023 & n))) : e += String.fromCharCode(n) } return e }, LC.decode = "undefined" != typeof TextDecoder ? LC.decodeWithTextDecoder : LC.decodeWithFromCharCode; var OC = function () { function A(A) { Yr.call(this, A), this.dracoLoader = null, this.ddsLoader = null } function e() { var A = {}; return { get: function (e) { return A[e] }, add: function (e, t) { A[e] = t }, remove: function (e) { delete A[e] }, removeAll: function () { A = {} } } } A.prototype = Object.assign(Object.create(Yr.prototype), { constructor: A, load: function (A, e, t, i) { var o, n = this; o = "" !== this.resourcePath ? this.resourcePath : "" !== this.path ? this.path : La.extractUrlBase(A), n.manager.itemStart(A); var r = function (e) { i ? i(e) : console.error(e), n.manager.itemError(A), n.manager.itemEnd(A) }, a = new bu(n.manager); a.setPath(this.path), a.setResponseType("arraybuffer"), "use-credentials" === n.crossOrigin && a.setWithCredentials(!0), a.load(A, (function (t) { try { n.parse(t, o, (function (t) { e(t), n.manager.itemEnd(A) }), r) } catch (A) { r(A) } }), t, r) }, setDRACOLoader: function (A) { return this.dracoLoader = A, this }, setDDSLoader: function (A) { return this.ddsLoader = A, this }, parse: function (A, e, a, s) { var l, c = {}; if ("string" == typeof A) l = A; else { var g = La.decodeText(new Uint8Array(A, 0, 4)); if (g === r) { try { c[t.KHR_BINARY_GLTF] = new h(A) } catch (A) { return void(s && s(A)) } l = c[t.KHR_BINARY_GLTF].content } else if ("b3dm" === g) { try { c[t.KHR_BINARY_GLTF] = new h(function (A) { var e = 0; e = 0; var t = Uint32Array.BYTES_PER_ELEMENT, i = new Uint8Array(A), o = new DataView(A), n = o.getUint32(e += t, !0); if (1 !== n) throw new Error("Only Batched 3D Model version 1 is supported. Version " + n + " is not."); var r, a = o.getUint32(e += t, !0), s = o.getUint32(e += t, !0), l = o.getUint32(e += t, !0), c = o.getUint32(e += t, !0), h = o.getUint32(e += t, !0); if (e += t, 570425344 > c ? 570425344 > h || (e -= t, r = c, c = s, h = l, s = 0, l = 0) : (e -= 2 * t, r = s, c = l, h = 0, s = 0, l = 0), 0 === s) ({ BATCH_LENGTH: r || 0 }); else { var d = LC(i, e, s); JSON.parse(d), e += s } if (e += l, c > 0) { var p = LC(i, e, c); JSON.parse(p), e += c, h > 0 && (e += h) } var g = 0 + a - e; if (0 === g) throw new Error("glTF byte length must be greater than 0."); var u = null; return e % 4 == 0 ? (new Uint8Array(A, e, g), u = A.slice(e)) : (new Uint8Array(i.subarray(e, e + g)), u = A.slice(e)), u }(A)) } catch (A) { return void(s && s(A)) } l = c[t.KHR_BINARY_GLTF].content } else l = La.decodeText(new Uint8Array(A)) } var m = JSON.parse(l); if (void 0 === m.asset || m.asset.version[0] < 2) s && s(new Error("THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported.")); else { if (m.extensionsUsed) for (var C = 0; m.extensionsUsed.length > C; ++C) { var y = m.extensionsUsed[C], v = m.extensionsRequired || []; switch (y) { case t.KHR_LIGHTS_PUNCTUAL: c[y] = new o(m); break; case t.KHR_MATERIALS_UNLIT: c[y] = new n; break; case t.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS: c[y] = new u; break; case t.KHR_DRACO_MESH_COMPRESSION: c[y] = new d(m, this.dracoLoader); break; case t.MSFT_TEXTURE_DDS: c[y] = new i(this.ddsLoader); break; case t.KHR_TEXTURE_TRANSFORM: c[y] = new p; break; case t.KHR_MESH_QUANTIZATION: c[y] = new f; break; default: 0 > v.indexOf(y) || console.warn('THREE.GLTFLoader: Unknown extension "' + y + '".') } } new q(m, c, { path: e || this.resourcePath || "", crossOrigin: this.crossOrigin, manager: this.manager }).parse(a, s) } } }); var t = { KHR_BINARY_GLTF: "KHR_binary_glTF", KHR_DRACO_MESH_COMPRESSION: "KHR_draco_mesh_compression", KHR_LIGHTS_PUNCTUAL: "KHR_lights_punctual", KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS: "KHR_materials_pbrSpecularGlossiness", KHR_MATERIALS_UNLIT: "KHR_materials_unlit", KHR_TEXTURE_TRANSFORM: "KHR_texture_transform", KHR_MESH_QUANTIZATION: "KHR_mesh_quantization", MSFT_TEXTURE_DDS: "MSFT_texture_dds" }; function i(A) { if (!A) throw new Error("THREE.GLTFLoader: Attempting to load .dds texture without importing DDSLoader"); this.name = t.MSFT_TEXTURE_DDS, this.ddsLoader = A } function o(A) { this.name = t.KHR_LIGHTS_PUNCTUAL, this.lightDefs = (A.extensions && A.extensions[t.KHR_LIGHTS_PUNCTUAL] || {}).lights || [] } function n() { this.name = t.KHR_MATERIALS_UNLIT } o.prototype.loadLight = function (A) { var e, t = this.lightDefs[A], i = new LA(16777215); void 0 !== t.color && i.fromArray(t.color); var o = void 0 !== t.range ? t.range : 0; switch (t.type) { case "directional": (e = new Ra(i)).target.position.set(0, 0, -1), e.add(e.target); break; case "point": (e = new Fa(i)).distance = o; break; case "spot": (e = new ba(i)).distance = o, t.spot = t.spot || {}, t.spot.innerConeAngle = void 0 !== t.spot.innerConeAngle ? t.spot.innerConeAngle : 0, t.spot.outerConeAngle = void 0 !== t.spot.outerConeAngle ? t.spot.outerConeAngle : Math.PI / 4, e.angle = t.spot.outerConeAngle, e.penumbra = 1 - t.spot.innerConeAngle / t.spot.outerConeAngle, e.target.position.set(0, 0, -1), e.add(e.target); break; default: throw new Error('THREE.GLTFLoader: Unexpected light type, "' + t.type + '".') } return e.position.set(0, 0, 0), e.decay = 2, void 0 !== t.intensity && (e.intensity = t.intensity), e.name = t.name || "light_" + A, Promise.resolve(e) }, n.prototype.getMaterialType = function () { return jA }, n.prototype.extendParams = function (A, e, t) { var i = []; A.color = new LA(1, 1, 1), A.opacity = 1; var o = e.pbrMetallicRoughness; if (o) { if (Array.isArray(o.baseColorFactor)) { var n = o.baseColorFactor; A.color.fromArray(n), A.opacity = n[3] } void 0 !== o.baseColorTexture && i.push(t.assignTexture(A, "map", o.baseColorTexture)) } return Promise.all(i) }; var r = "glTF", l = 1313821514, c = 5130562; function h(A) { this.name = t.KHR_BINARY_GLTF, this.content = null, this.body = null; var e = new DataView(A, 0, 12); if (this.header = { magic: La.decodeText(new Uint8Array(A.slice(0, 4))), version: e.getUint32(4, !0), length: e.getUint32(8, !0) }, this.header.magic !== r) throw new Error("THREE.GLTFLoader: Unsupported glTF-Binary header."); if (2 > this.header.version) throw new Error("THREE.GLTFLoader: Legacy binary file detected."); for (var i = new DataView(A, 12), o = 0; i.byteLength > o;) { var n = i.getUint32(o, !0), a = i.getUint32(o += 4, !0); if (o += 4, a === l) { var s = new Uint8Array(A, 12 + o, n); this.content = La.decodeText(s) } else if (a === c) { var h = 12 + o; this.body = A.slice(h, h + n) } o += n } if (null === this.content) throw new Error("THREE.GLTFLoader: JSON content not found.") } function d(A, e) { if (!e) throw new Error("THREE.GLTFLoader: No DRACOLoader instance provided."); this.name = t.KHR_DRACO_MESH_COMPRESSION, this.json = A, this.dracoLoader = e, this.dracoLoader.preload() } function p() { this.name = t.KHR_TEXTURE_TRANSFORM } function g(A) { yr.call(this), this.isGLTFSpecularGlossinessMaterial = !0; var e = ["#ifdef USE_SPECULARMAP", "\tuniform sampler2D specularMap;", "#endif"].join("\n"), t = ["#ifdef USE_GLOSSINESSMAP", "\tuniform sampler2D glossinessMap;", "#endif"].join("\n"), i = ["vec3 specularFactor = specular;", "#ifdef USE_SPECULARMAP", "\tvec4 texelSpecular = texture2D( specularMap, vUv );", "\ttexelSpecular = sRGBToLinear( texelSpecular );", "\t// reads channel RGB, compatible with a glTF Specular-Glossiness (RGBA) texture", "\tspecularFactor *= texelSpecular.rgb;", "#endif"].join("\n"), o = ["float glossinessFactor = glossiness;", "#ifdef USE_GLOSSINESSMAP", "\tvec4 texelGlossiness = texture2D( glossinessMap, vUv );", "\t// reads channel A, compatible with a glTF Specular-Glossiness (RGBA) texture", "\tglossinessFactor *= texelGlossiness.a;", "#endif"].join("\n"), n = ["PhysicalMaterial material;", "material.diffuseColor = diffuseColor.rgb;", "vec3 dxy = max( abs( dFdx( geometryNormal ) ), abs( dFdy( geometryNormal ) ) );", "float geometryRoughness = max( max( dxy.x, dxy.y ), dxy.z );", "material.specularRoughness = max( 1.0 - glossinessFactor, 0.0525 );// 0.0525 corresponds to the base mip of a 256 cubemap.", "material.specularRoughness += geometryRoughness;", "material.specularRoughness = min( material.specularRoughness, 1.0 );", "material.specularColor = specularFactor.rgb;"].join("\n"), r = { specular: { value: (new LA).setHex(16777215) }, glossiness: { value: 1 }, specularMap: { value: null }, glossinessMap: { value: null } }; this._extraUniforms = r, this.onBeforeCompile = function (A) { for (var a in r) A.uniforms[a] = r[a]; A.fragmentShader = A.fragmentShader.replace("uniform float roughness;", "uniform vec3 specular;"), A.fragmentShader = A.fragmentShader.replace("uniform float metalness;", "uniform float glossiness;"), A.fragmentShader = A.fragmentShader.replace("#include ", e), A.fragmentShader = A.fragmentShader.replace("#include ", t), A.fragmentShader = A.fragmentShader.replace("#include ", i), A.fragmentShader = A.fragmentShader.replace("#include ", o), A.fragmentShader = A.fragmentShader.replace("#include ", n) }, Object.defineProperties(this, { specular: { get: function () { return r.specular.value }, set: function (A) { r.specular.value = A } }, specularMap: { get: function () { return r.specularMap.value }, set: function (A) { r.specularMap.value = A } }, glossiness: { get: function () { return r.glossiness.value }, set: function (A) { r.glossiness.value = A } }, glossinessMap: { get: function () { return r.glossinessMap.value }, set: function (A) { r.glossinessMap.value = A, A ? (this.defines.USE_GLOSSINESSMAP = "", this.defines.USE_ROUGHNESSMAP = "") : (delete this.defines.USE_ROUGHNESSMAP, delete this.defines.USE_GLOSSINESSMAP) } } }), delete this.metalness, delete this.roughness, delete this.metalnessMap, delete this.roughnessMap, this.setValues(A) } function u() { return { name: t.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS, specularGlossinessParams: ["color", "map", "lightMap", "lightMapIntensity", "aoMap", "aoMapIntensity", "emissive", "emissiveIntensity", "emissiveMap", "bumpMap", "bumpScale", "normalMap", "normalMapType", "displacementMap", "displacementScale", "displacementBias", "specularMap", "specular", "glossinessMap", "glossiness", "alphaMap", "envMap", "envMapIntensity", "refractionRatio"], getMaterialType: function () { return g }, extendParams: function (A, e, t) { var i = e.extensions[this.name]; A.color = new LA(1, 1, 1), A.opacity = 1; var o = []; if (Array.isArray(i.diffuseFactor)) { var n = i.diffuseFactor; A.color.fromArray(n), A.opacity = n[3] } if (void 0 !== i.diffuseTexture && o.push(t.assignTexture(A, "map", i.diffuseTexture)), A.emissive = new LA(0, 0, 0), A.glossiness = void 0 !== i.glossinessFactor ? i.glossinessFactor : 1, A.specular = new LA(1, 1, 1), Array.isArray(i.specularFactor) && A.specular.fromArray(i.specularFactor), void 0 !== i.specularGlossinessTexture) { var r = i.specularGlossinessTexture; o.push(t.assignTexture(A, "glossinessMap", r)), o.push(t.assignTexture(A, "specularMap", r)) } return Promise.all(o) }, createMaterial: function (A) { var e = new g(A); return e.fog = !0, e.color = A.color, e.map = void 0 === A.map ? null : A.map, e.lightMap = null, e.lightMapIntensity = 1, e.aoMap = void 0 === A.aoMap ? null : A.aoMap, e.aoMapIntensity = 1, e.emissive = A.emissive, e.emissiveIntensity = 1, e.emissiveMap = void 0 === A.emissiveMap ? null : A.emissiveMap, e.bumpMap = void 0 === A.bumpMap ? null : A.bumpMap, e.bumpScale = 1, e.normalMap = void 0 === A.normalMap ? null : A.normalMap, e.normalMapType = 0, A.normalScale && (e.normalScale = A.normalScale), e.displacementMap = null, e.displacementScale = 1, e.displacementBias = 0, e.specularMap = void 0 === A.specularMap ? null : A.specularMap, e.specular = A.specular, e.glossinessMap = void 0 === A.glossinessMap ? null : A.glossinessMap, e.glossiness = A.glossiness, e.alphaMap = null, e.envMap = void 0 === A.envMap ? null : A.envMap, e.envMapIntensity = 1, e.refractionRatio = .98, e } } } function f() { this.name = t.KHR_MESH_QUANTIZATION } function m(A, e, t, i) { Ur.call(this, A, e, t, i) } d.prototype.decodePrimitive = function (A, e) { var t = this.json, i = this.dracoLoader, o = A.extensions[this.name].bufferView, n = A.extensions[this.name].attributes, r = {}, a = {}, s = {}; for (var l in n) { var c = K[l] || l.toLowerCase(); r[c] = n[l] } for (l in A.attributes) { c = K[l] || l.toLowerCase(); if (void 0 !== n[l]) { var h = t.accessors[A.attributes[l]]; s[c] = w[h.componentType], a[c] = !0 === h.normalized } } return e.getDependency("bufferView", o).then((function (A) { return new Promise((function (e) { i.decodeDracoFile(A, (function (A) { for (var t in A.attributes) { var i = a[t]; void 0 !== i && (A.attributes[t].normalized = i) } e(A) }), r, s) })) })) }, p.prototype.extendTexture = function (A, e) { return A = A.clone(), void 0 !== e.offset && A.offset.fromArray(e.offset), void 0 !== e.rotation && (A.rotation = e.rotation), void 0 !== e.scale && A.repeat.fromArray(e.scale), void 0 !== e.texCoord && console.warn('THREE.GLTFLoader: Custom UV sets in "' + this.name + '" extension not yet supported.'), A.needsUpdate = !0, A }, (g.prototype = Object.create(yr.prototype)).constructor = g, g.prototype.copy = function (A) { return yr.prototype.copy.call(this, A), this.specularMap = A.specularMap, this.specular.copy(A.specular), this.glossinessMap = A.glossinessMap, this.glossiness = A.glossiness, delete this.metalness, delete this.roughness, delete this.metalnessMap, delete this.roughnessMap, this }, (m.prototype = Object.create(Ur.prototype)).constructor = m, m.prototype.beforeStart_ = m.prototype.copySampleValue_ = function (A) { for (var e = this.resultBuffer, t = this.sampleValues, i = this.valueSize, o = A * i * 3 + i, n = 0; n !== i; n++) e[n] = t[o + n]; return e }, m.prototype.afterEnd_ = m.prototype.copySampleValue_, m.prototype.interpolate_ = function (A, e, t, i) { for (var o = this.resultBuffer, n = this.sampleValues, r = this.valueSize, a = 2 * r, s = 3 * r, l = i - e, c = (t - e) / l, h = c * c, d = h * c, p = A * s, g = p - s, u = -2 * d + 3 * h, f = d - h, m = 1 - u, C = f - h + c, y = 0; y !== r; y++) { o[y] = m * n[g + y + r] + C * (n[g + y + a] * l) + u * n[p + y + r] + f * (n[p + y] * l) } return o }; var C = 0, v = 1, I = 2, E = 3, B = 4, x = 5, S = 6, w = { 5120: Int8Array, 5121: Uint8Array, 5122: Int16Array, 5123: Uint16Array, 5125: Uint32Array, 5126: Float32Array }, b = { 9728: 1003, 9729: 1006, 9984: 1004, 9985: 1007, 9986: 1005, 9987: 1008 }, U = { 33071: 1001, 33648: 1002, 10497: 1e3 }, F = { SCALAR: 1, VEC2: 2, VEC3: 3, VEC4: 4, MAT2: 4, MAT3: 9, MAT4: 16 }, K = { POSITION: "position", NORMAL: "normal", TANGENT: "tangent", TEXCOORD_0: "uv", TEXCOORD_1: "uv2", COLOR_0: "color", WEIGHTS_0: "skinWeight", JOINTS_0: "skinIndex" }, Q = { scale: "scale", translation: "position", rotation: "quaternion", weights: "morphTargetInfluences" }, R = { CUBICSPLINE: void 0, LINEAR: 2301, STEP: 2300 }, T = "OPAQUE", k = "MASK", D = "BLEND", L = { "image/png": 1023, "image/jpeg": 1022 }; function N(A, e) { return "string" != typeof A || "" === A ? "" : (/^https?:\/\//i.test(e) && /^\//.test(A) && (e = e.replace(/(^https?:\/\/[^\/]+).*/i, "$1")), /^(https?:)?\/\//i.test(A) || /^data:.*,.*$/i.test(A) || /^blob:.*$/i.test(A) ? A : e + A) } function O(A, e, t) { for (var i in t.extensions) void 0 === A[i] && (e.userData.gltfExtensions = e.userData.gltfExtensions || {}, e.userData.gltfExtensions[i] = t.extensions[i]) } function V(A, e) { void 0 !== e.extras && ("object" === lc(e.extras) ? Object.assign(A.userData, e.extras) : console.warn("THREE.GLTFLoader: Ignoring primitive type .extras, " + e.extras)) } function G(A, e) { if (A.updateMorphTargets(), void 0 !== e.weights) for (var t = 0, i = e.weights.length; i > t; t++) A.morphTargetInfluences[t] = e.weights[t]; if (e.extras && Array.isArray(e.extras.targetNames)) { var o = e.extras.targetNames; if (A.morphTargetInfluences.length === o.length) { A.morphTargetDictionary = {}; for (t = 0, i = o.length; i > t; t++) A.morphTargetDictionary[o[t]] = t } else console.warn("THREE.GLTFLoader: Invalid extras.targetNames length. Ignoring names.") } } function P(A) { for (var e = "", t = Object.keys(A).sort(), i = 0, o = t.length; o > i; i++) e += t[i] + ":" + A[t[i]] + ";"; return e } function q(A, t, i) { this.json = A || {}, this.extensions = t || {}, this.options = i || {}, this.cache = new e, this.primitiveCache = {}, this.textureLoader = new Aa(this.options.manager), this.textureLoader.setCrossOrigin(this.options.crossOrigin), this.fileLoader = new bu(this.options.manager), this.fileLoader.setResponseType("arraybuffer"), "use-credentials" === this.options.crossOrigin && this.fileLoader.setWithCredentials(!0) } function j(A, e, t) { var i = e.attributes, o = []; function n(e, i) { return t.getDependency("accessor", e).then((function (e) { A.setAttribute(i, e) })) } for (var r in i) { var a = K[r] || r.toLowerCase(); a in A.attributes || o.push(n(i[r], a)) } if (void 0 !== e.indices && !A.index) { var s = t.getDependency("accessor", e.indices).then((function (e) { A.setIndex(e) })); o.push(s) } return V(A, e), function (A, e, t) { var i = e.attributes, o = new aA; if (void 0 !== i.POSITION) { var n = (h = t.json.accessors[i.POSITION]).max; if (void 0 !== (d = h.min) && void 0 !== n) { o.set(new y(d[0], d[1], d[2]), new y(n[0], n[1], n[2])); var r = e.targets; if (void 0 !== r) for (var a = new y, s = 0, l = r.length; l > s; s++) { var c = r[s]; if (void 0 !== c.POSITION) { var h, d; n = (h = t.json.accessors[c.POSITION]).max; void 0 !== (d = h.min) && void 0 !== n ? (a.setX(Math.max(Math.abs(d[0]), Math.abs(n[0]))), a.setY(Math.max(Math.abs(d[1]), Math.abs(n[1]))), a.setZ(Math.max(Math.abs(d[2]), Math.abs(n[2]))), o.expandByVector(a)) : console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.") } } A.boundingBox = o; var p = new cA; o.getCenter(p.center), p.radius = o.min.distanceTo(o.max) / 2, A.boundingSphere = p } else console.warn("THREE.GLTFLoader: Missing min/max properties for accessor POSITION.") } }(A, e, t), Promise.all(o).then((function () { return void 0 !== e.targets ? function (A, e, t) { for (var i = !1, o = !1, n = 0, r = e.length; r > n; n++) { if (void 0 !== (l = e[n]).POSITION && (i = !0), void 0 !== l.NORMAL && (o = !0), i && o) break } if (!i && !o) return Promise.resolve(A); var a = [], s = []; for (n = 0, r = e.length; r > n; n++) { var l = e[n]; if (i) { var c = void 0 !== l.POSITION ? t.getDependency("accessor", l.POSITION) : A.attributes.position; a.push(c) } if (o) { c = void 0 !== l.NORMAL ? t.getDependency("accessor", l.NORMAL) : A.attributes.normal; s.push(c) } } return Promise.all([Promise.all(a), Promise.all(s)]).then((function (e) { var t = e[1]; return i && (A.morphAttributes.position = e[0]), o && (A.morphAttributes.normal = t), A.morphTargetsRelative = !0, A })) }(A, e.targets, t) : A })) } function Y(A, e) { var t = A.getIndex(); if (null === t) { var i = [], o = A.getAttribute("position"); if (void 0 === o) return console.error("THREE.GLTFLoader.toTrianglesDrawMode(): Undefined position attribute. Processing not possible."), A; for (var n = 0; o.count > n; n++) i.push(n); A.setIndex(i), t = A.getIndex() } var r = t.count - 2, a = []; if (2 === e) for (n = 1; r >= n; n++) a.push(t.getX(0)), a.push(t.getX(n)), a.push(t.getX(n + 1)); else for (n = 0; r > n; n++) n % 2 == 0 ? (a.push(t.getX(n)), a.push(t.getX(n + 1)), a.push(t.getX(n + 2))) : (a.push(t.getX(n + 2)), a.push(t.getX(n + 1)), a.push(t.getX(n))); a.length / 3 !== r && console.error("THREE.GLTFLoader.toTrianglesDrawMode(): Unable to generate correct amount of triangles."); var s = A.clone(); return s.setIndex(a), s } return q.prototype.parse = function (A, e) { var t = this, i = this.json, o = this.extensions; this.cache.removeAll(), this.markDefs(), Promise.all([this.getDependencies("scene"), this.getDependencies("animation"), this.getDependencies("camera")]).then((function (e) { var n = { scene: e[0][i.scene || 0], scenes: e[0], animations: e[1], cameras: e[2], asset: i.asset, parser: t, userData: {} }; O(o, n, i), V(n, i), A(n) })).catch(e) }, q.prototype.markDefs = function () { for (var A = this.json.nodes || [], e = this.json.skins || [], t = this.json.meshes || [], i = {}, o = {}, n = 0, r = e.length; r > n; n++) for (var a = e[n].joints, s = 0, l = a.length; l > s; s++) A[a[s]].isBone = !0; for (var c = 0, h = A.length; h > c; c++) { var d = A[c]; void 0 !== d.mesh && (void 0 === i[d.mesh] && (i[d.mesh] = o[d.mesh] = 0), i[d.mesh]++, void 0 !== d.skin && (t[d.mesh].isSkinnedMesh = !0)) } this.json.meshReferences = i, this.json.meshUses = o }, q.prototype.getDependency = function (A, e) { var i = A + ":" + e, o = this.cache.get(i); if (!o) { switch (A) { case "scene": o = this.loadScene(e); break; case "node": o = this.loadNode(e); break; case "mesh": o = this.loadMesh(e); break; case "accessor": o = this.loadAccessor(e); break; case "bufferView": o = this.loadBufferView(e); break; case "buffer": o = this.loadBuffer(e); break; case "material": o = this.loadMaterial(e); break; case "texture": o = this.loadTexture(e); break; case "skin": o = this.loadSkin(e); break; case "animation": o = this.loadAnimation(e); break; case "camera": o = this.loadCamera(e); break; case "light": o = this.extensions[t.KHR_LIGHTS_PUNCTUAL].loadLight(e); break; default: throw new Error("Unknown type: " + A) } this.cache.add(i, o) } return o }, q.prototype.getDependencies = function (A) { var e = this.cache.get(A); if (!e) { var t = this; e = Promise.all((this.json[A + ("mesh" === A ? "es" : "s")] || []).map((function (e, i) { return t.getDependency(A, i) }))), this.cache.add(A, e) } return e }, q.prototype.loadBuffer = function (A) { var e = this.json.buffers[A], i = this.fileLoader; if (e.type && "arraybuffer" !== e.type) throw new Error("THREE.GLTFLoader: " + e.type + " buffer type is not supported."); if (void 0 === e.uri && 0 === A) return Promise.resolve(this.extensions[t.KHR_BINARY_GLTF].body); var o = this.options; return new Promise((function (A, t) { i.load(N(e.uri, o.path), A, void 0, (function () { t(new Error('THREE.GLTFLoader: Failed to load buffer "' + e.uri + '".')) })) })) }, q.prototype.loadBufferView = function (A) { var e = this.json.bufferViews[A]; return this.getDependency("buffer", e.buffer).then((function (A) { var t = e.byteOffset || 0; return A.slice(t, t + (e.byteLength || 0)) })) }, q.prototype.loadAccessor = function (A) { var e = this, t = this.json, i = this.json.accessors[A]; if (void 0 === i.bufferView && void 0 === i.sparse) return Promise.resolve(null); var o = []; return o.push(void 0 !== i.bufferView ? this.getDependency("bufferView", i.bufferView) : null), void 0 !== i.sparse && (o.push(this.getDependency("bufferView", i.sparse.indices.bufferView)), o.push(this.getDependency("bufferView", i.sparse.values.bufferView))), Promise.all(o).then((function (A) { var o, n = A[0], r = F[i.type], a = w[i.componentType], s = a.BYTES_PER_ELEMENT, l = i.byteOffset || 0, c = void 0 !== i.bufferView ? t.bufferViews[i.bufferView].byteStride : void 0, h = !0 === i.normalized; if (c && c !== s * r) { var d = Math.floor(l / c), p = "InterleavedBuffer:" + i.bufferView + ":" + i.componentType + ":" + d + ":" + i.count, g = e.cache.get(p); g || (g = new to(new a(n, d * c, i.count * c / s), c / s), e.cache.add(p, g)), o = new no(g, r, l % c / s, h) } else o = new YA(null === n ? new a(i.count * r) : new a(n, l, i.count * r), r, h); if (void 0 !== i.sparse) { var u = i.sparse.values.byteOffset || 0, f = new(0, w[i.sparse.indices.componentType])(A[1], i.sparse.indices.byteOffset || 0, i.sparse.count * F.SCALAR), m = new a(A[2], u, i.sparse.count * r); null !== n && (o = new YA(o.array.slice(), o.itemSize, o.normalized)); for (var C = 0, y = f.length; y > C; C++) { var v = f[C]; if (o.setX(v, m[C * r]), 2 > r || o.setY(v, m[C * r + 1]), 3 > r || o.setZ(v, m[C * r + 2]), 4 > r || o.setW(v, m[C * r + 3]), r >= 5) throw new Error("THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.") } } return o })) }, q.prototype.loadTexture = function (A) { var e, i = this, o = this.json, n = this.options, r = this.textureLoader, a = window.URL || window.webkitURL, s = o.textures[A], l = s.extensions || {}, c = (e = l[t.MSFT_TEXTURE_DDS] ? o.images[l[t.MSFT_TEXTURE_DDS].source] : o.images[s.source]).uri, h = !1; return void 0 !== e.bufferView && (c = i.getDependency("bufferView", e.bufferView).then((function (A) { h = !0; var t = new Blob([A], { type: e.mimeType }); return c = a.createObjectURL(t) }))), Promise.resolve(c).then((function (A) { var e = n.manager.getHandler(A); return e || (e = l[t.MSFT_TEXTURE_DDS] ? i.extensions[t.MSFT_TEXTURE_DDS].ddsLoader : r), new Promise((function (t, i) { e.load(N(A, n.path), t, void 0, i) })) })).then((function (A) { !0 === h && a.revokeObjectURL(c), A.flipY = !1, s.name && (A.name = s.name), e.mimeType in L && (A.format = L[e.mimeType]); var t = (o.samplers || {})[s.sampler] || {}; return A.magFilter = b[t.magFilter] || 1006, A.minFilter = b[t.minFilter] || 1008, A.wrapS = U[t.wrapS] || 1e3, A.wrapT = U[t.wrapT] || 1e3, A })) }, q.prototype.assignTexture = function (A, e, i) { var o = this; return this.getDependency("texture", i.index).then((function (n) { if (!n.isCompressedTexture) switch (e) { case "aoMap": case "emissiveMap": case "metalnessMap": case "normalMap": case "roughnessMap": n.format = 1022 } if (void 0 === i.texCoord || 0 == i.texCoord || "aoMap" === e && 1 == i.texCoord || console.warn("THREE.GLTFLoader: Custom UV set " + i.texCoord + " for texture " + e + " not yet supported."), o.extensions[t.KHR_TEXTURE_TRANSFORM]) { var r = void 0 !== i.extensions ? i.extensions[t.KHR_TEXTURE_TRANSFORM] : void 0; r && (n = o.extensions[t.KHR_TEXTURE_TRANSFORM].extendTexture(n, r)) } A[e] = n })) }, q.prototype.assignFinalMaterial = function (A) { var e = A.geometry, t = A.material, i = void 0 !== e.attributes.tangent, o = void 0 !== e.attributes.color, n = void 0 === e.attributes.normal, r = !0 === A.isSkinnedMesh, a = Object.keys(e.morphAttributes).length > 0, s = a && void 0 !== e.morphAttributes.normal; if (A.isPoints) { var l = this.cache.get(h = "PointsMaterial:" + t.uuid); l || (l = new Yo, qA.prototype.copy.call(l, t), l.color.copy(t.color), l.map = t.map, l.sizeAttenuation = !1, this.cache.add(h, l)), t = l } else if (A.isLine) { var c = this.cache.get(h = "LineBasicMaterial:" + t.uuid); c || (c = new ko, qA.prototype.copy.call(c, t), c.color.copy(t.color), this.cache.add(h, c)), t = c } if (i || o || n || r || a) { var h = "ClonedMaterial:" + t.uuid + ":"; t.isGLTFSpecularGlossinessMaterial && (h += "specular-glossiness:"), r && (h += "skinning:"), i && (h += "vertex-tangents:"), o && (h += "vertex-colors:"), n && (h += "flat-shading:"), a && (h += "morph-targets:"), s && (h += "morph-normals:"); var d = this.cache.get(h); d || (d = t.clone(), r && (d.skinning = !0), i && (d.vertexTangents = !0), o && (d.vertexColors = !0), n && (d.flatShading = !0), a && (d.morphTargets = !0), s && (d.morphNormals = !0), this.cache.add(h, d)), t = d } t.aoMap && void 0 === e.attributes.uv2 && void 0 !== e.attributes.uv && e.setAttribute("uv2", new YA(e.attributes.uv.array, 2)), t.normalScale && !i && (t.normalScale.y = -t.normalScale.y), A.material = t }, q.prototype.loadMaterial = function (A) { var e, i = this.extensions, o = this.json.materials[A], n = {}, r = o.extensions || {}, a = []; if (r[t.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS]) { var l = i[t.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS]; e = l.getMaterialType(), a.push(l.extendParams(n, o, this)) } else if (r[t.KHR_MATERIALS_UNLIT]) { var c = i[t.KHR_MATERIALS_UNLIT]; e = c.getMaterialType(), a.push(c.extendParams(n, o, this)) } else { e = yr; var h = o.pbrMetallicRoughness || {}; if (n.color = new LA(1, 1, 1), n.opacity = 1, Array.isArray(h.baseColorFactor)) { var d = h.baseColorFactor; n.color.fromArray(d), n.opacity = d[3] } void 0 !== h.baseColorTexture && a.push(this.assignTexture(n, "map", h.baseColorTexture)), n.metalness = void 0 !== h.metallicFactor ? h.metallicFactor : 1, n.roughness = void 0 !== h.roughnessFactor ? h.roughnessFactor : 1, void 0 !== h.metallicRoughnessTexture && (a.push(this.assignTexture(n, "metalnessMap", h.metallicRoughnessTexture)), a.push(this.assignTexture(n, "roughnessMap", h.metallicRoughnessTexture))) }!0 === o.doubleSided && (n.side = 2); var p = o.alphaMode || T; return p === D ? (n.transparent = !0, n.depthWrite = !1) : (n.transparent = !1, p === k && (n.alphaTest = void 0 !== o.alphaCutoff ? o.alphaCutoff : .5)), void 0 !== o.normalTexture && e !== jA && (a.push(this.assignTexture(n, "normalMap", o.normalTexture)), n.normalScale = new s(1, 1), void 0 !== o.normalTexture.scale && n.normalScale.set(o.normalTexture.scale, o.normalTexture.scale)), void 0 !== o.occlusionTexture && e !== jA && (a.push(this.assignTexture(n, "aoMap", o.occlusionTexture)), void 0 !== o.occlusionTexture.strength && (n.aoMapIntensity = o.occlusionTexture.strength)), void 0 !== o.emissiveFactor && e !== jA && (n.emissive = (new LA).fromArray(o.emissiveFactor)), void 0 !== o.emissiveTexture && e !== jA && a.push(this.assignTexture(n, "emissiveMap", o.emissiveTexture)), Promise.all(a).then((function () { var A; return A = e === g ? i[t.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS].createMaterial(n) : new e(n), o.name && (A.name = o.name), A.map && (A.map.encoding = 3001), A.emissiveMap && (A.emissiveMap.encoding = 3001), V(A, o), o.extensions && O(i, A, o), A })) }, q.prototype.loadGeometries = function (A) { var e = this, i = this.extensions, o = this.primitiveCache; function n(A) { return i[t.KHR_DRACO_MESH_COMPRESSION].decodePrimitive(A, e).then((function (t) { return j(t, A, e) })) } for (var r, a, s = [], l = 0, c = A.length; c > l; l++) { var h, d = A[l], p = (a = void 0, (a = (r = d).extensions && r.extensions[t.KHR_DRACO_MESH_COMPRESSION]) ? "draco:" + a.bufferView + ":" + a.indices + ":" + P(a.attributes) : r.indices + ":" + P(r.attributes) + ":" + r.mode), g = o[p]; if (g) s.push(g.promise); else h = d.extensions && d.extensions[t.KHR_DRACO_MESH_COMPRESSION] ? n(d) : j(new he, d, e), o[p] = { primitive: d, promise: h }, s.push(h) } return Promise.all(s) }, q.prototype.loadMesh = function (A) { for (var e, t = this, i = this.json.meshes[A], o = i.primitives, n = [], r = 0, a = o.length; a > r; r++) { var s = void 0 === o[r].material ? (void 0 === (e = this.cache).DefaultMaterial && (e.DefaultMaterial = new yr({ color: 16777215, emissive: 0, metalness: 1, roughness: 1, transparent: !1, depthTest: !0, side: 0 })), e.DefaultMaterial) : this.getDependency("material", o[r].material); n.push(s) } return n.push(t.loadGeometries(o)), Promise.all(n).then((function (e) { for (var n = e.slice(0, e.length - 1), r = e[e.length - 1], a = [], s = 0, l = r.length; l > s; s++) { var c, h = r[s], d = o[s], p = n[s]; if (d.mode === B || d.mode === x || d.mode === S || void 0 === d.mode) !0 !== (c = !0 === i.isSkinnedMesh ? new So(h, p) : new Ue(h, p)).isSkinnedMesh || c.geometry.attributes.skinWeight.normalized || c.normalizeSkinWeights(), d.mode === x ? c.geometry = Y(c.geometry, 1) : d.mode === S && (c.geometry = Y(c.geometry, 2)); else if (d.mode === v) c = new jo(h, p); else if (d.mode === E) c = new Go(h, p); else if (d.mode === I) c = new Ho(h, p); else { if (d.mode !== C) throw new Error("THREE.GLTFLoader: Primitive mode unsupported: " + d.mode); c = new Xo(h, p) } Object.keys(c.geometry.morphAttributes).length > 0 && G(c, i), c.name = i.name || "mesh_" + A, r.length > 1 && (c.name += "_" + s), V(c, i), t.assignFinalMaterial(c), a.push(c) } if (1 === a.length) return a[0]; var g = new Xi; for (s = 0, l = a.length; l > s; s++) g.add(a[s]); return g })) }, q.prototype.loadCamera = function (A) { var e, t = this.json.cameras[A], i = t[t.type]; if (i) return "perspective" === t.type ? e = new je(a.radToDeg(i.yfov), i.aspectRatio || 1, i.znear || 1, i.zfar || 2e6) : "orthographic" === t.type && (e = new Ka(i.xmag / -2, i.xmag / 2, i.ymag / 2, i.ymag / -2, i.znear, i.zfar)), t.name && (e.name = t.name), V(e, t), Promise.resolve(e); console.warn("THREE.GLTFLoader: Missing camera parameters.") }, q.prototype.loadSkin = function (A) { var e = this.json.skins[A], t = { joints: e.joints }; return void 0 === e.inverseBindMatrices ? Promise.resolve(t) : this.getDependency("accessor", e.inverseBindMatrices).then((function (A) { return t.inverseBindMatrices = A, t })) }, q.prototype.loadAnimation = function (A) { for (var e = this.json.animations[A], t = [], i = [], o = [], n = [], r = [], a = 0, s = e.channels.length; s > a; a++) { var l = e.channels[a], c = e.samplers[l.sampler], h = l.target, d = void 0 !== e.parameters ? e.parameters[c.input] : c.input, p = void 0 !== e.parameters ? e.parameters[c.output] : c.output; t.push(this.getDependency("node", void 0 !== h.node ? h.node : h.id)), i.push(this.getDependency("accessor", d)), o.push(this.getDependency("accessor", p)), n.push(c), r.push(h) } return Promise.all([Promise.all(t), Promise.all(i), Promise.all(o), Promise.all(n), Promise.all(r)]).then((function (t) { for (var i = t[0], o = t[1], n = t[2], r = t[3], a = t[4], s = [], l = 0, c = i.length; c > l; l++) { var h = i[l], d = o[l], p = n[l], g = r[l], u = a[l]; if (void 0 !== h) { var f; switch (h.updateMatrix(), h.matrixAutoUpdate = !0, Q[u.path]) { case Q.weights: f = Dr; break; case Q.rotation: f = Nr; break; case Q.position: case Q.scale: default: f = Vr } var C = h.name ? h.name : h.uuid, y = void 0 !== g.interpolation ? R[g.interpolation] : 2301, v = []; Q[u.path] === Q.weights ? h.traverse((function (A) { !0 === A.isMesh && A.morphTargetInfluences && v.push(A.name ? A.name : A.uuid) })) : v.push(C); var I = p.array; if (p.normalized) { var E; if (I.constructor === Int8Array) E = 1 / 127; else if (I.constructor === Uint8Array) E = 1 / 255; else if (I.constructor == Int16Array) E = 1 / 32767; else { if (I.constructor !== Uint16Array) throw new Error("THREE.GLTFLoader: Unsupported output accessor component type."); E = 1 / 65535 } for (var B = new Float32Array(I.length), x = 0, S = I.length; S > x; x++) B[x] = I[x] * E; I = B } for (x = 0, S = v.length; S > x; x++) { var w = new f(v[x] + "." + Q[u.path], d.array, I, y); "CUBICSPLINE" === g.interpolation && (w.createInterpolant = function (A) { return new m(this.times, this.values, this.getValueSize() / 3, A) }, w.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline = !0), s.push(w) } } } return new Gr(e.name ? e.name : "animation_" + A, void 0, s) })) }, q.prototype.loadNode = function (A) { var e, i = this.json, o = this.extensions, n = this, r = i.meshReferences, a = i.meshUses, s = i.nodes[A]; return (e = [], void 0 !== s.mesh && e.push(n.getDependency("mesh", s.mesh).then((function (A) { var e; if (r[s.mesh] > 1) { var t = a[s.mesh]++; (e = A.clone()).name += "_instance_" + t } else e = A; return void 0 !== s.weights && e.traverse((function (A) { if (A.isMesh) for (var e = 0, t = s.weights.length; t > e; e++) A.morphTargetInfluences[e] = s.weights[e] })), e }))), void 0 !== s.camera && e.push(n.getDependency("camera", s.camera)), s.extensions && s.extensions[t.KHR_LIGHTS_PUNCTUAL] && void 0 !== s.extensions[t.KHR_LIGHTS_PUNCTUAL].light && e.push(n.getDependency("light", s.extensions[t.KHR_LIGHTS_PUNCTUAL].light)), Promise.all(e)).then((function (A) { var e; if ((e = !0 === s.isBone ? new Uo : A.length > 1 ? new Xi : 1 === A.length ? A[0] : new H) !== A[0]) for (var t = 0, i = A.length; i > t; t++) e.add(A[t]); if (s.name && (e.userData.name = s.name, e.name = Fs.sanitizeNodeName(s.name)), V(e, s), s.extensions && O(o, e, s), void 0 !== s.matrix) { var n = new M; n.fromArray(s.matrix), e.applyMatrix4(n) } else void 0 !== s.translation && e.position.fromArray(s.translation), void 0 !== s.rotation && e.quaternion.fromArray(s.rotation), void 0 !== s.scale && e.scale.fromArray(s.scale); return e })) }, q.prototype.loadScene = function () { function A(e, t, i, o) { var n = i.nodes[e]; return o.getDependency("node", e).then((function (A) { return void 0 === n.skin ? A : o.getDependency("skin", n.skin).then((function (A) { for (var t = [], i = 0, n = (e = A).joints.length; n > i; i++) t.push(o.getDependency("node", e.joints[i])); return Promise.all(t) })).then((function (t) { return A.traverse((function (A) { if (A.isMesh) { for (var i = [], o = [], n = 0, r = t.length; r > n; n++) { var a = t[n]; if (a) { i.push(a); var s = new M; void 0 !== e.inverseBindMatrices && s.fromArray(e.inverseBindMatrices.array, 16 * n), o.push(s) } else console.warn('THREE.GLTFLoader: Joint "%s" could not be found.', e.joints[n]) } A.bind(new bo(i, o), A.matrixWorld) } })), A })); var e })).then((function (e) { t.add(e); var r = []; if (n.children) for (var a = n.children, s = 0, l = a.length; l > s; s++) { r.push(A(a[s], e, i, o)) } return Promise.all(r) })) } return function (e) { var t = this.json, i = this.extensions, o = this.json.scenes[e], n = new Xi; o.name && (n.name = o.name), V(n, o), o.extensions && O(i, n, o); for (var r = o.nodes || [], a = [], s = 0, l = r.length; l > s; s++) a.push(A(r[s], n, t, this)); return Promise.all(a).then((function () { return n })) } }(), A }(), VC = "REPLACE", GC = function A(e, t, i, o) { H.call(this); if (this.isRoot = o || !1, o || (this.matrix = kC.getTransfrom(i.transform)), this.refine = i.refine || VC, this.geometricError = i.geometricError || 0, this.boundingBox = kC.getBoxFromTileBoundingVolumeBox(i.boundingVolume.box), this.scene = null, this.model = e, this.json = i, this.level = t && t.level + 1 || 0, this.matrixAutoUpdate = !1, this.hasB3DM = !1, i.content && (i.content.url.endsWith("json") ? this.loadContent(i.content.url) : i.content.url.endsWith("b3dm") && (this.hasB3DM = !0, this.model.tilesList[i.content.url] = this, t && t.hasB3DM || (this.firstB3DM = !0, this.loadB3DM(i.content.url)))), i.children) for (var n = 0, r = i.children.length; r > n; n += 1) this.add(new A(e, this, i.children[n])) }; (GC.prototype = Object.create(H.prototype)).loadContent = function (A) { var e = this, t = e.model, i = t.dataUrl.tilesUrl(A); function o() { var A = t.fileLoader; A.setResponseType("json"), A.setCacheViable(!0), A.setRequestHeader({ Authorization: t.accessToken }), A.load(i, (function (A) { var i = {}; if ("string" == typeof A) try { i = JSON.parse(A) } catch (A) { return void t.dispatchEventEx({ type: Rc.ON_LOAD_INVALID_DATA, modelKey: t.modelKey }) } else i = A; e.add(new GC(t, parent, i.root, parent.level + 1, !0)) }), (function (A, e) { switch (A) { case 401: t.dispatchEventEx({ type: Rc.ACCOUNT_NO_EXIST, modelKey: t.modelKey, data: e }); break; case 403: t.dispatchEventEx({ type: Rc.NO_PERMISSION, modelKey: t.modelKey, data: e }); break; default: t.dispatchEventEx({ type: Rc.ON_NETWORK_ERROR, modelKey: t.modelKey, data: A }) } })) } if (vc.getDataFromIndexedDB) { var n = t.getStorage(); n && n.get(i, (function (A) { if (A) { var i = {}; if ("string" == typeof A) try { i = JSON.parse(A) } catch (A) { return void t.dispatchEventEx({ type: Rc.ON_LOAD_INVALID_DATA, modelKey: t.modelKey }) } else i = A; e.add(new GC(t, parent, i.root, !0)) } else o() }), (function () { o() })) } else o() }, GC.prototype.loadB3DM = function (A) { var e = this, t = e.model; e.loaderManager = new wu, e.loaderManager.model = t; var i = new OC(e.loaderManager); function o(A) { e.scene = A, e.loading = !1, e.loaded = !0, e.add(A.scene), t.tileLoadFinish() } e.loading = !0; var n = t.dataUrl.b3dmUrl(A || e.json.content.url); if (vc.getDataFromIndexedDB) { var r = t.getStorage(); r && r.get(n, (function (t) { t ? i.parse(t, A || e.json.content.url, o) : i.load(n, o) }), (function () { i.load(n, o) })) } else i.load(n, o) }; var PC = function (A, e, t, i) { TC.call(this, A, e, t, i), this.configLoader = new DC(this), this.tilesList = {}, this.isTilesModel = !0 }; (PC.prototype = Object.create(TC.prototype)).load = function (A) { var e = this; this.configLoader.load((function () { e.parseCfgFinish && e.parseCfgFinish(), e.manager.updateScene(), e.group.add(new GC(e, null, e.configLoader.config.root, !0)), e.loaded = !0 })) }, PC.prototype.tileLoadStart = function () {}, PC.prototype.tileLoadFinish = function () { this.group.updateMatrixWorld(!0, !0), this.manager.viewerImpl.render() }, PC.prototype.tileUnloadStart = function () {}, PC.prototype.tileUnloadFinish = function () {}, PC.prototype.checkTilesDataChanged = function (A) { for (var e in Bh.time("checkTilesDataChanged"), this.tilesList) if (this.tilesList.hasOwnProperty(e)) { var t = this.tilesList[e]; this.tilesNeedLoad(t.boundingBox.getCenter((new y).applyMatrix4(t.parent.matrixWorld).applyMatrix4(t.matrix)), t.boundingBox.getSize(new y).length()) || t.firstB3DM ? t.scene || t.loading ? t.visible = !0 : t.loadB3DM() : A ? (t.remove(t.scene), t.scene = null) : t.visible = !1 } Bh.timeEnd("checkTilesDataChanged") }, PC.prototype.tilesNeedLoad = function (A, e) { var t, i = this.manager.cameraFov; return t = (e || 0) * this.manager.domElementWidth / (2 * this.manager.cameraPosition.clone().sub(A).length() * Math.tan(i / 2)), Bh.debug("几何误差:", t), t > vc.geometricErrorThresholdValue }; var qC = function () { this.size = 0, this.counter = 0, this.expansion = 1, this._pool = null }; qC.prototype.init = function (A, e) { this.classType = A, this._pool = [], this._expand(e) }, qC.prototype._expand = function (A) { this.size += A; for (var e = 0; A > e; e += 1) this._pool.push(new this.classType) }, qC.prototype.acquire = function () { return this.size > this.counter || (this.expansion = Math.round(1.2 * this.expansion) + 1, this._expand(this.expansion)), this._pool[this.counter++] }, qC.prototype.clear = function () { this.counter = 0 }, qC.prototype.destroy = function () { for (var A = 0, e = this.size; e > A; A += 1) this._pool[A].destroy(); this.counter = 0, this.size = 0, this.expansion = 1, this._pool = null }, qC.prototype.getObjects = function () { return this._pool }; var jC = function (A) { Pe.call(this), this.type = "PhoneLightingMaterial", this.color = new LA(16777215), this.specular = new LA(1118481), this.shininess = 30, this.emissive = new LA(0), this.map = null, this.shadowMapEnabled = !1, this.defines = {}, this.uniforms = Ge.merge([Xe.common, Xe.lights, { diffuse: { value: new LA(16711680) }, opacity: { value: 1 }, specular: { value: new LA(1118481) }, shininess: { value: 30 }, emissive: { value: new LA(0) } }]), this.vertexShader = ["varying vec3 vViewPosition;", "varying vec3 vNormal;", "#include ", "void main() {", " #include ", " #include ", " #include ", " #include ", " #include ", " vNormal = normalize( transformedNormal );", " vViewPosition = - mvPosition.xyz;", "}"].join("\n"), this.fragmentShader = ["uniform vec3 diffuse;", "uniform float opacity;", "uniform vec3 specular;", "uniform float shininess;", "uniform vec3 emissive;", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "#include ", "void main() {", " vec4 diffuseColor = vec4( diffuse, opacity );", "#ifdef USE_MAP", " vec4 texelColor = texture2D( map, vUv );", " texelColor = mapTexelToLinear( texelColor );", " diffuseColor = vec4(texelColor.rgb, opacity);", "#endif", " ReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );", " vec3 totalEmissiveRadiance = emissive;", " float specularStrength = 1.0;", " #include ", " #include ", " gl_FragColor = linearToOutputTexel( diffuseColor );", "}"].join("\n"), this.lights = !1, this.defaultAttributeValues = { color: [1, 1, 1], uv: [0, 0], uv2: [0, 0] }, void 0 !== A && (void 0 !== A.attributes && console.error("PhoneLightingMaterial: attributes should now be defined in THREE.BufferGeometry instead."), this.setValues(A)), this.refreshUniforms() }; (jC.prototype = Object.create(Pe.prototype)).constructor = jC, jC.prototype.isShaderMaterial = !0, jC.prototype.copy = function (A) { return Pe.prototype.copy.call(this, A), this.color.copy(A.color), this.specular.copy(A.specular), this.shininess = A.shininess, this.emissive.copy(A.emissive), this }, jC.prototype.refreshUniforms = function () { this.uniforms.diffuse.value.set(this.color), this.uniforms.opacity.value = this.opacity, this.uniforms.specular.value.set(this.specular), this.uniforms.shininess.value = this.shininess, this.uniforms.emissive.value.set(this.emissive), this.uniforms.map.value = this.map }; var HC = function (A, e) { ep.call(this, gp.CLIPPLANE, { priority: 20 }); var t = []; t.push("clipPlane_right"), t.push("clipPlane_left"), t.push("clipPlane_back"), t.push("clipPlane_front"), t.push("clipPlane_top"), t.push("clipPlane_bottom"), this.cubeSize = A.clone(), this.center = e.clone(), this.visible = !1, this.rotatable = !1, this.selectIndex = null, this.planeOffset = new Array(6), this.planeRotate = [0, 0, 0], this.observer = null, this.uniforms = { iClipPlane: { type: "i", value: 0 }, vClipPlane: { type: "v4v", value: [new p, new p, new p, new p, new p, new p] } }, this.clipplanes = null, this.calculation = !0, this.boundingBox = new aA, this.calculateClipBoundingBox = function (A) { this.boundingBox.makeEmpty(); for (var e = new y, t = 0; A.length > t; t += 1) { var i = A[t].coplanarPoint(e); 0 !== i.x && (i.x > this.boundingBox.max.x ? this.boundingBox.max.x = i.x : this.boundingBox.min.x > i.x && (this.boundingBox.min.x = i.x)), 0 !== i.y && (i.y > this.boundingBox.max.y ? this.boundingBox.max.y = i.y : this.boundingBox.min.y > i.y && (this.boundingBox.min.y = i.y)), 0 !== i.z && (i.z > this.boundingBox.max.z ? this.boundingBox.max.z = i.z : this.boundingBox.min.z > i.z && (this.boundingBox.min.z = i.z)) } }, this.getClipBoundingBox = function () { return this.boundingBox }, this.isVisible = function () { return this.visible }, this.getPlaneNormal = function (A) { var e = new p, t = Math.floor(A / 2); return e.setComponent(t, Math.pow(-1, A % 2)), e.w = .5 * -this.cubeSize.getComponent(t), this.planeOffset[A] = 0, e }, this.planeMaterial = new jC({ color: 8158334, opacity: .3, transparent: !0, side: 0, lights: !1 }), this.planeHighLightMatrial = new jC({ color: 255, opacity: .3, transparent: !0, side: 0, lights: !1 }), this.initPlaneModel = function (A) { var e = Math.floor(A / 2), i = A % 2, o = new Ue(new et(0 === e ? this.cubeSize.z : this.cubeSize.x, 1 === e ? this.cubeSize.z : this.cubeSize.y), this.planeMaterial); switch (o.name = t[A], o.customTag = !0, o.position.setComponent(e, Math.pow(-1, i) * this.cubeSize.getComponent(e) * .5), A) { case 0: o.rotation.y = .5 * Math.PI; break; case 1: o.rotation.y = .5 * -Math.PI; break; case 2: o.rotation.x = .5 * -Math.PI; break; case 3: o.rotation.x = .5 * Math.PI; break; case 4: break; case 5: o.rotation.x = Math.PI } o.renderOrder = 90, this.add(o) }, this.initCapsBox = function () { if (this.boxMesh) return this.boxMesh; var A = new Ne(this.cubeSize.x, this.cubeSize.y, this.cubeSize.z); A.groups = null; var e = new Ue(A, new jC({ color: 16776960, side: 2, stencilWrite: !0, stencilFunc: 515, stencilRef: 1, stencilFuncMask: 255, stencilFail: 7680, stencilZFail: 7680, stencilZPass: 7680 })); return e.matrixWorld = this.matrixWorld, e.matrix = this.matrix, e.name = "capsBox", this.boxMesh = e, e }, this.initWireframes = function () { var A = [.5 * -this.cubeSize.x, .5 * -this.cubeSize.y, .5 * -this.cubeSize.z, .5 * this.cubeSize.x, .5 * -this.cubeSize.y, .5 * -this.cubeSize.z, .5 * this.cubeSize.x, .5 * this.cubeSize.y, .5 * -this.cubeSize.z, .5 * -this.cubeSize.x, .5 * this.cubeSize.y, .5 * -this.cubeSize.z, .5 * -this.cubeSize.x, .5 * -this.cubeSize.y, .5 * this.cubeSize.z, .5 * this.cubeSize.x, .5 * -this.cubeSize.y, .5 * this.cubeSize.z, .5 * this.cubeSize.x, .5 * this.cubeSize.y, .5 * this.cubeSize.z, .5 * -this.cubeSize.x, .5 * this.cubeSize.y, .5 * this.cubeSize.z], e = new he, t = new jC({ color: 0, lights: !0 }); e.setIndex([0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 3, 7, 1, 5, 2, 6]), e.setAttribute("position", new Ae(A, 3)), e.setAttribute("color", new Ae([1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1], 3)), e.computeBoundingSphere(); var i = new jo(e, t); i.name = "Wireframes", i.customTag = !0, this.add(i) }, this.updateClippingParams = function (A) {}, this.enable = function (A, e) { this.visible = e, this.uniforms.iClipPlane.value = A ? 6 : 0, this.updateClippingParams(this.uniforms), this.boxMesh && (this.boxMesh.visible = e) }, this.isEnabled = function () { return 0 !== this.uniforms.iClipPlane.value }; var i = function (A, e, t, i, o, n, r, a, s, l, c, h) { this.enable = A, this.visible = e, this.rotatable = t, this.calculation = i, this.planeOffset = o.slice(0), this.planeRotate = n.slice(0), this.position = r, this.scale = a, this.quaternion = s, this.cubeSize = l, this.center = c, this.boundingBox = h }; this.store = function () { return new i(!!this.uniforms.iClipPlane.value, this.visible, this.rotatable, this.calculation, this.planeOffset, this.planeRotate, this.position.clone(), this.scale.clone(), this.quaternion.clone(), this.cubeSize.clone(), this.center.clone(), this.boundingBox.clone()) }, this.restore = function (A) { this.calculation = !0, this.calculationPlanes(A.cubeSize, A.center), this.enable(A.enable, A.visible), this.rotatable = A.rotatable, this.calculation = A.calculation; for (var e = 0; 6 > e; e += 1) this.planeOffset[e] = A.planeOffset[e]; for (var t = 0; 3 > t; t += 1) this.planeRotate[t] = A.planeRotate[t]; this.position.copy(A.position), this.scale.copy(A.scale), this.quaternion._w = A.quaternion._w, this.quaternion._x = A.quaternion._x, this.quaternion._y = A.quaternion._y, this.quaternion._z = A.quaternion._z, this.update() }, this.reset = function () { this.calculation = !0; for (var A = 0; 6 > A; A += 1) this.planeOffset[A] = 0; for (A = 0; 3 > A; A += 1) this.planeRotate[A] = 0; this.position.copy(this.center), this.scale.copy(new y(1, 1, 1)), this.quaternion.copy(new f), this.update() }, this.calculationPlanes = function (A, e, t) { if (this.calculation || t) { this.cubeSize.copy(A), this.center.copy(e); for (var i = this.children.length - 1; i >= 0; i -= 1) this.remove(this.children[i]); for (i = 0; 6 > i; i += 1) this.uniforms.vClipPlane.value[i] = this.getPlaneNormal(i), this.initPlaneModel(i); this.initWireframes(), this.clipplanes = this.uniforms.vClipPlane.value.slice(0), this.reset() } }, this.update = function () { this.updateMatrixWorld(); var A = new M; A.getInverse(this.matrix), A.transpose(); for (var e = 0; 6 > e; e += 1) this.uniforms.vClipPlane.value[e] = this.clipplanes[e].clone().applyMatrix4(A); this.updateClippingParams(this.uniforms), this.observer && this.observer() }, this.offset = function (A, e) { this.calculation = !1; var t = Math.floor(A / 2); this.cubeSize.getComponent(t); A % 2 == 0 && this.planeOffset[A] + e > 0 && (e = -this.planeOffset[A]), A % 2 == 1 && 0 > this.planeOffset[A] + e && (e = -this.planeOffset[A]), this.planeOffset[A] += e; for (var i = new y, o = 0; 6 > o; o += 1) { var n = this.clipplanes[o].clone(), r = this.planeOffset[o], a = new y(n.x * r, n.y * r, n.z * r); i.add(a) } var s = 1 + i.getComponent(t) / this.cubeSize.getComponent(t); if ((s = 0 === s ? 1e-5 : s) > 0) { this.scale.setComponent(t, s); var l = this.uniforms.vClipPlane.value[A].clone(), c = new y(l.x, l.y, l.z); c.normalize(); var h = new y(c.x * (a = e), c.y * a, c.z * a); A % 2 == 1 ? this.position.sub(h.multiplyScalar(.5)) : this.position.add(h.multiplyScalar(.5)), this.update() } else this.planeOffset[A] -= e }; var o = new f, n = new y(1, 0, 0); this.rotX = function (A) { this.calculation = !1, o.setFromAxisAngle(n, A), this.quaternion.multiply(o), this.update() }; var r = new y(0, 1, 0); this.rotY = function (A) { this.calculation = !1, o.setFromAxisAngle(r, A), this.quaternion.multiply(o), this.update() }, this.setSectionBox = function (A, e) { this.calculation = !0; var t = new y(e.x - A.x, e.y - A.y, e.z - A.z), i = new y(.5 * (A.x + e.x), .5 * (A.y + e.y), .5 * (A.z + e.z)); this.calculationPlanes(t, i) }, this.calculateOffsetByBox = function (A, e) { var t = e.x - this.center.x - .5 * this.cubeSize.x; this.planeOffset[0] > t ? (this.moveSectionPlane("left", this.center.x - .5 * this.cubeSize.x - A.x), this.moveSectionPlane("right", t)) : (this.moveSectionPlane("right", t), this.moveSectionPlane("left", this.center.x - .5 * this.cubeSize.x - A.x)); var i = e.y - this.center.y - .5 * this.cubeSize.y; this.planeOffset[2] > i ? (this.moveSectionPlane("bottom", this.center.y - .5 * this.cubeSize.y - A.y), this.moveSectionPlane("top", i)) : (this.moveSectionPlane("top", i), this.moveSectionPlane("bottom", this.center.y - .5 * this.cubeSize.y - A.y)); var o = e.z - this.center.z - .5 * this.cubeSize.z; this.planeOffset[4] > o ? (this.moveSectionPlane("back", this.center.z - .5 * this.cubeSize.z - A.z), this.moveSectionPlane("front", o)) : (this.moveSectionPlane("front", o), this.moveSectionPlane("back", this.center.z - .5 * this.cubeSize.z - A.z)) }, this.getPlaneIndexByName = function (A) { var e = -1; return "right" === A ? e = 0 : "left" === A ? e = 1 : "top" === A ? e = 2 : "bottom" === A ? e = 3 : "front" === A ? e = 4 : "back" === A && (e = 5), e }, this.moveSectionPlane = function (A, e) { var t = this.getPlaneIndexByName(A); - 1 !== t && (t % 2 != 0 && (e = -e), this.offset(t, e - this.planeOffset[t])) }, this.recalculate = function () { return this.filter.getVisibleComponentsBbox() }, this.setProcess = function (A, e) { var t = this.getPlaneIndexByName(A), i = 0; (2 > t ? i = this.cubeSize.x : 4 > t ? i = this.cubeSize.y : 6 > t && (i = this.cubeSize.z), e > 1 ? e = 1 : 0 > e && (e = 0), -1 !== t) && (t % 2 != 1 && (e = -e), this.offset(t, e * i - this.planeOffset[t])) }, this.getProcess = function (A) { var e = this.getPlaneIndexByName(A); - 1 === e && console.log("faceName is illegal"); var t = 0; 2 > e ? t = this.cubeSize.x : 4 > e ? t = this.cubeSize.y : 6 > e && (t = this.cubeSize.z); var i = 1; e % 2 != 1 && (i = -1); var o = i * this.planeOffset[e] / t; return o > 1 ? o = 1 : 0 > o && (o = 0), o }; var a = new y(0, 0, 1); this.rotateSectionBox = function (A, e) { "x" === A ? this.planeRotate[0] = e : "y" === A ? this.planeRotate[1] = e : "z" === A && (this.planeRotate[2] = e), this.calculation = !0; var t = new f; t.setFromAxisAngle(n, this.planeRotate[0]); var i = new f; i.setFromAxisAngle(r, this.planeRotate[1]); var o = new f; o.setFromAxisAngle(a, this.planeRotate[2]); var s = new f; s.multiply(t), s.multiply(i), s.multiply(o), this.quaternion.copy(s), this.update() }, this.highLight = function () { null !== this.selectIndex && (this.children[this.selectIndex].material = this.planeHighLightMatrial) }, this.cancelHighLight = function () { null !== this.selectIndex && (this.children[this.selectIndex].material = this.planeMaterial, this.selectIndex = null) } }; (HC.prototype = Object.create(ep.prototype)).constructor = HC, HC.prototype.init = function () { this.calculationPlanes(this.cubeSize, this.center) }, HC.prototype.hitTest = function (A) { var e = null, t = null; if (this.raycast(A), null !== this.selectIndex) { var i = A.ray, o = new EA, n = this.uniforms.vClipPlane.value[this.selectIndex]; o.setComponents(n.x, n.y, n.z, n.w), e = i.distanceToPlane(o), t = 0 > i.direction.dot(o.normal) } return { sign: t, distance: e } }, HC.prototype.raycast = function (A) { if (this.visible) { var e = [], t = null; this.selectIndex = null; for (var i = 0; 6 > i; i += 1) if (this.children[i].raycast(A, e), e.length > 0) { var o = e.pop(); t && o.distance >= t.distance || (t = o, this.selectIndex = i), e = [] } } }, Xe.line = { linewidth: { value: 1 }, resolution: { value: new s(1, 1) }, dashScale: { value: 1 }, dashSize: { value: 1 }, dashOffset: { value: 0 }, gapSize: { value: 1 }, opacity: { value: 1 } }, it.line = { uniforms: Ge.merge([Xe.common, Xe.fog, Xe.line]), vertexShader: "\n #include \n #include \n #include \n #include \n #include \n\n uniform float linewidth;\n uniform vec2 resolution;\n\n attribute vec3 instanceStart;\n attribute vec3 instanceEnd;\n\n attribute vec3 instanceColorStart;\n attribute vec3 instanceColorEnd;\n\n varying vec2 vUv;\n\n #ifdef USE_DASH\n\n uniform float dashScale;\n attribute float instanceDistanceStart;\n attribute float instanceDistanceEnd;\n varying float vLineDistance;\n\n #endif\n\n void trimSegment( const in vec4 start, inout vec4 end ) {\n\n // trim end segment so it terminates between the camera plane and the near plane\n\n // conservative estimate of the near plane\n float a = projectionMatrix[ 2 ][ 2 ]; // 3nd entry in 3th column\n float b = projectionMatrix[ 3 ][ 2 ]; // 3nd entry in 4th column\n float nearEstimate = - 0.5 * b / a;\n\n float alpha = ( nearEstimate - start.z ) / ( end.z - start.z );\n\n end.xyz = mix( start.xyz, end.xyz, alpha );\n\n }\n\n void main() {\n\n #ifdef USE_COLOR\n\n vColor.xyz = ( position.y < 0.5 ) ? instanceColorStart : instanceColorEnd;\n\n #endif\n\n #ifdef USE_DASH\n\n vLineDistance = ( position.y < 0.5 ) ? dashScale * instanceDistanceStart : dashScale * instanceDistanceEnd;\n\n #endif\n\n float aspect = resolution.x / resolution.y;\n\n vUv = uv;\n\n // camera space\n vec4 start = modelViewMatrix * vec4( instanceStart, 1.0 );\n vec4 end = modelViewMatrix * vec4( instanceEnd, 1.0 );\n\n // special case for perspective projection, and segments that terminate either in, or behind, the camera plane\n // clearly the gpu firmware has a way of addressing this issue when projecting into ndc space\n // but we need to perform ndc-space calculations in the shader, so we must address this issue directly\n // perhaps there is a more elegant solution -- WestLangley\n\n bool perspective = ( projectionMatrix[ 2 ][ 3 ] == - 1.0 ); // 4th entry in the 3rd column\n\n if ( perspective ) {\n\n if ( start.z < 0.0 && end.z >= 0.0 ) {\n\n trimSegment( start, end );\n\n } else if ( end.z < 0.0 && start.z >= 0.0 ) {\n\n trimSegment( end, start );\n\n }\n\n }\n\n // clip space\n vec4 clipStart = projectionMatrix * start;\n vec4 clipEnd = projectionMatrix * end;\n\n // ndc space\n vec2 ndcStart = clipStart.xy / clipStart.w;\n vec2 ndcEnd = clipEnd.xy / clipEnd.w;\n\n // direction\n vec2 dir = ndcEnd - ndcStart;\n\n // account for clip-space aspect ratio\n dir.x *= aspect;\n dir = normalize( dir );\n\n // perpendicular to dir\n vec2 offset = vec2( dir.y, - dir.x );\n\n // undo aspect ratio adjustment\n dir.x /= aspect;\n offset.x /= aspect;\n\n // sign flip\n if ( position.x < 0.0 ) offset *= - 1.0;\n\n // endcaps\n if ( position.y < 0.0 ) {\n\n offset += - dir;\n\n } else if ( position.y > 1.0 ) {\n\n offset += dir;\n\n }\n\n // adjust for linewidth\n offset *= linewidth;\n\n // adjust for clip-space to screen-space conversion // maybe resolution should be based on viewport ...\n offset /= resolution.y;\n\n // select end\n vec4 clip = ( position.y < 0.5 ) ? clipStart : clipEnd;\n\n // back to clip space\n offset *= clip.w;\n\n clip.xy += offset;\n\n gl_Position = clip;\n\n vec4 mvPosition = ( position.y < 0.5 ) ? start : end; // this is an approximation\n\n #include \n #include \n #include \n\n }\n ", fragmentShader: "\n uniform vec3 diffuse;\n uniform float opacity;\n\n #ifdef USE_DASH\n\n uniform float dashSize;\n uniform float dashOffset;\n uniform float gapSize;\n\n #endif\n\n varying float vLineDistance;\n\n #include \n #include \n #include \n #include \n #include \n\n varying vec2 vUv;\n\n void main() {\n\n #include \n\n #ifdef USE_DASH\n\n if ( vUv.y < - 1.0 || vUv.y > 1.0 ) discard; // discard endcaps\n\n if ( mod( vLineDistance + dashOffset, dashSize + gapSize ) > dashSize ) discard; // todo - FIX\n\n #endif\n\n if ( abs( vUv.y ) > 1.0 ) {\n\n float a = vUv.x;\n float b = ( vUv.y > 0.0 ) ? vUv.y - 1.0 : vUv.y + 1.0;\n float len2 = a * a + b * b;\n\n if ( len2 > 1.0 ) discard;\n\n }\n\n vec4 diffuseColor = vec4( diffuse, opacity );\n\n #include \n #include \n\n gl_FragColor = vec4( diffuseColor.rgb, diffuseColor.a );\n\n #include \n #include \n #include \n #include \n\n }\n " }; var YC = function (A) { Pe.call(this, { type: "LineMaterial", uniforms: Ge.clone(it.line.uniforms), vertexShader: it.line.vertexShader, fragmentShader: it.line.fragmentShader, clipping: !0 }), this.dashed = !1, Object.defineProperties(this, { color: { enumerable: !0, get: function () { return this.uniforms.diffuse.value }, set: function (A) { this.uniforms.diffuse.value = A } }, linewidth: { enumerable: !0, get: function () { return this.uniforms.linewidth.value }, set: function (A) { this.uniforms.linewidth.value = A } }, dashScale: { enumerable: !0, get: function () { return this.uniforms.dashScale.value }, set: function (A) { this.uniforms.dashScale.value = A } }, dashSize: { enumerable: !0, get: function () { return this.uniforms.dashSize.value }, set: function (A) { this.uniforms.dashSize.value = A } }, dashOffset: { enumerable: !0, get: function () { return this.uniforms.dashOffset.value }, set: function (A) { this.uniforms.dashOffset.value = A } }, gapSize: { enumerable: !0, get: function () { return this.uniforms.gapSize.value }, set: function (A) { this.uniforms.gapSize.value = A } }, resolution: { enumerable: !0, get: function () { return this.uniforms.resolution.value }, set: function (A) { this.uniforms.resolution.value.copy(A) } }, opacity: { enumerable: !0, get: function () { return this.uniforms.opacity.value }, set: function (A) { this.uniforms.opacity.value = A } } }), this.setValues(A) }; (YC.prototype = Object.create(Pe.prototype)).constructor = YC, YC.prototype.isLineMaterial = !0; var WC, JC = function () { Na.call(this), this.type = "LineSegmentsGeometry"; this.setIndex([0, 2, 1, 2, 3, 1, 2, 4, 3, 4, 5, 3, 4, 6, 5, 6, 7, 5]), this.setAttribute("position", new Ae([-1, 2, 0, 1, 2, 0, -1, 1, 0, 1, 1, 0, -1, 0, 0, 1, 0, 0, -1, -1, 0, 1, -1, 0], 3)), this.setAttribute("uv", new Ae([-1, 2, 1, 2, -1, 1, 1, 1, -1, -1, 1, -1, -1, -2, 1, -2], 2)) }; JC.prototype = Object.assign(Object.create(Na.prototype), { constructor: JC, isLineSegmentsGeometry: !0, applyMatrix4: function (A) { var e = this.attributes.instanceStart, t = this.attributes.instanceEnd; return void 0 !== e && (e.applyMatrix4(A), t.applyMatrix4(A), e.needsUpdate = !0), null !== this.boundingBox && this.computeBoundingBox(), null !== this.boundingSphere && this.computeBoundingSphere(), this }, setPositions: function (A) { var e = null; A instanceof Float32Array ? e = A : Array.isArray(A) && (e = new Float32Array(A)); var t = new ks(e, 6, 1); return this.setAttribute("instanceStart", new no(t, 3, 0)), this.setAttribute("instanceEnd", new no(t, 3, 3)), this.computeBoundingBox(), this.computeBoundingSphere(), this }, setColors: function (A) { var e = null; A instanceof Float32Array ? e = A : Array.isArray(A) && (e = new Float32Array(A)); var t = new ks(e, 6, 1); return this.setAttribute("instanceColorStart", new no(t, 3, 0)), this.setAttribute("instanceColorEnd", new no(t, 3, 3)), this }, fromWireframeGeometry: function (A) { return this.setPositions(A.attributes.position.array), this }, fromEdgesGeometry: function (A) { return this.setPositions(A.attributes.position.array), this }, fromMesh: function (A) { return this.fromWireframeGeometry(new on(A.geometry)), this }, fromLineSegements: function (A) { var e = A.geometry; return e.isGeometry ? this.setPositions(e.vertices) : e.isBufferGeometry && this.setPositions(e.attributes.position.array), this }, computeBoundingBox: function () { var A = new aA; return function () { null === this.boundingBox && (this.boundingBox = new aA); var e = this.attributes.instanceStart, t = this.attributes.instanceEnd; void 0 !== e && void 0 !== t && (this.boundingBox.setFromBufferAttribute(e), A.setFromBufferAttribute(t), this.boundingBox.union(A)) } }(), computeBoundingSphere: (WC = new y, function () { null === this.boundingSphere && (this.boundingSphere = new cA), null === this.boundingBox && this.computeBoundingBox(); var A = this.attributes.instanceStart, e = this.attributes.instanceEnd; if (void 0 !== A && void 0 !== e) { var t = this.boundingSphere.center; this.boundingBox.getCenter(t); for (var i = 0, o = 0, n = A.count; n > o; o += 1) WC.fromBufferAttribute(A, o), i = Math.max(i, t.distanceToSquared(WC)), WC.fromBufferAttribute(e, o), i = Math.max(i, t.distanceToSquared(WC)); this.boundingSphere.radius = Math.sqrt(i), isNaN(this.boundingSphere.radius) && console.error("THREE.LineSegmentsGeometry.computeBoundingSphere(): Computed radius is NaN. The instanced position data is likely to have NaN values.", this) } } ), toJSON: function () {}, applyMatrix: function (A) { return console.warn("THREE.LineSegmentsGeometry: applyMatrix() has been renamed to applyMatrix4()."), this.applyMatrix4(A) } }); var zC, ZC, XC = function (A, e) { void 0 === A && (A = new JC), void 0 === e && (e = new YC({ color: 16777215 * Math.random() })), Ue.call(this, A, e), this.type = "LineSegments2" }; XC.prototype = Object.assign(Object.create(Ue.prototype), { constructor: XC, isLineSegments2: !0, computeLineDistances: (zC = new y, ZC = new y, function () { for (var A = this.geometry, e = A.attributes.instanceStart, t = A.attributes.instanceEnd, i = new Float32Array(2 * e.data.count), o = 0, n = 0, r = e.data.count; r > o; o += 1, n += 2) zC.fromBufferAttribute(e, o), ZC.fromBufferAttribute(t, o), i[n] = 0 === n ? 0 : i[n - 1], i[n + 1] = i[n] + zC.distanceTo(ZC); var a = new ks(i, 2, 1); return A.setAttribute("instanceDistanceStart", new no(a, 1, 0)), A.setAttribute("instanceDistanceEnd", new no(a, 1, 1)), this } ), raycast: function () { var A = new p, e = new p, t = new p, i = new y, o = new M, n = new Hs, r = new y; return function (s, l) { null === s.camera && console.error('LineSegments2: "Raycaster.camera" needs to be set in order to raycast against LineSegments2.'); var c = s.ray, h = s.camera, d = h.projectionMatrix, p = this.geometry, g = this.material, u = g.resolution, f = g.linewidth + (void 0 !== s.params.Line2 && s.params.Line2.threshold || 0), m = p.attributes.instanceStart, C = p.attributes.instanceEnd; c.at(1, t), t.w = 1, t.applyMatrix4(h.matrixWorldInverse), t.applyMatrix4(d), t.multiplyScalar(1 / t.w), t.x *= u.x / 2, t.y *= u.y / 2, t.z = 0, i.copy(t); var v = this.matrixWorld; o.multiplyMatrices(h.matrixWorldInverse, v); for (var I = 0, E = m.count; E > I; I += 1) { if (A.fromBufferAttribute(m, I), e.fromBufferAttribute(C, I), A.w = 1, e.w = 1, A.applyMatrix4(o), e.applyMatrix4(o), A.applyMatrix4(d), e.applyMatrix4(d), A.multiplyScalar(1 / A.w), e.multiplyScalar(1 / e.w), !(-1 > A.z && -1 > e.z) && !(A.z > 1 && e.z > 1)) { A.x *= u.x / 2, A.y *= u.y / 2, e.x *= u.x / 2, e.y *= u.y / 2, n.start.copy(A), n.start.z = 0, n.end.copy(e), n.end.z = 0; var B = n.closestPointToPointParameter(i, !0); n.at(B, r); var x = a.lerp(A.z, e.z, B), S = x >= -1 && 1 >= x, w = i.distanceTo(r) < .5 * f; if (S && w) { n.start.fromBufferAttribute(m, I), n.end.fromBufferAttribute(C, I), n.start.applyMatrix4(v), n.end.applyMatrix4(v); var M = new y, b = new y; c.distanceSqToSegment(n.start, n.end, b, M), l.push({ point: b, pointOnLine: M, distance: c.origin.distanceTo(b), object: this, face: null, faceIndex: I, uv: null, uv2: null }) } } } } }() }); var _C = function (A, e) { ep.call(this, gp.FILLCLIPPLANE, { priority: 20 }), this.cubeSize = A.clone(), this.originBoundingBox = (new aA).setFromCenterAndSize(e, A), this.boundingBox = this.originBoundingBox.clone(), this.center = e.clone(), this.length = .8 * this.originBoundingBox.getSize(new y).length(), this.planeOffset = 0, this.normalIndex = 3, this.visible = !1, this.rotatable = !1, this.hit = !1, this.clipplane = new p, this.observer = null, this.renderClipPlane = new EA, this.angleA = 0, this.angleB = 0, this.uniforms = { iClipPlane: { value: 0 }, vClipPlane: { value: new Array(new p) } }, this.planeMaterial = new jC({ color: 6724044, opacity: .3, transparent: !0, side: 2, lights: !0 }), this.planeMaterial.visible = !1, this.planeHighLightMatrial = new jC({ color: 6724044, opacity: .3, transparent: !0, side: 2, lights: !0 }), this.initPlaneModel = function () { for (var A = this.children.length - 1; A >= 0; A -= 1) this.remove(this.children[A]); this.planeOffset = 0; var e = this.length, t = new Ue(new At(e, e), this.planeMaterial); t.name = "fillClipPlane", t.customTag = !0, t.renderOrder = 90, this.position.copy(this.center), this.clipplane.set(0, 0, 1, 0), this.planeMesh = t, this.add(t) }, this.initWireframes = function () { var A = .5 * this.length, e = [-A, A, 0, A, A, 0, -A, -A, 0, A, -A, 0], t = new he, i = new jC({ color: 2003199, lights: !0 }); t.setIndex([0, 1, 1, 3, 3, 2, 2, 0]), t.setAttribute("position", new Ae(e, 3)); var o = new jo(t, i); o.name = "Wireframes", o.customTag = !0, this.wireframeMesh = o, this.add(o) }, this.getCoordinate = function () { var A = .5 * this.length, e = new y(-A, A, 0); e.applyMatrix4(this.matrix); var t = new y(A, A, 0); t.applyMatrix4(this.matrix); var i = new y(-A, -A, 0); return i.applyMatrix4(this.matrix), { axisX: e.clone().sub(t).normalize(), axisY: e.clone().sub(i).normalize() } }, this.initCapsPlane = function () { if (this.capPlane) return this.capPlane; this.planeMesh || this.initPlaneModel(); var A = this.length, e = new Ue(new At(A, A), new jC({ color: 16776960, side: 2, stencilWrite: !0, stencilFunc: 515, stencilRef: 1, stencilFuncMask: 255, stencilFail: 7680, stencilZFail: 7680, stencilZPass: 7680 })), t = this.planeMesh; e.matrixWorld = t.matrixWorld, e.matrix = this.matrix; for (var i = .5 * this.length, o = .01 * this.length, n = [], r = i - o; r > -i; r -= o) n.push(r, i, 0), n.push(i, r, 0); for (r = -i + o; i > r; r += o) n.push(-i, r, 0), n.push(r, -i, 0); var a = new YC({ color: 2236962, stencilWrite: !0, stencilFunc: 515, stencilRef: 1, stencilFuncMask: 255, stencilFail: 7680, stencilZFail: 7680, stencilZPass: 7680 }); a.linewidth = 1, a.resolution.set(window.innerWidth, window.innerHeight), a.depthTest = !1; var s = new JC; s.setPositions(n); var l = new XC(s, a); return l.matrix = this.matrix, l.matrixWorld = t.matrixWorld, this.capPlane = { planeMesh: e, lineMesh: l }, this.capPlane }, this.updateClippingParams = function (A) {}, this.getFillClipBoundingBox = function () { return this.boundingBox }, this.calculateFillClipBoundingBox = function (A) { this.boundingBox = this.originBoundingBox.clone(), 0 !== this.clipplane.x ? 1 === this.clipplane.x ? this.boundingBox.max.x = A.x : this.boundingBox.min.x = A.x : 0 !== this.clipplane.y ? 1 === this.clipplane.y ? this.boundingBox.max.y = A.y : this.boundingBox.min.y = A.y : 0 !== this.clipplane.z && (1 === this.clipplane.z ? this.boundingBox.max.z = A.z : this.boundingBox.min.z = A.z) }, this.enable = function (A, e) { this.visible = e, this.uniforms.iClipPlane.value = A ? 1 : 0, this.capPlane && (this.capPlane.lineMesh.visible = e, this.capPlane.planeMesh.visible = e), this.update() }, this.isEnabled = function () { return 0 !== this.uniforms.iClipPlane.value }, this.update = function () { this.updateMatrixWorld(); var A = new M; A.getInverse(this.matrix), A.transpose(), this.uniforms.vClipPlane.value[0] = this.clipplane.clone().applyMatrix4(A), this.updateClippingParams(this.uniforms), this.observer && this.observer() }, this.getClipPlane = function () { return this.clipplane.clone() }, this.offset = function (A) { var e = this.cubeSize.length(); this.planeOffset += A, Math.abs(this.planeOffset) > .5 * e && (this.planeOffset = this.planeOffset > 0 ? .5 * e : .5 * -e); var t = this.uniforms.vClipPlane.value[0].clone(), i = new y(t.x, t.y, t.z); i.normalize(); var o = new y(i.x * this.planeOffset, i.y * this.planeOffset, i.z * this.planeOffset); this.position.copy(this.center).add(o), this.update() }, this.setOffset = function (A) { var e = this.cubeSize.length(); this.planeOffset = A, Math.abs(A) > .5 * e && (this.planeOffset = A > 0 ? .5 * e : .5 * -e); var t = this.uniforms.vClipPlane.value[0].clone(), i = new y(t.x, t.y, t.z); i.normalize(); var o = new y(i.x * this.planeOffset, i.y * this.planeOffset, i.z * this.planeOffset); this.position.copy(this.center).add(o), this.update() }, this.changeNormal = function (A) { this.quaternion.set(0, 0, 0, 1), this.angleA = 0, this.angleB = 0, this.setNormal(A) }, this.setNormal = function (A) { var e = this.planeMesh, t = this.wireframeMesh; 0 === A ? (this.clipplane.set(1, 0, 0, 0), e.rotation.set(0, Math.PI / 2, 0), t.rotation.set(0, Math.PI / 2, 0)) : 1 === A ? (this.clipplane.set(-1, 0, 0, 0), e.rotation.set(0, -Math.PI / 2, 0), t.rotation.set(0, -Math.PI / 2, 0)) : 2 === A ? (this.clipplane.set(0, 0, 1, 0), e.rotation.set(Math.PI, 0, 0), t.rotation.set(Math.PI, 0, 0)) : 3 === A ? (this.clipplane.set(0, 0, -1, 0), e.rotation.set(0, 0, 0), t.rotation.set(0, 0, 0)) : 4 === A ? (this.clipplane.set(0, 1, 0, 0), e.rotation.set(-Math.PI / 2, 0, 0), t.rotation.set(-Math.PI / 2, 0, 0)) : 5 === A && (this.clipplane.set(0, -1, 0, 0), e.rotation.set(Math.PI / 2, 0, 0), t.rotation.set(Math.PI / 2, 0, 0)), this.normalIndex = A, e.updateMatrixWorld(), t.updateMatrixWorld(), this.capPlane && (this.capPlane.planeMesh.matrixWorld = e.matrixWorld, this.capPlane.lineMesh.matrixWorld = e.matrixWorld), this.update() }; var t = new f, i = new y(1, 0, 0); this.rotX = function (A) { t.setFromAxisAngle(i, A), this.quaternion.multiply(t), this.update() }; var o = new y(0, 1, 0); this.rotY = function (A) { t.setFromAxisAngle(o, A), this.quaternion.multiply(t), this.update() }; var n = new y(0, 0, 1); this.rotateByAxis = function (A, e) { t.setFromAxisAngle(A, e), this.quaternion.multiply(t) }, this.rotateAngleOffset = function (A, e) { var t = this.normalIndex; A = A % 360 / 180 * Math.PI, 0 === t || 1 === t ? ("y" === e && this.rotateByAxis(n, A), "z" === e && this.rotateByAxis(o, A)) : 2 === t || 3 === t ? ("x" === e && this.rotateByAxis(i, A), "z" === e && this.rotateByAxis(o, A)) : 4 !== t && 5 !== t || ("x" === e && this.rotateByAxis(i, A), "y" === e && this.rotateByAxis(n, A)), this.update() }, this.setRotateAngle = function (A, e) { this.quaternion.set(0, 0, 0, 1); var t = this.normalIndex; e = 0 > (e = void 0 === e ? this.angleB : e % 360) ? 360 + e : e, this.angleA = A = 0 > (A = void 0 === A ? this.angleA : A % 360) ? 360 + A : A, this.angleB = e, A = A / 180 * Math.PI, e = e / 180 * Math.PI, 0 === t || 1 === t ? (e = 0 === t ? e : -e, this.rotateByAxis(n, A = 0 === t ? -A : A), this.rotateByAxis(o, e)) : 2 === t || 3 === t ? (this.rotateByAxis(i, A), this.rotateByAxis(o, e)) : 4 !== t && 5 !== t || (e = 3 === t ? e : -e, this.rotateByAxis(i, A = 3 === t ? -A : A), this.rotateByAxis(n, e)), this.update() }, this.getRotateAngle = function () { return { angleA: this.angleA, angleB: this.angleB } }, this.highLight = function () { this.planeMesh.material = this.planeHighLightMatrial }, this.cancelHighLight = function () { this.planeMesh.material = this.planeMaterial, this.hit = !1 }; var r = function (A, e, t, i, o, n, r, a, s) { this.enable = A, this.visible = e, this.rotatable = t, this.planeOffset = i, this.position = o, this.scale = n, this.quaternion = r, this.cubeSize = a, this.center = s }; this.store = function () { return new r(!!this.uniforms.iClipPlane.value, this.visible, this.rotatable, this.planeOffset, this.position.clone(), this.scale.clone(), this.quaternion.clone(), this.cubeSize.clone(), this.center.clone()) }, this.restore = function (A) { this.enable(A.enable, A.visible), this.rotatable = A.rotatable, this.planeOffset = A.planeOffset, this.position.copy(A.position), this.scale.copy(A.scale), this.quaternion._w = A.quaternion._w, this.quaternion._x = A.quaternion._x, this.quaternion._y = A.quaternion._y, this.quaternion._z = A.quaternion._z, this.normalIndex = void 0 === A.normalIndex ? this.normalIndex : A.normalIndex, this.setNormal(this.normalIndex) }, this.setProcess = function (A) { var e = this.cubeSize.length(); A > 1 ? A = 1 : -1 > A && (A = -1), this.planeOffset = A * e * .5; var t = this.uniforms.vClipPlane.value[0].clone(), i = new y(t.x, t.y, t.z); i.normalize(); var o = new y(i.x * this.planeOffset, i.y * this.planeOffset, i.z * this.planeOffset); this.position.copy(this.center).add(o), this.update() }, this.restoreRotation = function () { this.quaternion.set(0, 0, 0, 1), this.update() }, this.getProcess = function () { var A = this.cubeSize.length(); return this.planeOffset / A * 2 } }; (_C.prototype = Object.create(ep.prototype)).constructor = _C, _C.prototype.init = function () { this.initPlaneModel(), this.initWireframes() }, _C.prototype.hitTest = function (A) { if (this.visible) { var e = null, t = null; if (this.hit = this.raycast(A), this.hit) { var i = A.ray, o = new EA, n = this.uniforms.vClipPlane.value[0]; o.setComponents(n.x, n.y, n.z, n.w), e = i.distanceToPlane(o), t = 0 > i.direction.dot(o.normal) } return { sign: t, distance: e } } this.hit = !1 }, _C.prototype.raycast = function (A, e) { var t = []; return this.planeMesh.raycast(A, t), t.length > 0 }, _C.prototype.resize = function (A, e) { var t = A.length() / this.length; this.scale.set(t, t, t), this.cubeSize.copy(A), e && (this.center = e.clone(), this.position.copy(this.center)), this.offset(0), this.updateMatrixWorld() }, _C.prototype.getSideLength = function () { return this.length * this.scale.x }; var $C = function (A, e) { this.cls = A, this.size = e, this._pool = [], this.counter = 0 }; $C.prototype.init = function (A) { for (var e = 0, t = this.size; t > e; e += 1) { var i = new this.cls; i.init(A), this._pool[e] = i } }, $C.prototype.resize = function (A, e) { this.size = A, this.collect(), this.init(e) }, $C.prototype.get = function (A) { return this.size > this.counter ? (this._pool[this.counter].spawn(A), this.counter += 1, this.counter - 1) : (Bh.log("the pool is full"), -1) }, $C.prototype.clear = function () { for (var A = 0, e = this.size; e > A; A += 1) this._pool[A].clear(); this.counter = 0 }, $C.prototype.destroy = function () { this.collect() }, $C.prototype.collect = function () { this._pool = [], this.counter = 0 }, $C.prototype.getObjects = function () { return this._pool }; var Ay = function (A, e) { var t = new he; t.setAttribute("position", new YA(new Float32Array(72), 3)), jo.call(this, t, new ko({ color: e })), void 0 !== A && this.updateBBox(A) }; (Ay.prototype = Object.create(jo.prototype)).constructor = Ay, Ay.prototype.unload = function () {}, Ay.prototype.updateBBox = function (A) { var e = A.min, t = A.max, i = this.geometry.attributes.position.array; i[0] = t.x, i[1] = t.y, i[2] = t.z, i[3] = e.x, i[4] = t.y, i[5] = t.z, i[6] = e.x, i[7] = t.y, i[8] = t.z, i[9] = e.x, i[10] = e.y, i[11] = t.z, i[12] = e.x, i[13] = e.y, i[14] = t.z, i[15] = t.x, i[16] = e.y, i[17] = t.z, i[18] = t.x, i[19] = e.y, i[20] = t.z, i[21] = t.x, i[22] = t.y, i[23] = t.z, i[24] = t.x, i[25] = t.y, i[26] = e.z, i[27] = e.x, i[28] = t.y, i[29] = e.z, i[30] = e.x, i[31] = t.y, i[32] = e.z, i[33] = e.x, i[34] = e.y, i[35] = e.z, i[36] = e.x, i[37] = e.y, i[38] = e.z, i[39] = t.x, i[40] = e.y, i[41] = e.z, i[42] = t.x, i[43] = e.y, i[44] = e.z, i[45] = t.x, i[46] = t.y, i[47] = e.z, i[48] = t.x, i[49] = t.y, i[50] = t.z, i[51] = t.x, i[52] = t.y, i[53] = e.z, i[54] = e.x, i[55] = t.y, i[56] = t.z, i[57] = e.x, i[58] = t.y, i[59] = e.z, i[60] = e.x, i[61] = e.y, i[62] = t.z, i[63] = e.x, i[64] = e.y, i[65] = e.z, i[66] = t.x, i[67] = e.y, i[68] = t.z, i[69] = t.x, i[70] = e.y, i[71] = e.z, this.geometry.attributes.position.needsUpdate = !0, this.geometry.computeBoundingBox(), this.geometry.computeBoundingSphere(), this.matrixAutoUpdate = !1 }; var ey = function () { ep.call(this, gp.EXTERNALSCENEMANAGER, { pickableType: Qc.Geometry, priority: 20 }), this.globalSpace = !0 }; (ey.prototype = Object.create(ep.prototype)).constructor = ey, ey.prototype.getNode = function (A) { for (var e = this.children, t = 0, i = e.length; i > t; t += 1) if (e[t].name === A.toString()) return e[t]; return null }, ey.prototype.removeNodeByName = function (A) { var e = this.getNode(A); return !!e && (this.remove(e), !0) }, ey.prototype.clearNodes = function () { this.clear() }, ey.prototype.setNodeVisibleByName = function (A, e) { var t = this.getNode(A); return !!t && (t.visible = e, !0) }, ey.prototype.showAllNodes = function () { for (var A = this.children, e = 0, t = A.length; t > e; e += 1) A[e].visible = !0 }, ey.prototype.hideAllNodes = function () { for (var A = this.children, e = 0, t = A.length; t > e; e += 1) A[e].visible = !1 }; var ty = function () { ep.call(this, gp.EXTRUDEBODYMANAGER, { pickableType: Qc.Geometry, priority: 20 }), this.globalSpace = !0, this.mapColorToNodeId = {}, this.selectionIds = {}, this.selectionColor = { red:240 , green: 224, blue:50 , alpha: .3 }, this.selectionEdgeColor = { red: 50, green: 224, blue: 240, alpha: 1 } }; function iy(A) { this.scene = A, this.lightArray = void 0, this.lightHelperArray = void 0, this.lightHelper = !1, this._currentPreset = void 0, this._intensityFactor = vc.LightIntensityFactor, this.defaultShadowLightDir = new y(100, -100, -160), this.defaultLightDir = new y(100, -100, -160), this.shadowLightDir = new y(100, -100, -160), this.lightDir = new y(100, -100, -160), this._ambientLight = void 0, this.setLightPreset(vc.LightPreset) } (ty.prototype = Object.create(ep.prototype)).constructor = ty, ty.prototype.addNode = function (A, e, t, i, o, n) { n = void 0 === n || n; var r = this.getNode(A); if (r) return r.material = i, this.setColorInMap(r.name, i), void((r = this.getNode("wireframe_" + A)) && (r.material = o, this.setColorInMap(r.name, o))); var a = [], l = 0; if (e.belong && "user" === e.belong) a = e.roomBoundary, l = e.offsetZ; else { e.version && "2.0" === e.version && (e = e.loops && e.loops.length > 0 ? e.loops[0] : []); for (var c = e.length, h = 0; c > h; h += 1) for (var d = e[h], p = d.length, g = 0; p - 1 > g; g += 1) { var u = d[g]; a.push(new s(u.x, u.y)), 0 === h && 0 === g && (l = u.z) } a.length > 0 && a.push(a[0]) } var f = new Jn(new Ba(a), { amount: t }); i.depthTest = !n, f.boundingBox || f.computeBoundingBox(); var m = new Ue(f, i); m.name = A.toString(), m.translateZ(l), this.setColorInMap(m.name, i), this.add(m), this.updateMatrixWorld(!0); var C = m.geometry.faces, y = []; for (h = 0, p = C.length; p > h; h += 1) y.push(C[h].a), y.push(C[h].b), y.push(C[h].c); var v = m.geometry.vertices, I = []; for (h = 0, p = v.length; p > h; h += 1) I.push(v[h].x), I.push(v[h].y), I.push(v[h].z); var E = Up(I, y, Math.PI / 3.5), B = new he; B.setIndex(new $A(E, 1)), B.setAttribute("position", new Ae(I, 3)), o.depthTest = !n, o.transparent = !0; var x = new jo(B, o); x.translateZ(l), x.name = "wireframe_" + A, this.setColorInMap(x.name, o), this.add(x), this.updateMatrixWorld(!0) }, ty.prototype.setColorInMap = function (A, e) { console.log(e.color.r); this.mapColorToNodeId[A] = { red: 255 * e.color.r, green: 255 * e.color.g, blue: 255 * e.color.b, alpha: e.opacity } }, ty.prototype.createMaterial = function (A) { return Kd.createStandardMaterial(A) }, ty.prototype.setNodeMaterial = function (A, e, t) { var i = this.getNode(A); if (i) { var o = i.material; for (var n in e) { o.hasOwnProperty(r = n) && (o[r] = "color" === r ? new LA(e[n]) : e[n]) } } if (i = this.getNode("wireframe_" + A)) { o = i.material; for (var n in t) { var r; o.hasOwnProperty(r = n) && (o[r] = "color" === r ? new LA(t[n]) : t[n]) } } }, ty.prototype.getNode = function (A) { for (var e = this.children, t = 0, i = e.length; i > t; t += 1) if (e[t].name === A.toString()) return e[t]; return null }, ty.prototype.removeNodeById = function (A) { var e = this.getNode(A); return e && (delete this.mapColorToNodeId[e.name], this.remove(e)), !!(e = this.getNode("wireframe_" + A)) && (delete this.mapColorToNodeId[e.name], this.remove(e), !0) }, ty.prototype.clearNodes = function () { this.clear(), this.mapColorToNodeId = {} }, ty.prototype.setNodeVisibleById = function (A, e) { var t = this.getNode(A); return t && (t.visible = e), !!(t = this.getNode("wireframe_" + A)) && (t.visible = e, !0) }, ty.prototype.showAllNodes = function () { for (var A = this.children, e = 0, t = A.length; t > e; e += 1) A[e].visible = !0 }, ty.prototype.hideAllNodes = function () { for (var A = this.children, e = 0, t = A.length; t > e; e += 1) A[e].visible = !1 }, ty.prototype.setNodeColorById = function (A, e) { var t = this.getNode(A); console.log('setNodeColorById...', t); if (t) { var i = t.material; return i.color = new LA(e.red / 255, e.green / 255, e.blue / 255), i.opacity = e.alpha, e !== this.selectionColor && e !== this.selectionEdgeColor && this.setColorInMap(t.name, i), !0 } return !1 }, ty.prototype.getNodeColorById = function (A) { return this.mapColorToNodeId[A] }, ty.prototype.setWireframeColorById = function (A, e) { console.log('setWireframeColorById'); return this.setNodeColorById("wireframe_" + A, e) }, ty.prototype.getWireframeColorById = function (A) { return this.getNodeColorById("wireframe_" + A) }, ty.prototype.applySelection = function (A) { console.log('applySelection77') console.log(this.selectionColor) this.clearSelection(); var e = this.selectionIds, t = this.mapColorToNodeId, i = A.sceneState.selectionSet; console.log('i>>',i) // debugger; for (var o in i) t[o] && (e[o] = !0, // this.setNodeColorById(o, this.selectionColor), this.setNodeColorById(o, { alpha: 0.3, blue: 50, green: 224, red: 240 }), this.setWireframeColorById(o, this.selectionEdgeColor)) }, ty.prototype.clearSelection = function () { console.log('clearSelection') var A = this.mapColorToNodeId; console.log('A',A) if (this.selectionIds) { console.log(this.selectionIds) for (var e = this.children, t = 0, i = e.length; i > t; t += 1) { var o = e[t], n = A[o.name]; o.material.color = new LA(n.red / 255, n.green / 255, n.blue / 255), o.material.opacity = n.alpha } this.selectionIds = {} } }, ty.prototype.applyHover = function (A) { var e = A.sceneState; if (e.hoverId && !e.isSelected(e.hoverId)) { var t = this.getNode(e.hoverId); if (t) { this.hoveredId = e.hoverId; var i = this.mapColorToNodeId[this.hoveredId], o = Kd.getHoverColorByColor({ r: i.red / 255, g: i.green / 255, b: i.blue / 255, a: i.alpha }); t.material.color.setRGB(o.r, o.g, o.b), t.material.opacity = o.a } } }, ty.prototype.clearHover = function () { var A = this.hoveredId; if (A) if (this.selectionIds[A]) this.hoveredId = null; else { var e = this.getNode(A); if (e) { var t = this.mapColorToNodeId[A]; e.material.color.setRGB(t.red / 255, t.green / 255, t.blue / 255), e.material.opacity = t.alpha, this.hoveredId = null } else this.hoveredId = null } }, iy.prototype.destroy = function () { this.scene = void 0, this._clearLights(), this._clearLightHelpers() }, iy.prototype.currentLights = function () { if (this.lightArray) return [].concat(this.lightArray) }, iy.prototype.setLightPreset = function (A) { this._currentPreset !== A && (vc.LightPreset = A, this._currentPreset = A, this._clearLights(), this._clearLightHelpers(), this._createLights(), this.setIntensityFactor(this._intensityFactor), this.lightHelper && this._createLightHelpers()) }, iy.prototype.getLightPreset = function () { return this._currentPreset }, iy.prototype.updateLights = function (A) { if (this.lightArray) { var e = new y(0, 0, 1), t = Math.PI / 4, i = A.position.clone(); i.sub(A.target), i.normalize(); var o = null; if (0 === this._currentPreset) { var n = this.lightArray[1]; n.position.set(i.x, i.y, i.z), n.updateMatrixWorld(!0) } else if (1 === this._currentPreset || 3 === this._currentPreset) { var r = this.lightArray[2], a = this.lightArray[3]; o = i.clone().applyAxisAngle(e, -1.2 * t), r.position.copy(o).normalize(), r.position.multiplyScalar(1e3), r.position.z = 600, r.updateMatrixWorld(), o = i.clone().applyAxisAngle(e, Number(t)), a.position.copy(o).normalize(), a.position.multiplyScalar(1e3), a.position.z = 600, a.updateMatrixWorld() } else if (2 === this._currentPreset) { var s = this.lightArray[1], l = this.scene.getBoundingBox().getCenter(new y), c = new y(l.x - (o = this.lightDir).x, l.y - o.y, l.z - o.z); s.position.copy(c), s.target.position.set(l.x, l.y, l.z), s.target.updateMatrixWorld(!0), s.updateMatrixWorld(!0) } else { s = this.lightArray[1]; o = i.clone().applyAxisAngle(e, -2 * t), s.position.copy(o).normalize(), s.position.multiplyScalar(1e3), s.position.z = 600, s.updateMatrixWorld() } this.lightHelperArray && this.updateLightHelper() } }, iy.prototype.updateLightHelper = function () { for (var A = 0; this.lightHelperArray.length > A; A += 1) { var e = this.lightHelperArray[A]; e.update(), e.updateMatrixWorld(!0) } }, iy.prototype.setIntensityFactor = function (A) { if (!isNaN(A)) { var e = Number(A); if (e >= 0 && (this._intensityFactor = e, vc.LightIntensityFactor = this._intensityFactor, this.lightArray)) for (var t = 0, i = this.lightArray.length; i > t; t += 1) { var o = this.lightArray[t]; o.intensity = o.initIntensity * this._intensityFactor } } }, iy.prototype.getIntensityFactor = function () { return this._intensityFactor }, iy.prototype.setAmbientLightIntensity = function (A) { if (this._ambientLight) { if (isNaN(A)) return; var e = Number(A); if (0 > e) return; this._ambientLight.intensity = e } }, iy.prototype.getAmbientLightIntensity = function () { if (this._ambientLight) return this._ambientLight.intensity }, iy.prototype._createLights = function () { var A = null; switch (this._currentPreset) { case 0: A = this._lightPreset0(); break; case 1: A = this._lightPreset1(); break; case 2: A = this._lightPreset2(); break; case 3: A = this._lightPreset3(); break; case 4: A = this._lightPreset4(); break; default: (A = this._commonLights(.72))[1].color.setHex(16777215) } if (this.lightArray = A, this.scene && this.lightArray) for (var e = 0, t = this.lightArray.length; t > e; e += 1) this.scene.add(this.lightArray[e]), this.lightArray[e].updateMatrixWorld() }, iy.prototype._clearLights = function () { if (this.lightArray) { for (var A = 0; this.lightArray.length > A; A += 1) { var e = this.lightArray[A]; e.parent && e.parent.remove(e) } this.lightArray = void 0 } this._ambientLight = void 0 }, iy.prototype._createLightHelpers = function () { if (this.lightArray) for (var A = 0; this.lightArray.length > A; A += 1) { var e = this.lightArray[A]; if (e instanceof Ra) { var t = new ll(e, 6e3); this.lightHelperArray || (this.lightHelperArray = []), this.lightHelperArray.push(t), this.scene && this.scene.add(t) } } }, iy.prototype._clearLightHelpers = function () { if (this.lightHelperArray) { for (var A = 0; this.lightHelperArray.length > A; A += 1) { var e = this.lightHelperArray[A]; e.parent && e.parent.remove(e) } this.lightHelperArray = void 0 } }, iy.prototype._commonLights = function (A, e) { var t = [], i = new Ta(16777215, .6); i.intensity = .3, i.initIntensity = i.intensity, t.push(i), this._ambientLight = i; var o = new Ra(16777215, 1); return o.color.setHex(14800580), o.position.set(-100, 100, 160), o.intensity = .72, o.initIntensity = o.intensity, o.distance = 300, o.updateMatrixWorld(), t.push(o), vc.EnableShadow && (o.castShadow = !0, o.shadow.camera.near = 0, o.shadow.camera.far = 5e6, o.shadow.camera.left = -2e5, o.shadow.camera.right = 2e5, o.shadow.camera.top = 2e5, o.shadow.camera.bottom = -2e5, o.distance = 1110, o.shadow.mapSize.height = 1028, o.shadow.mapSize.width = 1028), t }, iy.prototype._lightPreset0 = function () { var A = null; if (!vc.EnableLightmap) { A = []; var e = .3, t = new Sa(16777215, 16777215, e); A.push(t), t.initIntensity = e, t.position.set(0, 0, 500), t.updateMatrixWorld(!0); var i = new Ra(16777215, e = .7); A.push(i), i.initIntensity = e, i.color.setHSL(.1, .95, 1), i.position.set(-1, 1, .75), i.position.multiplyScalar(50) } return A }, iy.prototype._lightPreset1 = function () { var A = this._commonLights(.4, .56); A || (A = []); var e = new Ra(16777215, 1); A.push(e), e.color.setHex(16777215), e.position.set(100, 100, 100), e.intensity = .4, e.initIntensity = e.intensity, e.updateMatrixWorld(); var t = new Ra(16777215, 1); return A.push(t), t.color.setHex(16777215), t.position.set(-100, -100, 100), t.intensity = .18, t.initIntensity = t.intensity, t.updateMatrixWorld(), A }, iy.prototype._lightPreset2 = function () { var A = this._commonLights(); A || (A = []); var e = new Ra(16777215, 1); A.push(e), e.position.set(60, 130, 80), e.intensity = .28, e.initIntensity = e.intensity, e.updateMatrixWorld(); var t = new Ra(16777215, 1); A.push(t), t.color.setHex(8100788), t.position.set(100, -100, 80), t.intensity = .22, t.initIntensity = t.intensity, t.updateMatrixWorld(); var i = new Ra(16777215, 1); return A.push(i), i.color.setHex(8100788), i.position.set(-140, -50, 80), i.intensity = .18, i.initIntensity = i.intensity, i.updateMatrixWorld(), A }, iy.prototype._lightPreset3 = function () { var A = this._commonLights(.4, .56); A || (A = []); var e = new Ra(16777215, 1); A.push(e), e.color.setHex(16777215), e.position.set(100, 100, 100), e.intensity = .22, e.initIntensity = e.intensity, e.updateMatrixWorld(); var t = new Ra(16777215, 1); return A.push(t), t.color.setHex(16777215), t.position.set(-100, -100, 100), t.intensity = .18, t.initIntensity = t.intensity, t.updateMatrixWorld(), A }, iy.prototype._lightPreset4 = function () { var A = this._commonLights(.4, .56); A || (A = []); var e = new Ra(16777215, 1); A.push(e), e.color.setHex(16777215), e.position.set(100, 100, 100), e.intensity = .4, e.initIntensity = e.intensity, e.updateMatrixWorld(); var t = new Ra(16777215, 1); return A.push(t), t.color.setHex(16777215), t.position.set(-100, -100, 100), t.intensity = .1, t.initIntensity = t.intensity, t.updateMatrixWorld(), A[0].intensity = .3, A[1].intensity = .2, this.enableShadowLight(), A }, iy.prototype.enableShadowLight = function () { this.lightCastShadow ? this.lightCastShadow.visible = !0 : (this.lightCastShadow = new Ra(16777215, .15), this.lightCastShadow.intensity = .5, this.lightCastShadow.initIntensity = .5, this.lightCastShadow.castShadow = !0, this.lightCastShadow.shadow.mapSize.width = 1024, this.lightCastShadow.shadow.mapSize.height = 1024, this.lightCastShadow.shadow.bias = -9e-4, this.scene.add(this.lightCastShadow)), this.lightCastShadow.updateMatrixWorld() }, iy.prototype.getLightDirFromAltitudeAndAzimuth = function (A, e) { var t = Math.sin(e), i = Math.cos(e); return e > 0 && (i = -i), new y(t, i, Math.sin(A) / Math.cos(A)).multiplyScalar(-100) }, iy.prototype.disableShadowLight = function () { this.lightCastShadow && (this.lightCastShadow.visible = !1) }, iy.prototype.updateShadowLight = function () { if (null !== this.scene.geometryGroup.boundingBox && this.lightCastShadow && this.lightCastShadow.visible) { var A = this.scene.getBoundingBox().clone(), e = new y, t = A.getSize(e); t.multiplyScalar(.2), A.min.sub(t), A.max.add(t); var i = A.getCenter(new y), o = this.shadowLightDir, n = new y(i.x - o.x, i.y - o.y, i.z - o.z); this.lightCastShadow.position.set(n.x, n.y, n.z), this.lightCastShadow.target.position.set(i.x, i.y, i.z), this.lightCastShadow.target.updateMatrixWorld(!0), this.lightCastShadow.updateMatrixWorld(!0); var r = this.lightCastShadow.shadow.camera; r.position.set(n.x, n.y, n.z), r.lookAt(i), r.updateMatrixWorld(), r.matrixWorldInverse.getInverse(r.matrixWorld), t = A.getSize(new y), A.min.z = A.min.z - .05 * t.z; var a = new EA(new y(0, 0, 1), -A.min.z), s = a.normal.dot(o), l = A.max.clone(), c = -(l.dot(a.normal) + a.constant) / s, h = new y; h.copy(o).multiplyScalar(c).add(l), A.expandByPoint(h), A.applyMatrix4(r.matrixWorldInverse), r.left = A.min.x, r.right = A.max.x, r.top = A.max.y, r.bottom = A.min.y, r.far = 1.5 * -A.min.z, r.near = -A.max.z, r.updateProjectionMatrix() } }, iy.prototype.disableLights = function () { if (this.lightArray) for (var A = 0, e = this.lightArray.length; e > A; A += 1) this.lightArray[A].visible = !1 }, iy.prototype.enableLights = function () { if (this.lightArray) for (var A = 0, e = this.lightArray.length; e > A; A += 1) this.lightArray[A].visible = !0 }; var oy = function () { console.log('oy..................') H.call(this), this.type = "Scene", this.autoUpdate = !1, this.tempVector3 = new y, this.objectGroups = new ep, this.add(this.objectGroups), this.geometryGroup = new ep(gp.GEOMETRY, { pickableType: Qc.Geometry, globalSpace: !0 }), this.geometryGroup.boundingBox = new aA, this.pool = new $C(Kf, 0), this.expandScalar = 1.01, this.clipPlanes = null, this.fillClipPlane = null, this.areaNode = null, this.extrudeBodyManager = null, this.externalScene = null, this.externalComponentManager = null, this.customPlaneManager = null, this.axisGridManager = null, this.lightManager = new iy(this), this.selectedMeshes = [], this.nonSelectedMeshes = [], this.selectedInstanceMeshes = [], this.nonSelectedInstanceMeshes = [], this.componentTransformControl = void 0 }; (oy.prototype = Object.create(H.prototype)).constructor = oy, oy.prototype.createCapStencilMaterials = function () { this.backMaterial || (this.backMaterial = Kd.createStandardMaterial({ color: 16711680, colorWrite: !1, depthWrite: !1, depthTest: !1, side: 1, stencilWrite: !0, stencilFunc: 519, stencilRef: 1, stencilFuncMask: 255, stencilFail: 7680, stencilZFail: 7680, stencilZPass: 7682 }), this.frontMaterial = Kd.createStandardMaterial({ color: 255, colorWrite: !1, depthWrite: !1, depthTest: !1, side: 0, stencilWrite: !0, stencilFunc: 519, stencilRef: 1, stencilFuncMask: 255, stencilFail: 7680, stencilZFail: 7680, stencilZPass: 7683 }), this.backInstanceMaterial = Kd.createStandardMaterial({ color: 16711680, colorWrite: !1, depthWrite: !1, depthTest: !1, side: 1, stencilWrite: !0, stencilFunc: 519, stencilRef: 1, stencilFuncMask: 255, stencilFail: 7680, stencilZFail: 7680, stencilZPass: 7682 }), this.backInstanceMaterial.defines.USE_INSTANCE = "", this.backInstanceMaterial.defines.USE_INSTANCE_NORMAL = "", this.frontInstanceMaterial = Kd.createStandardMaterial({ color: 255, colorWrite: !1, depthWrite: !1, depthTest: !1, side: 0, stencilWrite: !0, stencilFunc: 519, stencilRef: 1, stencilFuncMask: 255, stencilFail: 7680, stencilZFail: 7680, stencilZPass: 7683 }), this.frontInstanceMaterial.defines.USE_INSTANCE = "", this.frontInstanceMaterial.defines.USE_INSTANCE_NORMAL = "") }, oy.prototype.destroy = function () { this.lightManager.destroy(), this.clearAll(), this.pool.destroy(), this.pool = null, this.geometryGroup = null, this.objectGroups = null, this.clipPlanes = null, this.fillClipPlane = null, this.areaNode = null, this.extrudeBodyManager = null, this.externalComponentManager = null, this.axisGridManager = null, this.IBLMaps = null, this.transformMatrix = null, this.selectedMeshes = null, this.nonSelectedMeshes = null, this.selectedInstanceMeshes = null, this.nonSelectedInstanceMeshes = null }, oy.prototype.resizePool = function (A) { vc.MergeComponent || (this.geometryGroup.clear(), this.pool.resize(A, { parent: this.geometryGroup })) }, oy.prototype.clearAll = function () { this.pool.clear(), this.autoUpdate = !1 }, oy.prototype.getRootNode = function () { return this.geometryGroup }, oy.prototype.getBoundingBox = function () { var A = this.getBoundingBoxWorld(); return A.applyMatrix4(this.geometryGroup.matrix), A }, oy.prototype.getGeometryBoundingBox = function () { var A = new aA; A.copy(this.geometryGroup.boundingBox); var e = new y, t = A.getSize(e); return t.multiplyScalar(this.expandScalar - 1), A.min.sub(t), A.max.add(t), A.applyMatrix4(this.geometryGroup.matrix), A }, oy.prototype.getBoundingBoxWorld = function () { var A = new aA, e = new y; return function () { A.copy(this.geometryGroup.boundingBox), this.componentTransformControl && A.union(this.componentTransformControl.getBoundingBox()); var t = A.getSize(e); return t.multiplyScalar(this.expandScalar - 1), A.min.sub(t), A.max.add(t), this.fillClipPlane && this.fillClipPlane.visible ? A.expandByObject(this.fillClipPlane) : this.clipPlanes && this.clipPlanes.visible && A.expandByObject(this.clipPlanes), A } }(), oy.prototype.setBoundingBoxWorld = function (A) { this.geometryGroup.boundingBox ? this.geometryGroup.boundingBox.copy(A) : this.geometryGroup.boundingBox = A; var e = A.clone(); if (this.clipPlanes && this.clipPlanes.visible) { var t = e.getSize(new y); t.multiplyScalar(this.expandScalar - 1), e.min.sub(t), e.max.add(t), this.clipPlanes.setSectionBox(e.min, e.max) } if (this.fillClipPlane && this.fillClipPlane.visible) { var i = new y; e.getSize(i), i.multiplyScalar(.05), e.min.sub(i), e.max.add(i), this.fillClipPlane.resize(e.getSize(i), e.getCenter(new y)) } }, oy.prototype.expandBoundingBoxWorldBy = function (A) { if (A) { var e = A; A instanceof Array == !1 && (e = [A]); for (var t = 0, i = e.length; i > t; t += 1) { var o = e[t]; (o instanceof Ue || o instanceof H) && this.geometryGroup.boundingBox.expandByObject(o) } } }, oy.prototype.getTransformMatrixGlobal = function () { return this.transformMatrix }, oy.prototype.getMatrixGlobal = function () { return this.geometryGroup.matrix.clone() }, oy.prototype.getGlobalScaleFactor = function () { return this.geometryGroup.matrix.elements[0] }, oy.prototype.getMatrixWorldGlobal = function () { return this.geometryGroup.matrixWorld }, oy.prototype.getRotationGlobal = function () { if (this.geometryGroup.matrix) { var A = new M; A.extractRotation(this.geometryGroup.matrix); var e = new F; return e.setFromRotationMatrix(A), e } return null }, oy.prototype.getTrackingPointFromBoundingBox = function (A, e) { if (!this.geometryGroup.boundingBox) return null; var t = e.origin, i = this.getBoundingBox(), o = 0, n = [new y, new y, new y, new y, new y, new y, new y, new y]; n[0].set(i.min.x, i.min.y, i.min.z), n[1].set(i.min.x, i.min.y, i.max.z), n[2].set(i.min.x, i.max.y, i.min.z), n[3].set(i.min.x, i.max.y, i.max.z), n[4].set(i.max.x, i.min.y, i.min.z), n[5].set(i.max.x, i.min.y, i.max.z), n[6].set(i.max.x, i.max.y, i.min.z), n[7].set(i.max.x, i.max.y, i.max.z); for (var r = 0; 8 > r; r += 1) { var a = new y; a.subVectors(n[r], t); var s = a.dot(A); s > o && (o = s) } var l = A.clone().multiplyScalar(o), c = t.clone().add(l), h = new EA; return h.setFromNormalAndCoplanarPoint(A, c), e.intersectPlane(h, new y) }, oy.prototype.getNearDepthByRect = function () { var A = new aA, e = 1 / 0, t = new M, i = new y; function o(A) { i.setFromMatrixPosition(A.matrixWorld), i.applyProjection(t); var o = i.z; o >= e || 0 > o || o > 1 || (e = o) } return function (i, n) { function r(e) { if (e instanceof Kf) { if (! function (e, t) { if (!t.boundingBox || t instanceof Ue) { var i = t.geometry; null === i.boundingBox && i.computeBoundingBox(), A.copy(i.boundingBox), A.applyMatrix4(t.matrixWorld) } else A.copy(t.boundingBox), A.applyMatrix4(t.matrixWorld); return e.intersectsBox(A) }(i, e)) return; o(e) } else if (e.worldBoundingBox) { if (!i.intersectsBox(e.worldBoundingBox)) return; o(e) } var t = e.children; if (t) for (var n = 0, a = t.length; a > n; n += 1) { var s = t[n]; s.visible && r(s) } } e = 1 / 0, t.multiplyMatrices(n.projectionMatrix, n.matrixWorldInverse); for (var a = this.geometryGroup.children, s = 0, l = a.length; l > s; s += 1) { var c = a[s]; c.visible && r(c) } return e } }(), oy.prototype.getExpandScalar = function () { return this.expandScalar }, oy.prototype.hasClipPlanes = function () { return null !== this.clipPlanes }, oy.prototype.getClipPlanes = function (A) { var e = this.getBoundingBox(), t = e.getSize(new y), i = e.getCenter(this.tempVector3); return null === this.clipPlanes ? (this.clipPlanes = new HC(t, i), this.objectGroups.add(this.clipPlanes)) : A && this.clipPlanes.setSectionBox(e.min, e.max), this.clipPlanes }, oy.prototype.setClipPlanes = function (A) { if (A) { var e = this.getClipPlanes(); A.setFromCenterAndSize(A.getCenter(new y), A.getSize(new y).multiplyScalar(this.expandScalar)), e.setSectionBox(A.min, A.max) } }, oy.prototype.resetClipPlanes = function () { var A = this.getClipPlanes(), e = this.getBoundingBox(); A.reset(), e.max.x !== -1 / 0 && e.max.y !== -1 / 0 && e.max.z !== -1 / 0 && e.min.x !== 1 / 0 && e.min.y !== 1 / 0 && e.min.z !== 1 / 0 ? (e.setFromCenterAndSize(e.getCenter(new y), e.getSize(new y)), A.setSectionBox(e.min, e.max)) : this.clipPlanes = null }, oy.prototype.hasFillClipPlanes = function () { return null != this.fillClipPlane }, oy.prototype.getFillClipPlane = function () { var A = new aA; A.copy(this.geometryGroup.boundingBox), A.applyMatrix4(this.geometryGroup.matrix); var e = A.getSize(new y); e.multiplyScalar(.05), A.min.sub(e), A.max.add(e); var t = A.getSize(new y), i = A.getCenter(new y); return null === this.fillClipPlane ? (this.fillClipPlane = new _C(t, i), this.objectGroups.add(this.fillClipPlane)) : this.fillClipPlane.cubeSize.equals(t) || this.fillClipPlane.resize(t, i), this.fillClipPlane }, oy.prototype.disableClipPlanes = function () { null != this.clipPlanes && (this.clipPlanes.enable(!1, !1), this.clipPlanes.update()), null != this.fillClipPlane && (this.fillClipPlane.enable(!1, !1), this.fillClipPlane.update()) }, oy.prototype.getAreaNode = function () { return this.areaNode }, oy.prototype.getAxisGridManager = function () { return this.axisGridManager }, oy.prototype.getExtrudeBodyManager = function () { return null === this.extrudeBodyManager && (this.extrudeBodyManager = new ty, this.objectGroups.add(this.extrudeBodyManager), this.extrudeBodyManager.matrix.copy(this.geometryGroup.matrix), this.extrudeBodyManager.matrixAutoUpdate = !1, this.extrudeBodyManager.updateMatrixWorld(!0)), this.extrudeBodyManager }, oy.prototype.getCustomPlaneManager = function () { return this.customPlaneManager }, oy.prototype.getExternalScene = function () { return null === this.externalScene && (this.externalScene = new ey, this.add(this.externalScene), this.externalScene.updateMatrixWorld(!0)), this.externalScene }, oy.prototype.shrinkScopeByClipPlane = function (A, e) { if (this.clipPlanes && this.clipPlanes.isEnabled()) { var t = this.clipPlanes.hitTest(A); if (null === t.distance && void 0 === t.distance) return; t.sign ? t.distance > e.near && (e.near = t.distance) : e.far > t.distance && (e.far = t.distance) } }, oy.prototype.updateWorldMatrixByMatrix = function (A) { for (var e = this.objectGroups.children, t = 0, i = e.length; i > t; t += 1) e[t].globalSpace && (e[t].matrix.copy(A), e[t].matrixAutoUpdate = !1, e[t].updateMatrixWorld(!0)) }, oy.prototype.currentLights = function () { return this.lightManager.currentLights() }, oy.prototype.setLightPreset = function (A) { this.lightManager.setLightPreset(A) }, oy.prototype.getLightPreset = function () { return this.lightManager.getLightPreset() }, oy.prototype.setLightIntensityFactor = function (A) { this.lightManager.setIntensityFactor(A) }, oy.prototype.updateLights = function (A) { this.lightManager.updateLights(A) }, oy.prototype.setAmbientLightIntensity = function (A) { this.lightManager.setAmbientLightIntensity(A) }, oy.prototype.getAmbientLightIntensity = function () { return this.lightManager.getAmbientLightIntensity() }, oy.prototype.getOrCreateGroup = function (A, e) { for (var t = this.objectGroups.children, i = 0, o = t.length; o > i; i += 1) if (t[i].name === A) return t[i]; var n = new ep(A, e); return n.isGlobalSpace() && (n.matrix.copy(this.geometryGroup.matrix), n.matrixAutoUpdate = !1, n.updateMatrixWorld(!0)), this.objectGroups.add(n), n }, oy.prototype.getGroup = function (A) { for (var e = this.objectGroups.children, t = 0, i = e.length; i > t; t += 1) if (e[t].name === A) return e[t]; return null }, oy.prototype.getGroupType = function (A) { var e = A.split("|"); return { groupType: e[0], modelKey: e.length > 1 ? e[1] : void 0 } }, oy.prototype.getGroups = function () { return this.objectGroups.children }, oy.prototype.removeGroup = function (A) { this.objectGroups.remove(A) }, oy.prototype.removeGroupByName = function (A) { this.objectGroups.removeByName(A) }, oy.prototype.hasGroup = function (A) { return this.objectGroups.hasChild(A) }, oy.prototype.prepareScene = function () {}, oy.prototype.parseRootNode = function (A) { var e = this.geometryGroup, t = uh.box3FromObject(A.minBoundary, A.maxBoundary); null === e.boundingBox || e.boundingBox.isEmpty() ? e.boundingBox = t : (e.boundingBox.expandByPoint(t.min), e.boundingBox.expandByPoint(t.max)), e.updateMatrixWorld(!0) }, oy.prototype.intersectToWorld = function (A, e) { var t = this.getMatrixGlobal(); A.worldPosition = Tu.getWorldPositionOfMesh(A.point, t); var i = e.getComponentInfoByUserId(A.userId); i && (A.worldBoundingBox = i.boundingBox.clone()) }, oy.prototype.worldToDrawing = function (A) { var e = this.getMatrixGlobal(), t = new y(A.x, A.y, A.z); return t.applyMatrix4(e), t }, oy.prototype.drawingToWorld = function (A) { var e = this.getMatrixGlobal(), t = new M; t.getInverse(e); var i = new y(A.x, A.y, A.z); return i.applyMatrix4(t), i }, oy.prototype.getBoundingBoxWorldByMesh = function (A) { var e = this.getMatrixGlobal(), t = A.boundingBox; t || (A.geometry.boundingBox || A.geometry.computeBoundingBox(), t = A.geometry.boundingBox); var i = t.clone(); i.applyMatrix4(A.matrixWorld); var o = new M; return o.getInverse(e), i.applyMatrix4(o), i }, oy.prototype.getObjectPool = function () { return this.pool }, oy.prototype.getBoundingBoxOfGeometries = function (A) { var e = new aA, t = []; if (Array.isArray(A)) t = A; else for (var i in A) A.hasOwnProperty(i) && t.push(i); for (var o = 0, n = t.length; n > o; o += 1) { var r = this.objectGroups.getObjectByProperty("key", t[o]); if (r) { var a = r.geometry; if (a) { a.boundingBox || a.computeBoundingBox(); var s = a.boundingBox; if (s) { var l = s.clone(); r.matrixWorld && l.applyMatrix4(r.matrixWorld), e.expandByPoint(l.min), e.expandByPoint(l.max) } } else Bh.log("empty geometry!") } } return e }, oy.prototype.adjustInstanceVisibility = function (A) { this.traverse((function (e) { if ((e instanceof Ue || e instanceof jo) && e.geometry instanceof Na) { var t = e.visible; A && !e.bVisible || (e.visible = A), e.bVisible = t } })) }, oy.prototype.adjustVisibility = function (A) { this.traverse((function (e) { if ((e instanceof Ue || e instanceof jo) && !(e.geometry instanceof Na)) { var t = e.visible; A && !e.bVisible || (e.visible = A), e.bVisible = t } })) }, oy.prototype.changeVisibilityOfSelectedObjects = function (A) { var e = this; A || (e.selectedMeshes.length = 0, e.selectedInstanceMeshes.length = 0); var t = e.selectedMeshes, i = e.selectedInstanceMeshes; this.traverse((function (o) { (o instanceof Ue || o instanceof jo) && (o.geometry instanceof Na ? A ? function (A) { for (var t = 0, i = e.selectedInstanceMeshes.length; i > t; t += 1) { if (A === e.selectedInstanceMeshes[t].object) { for (var o = e.selectedInstanceMeshes[t].indices, n = A.geometry.getAttribute("vState").array, r = 0, a = o.length; a > r; r += 1) n[o[r]] = Hc.SELECTED; A.geometry.getAttribute("vState").needsUpdate = !0 } } }(o) : function (A) { if (A.visible) { for (var e = [], t = A.geometry.getAttribute("vState").array, o = 0; t.length > o; o += 1) t[o] === Hc.SELECTED && (e.push(o), t[o] = Hc.HIDDEN); e.length && (A.geometry.getAttribute("vState").needsUpdate = !0, i.push({ object: A, indices: e })) } }(o) : A ? function (A) { for (var t = 0, i = e.selectedMeshes.length; i > t; t += 1) { if (A === e.selectedMeshes[t].object) for (var o = e.selectedMeshes[t].indices, n = 0, r = o.length; r > n; n += 1) { var a = o[n], s = A.geometry.groups[a.idx]; s.start = a.start, s.count = a.count } } }(o) : function (A) { if (A._indicesGroup && A.visible) { var e = [], i = A.geometry.groups; if (i && i.length) { for (var o = 0, n = i.length; n > o; o += 1) { var r = i[o]; r.materialIndex === zc.SELECTED && (e.push({ idx: o, start: r.start, count: r.count }), r.start = 0, r.count = 0) } e.length && t.push({ object: A, indices: e }) } } }(o)) })) }, oy.prototype.changeVisibilityOfNonSelectedObjects = function (A) { var e = this; A || (e.nonSelectedMeshes.length = 0, e.nonSelectedInstanceMeshes.length = 0); var t = e.nonSelectedMeshes, i = e.nonSelectedInstanceMeshes; this.traverse((function (o) { (o instanceof Ue || o instanceof jo) && (o.geometry instanceof Na ? A ? function (A) { for (var t = 0, i = e.nonSelectedInstanceMeshes.length; i > t; t += 1) { if (A === e.nonSelectedInstanceMeshes[t].object) { for (var o = e.nonSelectedInstanceMeshes[t].indices, n = A.geometry.getAttribute("vState").array, r = 0, a = o.length; a > r; r += 1) n[o[r].idx] = o[r].state; A.geometry.getAttribute("vState").needsUpdate = !0 } } }(o) : function (A) { if (A.visible) { for (var e = [], t = A.geometry.getAttribute("vState").array, o = 0, n = t.length; n > o; o += 1) t[o] !== Hc.SELECTED && t[o] !== Hc.HIDDEN && (e.push({ idx: o, state: t[o] }), t[o] = Hc.HIDDEN); e.length && (A.geometry.getAttribute("vState").needsUpdate = !0, i.push({ object: A, indices: e })) } }(o) : A ? function (A) { for (var t = 0, i = e.nonSelectedMeshes.length; i > t; t += 1) { if (A === e.nonSelectedMeshes[t].object) { var o = e.nonSelectedMeshes[t].indices; if (null === o) A.visible = !0; else for (var n = 0, r = o.length; r > n; n += 1) { var a = o[n], s = A.geometry.groups[a.idx]; s.start = a.start, s.count = a.count } } } }(o) : function (A) { if (A._indicesGroup && A.visible) { var e = [], i = A.geometry.groups; if (i && i.length) { for (var o = 0, n = i.length; n > o; o += 1) { var r = i[o]; r.materialIndex !== zc.SELECTED && (e.push({ idx: o, start: r.start, count: r.count }), r.start = 0, r.count = 0) } e.length ? t.push({ object: A, indices: e }) : (A.visible = !1, t.push({ object: A, indices: null })) } else A.visible = !1, t.push({ object: A, indices: null }) } }(o)) })) }, oy.prototype.clearSelectedAndNonSelectedMeshes = function () { this.selectedMeshes.length = 0, this.nonSelectedMeshes.length = 0, this.selectedInstanceMeshes.length = 0, this.nonSelectedInstanceMeshes.length = 0 }, oy.prototype.setSkyBox = function (A, e, t, i, o) { var n = A, r = e || [Pd.skyBoxLeft, Pd.skyBoxRight, Pd.skyBoxBack, Pd.skyBoxFront, Pd.skyBoxUp, Pd.skyBoxDown], a = this; (new $r).setPath(n).load(r, (function (A) { a.background = A, t && t() }), i, o) }, oy.prototype.drawBoundingBox = function (A) { if (A) { var e = this.getOrCreateGroup("BoundingBox", { pickable: 0, priority: 2 }), t = this.getBoundingBox(); void 0 === this.boudingBoxNode ? (this.boudingBoxNode = new Ay(t, 16711680), e.add(this.boudingBoxNode)) : this.boudingBoxNode.updateBBox(t), this.boudingBoxNode.updateMatrixWorld(!0) } else this.removeGroupByName("BoundingBox") }, oy.prototype.calculateGisMapBox = function (A) { var e = this.getGroup("ExternalComponentManager"), t = this.getBoundingBoxWorld(), i = t.clone(); if (e) { var o = A.position.clone(), n = this.getMatrixWorldGlobal(), r = (new M).getInverse(n); o.applyMatrix4(r); var a = 6370856e3, s = o.z - t.min.z; s = Math.abs(s); var l = a * Math.acos(a / (a + s)); i.min.x = o.x - l, i.max.x = o.x + l, i.min.y = o.y - l, i.max.y = o.y + l, i.min.z = t.min.z, i.max.z = t.max.z } return i }, oy.prototype.getReceivingPlane = function (A) { if (!this.receivingPlane) { this.receivingPlane = this.getOrCreateGroup(gp.RECEIVESHADOWPLANE); var e = new mr; e.transparent = !0, e.opacity = .2, e.side = 2; var t = new Ue(new et(1e6, 1e6), e); t.receiveShadow = !0, this.receivingPlane.add(t), this.add(this.receivingPlane), this.receivingPlane.matrixAutoUpdate = !1, this.updateReceivingPlane() } return this.receivingPlane.visible = A, this.receivingPlane }, oy.prototype.updateReceivingPlane = function () { var A = this.receivingPlane.children[0], e = this.getBoundingBoxWorld(), t = e.getCenter(new y), i = e.getSize(new y); A.position.z = e.min.z - .05 * i.z, A.position.x = t.x, A.position.y = t.y, A.scale.x = i.x / 1e4, A.scale.y = i.y / 1e4, this.receivingPlane.updateMatrixWorld(!0) }, Object.defineProperties(oy.prototype, { lightArray: { get: function () { return Bh.warn("EIMMODEL.Scene: .lightArray 现在为 .lightManager.lightArray"), this.lightManager.lightArray } }, lightHelperArray: { get: function () { return Bh.warn("EIMMODEL.Scene: .lightHelperArray 现在为 .lightManager.lightHelperArray"), this.lightManager.lightHelperArray } } }); var ny = function (A) { this.selectionSet = {}, this.selectionMaterial = Kd.createHighlightMaterial(), this.selectionMaterial.colorState = Yc.SELECT, this.selectionMaterial.name = "selection", this.selectionMaterial.refreshUniforms(), this.hoverId = void 0, this.hoverMaterialDefaultParams = { color: 14540253, opacity: .9, transparent: !0, side: 2 }, this.hoverMaterial = Kd.createStandardMaterial(this.hoverMaterialDefaultParams), this.hoverMaterial.name = "hover", this.boxMaterialDefaultParams = { color: 16776960, opacity: 1, transparent: !1 }, this.boxMaterial = new ko(this.boxMaterialDefaultParams), this.boxMaterial.name = "box", this.modelManager = A, this.blinkComponentIds = {}; var e = this; this.filter = A.filter, this.filter.observerForSceneState = function (t) { e.removeSelection(t), e.clearBlinkComponentsById(t), A.viewerImpl.render() }, this.phongHoverMaterial = new Ir(this.hoverMaterialDefaultParams), this.phongSelectionMaterial = new Ir(vc.SelectionColor) }; ny.prototype = { constructor: ny, destroy: function () { this.selectionSet = null, this.blinkComponentIds = null, this.modelManager = null, this.selectionMaterial.destroy(), this.selectionMaterial = null, this.hoverMaterial.destroy(), this.hoverMaterial = null, this.phongHoverMaterial.dispose(), this.phongHoverMaterial = null, this.phongSelectionMaterial.dispose(), this.phongSelectionMaterial = null }, _dispatchChangeEvent: function () { var A = this.getSelection(); if (vc.EnableSelectionBoundingBox) { var e = this.modelManager.scene.getOrCreateGroup("BoundingBox"); if (A && A.length > 0) { var t = this.modelManager.viewerImpl.getBoundingBoxByIds(A); if (t.isEmpty()) return void(e.visible = !1); e.visible = !0; var i = e.getObjectByName("Box"); if (!i) { var o = new Uint16Array([0, 1, 1, 2, 2, 3, 3, 0, 4, 5, 5, 6, 6, 7, 7, 4, 0, 4, 1, 5, 2, 6, 3, 7]), n = new Float32Array(24), r = new he; r.setIndex(new YA(o, 1)), r.setAttribute("position", new YA(n, 3)), (i = new jo(r, this.boxMaterial)).name = "Box", i.matrixAutoUpdate = !1, e.add(i) } var a = i.geometry.attributes.position, s = a.array, l = t.min, c = t.max; s[0] = c.x, s[1] = c.y, s[2] = c.z, s[3] = l.x, s[4] = c.y, s[5] = c.z, s[6] = l.x, s[7] = l.y, s[8] = c.z, s[9] = c.x, s[10] = l.y, s[11] = c.z, s[12] = c.x, s[13] = c.y, s[14] = l.z, s[15] = l.x, s[16] = c.y, s[17] = l.z, s[18] = l.x, s[19] = l.y, s[20] = l.z, s[21] = c.x, s[22] = l.y, s[23] = l.z, a.needsUpdate = !0 } else e.visible = !1 } else { var h = this.modelManager.scene.getObjectByName("BoundingBox"); h && (h.visible = !1) } // debugger; this.modelManager.dispatchEvent({ type: Rc.ON_SELECTION_CHANGED, selectionList: A }) }, clearSelection: function (A) { var e, t = !1; if (void 0 === A) { var i = []; for (var o in this.selectionSet) { for (var n in t = !1, e = this.getSelectionSet(o)) if (e.hasOwnProperty(n)) { t = !0; break } t && i.push(o) } if (i.length) { for (var r = 0, a = i.length; a > r; r += 1) this.selectionSet[i[r]] = {}, this.modelManager.clearSelection(i[r]); this._dispatchChangeEvent() } } else { for (var n in e = this.getSelectionSet(A)) if (e.hasOwnProperty(n)) { t = !0; break } t && (this.selectionSet[A] = {}, this.modelManager.clearSelection(A), this._dispatchChangeEvent()) } }, addSelection: function (A, e) { console.log('addSelection1111111111111111'); if (A && A.length >= 1) { var t, i = [], o = !1, n = this.modelManager, r = this.filter; if (void 0 === e) { console.log('addSelection if'); for (var a = {}, s = n.getModelKeys(), l = [], c = 0, h = s.length; h > c; c += 1) { // console.log('addSelection22222222222222222222'); var d = s[c]; // debugger; t = this.getSelectionSet(d), o = !1; for (var p = A.length - 1; p >= 0; p -= 1) { // console.log('n.isUserIdExist(f = A[p], d) :>> ', n.isUserIdExist(f = A[p], d)); // console.log('r.isComponentActive(f, d) :>> ', r.isComponentActive(f, d)); n.isUserIdExist(f = A[p], d) && (!t[f] && r.isComponentActive(f, d) && (t[f] = !0, o = !0), a[f] = !0) } // console.log('d :>> ', d); o && l.push(d) } // for (p = A.length - 1; p >= 0; p -= 1) { // a[f = A[p]] || i.push(f) // } // if (i.length > 0 && n.dispatchEvent({ // type: Rc.ON_SELECTION_FAILED, // failedId: i // }), // l.length) { // for (var g = 0, u = l.length; u > g; g += 1) // this.modelManager.applySelection(l[g]); // // debugger; // this._dispatchChangeEvent() // } // debugger; } else { console.log('addSelection else'); t = this.getSelectionSet(e); for (p = A.length - 1; p >= 0; p -= 1) { var f; n.isUserIdExist(f = A[p], e) ? !t[f] && r.isComponentActive(f, e) && (t[f] = !0, o = !0) : i.push(f) } i.length > 0 && n.dispatchEvent({ type: Rc.ON_SELECTION_FAILED, failedId: i }), o && (this.modelManager.applySelection(e), this._dispatchChangeEvent()) } } }, setSelection: function (A, e) { if (A && A.length >= 1){ // debugger; if (void 0 === e) { console.log('setSelection if') for (var t in this.selectionSet) delete this.selectionSet[t]; // debugger; this.addSelection(A) } else console.log('setSelection else') this.selectionSet[e] = {}, this.addSelection(A, e) } }, removeSelection: function (A, e) { console.log('removeSelection'); if (A && A.length >= 1) { var t = !1; if (void 0 === e) { var i = []; for (var o in this.selectionSet) { var n = this.getSelectionSet(o); t = !1; for (var r = 0, a = A.length; a > r; r += 1) { var s = A[r]; n[s] && (delete n[s], t = !0) } t && i.push(o) } if (i.length) { for (var l = 0, c = i.length; c > l; l += 1) this.modelManager.applySelection(i[l]); this._dispatchChangeEvent() } } else { for (var h = this.getSelectionSet(e), d = 0, p = A.length; p > d; d += 1) { var g = A[d]; h[g] && (delete h[g], t = !0) } t && (this.modelManager.applySelection(e), this._dispatchChangeEvent()) } } }, getSelection: function (A) { var e = {}; if (void 0 === A) for (var t in this.selectionSet) for (var i = this.getSelectionSet(t), o = Object.keys(i), n = 0, r = o.length; r > n; n += 1) e[o[n]] = !0; else e = this.getSelectionSet(t); return Object.keys(e) }, hasSelection: function (A) { var e, t = !1; if (void 0 === A) for (var i in this.selectionSet) { for (var o in e = this.getSelectionSet(i)) if (e.hasOwnProperty[o]) { t = !0; break } if (t) break } else for (var o in e = this.getSelection(A)) if (e.hasOwnProperty[o]) { t = !0; break } return t }, getSelectionSet: function (A) { if (void 0 === A) { var e = {}; for (var t in this.selectionSet) for (var i = this.getSelectionSet(t), o = Object.keys(i), n = 0, r = o.length; r > n; n += 1) e[o[n]] = !0; return e } return void 0 === this.selectionSet[A] && (this.selectionSet[A] = {}), this.selectionSet[A] }, isSelected: function (A, e) { var t, i = !1; if (void 0 === e) { for (var o in this.selectionSet) if ((t = this.selectionSet[o]) && t[A]) { i = !0; break } } else (t = this.selectionSet[e]) && t[A] && (i = !0); return i }, setHoverId: function (A, e) { this.hoverId = A, this.modelManager.applyHover(e) }, clearHover: function (A) { this.hoverId = void 0, this.modelManager.clearHover(A) }, getHoverMaterial: function (A) { var e = A && A.isMeshPhongMaterial ? this.phongHoverMaterial.clone() : this.hoverMaterial.clone(); if (A && A.hasOwnProperty("color")) { var t = A.color.clone(), i = Math.max(t.r, Math.max(t.g, t.b)); 0 === i && (i = .5), t.r += 0 === t.r ? .3 * i : .2 * t.r, t.g += 0 === t.g ? .3 * i : .2 * t.g, t.b += 0 === t.b ? .3 * i : .2 * t.b, t.r > 1 && (t.r = 1), t.g > 1 && (t.g = 1), t.b > 1 && (t.b = 1), 1 === t.r && 1 === t.g && 1 === t.b && (t.r = .87, t.g = .87, t.b = .87), e.color.setHex(t.getHex()), e.opacity = void 0 !== A.opacity ? A.opacity : this.hoverMaterialDefaultParams.opacity, e.transparent = void 0 !== A.transparent ? A.transparent : this.hoverMaterialDefaultParams.transparent, e.side = void 0 !== A.side ? A.side : this.hoverMaterialDefaultParams.side, void 0 !== A.metalness && (e.metalness = A.metalness), void 0 !== A.roughness && (e.roughness = A.roughness), void 0 !== A.bumpMap && (e.bumpMap = A.bumpMap), void 0 !== A.alphaMap && (e.alphaMap = A.alphaMap), void 0 !== A.emissiveMap && (e.emissiveMap = A.emissiveMap), void 0 !== A.envMap && (e.envMap = A.envMap), void 0 !== A.envMapIntensity && (e.envMapIntensity = A.envMapIntensity), null != A.map && (e.map = A.map), e.opacity = Kd.getHoverOpacity(e.opacity), e.transparent = !0, e.needsUpdate = !0 } return e }, getHoverColorByMaterial: function (A) { var e = void 0 !== A.opacity ? A.opacity : this.hoverMaterialDefaultParams.opacity; if (e = Kd.getHoverOpacity(e), !A.hasOwnProperty("color")) return { rgbaColor: [this.hoverMaterial.color.r, this.hoverMaterial.color.g, this.hoverMaterial.color.b, e], transparent: !0 }; var t = A.color.clone(); return { rgbaColor: [t.r, t.g, t.b, e], transparent: !0 } }, setSelectionColor: function (A, e) { console.log('setSelectionColor'); var t = this.selectionMaterial.opacity; e = void 0 === e ? t : e, "0x" + this.selectionMaterial.color.getHexString() === A && t === e || (this.selectionMaterial.color.setHex(A), e && (this.selectionMaterial.opacity = e), this.selectionMaterial.needsUpdate = !0) }, getSelectionColor: function () { var A = this.selectionMaterial.opacity; return new Xh(this.selectionMaterial.color.getHex(), A) }, getSelectionMaterial: function () { return this.selectionMaterial.clone() }, setBlinkComponentsById: function (A, e) { if (this.blinkComponentIds = {}, A && 0 !== A.length) { for (var t = A.length - 1; t >= 0; t -= 1) { this.filter.isComponentActive(A[t], e) && (this.blinkComponentIds[A[t]] = !0) } this.modelManager.applyBlink() } }, addBlinkComponentsById: function (A, e) { if (A && A.length) { for (var t = this.blinkComponentIds, i = !1, o = A.length - 1; o >= 0; o -= 1) { var n = A[o]; !t[n] && this.filter.isComponentActive(n) && (t[n] = !0, i = !0) } i && this.modelManager.applyBlink() } }, clearBlinkComponentsById: function (A, e) { if (A && A.length) { for (var t = !1, i = this.blinkComponentIds, o = 0, n = A.length; n > o; o += 1) { var r = A[o]; i[r] && (delete i[r], t = !0) } t && this.modelManager.applyBlink() } }, clearAllBlinkComponents: function () { var A = !1; uh.isOwnEmptyObject(this.blinkComponentIds) || (A = !0, this.blinkComponentIds = {}), A && this.modelManager.clearBlink() }, getBlinkComponents: function () { return Object.keys(this.blinkComponentIds) }, getBlinkComponentsIdMap: function (A) { var e = this; if (this.modelManager.getBlinkEnabled()) { if (A) { var t = this.getBlinkComponents(), i = {}; return t.forEach((function (t) { var o = e.modelManager.filterHelper.distributeId(t), n = o.modelKey, r = o.objectId; n && n.toString() !== A.toString() || (i[r] = e.blinkComponentIds[t]) })), i } return this.blinkComponentIds } return null }, getBlinkMaterial: function (A) { return Kd.getBlinkMaterial(A, this.modelManager.getBlinkColor()) }, getBoxMaterial: function () { return this.boxMaterial.clone() }, setBoxColor: function (A, e) { var t = this.boxMaterial.opacity; e = void 0 === e ? t : e, "0x" + this.boxMaterial.color.getHexString() === A && t === e || (this.boxMaterial.color.setHex(A), e && (this.boxMaterial.opacity = e), this.boxMaterial.needsUpdate = !0, this.boxMaterial.color.setHex(A), this.boxMaterial.needsUpdate = !0) } }; var ry = function () { this.hiddenUserIdMap = {} }; ry.prototype.destroy = function () { this.hiddenUserIdMap = null }, ry.prototype.hideByUserId = function (A, e) { this.hiddenUserIdMap || (this.hiddenUserIdMap = {}), this.hiddenUserIdMap[A] = !!e }, ry.prototype.cancelHiddenByUserId = function (A) { this.hiddenUserIdMap && delete this.hiddenUserIdMap[A] }, ry.prototype.cancelAllHidden = function () { this.hiddenUserIdMap = null }, ry.prototype.isHidden = function (A) { return !!this.hiddenUserIdMap[A] }, ry.prototype.hasHidden = function () { return !uh.isEmptyObject(this.hiddenUserIdMap) }; var ay = function () { this.materialDefaultParams = { color: 14540253, opacity: .5, transparent: !0, side: 0 }, this.material = Kd.createPhongMaterial(this.materialDefaultParams) }; ay.prototype.destroy = function () { this.material = null }, ay.prototype.resetColor = function () { this.material.color.setHex(this.materialDefaultParams.color) }, ay.prototype.resetOpacity = function () { this.material.opacity = this.materialDefaultParams.opacity }, ay.prototype.reset = function () { this.material.color.setHex(this.materialDefaultParams.color), this.material.opacity = this.materialDefaultParams.opacity, this.material.transparent = this.materialDefaultParams.transparent, this.material.side = this.materialDefaultParams.side, this.material.needsUpdate = !0 }; var sy = function (A) { this.manager = A, this.requestCount = 0, this.maxRequestCount = 1e5, this.loading = !1, this.delayIntervalTime = 300 }; sy.prototype.destroy = function () { this.manager = null, this.currentConditions = null, this.delayLoadTimer && (clearTimeout(this.delayLoadTimer), this.delayLoadTimer = null) }, sy.prototype.isValidModel = function (A) { return !(A.isEmptyScene() || !A.isLayerData()) }, sy.prototype.loadGeopkOnDemandByConditionsWithDelay = function (A, e, t, i) { var o = this, n = this.delayIntervalTime; o.delayLoadTimer && clearTimeout(o.delayLoadTimer), o.delayLoadTimer = setTimeout((function () { o.loadGeopkOnDemandByConditions(A, e, t, i) }), n) }, sy.prototype.loadGeopkOnDemandByConditions = function (A, e, t, i) { if (this.currentConditions = A, this.requestCount += 1, this.requestCount > this.maxRequestCount && (this.requestCount = 0), !this.loading) { this.loading = !0; var o = this; requestAnimationFrame(function A(n) { var r = n, a = o.currentConditions; return function () { o._loadGeopkOnDemandByConditions(a, e, t, (function () { r !== o.requestCount ? requestAnimationFrame(A(o.requestCount)) : (o.loading = !1, i && i(a), a = null) })) } }(this.requestCount)) } }, sy.prototype._loadGeopkOnDemandByConditions = function (A, e, t, i) { var o = this; this.manager.traverseModels((function (n) { o.isValidModel(n) && n._getHandler().loadGeopkOnDemand(A, e, t, i) })) }, sy.prototype.getBoundingBoxOnDemand = function () { var A = new aA, e = this; return this.manager.traverseModels((function (t) { if (e.isValidModel(t)) { var i = t._getHandler().getLayerProvider().getUnionBoundingBoxOnDemand(); i && A.union(i) } })), A.isEmpty() ? null : A }, sy.prototype.isLoading = function () { return this.loading }, sy.prototype.getBoundingBoxForUsedComponent = function () { var A = this.manager, e = new aA; return A.traverseModels((function (t) { var i = t.getLoadedUserIdsObject(); i && e.union(A.getBoundingBoxByIds(i)) })), e.isEmpty() ? null : e }; var ly = function (A, e) { vc.UseWorker && mh.isSupportWorker() && (this.websocketWorker = new Worker("src/worker/WebsocketWorker.js"), this.prepareDataWorkers = new Worker("src/worker/PrepareDataWorker.js")), mh.isMobileDevice() && (vc.maxObjectNumInPool = 6e3, vc.maxDrawCacheNum = 4e3), this.scene = new oy(this), this.filter = A, this.crossOrigin = !0, this.models = {}, this.viewerImpl = e, this.materialPool = null, this.occlusionCamera = null, this.containsCamera = !1, this.highPriorityCategories = { inner: {}, outer: {} }, this.octantToObjectMap = {}, this.instanceGeometries = {}, this.sceneState = new ny(this), this.modelState = new ny(this), this.filter.setSceneStateHelper(this.sceneState), this.rotation = new f, this.boundingBox = new aA, this.explosionList = {}, this.IBLMaterial = !1, this.clippingCaps = !1, this.blinkStartTime = null, this.blinkEnabled = !1, this.blinkIntervalTime = 600, this.blinkPermited = !1, this.defaultBlinkColor = (new LA).setHex(3330982), this.defaultBlinkAlpha = 1, this.blinkColor = new p(this.defaultBlinkColor.r, this.defaultBlinkColor.g, this.defaultBlinkColor.b, this.defaultBlinkAlpha), this.selectPriority = !0, this.materialOverrideSet = null, this.plugins = [], this.cameraFov = 0, this.cameraPosition = new y, this.domElementWidth = 1, this.transformComponent = {} }; Object.assign(ly.prototype, Ld.prototype), ly.prototype.destroy = function () { for (var A in this.removeAllEventListener(), this.models) this.models[A].destroy(); this.models = null, this.octantToObjectMap = null, this.materialPool && (this.materialPool.destroy(), this.materialPool = null), this.occlusionCamera && (this.occlusionCamera = null); for (var e = 0, t = this.plugins.length; t > e; e += 1) this.plugins[e].destroy(); this.plugins = null, this.loadOnDemandDirector && (this.loadOnDemandDirector.destroy(), this.loadOnDemandDirector = null), this.highPriorityCategories = null, this.rotation = null, this.boundingBox = null, this.scene.destroy(), this.scene = null, this.filter = null, this.sceneState.destroy(), this.sceneState = null, this.modelState.destroy(), this.modelState = null, this.blinkStartTime = null, this.defaultBlinkColor = null, this.blinkColor = null, this.floorExplosionList = null, this.explosionTranslation = null }, ly.prototype.registerPlugin = function (A) { this.plugins.push(A) }, ly.prototype.removeAllEventListener = function () { this._listeners = void 0 }, ly.prototype.prepareCapScene = function () { this.capsScene ? this.clippingCaps || (this.initCapPlane(), this.initCapBox()) : (this.capsScene = new oy, this.clippingCaps || (this.initCapPlane(), this.initCapBox()), this.scene.createCapStencilMaterials()) }, ly.prototype.initCapPlane = function () { var A = this.scene.getFillClipPlane().initCapsPlane(); this.capsScene.add(A.planeMesh), this.capsScene.add(A.lineMesh), this.clippingCaps = !0 }, ly.prototype.initCapBox = function () { var A = this.scene.getClipPlanes().initCapsBox(); A.material.needsUpdate = !0, A.visible = !0, this.capsScene.add(A), this.clippingCaps = !0 }, ly.prototype.getAllComponents = function () { return this.scene.pool._pool }, ly.prototype.getAllComponentsKey = function () { var A = []; for (var e in this.models) if (this.models.hasOwnProperty(e)) { var t = this.models[e]; if (t) { var i = t.getComponentlist(); A = A.concat(i) } } return A }, ly.prototype.getComponentsKeyByModelKey = function (A) { var e = []; if (this.models.hasOwnProperty(A)) { var t = this.models[A]; if (t) e = t.getComponentlist() } return e }, ly.prototype.getComponent = function (A) { for (var e in this.models) if (this.models.hasOwnProperty(e)) { var t = this.models[e]; if (t.isLoaded() && t.getComponentInfo(A)) { var i = t.getComponentInfo(A); if (i) return i } } for (var o = 0, n = this.plugins.length; n > o; o += 1) if (this.plugins[o].getNodeInfosByUserId) { var r = this.plugins[o].getNodeInfosByUserId(A); if (r) return r } }, ly.prototype.getStorage = function () { return this.storage }, ly.prototype.updateTransformComponentList = function (A) { this.transformComponent[A] = !0 }, ly.prototype._updateOcclusionCamera = function (A) { var e = A.near, t = A.distanceFromWorldToDrawing(this.getMatrixWorldGlobal(), vc.OcclusionDistanceToCamera); this.occlusionCamera ? this.occlusionCamera.copy(A) : this.occlusionCamera = A.clone(), this.occlusionCamera.setNearFar(e, t), this.occlusionCamera.updateMVP() }, ly.prototype._clearMaterialPool = function () { this.materialPool && this.materialPool.clear() }, ly.prototype.acquireMaterial = function () { return this.materialPool ? this.materialPool.acquire() : null }, ly.prototype.getObjectPool = function () { return this.scene.getObjectPool() }, ly.prototype.getFrustumFromOcclusionCamera = function () { return this.occlusionCamera.getFrustum(!1) }, ly.prototype.getOcclusionCamera = function () { return this.occlusionCamera }, ly.prototype.prepareScene = function (A, e) { var t = this.models; for (var i in vc.MergeComponent || (this.clearPool(), this.clearObjectRangeFromOctantMap()), vc.OcclusionTranslucentEnabled && (null === this.materialPool && (this.materialPool = new qC, this.materialPool.init(ay, 50)), this._clearMaterialPool(), this._updateOcclusionCamera(A)), t) if (t.hasOwnProperty(i)) { var o = t[i]; !vc.RendererWhenLoad && !o.isLoaded() || o.isEmptyScene() || o.prepare(A, e) } this.dealStateChanged() }, ly.prototype.clearPool = function () { this.scene.getObjectPool().clear() }, ly.prototype.clearObjectRangeFromOctantMap = function () { this.octantToObjectMap && this.octantToObjectMap.pool && (this.octantToObjectMap.pool = {}) }, ly.prototype.setDrawableModel = function (A) { this.isDrawableModel = A }, ly.prototype.isDrawable = function () { return this.isDrawableModel }, ly.prototype.load = function (A, e, t) { var i = this.models, o = i[A.modelKey], n = this; if (this.setDrawableModel(!1), void 0 !== o) return this.setDrawableModel(!0), o.isVisible() || (o.setVisible(!0), o.dispatchEventEx({ type: Rc.ON_LOAD_COMPLETE })), o; var r = []; for (var a in i) i.hasOwnProperty(a) && r.push(i[a].index); r.sort(); for (var s = 0; r.length > s && r[s] === s; s += 1) ; return o = new("GIS" === A.type ? PC : TC)(this, A, (function (e, t) { if (vc.UseWorker) { if (n.websocketWorker && n.prepareDataWorkers) { var i = JSON.parse(window.localStorage.getItem("bos_IndexedDB")); i || (i = { version: 1 }), window.localStorage.setItem("bos_IndexedDB", JSON.stringify(i)); var r = i.version; n.websocketWorker.postMessage({ type: "INITIALIZE_DATABASE", data: { modelKey: o.modelKey, dbName: o.projectKey, version: r } }), n.websocketWorker.onmessage = o.onWSWorkerMessage, n.prepareDataWorkers.postMessage({ type: "INITIALIZE_DATABASE", data: { modelKey: o.modelKey, dbName: o.projectKey, version: r } }), n.prepareDataWorkers.onmessage = o.onPDWorkerMessage } } else e.load(A.notifyProgress) }), t), this.filter.addModel(o.modelKey), this.models[A.modelKey] = o, o }, ly.prototype.loadTiles = function (A, e, t) { var i = this.models, o = i[A.modelKey], n = this; if (void 0 !== o) return o.isVisible() || (o.setVisible(!0), o.dispatchEventEx({ type: Rc.ON_LOAD_COMPLETE })), o; var r = []; for (var a in i) i.hasOwnProperty(a) && r.push(i[a].index); r.sort(); for (var s = 0; r.length > s && r[s] === s; s += 1) ; return o = new PC(this, A, (function (e, t) { if (vc.UseWorker) { if (n.websocketWorker && n.prepareDataWorkers) { var i = JSON.parse(window.localStorage.getItem("bos_IndexedDB")); i || (i = { version: 1 }), window.localStorage.setItem("bos_IndexedDB", JSON.stringify(i)); var r = i.version; n.websocketWorker.postMessage({ type: "INITIALIZE_DATABASE", data: { modelKey: o.modelKey, dbName: o.projectKey, version: r } }), n.websocketWorker.onmessage = o.onWSWorkerMessage, n.prepareDataWorkers.postMessage({ type: "INITIALIZE_DATABASE", data: { modelKey: o.modelKey, dbName: o.projectKey, version: r } }), n.prepareDataWorkers.onmessage = o.onPDWorkerMessage } } else e.load(A.notifyProgress) }), t), this.models[A.modelKey] = o, o }, ly.prototype.loadModels = function (A) { var e = this.models[A.modelKey], t = this; return void 0 !== e ? (e.isVisible() || (e.setVisible(!0), e.dispatchEventEx({ type: Rc.ON_LOAD_COMPLETE })), e) : (e = new TC(this, A, (function () { if (vc.UseWorker) { if (t.websocketWorker && t.prepareDataWorkers) { var i = JSON.parse(window.localStorage.getItem("bos_IndexedDB")); i || (i = { version: 1 }), window.localStorage.setItem("bos_IndexedDB", JSON.stringify(i)); var o = i.version; t.websocketWorker.postMessage({ type: "INITIALIZE_DATABASE", data: { modelKey: e.modelKey, dbName: e.projectKey, version: o } }), t.websocketWorker.onmessage = e.onWSWorkerMessage, t.prepareDataWorkers.postMessage({ type: "INITIALIZE_DATABASE", data: { modelKey: e.modelKey, dbName: e.projectKey, version: o } }), t.prepareDataWorkers.onmessage = e.onPDWorkerMessage } } else e.load(A.notifyProgress) })), this.models[A.modelKey] = e, e) }, ly.prototype.unload = function (A) { var e = this.models[A]; return !!e && (e.destroy(), delete this.models[A], this.filter.removeModel(A), this.filter.reinitFilterManager(this.getNodeInfos()), this.updateScene(), this.updateFilterManager(), this.filter.getObjectInfoManager().calculateVisibleComponentsBbox(), !0) }, ly.prototype.unloadAll = function () { for (var A = this.getModelKeys(), e = 0, t = A.length; t > e; e += 1) this.unload(A[e]); this.clearPool(), this.models = {} }, ly.prototype.showModel = function (A) { var e = this.models[A]; return !!e && (e.setVisible(!0), !0) }, ly.prototype.hideModel = function (A) { var e = this.models[A]; return !!e && (e.setVisible(!1), !0) }, ly.prototype.getModelKeys = function () { var A = this.models, e = []; for (var t in A) A.hasOwnProperty(t) && e.push(t); return e }, ly.prototype.updateScene = function () { this.updateSceneBoundingBox() }, ly.prototype.updateSceneBoundingBox = function () { var A = this.models, e = this.boundingBox; for (var t in e.makeEmpty(), A) if (A.hasOwnProperty(t)) { var i = A[t]; if (!i.isEmptyScene()) { var o = i.getBoundingBoxWorld(); if (!o || o.isEmpty()) continue; e.isEmpty() ? e.copy(o) : (e.expandByPoint(o.min), e.expandByPoint(o.max)) } } for (var n = 0, r = this.plugins.length; r > n; n += 1) { var a = this.plugins[n]; if ("function" == typeof a.getBoundingBoxWorld) { var s = a.getBoundingBoxWorld(); s && e.union(s) } } this.scene.setBoundingBoxWorld(e) }, ly.prototype.parseSceneRootNode = function (A) { this.scene.parseRootNode(A), this.updateSceneBoundingBox() }, ly.prototype.updateSceneRootMatrix = function () { var A = !1, e = new M, t = new M, i = new f, o = this.models; for (var n in this.models) if (o.hasOwnProperty(n)) { var r = o[n]; if (!r.isEmptyScene()) { i.copy(r.getTransforms().rotation), e.copy(r.getTransforms().transformMatrix), A = r.getTransforms().transformed; break } } if (this.scene.setTransformMatrixGlobal(e), A) t.copy(e); else { var a = new y(1, 1, 1), s = vc.SceneSize, l = this.boundingBox.getSize(new y), c = Math.max(l.x, l.y, l.z); a.multiplyScalar(s / c), t.makeRotationFromQuaternion(i), t.scale(a) } this.scene.updateWorldMatrixByMatrix(t) }, ly.prototype.updateSceneRenderable = function () { var A = this.models, e = vc.maxObjectNumInPool, t = [], i = 0; for (var o in A) { if (A.hasOwnProperty(o)) (a = A[o]).isEmptyScene() || (i += a.model.getStatistics().renderableTotalForPool, t.push(o)) } for (var n = 0, r = t.length; r > n; n += 1) { var a = A[o = t[n]], s = Math.floor(a.getStatistics().renderableTotalForPool / i * e); s > a.getStatistics().renderableTotalForPool && (s = a.getStatistics().renderableTotalForPool), a.setRenderableCount(s) } }, ly.prototype.updateOctreeNode = function () { var A = this.models; for (var e in this.models) if (A.hasOwnProperty(e)) { var t = A[e]; t.isLoaded() && !t.isEmptyScene() && t.updateOctreeNode(!0) } }, ly.prototype.updateMaterials = function () { var A = this.models; for (var e in this.models) if (A.hasOwnProperty(e)) { var t = A[e]; t.isLoaded() && !t.isEmptyScene() && t.materialManager.updateMaterials(t) } }, ly.prototype.updateMaterialsValue = function (A, e) { var t = this.models; for (var i in this.models) if (t.hasOwnProperty(i)) { var o = t[i]; o.isLoaded() && !o.isEmptyScene() && o.materialManager.updateMaterialsValue(o, A, e) } this.materialOverrideSet && this.materialOverrideSet.updateMaterialsValue(A, e) }, ly.prototype.enableColorWithoutLight = function (A) { var e = this.models; for (var t in this.models) if (e.hasOwnProperty(t)) { var i = e[t]; i.isLoaded() && i.isEmptyScene() } }, ly.prototype.switchNewStyleMaterial = function (A) { var e = this.models; for (var t in this.models) if (e.hasOwnProperty(t)) { var i = e[t]; i.isLoaded() && !i.isEmptyScene() && i.materialManager.switchNewStyleMaterial(i, A) } }, ly.prototype.changeAllMaterials = function (A) { if (this.IBLMaterial !== A) { var e = this.models; for (var t in this.models) if (e.hasOwnProperty(t)) { var i = e[t]; i.isEmptyScene() || i.materialManager.changeAllMaterials(i, A) } this.IBLMaterial = A } }, ly.prototype.setCrossOrigin = function (A) { this.crossOrigin = A }, ly.prototype.getMatrixWorldGlobal = function () { return this.scene.getMatrixWorldGlobal() }, ly.prototype.hasModel = function () { var A = this.models; for (var e in A) { if (A.hasOwnProperty(e)) if (A[e].isLoaded()) return !0 } return !1 }, ly.prototype.isEmpty = function () { if (this.hasModel()) return !1; for (var A = !1, e = 0, t = this.plugins.length; t > e; e += 1) { var i = this.plugins[e]; if ("function" == typeof i.isEmpty && !i.isEmpty()) { A = !0; break } } return !A }, ly.prototype.hasModelDataReady = function () { var A = this.models, e = !1; for (var t in A) { if (A.hasOwnProperty(t)) if (e = !0, !A[t].isDataReady()) return !1 } return e }, ly.prototype.isLayerData = function () { var A = this.models; for (var e in A) { if (A.hasOwnProperty(e)) if (A[e].isLayerData()) return !0 } return !1 }, ly.prototype.getModel = function (A) { var e = this.models[A]; return e || null }, ly.prototype.getFirstModel = function () { var A = Object.keys(this.models)[0]; return this.models[A] }, ly.prototype.showOctreeBox = function (A) { vc.ShowOctant || this.scene.removeGroupByName(gp.OCTREENODE) }, ly.prototype.setCategoriesToHighPriority = function (A, e) { var t = A.length; if (t >= 1) for (var i = this.highPriorityCategories[e] = {}, o = 0; t > o; o += 1) i[A[o]] = !0 }, ly.prototype.getCategoriesFromHighPriority = function (A) { return this.highPriorityCategories[A] }, ly.prototype.clearCategoriesFromHighPriority = function (A) { this.highPriorityCategories[A] = {} }, ly.prototype.clearAllCategoriesFromHighPriority = function () { this.clearCategoriesFromHighPriority("inner"), this.clearCategoriesFromHighPriority("outer") }, ly.prototype.calculateCameraModelRelation = function (A) { var e = !1, t = this.models; for (var i in t) if (t.hasOwnProperty(i)) { var o = t[i]; o && o.isLoaded() && !o.isEmptyScene() && (o.calculateCameraModelRelation(A), e = e || o.containsCamera) } this.containsCamera = e }, ly.prototype.getCameraNameList = function () { var A = this.models, e = []; for (var t in A) if (A.hasOwnProperty(t)) { var i = A[t]; i.isEmptyScene() || (e = e.concat(i.getCameraNameList())) } return e }, ly.prototype.getCamera = function (A) { var e = this.models, t = null; for (var i in e) if (e.hasOwnProperty(i)) { var o = e[i]; if (!o.isEmptyScene() && (t = o.getCamera(A))) break } return t }, ly.prototype.getNumOfElements = function () { var A = this.models, e = 0; for (var t in this.models) if (A.hasOwnProperty(t)) { var i = A[t]; i.isEmptyScene() || (e += i.getStatistics().numOfElements) } return e }, ly.prototype.getNumOfRenderables = function () { var A = this.models, e = 0; for (var t in this.models) if (A.hasOwnProperty(t)) { var i = A[t]; i.isEmptyScene() || (e += i.getStatistics().renderableTotal) } return e }, ly.prototype.getNumOfTriangles = function () { var A = this.models, e = 0; for (var t in this.models) if (A.hasOwnProperty(t)) { var i = A[t]; i.isEmptyScene() || (e += i.getStatistics().numOfTriangles) } return e }, ly.prototype.getScene = function () { return this.scene }, ly.prototype.getOctreeRoots = function () { var A = this.models, e = {}; for (var t in A) if (A.hasOwnProperty(t)) { var i = A[t]; if (i.isLoaded() && !i.isEmptyScene()) { var o = i.getEncodedDatabagId(); e[o] = [], i.getModelDescriptor().getOctreeRoots(e[o]) } } return e }, ly.prototype.getModelSnapshotPhoto = function () { return this.viewerImpl.render(), { imgURL: this.viewerImpl.getRenderer().domElement.toDataURL("image/png"), height: this.viewerImpl.domElement.offsetHeight, width: this.viewerImpl.domElement.offsetWidth } }, ly.prototype.addMeshToOctantMap = function (A, e, t) { var i = this.octantToObjectMap; i[A] || (i[A] = {}), i[A].mesh || (i[A].mesh = {}), i[A].mesh[e] || (i[A].mesh[e] = []), i[A].mesh[e].push(t) }, ly.prototype.addNodeInfoToOctantMap = function (A, e, t) { var i = this.octantToObjectMap; i[A] || (i[A] = {}), i[A].info || (i[A].info = {}), i[A].info[e] || (i[A].info[e] = []), i[A].info[e].push(t) }, ly.prototype.removeNodeInfoFromOctantMap = function (A, e) { var t = this.octantToObjectMap; if (t[A] && t[A].info && t[A].info[e.componentKey]) for (var i = t[A].info[e.componentKey], o = i.length - 1; o >= 0; o -= 1) if (e.nodeId === i[o].nodeId) { i.splice(o); break } }, ly.prototype.clearNodeInfosFromOctantMap = function (A) { var e = this.octantToObjectMap; e[A] && e[A].info && (e[A] = null) }, ly.prototype.removeAllFromOctantMap = function (A) { var e = this.octantToObjectMap; e[A] && delete e[A] }, ly.prototype.clearMeshFromOctantMap = function (A) { var e = this.octantToObjectMap; e[A] && e[A].mesh && delete e[A].mesh }, ly.prototype.removeMeshFromOctantMap = function (A, e) { var t = this.octantToObjectMap; if (t[A] && t[A].mesh) { var i = 0, o = t[A].mesh[e]; for (i = o.length - 1; i >= 0; i -= 1) delete o[i]; delete t[A].mesh[e] } }, ly.prototype.removeBatchedMeshFromOctantMap = function (A, e) { var t = this.octantToObjectMap; if (t[A] && t[A].mesh && t[A].info) { var i = 0, o = t[A].info[e]; for (i = o.length - 1; i >= 0; i -= 1) o.splice(i); delete t[A].info[e] } }, ly.prototype.getOctantMap = function () { return this.octantToObjectMap }, ly.prototype.isFilterApplied = function () { return this.filterApplied }, ly.prototype.setFilterApplied = function (A) { this.filterApplied = A }, ly.prototype.applyFilter = function () { for (var A in Bh.time("applyFilter"), this.models) { this.models[A].applyFilter() } for (var e = 0, t = this.plugins.length; t > e; e += 1) this.plugins[e].applyFilter(); this.setFilterApplied(!0), Bh.timeEnd("applyFilter") }, ly.prototype.applySelection = function () { console.log('applySelection22') for (var A in this.selectPriority = !0, this.models) { this.models[A].applySelection() } this.scene.getExtrudeBodyManager().applySelection(this); for (var e = 0, t = this.plugins.length; t > e; e += 1) this.plugins[e].applySelection() }, ly.prototype.clearSelection = function () { for (var A in this.selectPriority = !0, this.models) { this.models[A].clearSelection() } this.scene.getExtrudeBodyManager().clearSelection(); for (var e = 0, t = this.plugins.length; t > e; e += 1) this.plugins[e].clearSelection() }, ly.prototype.applyHover = function () { if (vc.Hover && !vc.EnableRenderPass) for (var A in this.models) { this.models[A].applyHover() } this.scene.getExtrudeBodyManager().applyHover(this); for (var e = 0, t = this.plugins.length; t > e; e += 1) this.plugins[e].applyHover() }, ly.prototype.clearHover = function () { if (vc.Hover && !vc.EnableRenderPass) for (var A in this.models) { this.models[A].clearHover() } this.scene.getExtrudeBodyManager().clearHover(); for (var e = 0, t = this.plugins.length; t > e; e += 1) this.plugins[e].clearHover() }, ly.prototype.chooseRendering = function (A) {}, ly.prototype.isUserIdExist = function (A) { var e = !1; for (var t in this.models) { if (this.models.hasOwnProperty(t)) if (this.models[t].getModelDescriptor().isUserIdExist(A)) { e = !0; break } } for (var i = 0, o = this.plugins.length; o > i; i += 1) if (this.plugins[i].isUserIdExist && this.plugins[i].isUserIdExist(A)) { e = !0; break } return e }, ly.prototype.getNodeInfosByUserId = function (A) { var e = []; for (var t in this.models) { var i = this.models[t]; if (i && i.isLoaded()) { var o = this.models[t].getModelDescriptor().getNodeInfosByUserId(A); o && (e = e.concat(o)) } } for (var n = 0, r = this.plugins.length; r > n; n += 1) if (this.plugins[n].getNodeInfosByUserId) { var a = this.plugins[n].getNodeInfosByUserId(A); a && (e = e.concat(a)) } return e.length ? e : null }, ly.prototype.getNodeInfos = function () { var A = {}; for (var e in this.models) if (this.models[e].isLoaded()) { var t = this.models[e].getModelDescriptor().getAllNodeInfos(); t && (A[e] = t) } var i = this.getNodeInfosInPlugins(); return Object.assign(A, i), A }, ly.prototype.getNodeInfosInPlugins = function () { for (var A = {}, e = 0, t = this.plugins.length; t > e; e += 1) this.plugins[e].getAllNodeInfos && this.plugins[e].getAllNodeInfos(A); return A }, ly.prototype.getMaterialByNodeId = function (A, e, t) { var i = this.models[A]; if (!i) return null; for (var o = i.getModelDescriptor().getNodeInfosByUserId(e), n = -1, r = 0, a = o.length; a > r; r += 1) if (o[r].nodeId === t) { n = r; break } return -1 !== n ? i.getMaterialByMaterialId(o[n].materialId) : null }, ly.prototype.getNodeInfoByNodeId = function (A, e, t) { var i = this.models[A]; if (!i) return null; for (var o = i.getModelDescriptor().getNodeInfosByUserId(e), n = -1, r = 0, a = o.length; a > r; r += 1) if (o[r].nodeId === t) { n = r; break } return -1 !== n ? o[n] : null }, ly.prototype.getComponentInfoByUserId = function (A) { var e = this.getNodeInfosByUserId(A); if (e && e.length > 0) { for (var t = new aA, i = [], o = 0, n = e.length; n > o; o += 1) t.union(e[o].boundingBox), -1 === i.indexOf(e[o].materialId) && i.push(e[o].materialId); return { userId: A, state: 0, materials: i, boundingBox: t, userData: e[0].userData } } return null }, ly.prototype.getBoundingBoxByIds = function (A) { var e = this.getScene(), t = new aA; for (var i in A) if (!this.isHiddenUserId(i)) { Array.isArray(A) && (i = A[i]); var o = this.getComponentInfoByUserId(i); if (o) t.union(o.boundingBox); else { var n = e.getExtrudeBodyManager().getNode(i); if (n) { var r = n.geometry.boundingBox.clone(); n.matrix && r.applyMatrix4(n.matrix), t.union(r) } } } return t }, ly.prototype.createMaterialOverrideSet = function (A, e) { this.materialOverrideSet = new MaterialOverriderSet(A, e), vc.EnableTextureMapping = !0 }, ly.prototype.getMaterialOverrideSet = function () { return this.materialOverrideSet }, ly.prototype.getOverrideMaterialByNodeInfo = function (A) { return this.materialOverrideSet ? this.materialOverrideSet.getOverrideMaterialByNodeInfo(A) : null }, ly.prototype.getOverrideMaterialByName = function (A) { return this.materialOverrideSet ? this.materialOverrideSet.getOverrideMaterialByName(A) : null }, ly.prototype.loadOverrideMaterialsByDemand = function (A, e) { if (this.materialOverrideSet) { var t = this.getConditions(); this.materialOverrideSet.loadByDemand(t, A, e) } else e && e() }, ly.prototype.getConditions = function () { var A = {}, e = {}, t = {}; for (var i in this.models) { var o = this.models[i].getModelDescriptor().getAllNodeInfos(); if (o) for (var i in o) if (o.hasOwnProperty(i)) for (var n = 0, r = o[i].length; r > n; n += 1) { var a = o[i][n].userData; e[o[i][n].userId] = !0, t[a.systemTypeId] = !0, A[a.familyId] = !0 } } return { familyIds: A, elementIds: e, systemTypeIds: t } }, ly.prototype.isHiddenUserId = function (A) { var e = !1; for (var t in this.models) { if (this.models.hasOwnProperty(t)) if ((t = this.models[t]).isHiddenUserId(A)) { e = !0; break } } return e }, ly.prototype.isHiddenSourceObjectUserId = function (A) { return !!this.sourceObjectManager && this.sourceObjectManager.isHidden(A) }, ly.prototype.hasHiddenSourceObjectUserId = function () { return !!this.sourceObjectManager && this.sourceObjectManager.hasHidden() }, ly.prototype.updateMeshNodes = function () { for (var A in this.models) { if (this.models.hasOwnProperty(A)) (A = this.models[A]).updateMeshNodes() } }, ly.prototype.getMinDistanceObjects = function (A, e) { var t = this, i = {}; for (var o in this.models) if (this.models.hasOwnProperty(o)) { (o = this.models[o]).minDistanceObjects = {}; var n = o.getMeshesByUserIds(A), r = o.getMeshesByUserIds(e); if (n && n.length > 0 && (i[A] = n), r && r.length > 0 && (i[e] = r), i[A] && i[e]) return i } var a = null, s = null, l = null, c = null, h = null, d = function () { var i = {}, o = function (A, e, t) { var o = {}; o.mesh = A; var n = new M; t ? n.multiplyMatrices(t, A.matrix) : n = A.matrix, o.matrix = n; var r = A.geometry.boundingBox; r || (A.geometry.computeBoundingBox(), r = o.mesh.geometry.boundingBox); var a = r.clone().applyMatrix4(n); o.boundingBox = a, i[e] && (i[e] = []), i[e].push(o) }; if (!(a = t.scene.getGroup("ExternalComponentManager"))) return { v: void 0 }; for (l = 0, c = (s = a.children).length; c > l; l += 1) (h = s[l]).name !== A && h.name !== e || (uh.isGroupObject(h) ? h.traverseVisible((function (A) { uh.isMeshObject(A) && o(A, h.name, h.matrix) })) : o(h, h.name)); return { v: i } }(); return d && d.v && (d.v[A] && d.v[A].length > 0 && (i[A] = d.v[A]), d.v[e] && d.v[e].length > 0 && (i[e] = d.v[e]), i[A] && i[e]) || i[A] && i[e] ? i : null }, ly.prototype.getMeshByUserId = function (A) { for (var e in this.models) if (this.models.hasOwnProperty(e)) { var t = (e = this.models[e]).getMeshesByUserIds(A); if (t) return t } return null }, ly.prototype.adjustVisibility = function (A) { for (var e in this.models) this.models[e] && this.models[e]._getHandler().adjustVisibility(A); for (var t = 0, i = this.plugins.length; i > t; t += 1) { var o = this.plugins[t]; o.adjustVisibility && "function" == typeof o.adjustVisibility && o.adjustVisibility(A) } this.otherAdjustVisibility && this.otherAdjustVisibility(A) }, ly.prototype.changeVisibilityOfSelectedObjects = function (A) { for (var e in this.models) this.models[e] && this.models[e]._getHandler().changeVisibilityOfSelectedObjects(A); for (var t = 0, i = this.plugins.length; i > t; t += 1) { var o = this.plugins[t]; o.changeVisibilityOfSelectedObjects && "function" == typeof o.changeVisibilityOfSelectedObjects && o.changeVisibilityOfSelectedObjects(A) } }, ly.prototype.changeVisibilityOfNonSelectedObjects = function (A) { for (var e in this.models) this.models[e] && this.models[e]._getHandler().changeVisibilityOfNonSelectedObjects(A); this.otherAdjustVisibility && this.otherAdjustVisibility(A); for (var t = 0, i = this.plugins.length; i > t; t += 1) { var o = this.plugins[t]; o.changeVisibilityOfNonSelectedObjects && "function" == typeof o.changeVisibilityOfNonSelectedObjects && o.changeVisibilityOfNonSelectedObjects(A) } }, ly.prototype.adjustInstanceVisibility = function (A) { for (var e in this.models) this.models[e] && this.models[e].merged && this.models[e]._getHandler().adjustInstanceVisibility(A) }, ly.prototype.adjustVisibilityOfObjectsWithoutOutline = function (A) { for (var e in this.models) if (this.models[e]) { var t = this.models[e].axisNetManager; t && t.visibleByUser && (A ? this.models[e].axisNetManager.privateShow() : this.models[e].axisNetManager.privateHide()) } for (var i = 0, o = this.plugins.length; o > i; i += 1) { var n = this.plugins[i]; n.adjustVisibilityOfObjectsWithoutOutline && "function" == typeof n.adjustVisibilityOfObjectsWithoutOutline && n.adjustVisibilityOfObjectsWithoutOutline(A) } var r; this.scene.hasClipPlanes() && ((r = this.scene.getClipPlanes()).isEnabled() && (!1 === A && r.visible ? (r.visible = !1, r._hideByModelManager = !0) : !0 === A && r._hideByModelManager && (r.visible = !0, delete r._hideByModelManager))); this.scene.hasFillClipPlanes() && ((r = this.scene.getFillClipPlane()).isEnabled() && (!1 === A && r.visible ? (r.visible = !1, r._hideByModelManager = !0) : !0 === A && r._hideByModelManager && (r.visible = !0, delete r._hideByModelManager))); this.scene.receivingPlane && (!1 === A && this.scene.receivingPlane.visible ? (this.scene.receivingPlane.visible = !1, this.scene.receivingPlane._hideByModelManager = !0) : !0 === A && this.scene.receivingPlane._hideByModelManager && (this.scene.receivingPlane.visible = !0, delete this.scene.receivingPlane._hideByModelManager)), this.otherAdjustVisibility && this.otherAdjustVisibility(A); for (var a = this.scene.children, s = (i = 0, a.length); s > i; i += 1) { var l = a[i]; l !== this.scene.objectGroups && !0 !== l.isLight && !0 === l.isObject3D && (l.visible = A) } }, ly.prototype.changeInstanceVisibilityOfSelectedObjects = function (A) { for (var e in this.models) this.models[e] && this.models[e].merged && this.models[e]._getHandler().changeInstanceVisibilityOfSelectedObjects(A) }, ly.prototype.changeInstanceVisibilityOfNonSelectedObjects = function (A) { for (var e in this.models) this.models[e] && this.models[e].merged && this.models[e]._getHandler().changeInstanceVisibilityOfNonSelectedObjects(A) }, ly.prototype.restoreVisibilityOfObjects = function () { for (var A in this.models) this.models[A] && this.models[A]._getHandler().restoreVisibilityOfObjects(); this.otherAdjustVisibility && this.otherAdjustVisibility(!0) }, ly.prototype.getComponentKeysByTypeFromList = function (A, e) { var t = []; for (var i in this.models) { if (this.models.hasOwnProperty(i)) if ((i = this.models[i]).isLoaded()) { var o = i.getComponentKeysByTypeFromList(A, e); o && (t = t.concat(o)) } } return t }, ly.prototype.getComponentKeysByType = function (A) { var e = []; for (var t in this.models) { if (this.models.hasOwnProperty(t)) if ((t = this.models[t]).isLoaded()) { var i = t.getComponentKeysByType(A); i && (e = e.concat(i)) } } return e }, ly.prototype.getComponentKeysByName = function (A) { var e = []; for (var t in this.models) if (this.models.hasOwnProperty(t)) { var i = (t = this.models[t]).getComponentKeysByName(A); i && (e = e.concat(i)) } return e }, ly.prototype.getComponentKeysByProperty = function (A, e) { var t = []; for (var i in this.models) if (this.models.hasOwnProperty(i)) { var o = (i = this.models[i]).getComponentKeysByProperty(A, e); o && (t = t.concat(o)) } return t }, ly.prototype.getBlinkMaterials = function () { var A = []; for (var e in this.models) this.models[e] && this.models[e]._getHandler().getBlinkMaterials && (A = A.concat(this.models[e]._getHandler().getBlinkMaterials())); return A }, ly.prototype.resetBlinkMaterial = function () { for (var A = this.getBlinkMaterials(), e = 0, t = A.length; t > e; e += 1) A[e].resetBlinkUniformValue() }, ly.prototype.updateBlinkMaterial = function () { if (null !== this.blinkStartTime) { if (Date.now() - this.blinkStartTime >= this.blinkIntervalTime) { this.blinkStartTime = Date.now(), this.indexSwitch = !this.indexSwitch; for (var A = this.indexSwitch ? Yc.BLINK : Yc.NONE, e = this.getBlinkMaterials(), t = 0, i = e.length; i > t; t += 1) e[t].updateBlinkUniformValue(A, this.blinkColor) } } else this.blinkStartTime = Date.now() }, ly.prototype.getBlinkColor = function () { return this.blinkColor }, ly.prototype.setBlinkColor = function (A, e) { if (A) { var t = uh.hexToRgb(A); this.blinkColor.fromArray([t.r, t.g, t.b, e || 1]) } else this.blinkColor.set(this.defaultBlinkColor.r, this.defaultBlinkColor.g, this.defaultBlinkColor.b, this.defaultBlinkAlpha) }, ly.prototype.setBlinkIntervalTime = function (A) { this.blinkIntervalTime > 0 && (this.blinkIntervalTime = A) }, ly.prototype.enableBlink = function (A) { this.blinkEnabled = A, A ? null === this.blinkStartTime && (this.blinkStartTime = Date.now()) : (this.blinkStartTime = null, this.resetBlinkMaterial()), this.applyBlink() }, ly.prototype.getBlinkEnabled = function () { return !this.isBlinkPermited() && this.blinkEnabled }, ly.prototype.getBlinkComponentsIdMap = function () { return this.isBlinkPermited() ? null : this.sceneState.getBlinkComponentsIdMap() }, ly.prototype.applyBlink = function () { if (!this.isBlinkPermited()) for (var A in this.selectPriority = !1, this.models) { this.models[A].applyBlink() } }, ly.prototype.clearBlink = function () { if (!this.isBlinkPermited()) for (var A in this.selectPriority = !1, this.models) { this.models[A].clearBlink() } }, ly.prototype.permitBlink = function (A) { this.blinkPermited = A }, ly.prototype.isBlinkPermited = function () { return this.blinkPermited }, ly.prototype.isSelectPriority = function () { return this.selectPriority }, ly.prototype.getSceneState = function () { return this.sceneState }, ly.prototype.getModelSceneState = function () { return this.modelState }, ly.prototype.disposeBufferAfterVbo = function () { if (vc.EnableDisposeBufferAfterVbo) for (var A in this.models) { this.models[A].disposeBufferAfterVbo() } }, ly.prototype.getSourceObjectManager = function () { return this.sourceObjectManager || (this.sourceObjectManager = new ry), this.sourceObjectManager }, ly.prototype.isHiddenUserId = function (A) { return !!this.sourceObjectManager && this.sourceObjectManager.isHidden(A) }, ly.prototype.hasHiddenUserId = function () { return !!this.sourceObjectManager && this.sourceObjectManager.hasHidden() }, ly.prototype.traverseModels = function (A, e) { for (var t in this.models) { var i = this.models[t]; if (e && e(i)) break; A && A(i) } }, ly.prototype.traverseLoadedModels = function (A) { for (var e in this.models) { var t = this.models[e]; t && t.isLoaded() && A(t) } }, ly.prototype.getStatisticsInfo = function () { var A = 0, e = 0, t = 0, i = 0; for (var o in this.models) { var n = this.models[o]; if (n && n.isLoaded()) { var r = n.getTrianglesCount(); A += r.positionsCount, e += r.trianglesCount, t += r.realPositionCount, i += r.realTrianglesCount } } return { positionsCount: A, trianglesCount: e, realPositionCount: t, realTrianglesCount: i, componentCount: this.getAllComponentsKey().length } }, ly.prototype.dealStateChanged = function () { this.hasModelDataReady() && (this.isRenderStateChanged() || this.filter.isStateChanged()) && (this.isRenderStateChanged() && this.setRenderStateChanged(!1), this.filter.isStateChanged() && this.filter.disableStateChanged(), this.applyFilter()) }, ly.prototype.setRenderStateChanged = function (A) { this._renderStateChanged = A }, ly.prototype.isRenderStateChanged = function () { return this._renderStateChanged }, ly.prototype.hasLoadOnDemandDirector = function () { return !!this.loadOnDemandDirector }, ly.prototype.getLoadOnDemandDirector = function () { return this.loadOnDemandDirector || (this.loadOnDemandDirector = new sy(this)), this.loadOnDemandDirector }, ly.prototype.checkLayerDataLoading = function () { return !!(this.isLayerData() && this.hasLoadOnDemandDirector() && this.getLoadOnDemandDirector().isLoading()) && (this.filter.isStateChanged() && this.filter.disableStateChanged(), !0) }, ly.prototype.updateFilterManager = function () { var A = this.getNodeInfos(), e = this.filter; e.clearFilterManager(), e.initFilterManager(A), e.isStateChanged() && e.disableStateChanged(), this.updateMeshNodes(), this.applyFilter() }, ly.prototype.isDrawingBoardlineEnabled = function () { return !(!vc.DrawingBoardlineEnabled || vc.DrawingStyle !== jc.BOARDLINE && vc.DrawingStyle !== jc.SHADINGWITHLINE) }, ly.prototype.isOnlyWireframe = function () { return vc.DrawingStyle === jc.BOARDLINE }, ly.prototype.getExplosionExtent = function () { return this.explosionExtent }, ly.prototype.setExplosionExtent = function (A) { var e = A - this.explosionExtent; for (var t in this.models) this.models[t] && this.models[t].explode(e); this.explosionExtent = A }, ly.prototype.updateAnimation = function () { var A = this.viewerImpl.clock.getDelta(); for (var e in this.models) if (this.models.hasOwnProperty(e)) { var t = this.models[e]; if (t.hasAnimation && t.mixer) { var i = t.mixer; t.singleStepMode ? (i.update(t.sizeOfNextStep), t.sizeOfNextStep = 0) : i.update(A) } } }, ly.prototype.needUpdateAnimation = function () { for (var A in this.models) if (this.models.hasOwnProperty(A)) { var e = this.models[A]; if (e.hasAnimation && e.mixer && e.needUpdate) return !0 } return !1 }, ly.prototype.unloadGeopkOnDemand = function (A, e) { var t = this.models; for (var i in t) if (t.hasOwnProperty(i)) { var o = t[i]; o.isLoaded() && !o.isEmptyScene() && o.isLayerData() && o.unloadGeopkOnDemand(A, e) } }, ly.prototype.loadGeopkOnDemand = function (A, e, t, i) { this.getLoadOnDemandDirector().loadGeopkOnDemandByConditions(A, e, t, i) }, ly.prototype.loadAllGeosOnDemand = function (A, e) { var t = this.models; for (var i in t) if (t.hasOwnProperty(i)) { var o = t[i]; o.isLoaded() && !o.isEmptyScene() && o.isLayerData() && o.loadAllGeosOnDemand(A, e) } }, ly.prototype.getBoundingBoxOnDemand = function () { var A = this.models, e = new aA; for (var t in A) if (A.hasOwnProperty(t)) { var i = A[t]; if (i.isLoaded() && !i.isEmptyScene() && i.isLayerData()) { var o = i.getUnionBoundingBoxOnDemand(); o && e.union(o) } } return e }, ly.prototype.setConditionsOnDemandLoad = function (A) { this.conditionsOnDemandLoad = A; var e = this.models; for (var t in e) if (e.hasOwnProperty(t)) { var i = e[t]; i.isLoaded() && !i.isEmptyScene() && i.isLayerData() && i.setConditionsChangedOnDemand(!0) } }, ly.prototype.getConditionsOnDemandLoad = function () { return this.conditionsOnDemandLoad }, ly.prototype.componentsExplosion = function (A) { var e = this.models; for (var t in e) { if (e.hasOwnProperty(t)) e[t].componentsExplosion(A) } }, ly.prototype.closeComponentsExplosion = function (A) { var e = this.models; for (var t in e) { if (e.hasOwnProperty(t)) e[t].closeComponentsExplosion(A) } }, ly.prototype.canFloorExplosion = function () { var A = this.models, e = !1; for (var t in A) { if (A.hasOwnProperty(t)) A[t].floorManager && (e = !0) } return e }, ly.prototype.floorExplosion = function (A) { var e = this.models, t = !1; for (var i in e) { if (e.hasOwnProperty(i)) e[i].floorExplosion(A) && (this.updateSceneBoundingBox(), t = !0) } return t }, ly.prototype.closeFloorExplosion = function () { var A = this.models; for (var e in A) { if (A.hasOwnProperty(e)) A[e].closeFloorExplosion() } }, ly.prototype.checkTilesDataChanged = function (A, e) { if (!this.cameraPosition.equals(A.position) || this.cameraFov !== A.fov || this.domElementWidth !== e.domElement.width) { this.cameraFov = A.fov || 45, this.cameraPosition = A.position.clone() || new y, this.domElementWidth = e.domElement.width || 1e3; var t = !1, i = this.checkMemory(); for (var o in i > vc.MaximumAvailableMemory && (t = !0), this.models) if (this.models.hasOwnProperty(o)) { var n = this.models[o]; n.isTilesModel && n.checkTilesDataChanged(t) } } }, ly.prototype.checkMemory = function () { var A = 0, e = this.viewerImpl.getRenderer().info; return A += 6 * (e.render.triangles || 0), A += 1024 * (e.memory.textures || 0) * 1024 / 4, A += 1024 * (e.render.calls || 0) / 4, A += 1024 * (e.memory.geometries || 0) / 4, A *= 1 / 1048576, A = Math.ceil(A) }, ly.prototype.getMeshIdFromOctantMap = function (A) { return A.single ? A.nodeId : A.instanceOrNot ? uh.getCombinedKeyString(A.uv2Info ? [A.materialId, A.geometryId, A.uv2Info.byteOffset] : [A.materialId, A.geometryId]) : vc.MergeComponent ? uh.getCombinedKeyString([A.materialId, A.uv ? "1" : "0", A.type === $u.EnumNodeItemType.LINE ? "lines" : "meshes"]) : A.nodeId }; var cy, hy, dy, py = { uniforms: { tDiffuse: { value: null }, opacity: { value: 1 } }, vertexShader: ["varying vec2 vUv;", "void main() {", "vUv = uv;", "gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );", "}"].join("\n"), fragmentShader: ["uniform float opacity;", "uniform sampler2D tDiffuse;", "varying vec2 vUv;", "void main() {", "vec4 texel = texture2D( tDiffuse, vUv );", "gl_FragColor = opacity * texel;", "}"].join("\n") }; function gy() { this.enabled = !0, this.needsSwap = !0, this.clear = !1, this.renderToScreen = !1 } Object.assign(gy.prototype, { setSize: function () {}, render: function () { console.error("THREE.Pass: .render() must be implemented in derived pass.") } }), gy.FullScreenQuad = (cy = new Ka(-1, 1, 1, -1, 0, 1), hy = new et(2, 2), dy = function (A) { this._mesh = new Ue(hy, A) }, Object.defineProperty(dy.prototype, "material", { get: function () { return this._mesh.material }, set: function (A) { this._mesh.material = A } }), Object.assign(dy.prototype, { render: function (A) { A.render(this._mesh, cy) } }), dy); var uy = function (A, e) { gy.call(this), this.textureID = void 0 !== e ? e : "tDiffuse", A instanceof Pe ? (this.uniforms = A.uniforms, this.material = A) : A && (this.uniforms = Ge.clone(A.uniforms), this.material = new Pe({ defines: Object.assign({}, A.defines), uniforms: this.uniforms, vertexShader: A.vertexShader, fragmentShader: A.fragmentShader })), this.fsQuad = new gy.FullScreenQuad(this.material) }; uy.prototype = Object.assign(Object.create(gy.prototype), { constructor: uy, render: function (A, e, t) { this.uniforms[this.textureID] && (this.uniforms[this.textureID].value = t.texture), this.fsQuad.material = this.material, this.renderToScreen ? (A.setRenderTarget(null), this.fsQuad.render(A)) : (A.setRenderTarget(e), this.clear && A.clear(A.autoClearColor, A.autoClearDepth, A.autoClearStencil), this.fsQuad.render(A)) } }); var fy = function (A, e) { gy.call(this), this.scene = A, this.camera = e, this.clear = !0, this.needsSwap = !1, this.inverse = !1 }; fy.prototype = Object.assign(Object.create(gy.prototype), { constructor: fy, render: function (A, e, t) { var i = A.getContext(), o = A.state; o.buffers.color.setMask(!1), o.buffers.depth.setMask(!1), o.buffers.color.setLocked(!0), o.buffers.depth.setLocked(!0); var n = null, r = null; this.inverse ? (r = 0, n = 1) : (r = 1, n = 0), o.buffers.stencil.setTest(!0), o.buffers.stencil.setOp(i.REPLACE, i.REPLACE, i.REPLACE), o.buffers.stencil.setFunc(i.ALWAYS, r, 4294967295), o.buffers.stencil.setClear(n), o.buffers.stencil.setLocked(!0), A.setRenderTarget(t), this.clear && A.clear(), A.render(this.scene, this.camera), A.setRenderTarget(e), this.clear && A.clear(), A.render(this.scene, this.camera), o.buffers.color.setLocked(!1), o.buffers.depth.setLocked(!1), o.buffers.stencil.setLocked(!1), o.buffers.stencil.setFunc(i.EQUAL, 1, 4294967295), o.buffers.stencil.setOp(i.KEEP, i.KEEP, i.KEEP), o.buffers.stencil.setLocked(!0) } }); var my = function () { gy.call(this), this.needsSwap = !1 }; my.prototype = Object.create(gy.prototype), Object.assign(my.prototype, { render: function (A) { A.state.buffers.stencil.setLocked(!1), A.state.buffers.stencil.setTest(!1) } }); var Cy = function (A, e) { if (this.renderer = A, void 0 === e) { var t = { minFilter: 1006, magFilter: 1006, format: 1023, stencilBuffer: !1 }, i = A.getSize(new s); this._pixelRatio = A.getPixelRatio(), this._width = i.width, this._height = i.height, (e = new g(this._width * this._pixelRatio, this._height * this._pixelRatio, t)).texture.name = "EffectComposer.rt1" } else this._pixelRatio = 1, this._width = e.width, this._height = e.height; this.renderTarget1 = e, this.renderTarget2 = e.clone(), this.renderTarget2.texture.name = "EffectComposer.rt2", this.writeBuffer = this.renderTarget1, this.readBuffer = this.renderTarget2, this.renderToScreen = !0, this.passes = [], void 0 === py && console.error("THREE.EffectComposer relies on CopyShader"), void 0 === uy && console.error("THREE.EffectComposer relies on ShaderPass"), this.copyPass = new uy(py), this.clock = new as }; Object.assign(Cy.prototype, { swapBuffers: function () { var A = this.readBuffer; this.readBuffer = this.writeBuffer, this.writeBuffer = A }, addPass: function (A) { this.passes.push(A), A.setSize(this._width * this._pixelRatio, this._height * this._pixelRatio) }, insertPass: function (A, e) { this.passes.splice(e, 0, A) }, isLastEnabledPass: function (A) { for (var e = A + 1; this.passes.length > e; e += 1) if (this.passes[e].enabled) return !1; return !0 }, render: function (A) { void 0 === A && (A = this.clock.getDelta()); var e = this.renderer.getRenderTarget(), t = !1, i = null, o = null, n = this.passes.length; for (o = 0; n > o; o += 1) if (!1 !== (i = this.passes[o]).enabled) { if (i.renderToScreen = this.renderToScreen && this.isLastEnabledPass(o), i.render(this.renderer, this.writeBuffer, this.readBuffer, A, t), i.needsSwap) { if (t) { var r = this.renderer.getContext(), a = this.renderer.state.buffers.stencil; a.setFunc(r.NOTEQUAL, 1, 4294967295), this.copyPass.render(this.renderer, this.writeBuffer, this.readBuffer, A), a.setFunc(r.EQUAL, 1, 4294967295) } this.swapBuffers() } void 0 !== fy && (i instanceof fy ? t = !0 : i instanceof my && (t = !1)) } this.renderer.setRenderTarget(e) }, reset: function (A) { if (void 0 === A) { var e = this.renderer.getSize(new s); this._pixelRatio = this.renderer.getPixelRatio(), this._width = e.width, this._height = e.height, (A = this.renderTarget1.clone()).setSize(this._width * this._pixelRatio, this._height * this._pixelRatio) } this.renderTarget1.dispose(), this.renderTarget2.dispose(), this.renderTarget1 = A, this.renderTarget2 = A.clone(), this.writeBuffer = this.renderTarget1, this.readBuffer = this.renderTarget2 }, setSize: function (A, e) { this._width = A, this._height = e; var t = this._width * this._pixelRatio, i = this._height * this._pixelRatio; this.renderTarget1.setSize(t, i), this.renderTarget2.setSize(t, i); for (var o = 0; this.passes.length > o; o += 1) this.passes[o].setSize(t, i) }, setPixelRatio: function (A) { this._pixelRatio = A, this.setSize(this._width, this._height) } }); var yy = function () { this.enabled = !0, this.needsSwap = !0, this.clear = !1, this.renderToScreen = !1 }; Object.assign(yy.prototype, { setSize: function () {}, render: function () { console.error("THREE.Pass: .render() must be implemented in derived pass.") } }), yy.FullScreenQuad = function () { var A = new Ka(-1, 1, 1, -1, 0, 1), e = new et(2, 2), t = function (A) { this._mesh = new Ue(e, A) }; return Object.defineProperty(t.prototype, "material", { get: function () { return this._mesh.material }, set: function (A) { this._mesh.material = A } }), Object.assign(t.prototype, { render: function (e) { e.render(this._mesh, A) } }), t }(); var vy = { uniforms: { tDiffuse: { value: null }, resolution: { value: new s(1 / 1024, 1 / 512) } }, vertexShader: ["varying vec2 vUv;", "void main() {", "vUv = uv;", "gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );", "}"].join("\n"), fragmentShader: ["precision highp float;", "", "uniform sampler2D tDiffuse;", "", "uniform vec2 resolution;", "", "varying vec2 vUv;", "", "// FXAA 3.11 implementation by NVIDIA, ported to WebGL by Agost Biro (biro@archilogic.com)", "", "//----------------------------------------------------------------------------------", "// File: es3-kepler FXAA assets shaders/FXAA_DefaultES.frag", "// SDK Version: v3.00", "// Email: gameworks@nvidia.com", "// Site: http://developer.nvidia.com/", "//", "// Copyright (c) 2014-2015, NVIDIA CORPORATION. All rights reserved.", "//", "// Redistribution and use in source and binary forms, with or without", "// modification, are permitted provided that the following conditions", "// are met:", "// * Redistributions of source code must retain the above copyright", "// notice, this list of conditions and the following disclaimer.", "// * Redistributions in binary form must reproduce the above copyright", "// notice, this list of conditions and the following disclaimer in the", "// documentation and/or other materials provided with the distribution.", "// * Neither the name of NVIDIA CORPORATION nor the names of its", "// contributors may be used to endorse or promote products derived", "// from this software without specific prior written permission.", "//", "// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``AS IS'' AND ANY", "// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE", "// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR", "// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR", "// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,", "// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,", "// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR", "// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY", "// OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT", "// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE", "// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.", "//", "//----------------------------------------------------------------------------------", "", "#define FXAA_PC 1", "#define FXAA_GLSL_100 1", "#define FXAA_QUALITY_PRESET 12", "", "#define FXAA_GREEN_AS_LUMA 1", "", "/*--------------------------------------------------------------------------*/", "#ifndef FXAA_PC_CONSOLE", " //", " // The console algorithm for PC is included", " // for developers targeting really low spec machines.", " // Likely better to just run FXAA_PC, and use a really low preset.", " //", " #define FXAA_PC_CONSOLE 0", "#endif", "/*--------------------------------------------------------------------------*/", "#ifndef FXAA_GLSL_120", " #define FXAA_GLSL_120 0", "#endif", "/*--------------------------------------------------------------------------*/", "#ifndef FXAA_GLSL_130", " #define FXAA_GLSL_130 0", "#endif", "/*--------------------------------------------------------------------------*/", "#ifndef FXAA_HLSL_3", " #define FXAA_HLSL_3 0", "#endif", "/*--------------------------------------------------------------------------*/", "#ifndef FXAA_HLSL_4", " #define FXAA_HLSL_4 0", "#endif", "/*--------------------------------------------------------------------------*/", "#ifndef FXAA_HLSL_5", " #define FXAA_HLSL_5 0", "#endif", "/*==========================================================================*/", "#ifndef FXAA_GREEN_AS_LUMA", " //", " // For those using non-linear color,", " // and either not able to get luma in alpha, or not wanting to,", " // this enables FXAA to run using green as a proxy for luma.", " // So with this enabled, no need to pack luma in alpha.", " //", " // This will turn off AA on anything which lacks some amount of green.", " // Pure red and blue or combination of only R and B, will get no AA.", " //", " // Might want to lower the settings for both,", " // fxaaConsoleEdgeThresholdMin", " // fxaaQualityEdgeThresholdMin", " // In order to insure AA does not get turned off on colors", " // which contain a minor amount of green.", " //", " // 1 = On.", " // 0 = Off.", " //", " #define FXAA_GREEN_AS_LUMA 0", "#endif", "/*--------------------------------------------------------------------------*/", "#ifndef FXAA_EARLY_EXIT", " //", " // Controls algorithm's early exit path.", " // On PS3 turning this ON adds 2 cycles to the shader.", " // On 360 turning this OFF adds 10ths of a millisecond to the shader.", " // Turning this off on console will result in a more blurry image.", " // So this defaults to on.", " //", " // 1 = On.", " // 0 = Off.", " //", " #define FXAA_EARLY_EXIT 1", "#endif", "/*--------------------------------------------------------------------------*/", "#ifndef FXAA_DISCARD", " //", " // Only valid for PC OpenGL currently.", " // Probably will not work when FXAA_GREEN_AS_LUMA = 1.", " //", " // 1 = Use discard on pixels which don't need AA.", " // For APIs which enable concurrent TEX+ROP from same surface.", " // 0 = Return unchanged color on pixels which don't need AA.", " //", " #define FXAA_DISCARD 0", "#endif", "/*--------------------------------------------------------------------------*/", "#ifndef FXAA_FAST_PIXEL_OFFSET", " //", " // Used for GLSL 120 only.", " //", " // 1 = GL API supports fast pixel offsets", " // 0 = do not use fast pixel offsets", " //", " #ifdef GL_EXT_gpu_shader4", " #define FXAA_FAST_PIXEL_OFFSET 1", " #endif", " #ifdef GL_NV_gpu_shader5", " #define FXAA_FAST_PIXEL_OFFSET 1", " #endif", " #ifdef GL_ARB_gpu_shader5", " #define FXAA_FAST_PIXEL_OFFSET 1", " #endif", " #ifndef FXAA_FAST_PIXEL_OFFSET", " #define FXAA_FAST_PIXEL_OFFSET 0", " #endif", "#endif", "/*--------------------------------------------------------------------------*/", "#ifndef FXAA_GATHER4_ALPHA", " //", " // 1 = API supports gather4 on alpha channel.", " // 0 = API does not support gather4 on alpha channel.", " //", " #if (FXAA_HLSL_5 == 1)", " #define FXAA_GATHER4_ALPHA 1", " #endif", " #ifdef GL_ARB_gpu_shader5", " #define FXAA_GATHER4_ALPHA 1", " #endif", " #ifdef GL_NV_gpu_shader5", " #define FXAA_GATHER4_ALPHA 1", " #endif", " #ifndef FXAA_GATHER4_ALPHA", " #define FXAA_GATHER4_ALPHA 0", " #endif", "#endif", "", "", "/*============================================================================", " FXAA QUALITY - TUNING KNOBS", "------------------------------------------------------------------------------", "NOTE the other tuning knobs are now in the shader function inputs!", "============================================================================*/", "#ifndef FXAA_QUALITY_PRESET", " //", " // Choose the quality preset.", " // This needs to be compiled into the shader as it effects code.", " // Best option to include multiple presets is to", " // in each shader define the preset, then include this file.", " //", " // OPTIONS", " // -----------------------------------------------------------------------", " // 10 to 15 - default medium dither (10=fastest, 15=highest quality)", " // 20 to 29 - less dither, more expensive (20=fastest, 29=highest quality)", " // 39 - no dither, very expensive", " //", " // NOTES", " // -----------------------------------------------------------------------", " // 12 = slightly faster then FXAA 3.9 and higher edge quality (default)", " // 13 = about same speed as FXAA 3.9 and better than 12", " // 23 = closest to FXAA 3.9 visually and performance wise", " // _ = the lowest digit is directly related to performance", " // _ = the highest digit is directly related to style", " //", " #define FXAA_QUALITY_PRESET 12", "#endif", "", "", "/*============================================================================", "", " FXAA QUALITY - PRESETS", "", "============================================================================*/", "", "/*============================================================================", " FXAA QUALITY - MEDIUM DITHER PRESETS", "============================================================================*/", "#if (FXAA_QUALITY_PRESET == 10)", " #define FXAA_QUALITY_PS 3", " #define FXAA_QUALITY_P0 1.5", " #define FXAA_QUALITY_P1 3.0", " #define FXAA_QUALITY_P2 12.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 11)", " #define FXAA_QUALITY_PS 4", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 3.0", " #define FXAA_QUALITY_P3 12.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 12)", " #define FXAA_QUALITY_PS 5", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 4.0", " #define FXAA_QUALITY_P4 12.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 13)", " #define FXAA_QUALITY_PS 6", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 4.0", " #define FXAA_QUALITY_P5 12.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 14)", " #define FXAA_QUALITY_PS 7", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 2.0", " #define FXAA_QUALITY_P5 4.0", " #define FXAA_QUALITY_P6 12.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 15)", " #define FXAA_QUALITY_PS 8", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 2.0", " #define FXAA_QUALITY_P5 2.0", " #define FXAA_QUALITY_P6 4.0", " #define FXAA_QUALITY_P7 12.0", "#endif", "", "/*============================================================================", " FXAA QUALITY - LOW DITHER PRESETS", "============================================================================*/", "#if (FXAA_QUALITY_PRESET == 20)", " #define FXAA_QUALITY_PS 3", " #define FXAA_QUALITY_P0 1.5", " #define FXAA_QUALITY_P1 2.0", " #define FXAA_QUALITY_P2 8.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 21)", " #define FXAA_QUALITY_PS 4", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 8.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 22)", " #define FXAA_QUALITY_PS 5", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 8.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 23)", " #define FXAA_QUALITY_PS 6", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 2.0", " #define FXAA_QUALITY_P5 8.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 24)", " #define FXAA_QUALITY_PS 7", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 2.0", " #define FXAA_QUALITY_P5 3.0", " #define FXAA_QUALITY_P6 8.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 25)", " #define FXAA_QUALITY_PS 8", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 2.0", " #define FXAA_QUALITY_P5 2.0", " #define FXAA_QUALITY_P6 4.0", " #define FXAA_QUALITY_P7 8.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 26)", " #define FXAA_QUALITY_PS 9", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 2.0", " #define FXAA_QUALITY_P5 2.0", " #define FXAA_QUALITY_P6 2.0", " #define FXAA_QUALITY_P7 4.0", " #define FXAA_QUALITY_P8 8.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 27)", " #define FXAA_QUALITY_PS 10", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 2.0", " #define FXAA_QUALITY_P5 2.0", " #define FXAA_QUALITY_P6 2.0", " #define FXAA_QUALITY_P7 2.0", " #define FXAA_QUALITY_P8 4.0", " #define FXAA_QUALITY_P9 8.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 28)", " #define FXAA_QUALITY_PS 11", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 2.0", " #define FXAA_QUALITY_P5 2.0", " #define FXAA_QUALITY_P6 2.0", " #define FXAA_QUALITY_P7 2.0", " #define FXAA_QUALITY_P8 2.0", " #define FXAA_QUALITY_P9 4.0", " #define FXAA_QUALITY_P10 8.0", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_QUALITY_PRESET == 29)", " #define FXAA_QUALITY_PS 12", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.5", " #define FXAA_QUALITY_P2 2.0", " #define FXAA_QUALITY_P3 2.0", " #define FXAA_QUALITY_P4 2.0", " #define FXAA_QUALITY_P5 2.0", " #define FXAA_QUALITY_P6 2.0", " #define FXAA_QUALITY_P7 2.0", " #define FXAA_QUALITY_P8 2.0", " #define FXAA_QUALITY_P9 2.0", " #define FXAA_QUALITY_P10 4.0", " #define FXAA_QUALITY_P11 8.0", "#endif", "", "/*============================================================================", " FXAA QUALITY - EXTREME QUALITY", "============================================================================*/", "#if (FXAA_QUALITY_PRESET == 39)", " #define FXAA_QUALITY_PS 12", " #define FXAA_QUALITY_P0 1.0", " #define FXAA_QUALITY_P1 1.0", " #define FXAA_QUALITY_P2 1.0", " #define FXAA_QUALITY_P3 1.0", " #define FXAA_QUALITY_P4 1.0", " #define FXAA_QUALITY_P5 1.5", " #define FXAA_QUALITY_P6 2.0", " #define FXAA_QUALITY_P7 2.0", " #define FXAA_QUALITY_P8 2.0", " #define FXAA_QUALITY_P9 2.0", " #define FXAA_QUALITY_P10 4.0", " #define FXAA_QUALITY_P11 8.0", "#endif", "", "", "", "/*============================================================================", "", " API PORTING", "", "============================================================================*/", "#if (FXAA_GLSL_100 == 1) || (FXAA_GLSL_120 == 1) || (FXAA_GLSL_130 == 1)", " #define FxaaBool bool", " #define FxaaDiscard discard", " #define FxaaFloat float", " #define FxaaFloat2 vec2", " #define FxaaFloat3 vec3", " #define FxaaFloat4 vec4", " #define FxaaHalf float", " #define FxaaHalf2 vec2", " #define FxaaHalf3 vec3", " #define FxaaHalf4 vec4", " #define FxaaInt2 ivec2", " #define FxaaSat(x) clamp(x, 0.0, 1.0)", " #define FxaaTex sampler2D", "#else", " #define FxaaBool bool", " #define FxaaDiscard clip(-1)", " #define FxaaFloat float", " #define FxaaFloat2 float2", " #define FxaaFloat3 float3", " #define FxaaFloat4 float4", " #define FxaaHalf half", " #define FxaaHalf2 half2", " #define FxaaHalf3 half3", " #define FxaaHalf4 half4", " #define FxaaSat(x) saturate(x)", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_GLSL_100 == 1)", " #define FxaaTexTop(t, p) texture2D(t, p, 0.0)", " #define FxaaTexOff(t, p, o, r) texture2D(t, p + (o * r), 0.0)", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_GLSL_120 == 1)", " // Requires,", " // #version 120", " // And at least,", " // #extension GL_EXT_gpu_shader4 : enable", " // (or set FXAA_FAST_PIXEL_OFFSET 1 to work like DX9)", " #define FxaaTexTop(t, p) texture2DLod(t, p, 0.0)", " #if (FXAA_FAST_PIXEL_OFFSET == 1)", " #define FxaaTexOff(t, p, o, r) texture2DLodOffset(t, p, 0.0, o)", " #else", " #define FxaaTexOff(t, p, o, r) texture2DLod(t, p + (o * r), 0.0)", " #endif", " #if (FXAA_GATHER4_ALPHA == 1)", " // use #extension GL_ARB_gpu_shader5 : enable", " #define FxaaTexAlpha4(t, p) textureGather(t, p, 3)", " #define FxaaTexOffAlpha4(t, p, o) textureGatherOffset(t, p, o, 3)", " #define FxaaTexGreen4(t, p) textureGather(t, p, 1)", " #define FxaaTexOffGreen4(t, p, o) textureGatherOffset(t, p, o, 1)", " #endif", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_GLSL_130 == 1)", ' // Requires "#version 130" or better', " #define FxaaTexTop(t, p) textureLod(t, p, 0.0)", " #define FxaaTexOff(t, p, o, r) textureLodOffset(t, p, 0.0, o)", " #if (FXAA_GATHER4_ALPHA == 1)", " // use #extension GL_ARB_gpu_shader5 : enable", " #define FxaaTexAlpha4(t, p) textureGather(t, p, 3)", " #define FxaaTexOffAlpha4(t, p, o) textureGatherOffset(t, p, o, 3)", " #define FxaaTexGreen4(t, p) textureGather(t, p, 1)", " #define FxaaTexOffGreen4(t, p, o) textureGatherOffset(t, p, o, 1)", " #endif", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_HLSL_3 == 1)", " #define FxaaInt2 float2", " #define FxaaTex sampler2D", " #define FxaaTexTop(t, p) tex2Dlod(t, float4(p, 0.0, 0.0))", " #define FxaaTexOff(t, p, o, r) tex2Dlod(t, float4(p + (o * r), 0, 0))", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_HLSL_4 == 1)", " #define FxaaInt2 int2", " struct FxaaTex { SamplerState smpl; Texture2D tex; };", " #define FxaaTexTop(t, p) t.tex.SampleLevel(t.smpl, p, 0.0)", " #define FxaaTexOff(t, p, o, r) t.tex.SampleLevel(t.smpl, p, 0.0, o)", "#endif", "/*--------------------------------------------------------------------------*/", "#if (FXAA_HLSL_5 == 1)", " #define FxaaInt2 int2", " struct FxaaTex { SamplerState smpl; Texture2D tex; };", " #define FxaaTexTop(t, p) t.tex.SampleLevel(t.smpl, p, 0.0)", " #define FxaaTexOff(t, p, o, r) t.tex.SampleLevel(t.smpl, p, 0.0, o)", " #define FxaaTexAlpha4(t, p) t.tex.GatherAlpha(t.smpl, p)", " #define FxaaTexOffAlpha4(t, p, o) t.tex.GatherAlpha(t.smpl, p, o)", " #define FxaaTexGreen4(t, p) t.tex.GatherGreen(t.smpl, p)", " #define FxaaTexOffGreen4(t, p, o) t.tex.GatherGreen(t.smpl, p, o)", "#endif", "", "", "/*============================================================================", " GREEN AS LUMA OPTION SUPPORT FUNCTION", "============================================================================*/", "#if (FXAA_GREEN_AS_LUMA == 0)", " FxaaFloat FxaaLuma(FxaaFloat4 rgba) { return rgba.w; }", "#else", " FxaaFloat FxaaLuma(FxaaFloat4 rgba) { return rgba.y; }", "#endif", "", "", "", "", "/*============================================================================", "", " FXAA3 QUALITY - PC", "", "============================================================================*/", "#if (FXAA_PC == 1)", "/*--------------------------------------------------------------------------*/", "FxaaFloat4 FxaaPixelShader(", " //", " // Use noperspective interpolation here (turn off perspective interpolation).", " // {xy} = center of pixel", " FxaaFloat2 pos,", " //", " // Used only for FXAA Console, and not used on the 360 version.", " // Use noperspective interpolation here (turn off perspective interpolation).", " // {xy_} = upper left of pixel", " // {_zw} = lower right of pixel", " FxaaFloat4 fxaaConsolePosPos,", " //", " // Input color texture.", " // {rgb_} = color in linear or perceptual color space", " // if (FXAA_GREEN_AS_LUMA == 0)", " // {__a} = luma in perceptual color space (not linear)", " FxaaTex tex,", " //", " // Only used on the optimized 360 version of FXAA Console.", ' // For everything but 360, just use the same input here as for "tex".', " // For 360, same texture, just alias with a 2nd sampler.", " // This sampler needs to have an exponent bias of -1.", " FxaaTex fxaaConsole360TexExpBiasNegOne,", " //", " // Only used on the optimized 360 version of FXAA Console.", ' // For everything but 360, just use the same input here as for "tex".', " // For 360, same texture, just alias with a 3nd sampler.", " // This sampler needs to have an exponent bias of -2.", " FxaaTex fxaaConsole360TexExpBiasNegTwo,", " //", " // Only used on FXAA Quality.", " // This must be from a constant/uniform.", " // {x_} = 1.0/screenWidthInPixels", " // {_y} = 1.0/screenHeightInPixels", " FxaaFloat2 fxaaQualityRcpFrame,", " //", " // Only used on FXAA Console.", " // This must be from a constant/uniform.", " // This effects sub-pixel AA quality and inversely sharpness.", " // Where N ranges between,", " // N = 0.50 (default)", " // N = 0.33 (sharper)", " // {x__} = -N/screenWidthInPixels", " // {_y_} = -N/screenHeightInPixels", " // {_z_} = N/screenWidthInPixels", " // {__w} = N/screenHeightInPixels", " FxaaFloat4 fxaaConsoleRcpFrameOpt,", " //", " // Only used on FXAA Console.", " // Not used on 360, but used on PS3 and PC.", " // This must be from a constant/uniform.", " // {x__} = -2.0/screenWidthInPixels", " // {_y_} = -2.0/screenHeightInPixels", " // {_z_} = 2.0/screenWidthInPixels", " // {__w} = 2.0/screenHeightInPixels", " FxaaFloat4 fxaaConsoleRcpFrameOpt2,", " //", " // Only used on FXAA Console.", " // Only used on 360 in place of fxaaConsoleRcpFrameOpt2.", " // This must be from a constant/uniform.", " // {x__} = 8.0/screenWidthInPixels", " // {_y_} = 8.0/screenHeightInPixels", " // {_z_} = -4.0/screenWidthInPixels", " // {__w} = -4.0/screenHeightInPixels", " FxaaFloat4 fxaaConsole360RcpFrameOpt2,", " //", " // Only used on FXAA Quality.", " // This used to be the FXAA_QUALITY_SUBPIX define.", " // It is here now to allow easier tuning.", " // Choose the amount of sub-pixel aliasing removal.", " // This can effect sharpness.", " // 1.00 - upper limit (softer)", " // 0.75 - default amount of filtering", " // 0.50 - lower limit (sharper, less sub-pixel aliasing removal)", " // 0.25 - almost off", " // 0.00 - completely off", " FxaaFloat fxaaQualitySubpix,", " //", " // Only used on FXAA Quality.", " // This used to be the FXAA_QUALITY_EDGE_THRESHOLD define.", " // It is here now to allow easier tuning.", " // The minimum amount of local contrast required to apply algorithm.", " // 0.333 - too little (faster)", " // 0.250 - low quality", " // 0.166 - default", " // 0.125 - high quality", " // 0.063 - overkill (slower)", " FxaaFloat fxaaQualityEdgeThreshold,", " //", " // Only used on FXAA Quality.", " // This used to be the FXAA_QUALITY_EDGE_THRESHOLD_MIN define.", " // It is here now to allow easier tuning.", " // Trims the algorithm from processing darks.", " // 0.0833 - upper limit (default, the start of visible unfiltered edges)", " // 0.0625 - high quality (faster)", " // 0.0312 - visible limit (slower)", " // Special notes when using FXAA_GREEN_AS_LUMA,", " // Likely want to set this to zero.", " // As colors that are mostly not-green", " // will appear very dark in the green channel!", " // Tune by looking at mostly non-green content,", " // then start at zero and increase until aliasing is a problem.", " FxaaFloat fxaaQualityEdgeThresholdMin,", " //", " // Only used on FXAA Console.", " // This used to be the FXAA_CONSOLE_EDGE_SHARPNESS define.", " // It is here now to allow easier tuning.", " // This does not effect PS3, as this needs to be compiled in.", " // Use FXAA_CONSOLE_PS3_EDGE_SHARPNESS for PS3.", " // Due to the PS3 being ALU bound,", " // there are only three safe values here: 2 and 4 and 8.", " // These options use the shaders ability to a free *|/ by 2|4|8.", " // For all other platforms can be a non-power of two.", " // 8.0 is sharper (default!!!)", " // 4.0 is softer", " // 2.0 is really soft (good only for vector graphics inputs)", " FxaaFloat fxaaConsoleEdgeSharpness,", " //", " // Only used on FXAA Console.", " // This used to be the FXAA_CONSOLE_EDGE_THRESHOLD define.", " // It is here now to allow easier tuning.", " // This does not effect PS3, as this needs to be compiled in.", " // Use FXAA_CONSOLE_PS3_EDGE_THRESHOLD for PS3.", " // Due to the PS3 being ALU bound,", " // there are only two safe values here: 1/4 and 1/8.", " // These options use the shaders ability to a free *|/ by 2|4|8.", " // The console setting has a different mapping than the quality setting.", " // Other platforms can use other values.", " // 0.125 leaves less aliasing, but is softer (default!!!)", " // 0.25 leaves more aliasing, and is sharper", " FxaaFloat fxaaConsoleEdgeThreshold,", " //", " // Only used on FXAA Console.", " // This used to be the FXAA_CONSOLE_EDGE_THRESHOLD_MIN define.", " // It is here now to allow easier tuning.", " // Trims the algorithm from processing darks.", " // The console setting has a different mapping than the quality setting.", " // This only applies when FXAA_EARLY_EXIT is 1.", " // This does not apply to PS3,", " // PS3 was simplified to avoid more shader instructions.", " // 0.06 - faster but more aliasing in darks", " // 0.05 - default", " // 0.04 - slower and less aliasing in darks", " // Special notes when using FXAA_GREEN_AS_LUMA,", " // Likely want to set this to zero.", " // As colors that are mostly not-green", " // will appear very dark in the green channel!", " // Tune by looking at mostly non-green content,", " // then start at zero and increase until aliasing is a problem.", " FxaaFloat fxaaConsoleEdgeThresholdMin,", " //", " // Extra constants for 360 FXAA Console only.", " // Use zeros or anything else for other platforms.", " // These must be in physical constant registers and NOT immediates.", " // Immediates will result in compiler un-optimizing.", " // {xyzw} = float4(1.0, -1.0, 0.25, -0.25)", " FxaaFloat4 fxaaConsole360ConstDir", ") {", "/*--------------------------------------------------------------------------*/", " FxaaFloat2 posM;", " posM.x = pos.x;", " posM.y = pos.y;", " #if (FXAA_GATHER4_ALPHA == 1)", " #if (FXAA_DISCARD == 0)", " FxaaFloat4 rgbyM = FxaaTexTop(tex, posM);", " #if (FXAA_GREEN_AS_LUMA == 0)", " #define lumaM rgbyM.w", " #else", " #define lumaM rgbyM.y", " #endif", " #endif", " #if (FXAA_GREEN_AS_LUMA == 0)", " FxaaFloat4 luma4A = FxaaTexAlpha4(tex, posM);", " FxaaFloat4 luma4B = FxaaTexOffAlpha4(tex, posM, FxaaInt2(-1, -1));", " #else", " FxaaFloat4 luma4A = FxaaTexGreen4(tex, posM);", " FxaaFloat4 luma4B = FxaaTexOffGreen4(tex, posM, FxaaInt2(-1, -1));", " #endif", " #if (FXAA_DISCARD == 1)", " #define lumaM luma4A.w", " #endif", " #define lumaE luma4A.z", " #define lumaS luma4A.x", " #define lumaSE luma4A.y", " #define lumaNW luma4B.w", " #define lumaN luma4B.z", " #define lumaW luma4B.x", " #else", " FxaaFloat4 rgbyM = FxaaTexTop(tex, posM);", " #if (FXAA_GREEN_AS_LUMA == 0)", " #define lumaM rgbyM.w", " #else", " #define lumaM rgbyM.y", " #endif", " #if (FXAA_GLSL_100 == 1)", " FxaaFloat lumaS = FxaaLuma(FxaaTexOff(tex, posM, FxaaFloat2( 0.0, 1.0), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaE = FxaaLuma(FxaaTexOff(tex, posM, FxaaFloat2( 1.0, 0.0), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaN = FxaaLuma(FxaaTexOff(tex, posM, FxaaFloat2( 0.0,-1.0), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaW = FxaaLuma(FxaaTexOff(tex, posM, FxaaFloat2(-1.0, 0.0), fxaaQualityRcpFrame.xy));", " #else", " FxaaFloat lumaS = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2( 0, 1), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaE = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2( 1, 0), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaN = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2( 0,-1), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaW = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2(-1, 0), fxaaQualityRcpFrame.xy));", " #endif", " #endif", "/*--------------------------------------------------------------------------*/", " FxaaFloat maxSM = max(lumaS, lumaM);", " FxaaFloat minSM = min(lumaS, lumaM);", " FxaaFloat maxESM = max(lumaE, maxSM);", " FxaaFloat minESM = min(lumaE, minSM);", " FxaaFloat maxWN = max(lumaN, lumaW);", " FxaaFloat minWN = min(lumaN, lumaW);", " FxaaFloat rangeMax = max(maxWN, maxESM);", " FxaaFloat rangeMin = min(minWN, minESM);", " FxaaFloat rangeMaxScaled = rangeMax * fxaaQualityEdgeThreshold;", " FxaaFloat range = rangeMax - rangeMin;", " FxaaFloat rangeMaxClamped = max(fxaaQualityEdgeThresholdMin, rangeMaxScaled);", " FxaaBool earlyExit = range < rangeMaxClamped;", "/*--------------------------------------------------------------------------*/", " if(earlyExit)", " #if (FXAA_DISCARD == 1)", " FxaaDiscard;", " #else", " return rgbyM;", " #endif", "/*--------------------------------------------------------------------------*/", " #if (FXAA_GATHER4_ALPHA == 0)", " #if (FXAA_GLSL_100 == 1)", " FxaaFloat lumaNW = FxaaLuma(FxaaTexOff(tex, posM, FxaaFloat2(-1.0,-1.0), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaSE = FxaaLuma(FxaaTexOff(tex, posM, FxaaFloat2( 1.0, 1.0), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaNE = FxaaLuma(FxaaTexOff(tex, posM, FxaaFloat2( 1.0,-1.0), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaSW = FxaaLuma(FxaaTexOff(tex, posM, FxaaFloat2(-1.0, 1.0), fxaaQualityRcpFrame.xy));", " #else", " FxaaFloat lumaNW = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2(-1,-1), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaSE = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2( 1, 1), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaNE = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2( 1,-1), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaSW = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2(-1, 1), fxaaQualityRcpFrame.xy));", " #endif", " #else", " FxaaFloat lumaNE = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2(1, -1), fxaaQualityRcpFrame.xy));", " FxaaFloat lumaSW = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2(-1, 1), fxaaQualityRcpFrame.xy));", " #endif", "/*--------------------------------------------------------------------------*/", " FxaaFloat lumaNS = lumaN + lumaS;", " FxaaFloat lumaWE = lumaW + lumaE;", " FxaaFloat subpixRcpRange = 1.0/range;", " FxaaFloat subpixNSWE = lumaNS + lumaWE;", " FxaaFloat edgeHorz1 = (-2.0 * lumaM) + lumaNS;", " FxaaFloat edgeVert1 = (-2.0 * lumaM) + lumaWE;", "/*--------------------------------------------------------------------------*/", " FxaaFloat lumaNESE = lumaNE + lumaSE;", " FxaaFloat lumaNWNE = lumaNW + lumaNE;", " FxaaFloat edgeHorz2 = (-2.0 * lumaE) + lumaNESE;", " FxaaFloat edgeVert2 = (-2.0 * lumaN) + lumaNWNE;", "/*--------------------------------------------------------------------------*/", " FxaaFloat lumaNWSW = lumaNW + lumaSW;", " FxaaFloat lumaSWSE = lumaSW + lumaSE;", " FxaaFloat edgeHorz4 = (abs(edgeHorz1) * 2.0) + abs(edgeHorz2);", " FxaaFloat edgeVert4 = (abs(edgeVert1) * 2.0) + abs(edgeVert2);", " FxaaFloat edgeHorz3 = (-2.0 * lumaW) + lumaNWSW;", " FxaaFloat edgeVert3 = (-2.0 * lumaS) + lumaSWSE;", " FxaaFloat edgeHorz = abs(edgeHorz3) + edgeHorz4;", " FxaaFloat edgeVert = abs(edgeVert3) + edgeVert4;", "/*--------------------------------------------------------------------------*/", " FxaaFloat subpixNWSWNESE = lumaNWSW + lumaNESE;", " FxaaFloat lengthSign = fxaaQualityRcpFrame.x;", " FxaaBool horzSpan = edgeHorz >= edgeVert;", " FxaaFloat subpixA = subpixNSWE * 2.0 + subpixNWSWNESE;", "/*--------------------------------------------------------------------------*/", " if(!horzSpan) lumaN = lumaW;", " if(!horzSpan) lumaS = lumaE;", " if(horzSpan) lengthSign = fxaaQualityRcpFrame.y;", " FxaaFloat subpixB = (subpixA * (1.0/12.0)) - lumaM;", "/*--------------------------------------------------------------------------*/", " FxaaFloat gradientN = lumaN - lumaM;", " FxaaFloat gradientS = lumaS - lumaM;", " FxaaFloat lumaNN = lumaN + lumaM;", " FxaaFloat lumaSS = lumaS + lumaM;", " FxaaBool pairN = abs(gradientN) >= abs(gradientS);", " FxaaFloat gradient = max(abs(gradientN), abs(gradientS));", " if(pairN) lengthSign = -lengthSign;", " FxaaFloat subpixC = FxaaSat(abs(subpixB) * subpixRcpRange);", "/*--------------------------------------------------------------------------*/", " FxaaFloat2 posB;", " posB.x = posM.x;", " posB.y = posM.y;", " FxaaFloat2 offNP;", " offNP.x = (!horzSpan) ? 0.0 : fxaaQualityRcpFrame.x;", " offNP.y = ( horzSpan) ? 0.0 : fxaaQualityRcpFrame.y;", " if(!horzSpan) posB.x += lengthSign * 0.5;", " if( horzSpan) posB.y += lengthSign * 0.5;", "/*--------------------------------------------------------------------------*/", " FxaaFloat2 posN;", " posN.x = posB.x - offNP.x * FXAA_QUALITY_P0;", " posN.y = posB.y - offNP.y * FXAA_QUALITY_P0;", " FxaaFloat2 posP;", " posP.x = posB.x + offNP.x * FXAA_QUALITY_P0;", " posP.y = posB.y + offNP.y * FXAA_QUALITY_P0;", " FxaaFloat subpixD = ((-2.0)*subpixC) + 3.0;", " FxaaFloat lumaEndN = FxaaLuma(FxaaTexTop(tex, posN));", " FxaaFloat subpixE = subpixC * subpixC;", " FxaaFloat lumaEndP = FxaaLuma(FxaaTexTop(tex, posP));", "/*--------------------------------------------------------------------------*/", " if(!pairN) lumaNN = lumaSS;", " FxaaFloat gradientScaled = gradient * 1.0/4.0;", " FxaaFloat lumaMM = lumaM - lumaNN * 0.5;", " FxaaFloat subpixF = subpixD * subpixE;", " FxaaBool lumaMLTZero = lumaMM < 0.0;", "/*--------------------------------------------------------------------------*/", " lumaEndN -= lumaNN * 0.5;", " lumaEndP -= lumaNN * 0.5;", " FxaaBool doneN = abs(lumaEndN) >= gradientScaled;", " FxaaBool doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P1;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P1;", " FxaaBool doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P1;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P1;", "/*--------------------------------------------------------------------------*/", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P2;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P2;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P2;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P2;", "/*--------------------------------------------------------------------------*/", " #if (FXAA_QUALITY_PS > 3)", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P3;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P3;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P3;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P3;", "/*--------------------------------------------------------------------------*/", " #if (FXAA_QUALITY_PS > 4)", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P4;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P4;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P4;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P4;", "/*--------------------------------------------------------------------------*/", " #if (FXAA_QUALITY_PS > 5)", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P5;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P5;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P5;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P5;", "/*--------------------------------------------------------------------------*/", " #if (FXAA_QUALITY_PS > 6)", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P6;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P6;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P6;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P6;", "/*--------------------------------------------------------------------------*/", " #if (FXAA_QUALITY_PS > 7)", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P7;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P7;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P7;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P7;", "/*--------------------------------------------------------------------------*/", " #if (FXAA_QUALITY_PS > 8)", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P8;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P8;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P8;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P8;", "/*--------------------------------------------------------------------------*/", " #if (FXAA_QUALITY_PS > 9)", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P9;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P9;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P9;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P9;", "/*--------------------------------------------------------------------------*/", " #if (FXAA_QUALITY_PS > 10)", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P10;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P10;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P10;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P10;", "/*--------------------------------------------------------------------------*/", " #if (FXAA_QUALITY_PS > 11)", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P11;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P11;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P11;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P11;", "/*--------------------------------------------------------------------------*/", " #if (FXAA_QUALITY_PS > 12)", " if(doneNP) {", " if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));", " if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));", " if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;", " if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;", " doneN = abs(lumaEndN) >= gradientScaled;", " doneP = abs(lumaEndP) >= gradientScaled;", " if(!doneN) posN.x -= offNP.x * FXAA_QUALITY_P12;", " if(!doneN) posN.y -= offNP.y * FXAA_QUALITY_P12;", " doneNP = (!doneN) || (!doneP);", " if(!doneP) posP.x += offNP.x * FXAA_QUALITY_P12;", " if(!doneP) posP.y += offNP.y * FXAA_QUALITY_P12;", "/*--------------------------------------------------------------------------*/", " }", " #endif", "/*--------------------------------------------------------------------------*/", " }", " #endif", "/*--------------------------------------------------------------------------*/", " }", " #endif", "/*--------------------------------------------------------------------------*/", " }", " #endif", "/*--------------------------------------------------------------------------*/", " }", " #endif", "/*--------------------------------------------------------------------------*/", " }", " #endif", "/*--------------------------------------------------------------------------*/", " }", " #endif", "/*--------------------------------------------------------------------------*/", " }", " #endif", "/*--------------------------------------------------------------------------*/", " }", " #endif", "/*--------------------------------------------------------------------------*/", " }", " #endif", "/*--------------------------------------------------------------------------*/", " }", "/*--------------------------------------------------------------------------*/", " FxaaFloat dstN = posM.x - posN.x;", " FxaaFloat dstP = posP.x - posM.x;", " if(!horzSpan) dstN = posM.y - posN.y;", " if(!horzSpan) dstP = posP.y - posM.y;", "/*--------------------------------------------------------------------------*/", " FxaaBool goodSpanN = (lumaEndN < 0.0) != lumaMLTZero;", " FxaaFloat spanLength = (dstP + dstN);", " FxaaBool goodSpanP = (lumaEndP < 0.0) != lumaMLTZero;", " FxaaFloat spanLengthRcp = 1.0/spanLength;", "/*--------------------------------------------------------------------------*/", " FxaaBool directionN = dstN < dstP;", " FxaaFloat dst = min(dstN, dstP);", " FxaaBool goodSpan = directionN ? goodSpanN : goodSpanP;", " FxaaFloat subpixG = subpixF * subpixF;", " FxaaFloat pixelOffset = (dst * (-spanLengthRcp)) + 0.5;", " FxaaFloat subpixH = subpixG * fxaaQualitySubpix;", "/*--------------------------------------------------------------------------*/", " FxaaFloat pixelOffsetGood = goodSpan ? pixelOffset : 0.0;", " FxaaFloat pixelOffsetSubpix = max(pixelOffsetGood, subpixH);", " if(!horzSpan) posM.x += pixelOffsetSubpix * lengthSign;", " if( horzSpan) posM.y += pixelOffsetSubpix * lengthSign;", " #if (FXAA_DISCARD == 1)", " return FxaaTexTop(tex, posM);", " #else", " return FxaaFloat4(FxaaTexTop(tex, posM).xyz, lumaM);", " #endif", "}", "/*==========================================================================*/", "#endif", "", "void main() {", " gl_FragColor = FxaaPixelShader(", " vUv,", " vec4(0.0),", " tDiffuse,", " tDiffuse,", " tDiffuse,", " resolution,", " vec4(0.0),", " vec4(0.0),", " vec4(0.0),", " 0.75,", " 0.166,", " 0.0833,", " 0.0,", " 0.0,", " 0.0,", " vec4(0.0)", " );", "", " // TODO avoid querying texture twice for same texel", " gl_FragColor.a = texture2D(tDiffuse, vUv).a;", "}"].join("\n") }, Iy = function (A, e, t, i, o) { gy.call(this), this.scene = A, this.camera = e, this.overrideMaterial = t, this.clearColor = i, this.clearAlpha = void 0 !== o ? o : 0, this.clear = !0, this.clearDepth = !1, this.needsSwap = !1 }; Iy.prototype = Object.assign(Object.create(gy.prototype), { constructor: Iy, render: function (A, e, t) { var i = A.autoClear; A.autoClear = !1, this.scene.overrideMaterial = this.overrideMaterial; var o = null, n = null; this.clearColor && (n = A.getClearColor().getHex(), o = A.getClearAlpha(), A.setClearColor(this.clearColor, this.clearAlpha)), this.clearDepth && A.clearDepth(), A.setRenderTarget(this.renderToScreen ? null : t), this.clear && A.clear(A.autoClearColor, A.autoClearDepth, A.autoClearStencil), A.render(this.scene, this.camera), this.clearColor && A.setClearColor(n, o), this.scene.overrideMaterial = null, A.autoClear = i } }); var Ey = function (A, e, t, i, o) { gy.call(this), this.modelManager = e, this.renderScene = t, this.renderCamera = i, this.selectedObjectIds = void 0 !== o ? o : [], this.defaultEdgeColor = (new LA).setHex(4173056), this.defaultEdgeAlpha = .95, this.edgeColor = new p(this.defaultEdgeColor.r, this.defaultEdgeColor.g, this.defaultEdgeColor.b, this.defaultEdgeAlpha), this.edgeLength = 2, this.resolution = void 0 !== A ? new s(A.x, A.y) : new s(256, 256); var n = { minFilter: 1006, magFilter: 1006, format: 1023 }; this.renderTargetDepthBuffer = new g(this.resolution.x, this.resolution.y, n), this.renderTargetDepthBuffer.texture.name = "OutlinePass.depth", this.renderTargetDepthBuffer.texture.generateMipmaps = !1, this.renderTargetMaskBuffer = new g(this.resolution.x, this.resolution.y, n), this.renderTargetMaskBuffer.texture.name = "OutlinePass.mask", this.renderTargetMaskBuffer.texture.generateMipmaps = !1, this.renderTargetMaskDownSampleBuffer = new g(this.resolution.x, this.resolution.y, n), this.renderTargetMaskDownSampleBuffer.texture.name = "OutlinePass.depthDownSample", this.renderTargetMaskDownSampleBuffer.texture.generateMipmaps = !1, this.renderTargetEdgeBuffer = new g(this.resolution.x, this.resolution.y, n), this.renderTargetEdgeBuffer.texture.name = "OutlinePass.edge", this.renderTargetEdgeBuffer.texture.generateMipmaps = !1, this.renderTargetColorBuffer = new g(this.resolution.x, this.resolution.y, n), this.renderTargetColorBuffer.texture.name = "OutlinePass.color", this.renderTargetColorBuffer.texture.generateMipmaps = !1, this.depthMaterial = new ji, this.depthMaterial.side = 2, this.depthMaterial.depthPacking = 3201, this.depthMaterial.blending = 0, this.InstancedDepthMaterial = new Su, this.InstancedDepthMaterial.side = 2, this.InstancedDepthMaterial.depthPacking = 3201, this.InstancedDepthMaterial.blending = 0, this.prepareMaskMaterial = this.getPrepareMaskMaterial(), this.prepareMaskMaterial.side = 2, this.prepareMaskInstancedMaterial = this.getPrepareMaskInstancedMaterial(), this.prepareMaskInstancedMaterial.side = 2, this.edgeDetectionMaterial = this.getEdgeDetectionMaterial(), this.overlayMaterial = this.getOverlayMaterial(), void 0 === py && console.error("OutlinePass relies on THREE.CopyShader"); var r = py; return this.copyUniforms = Ge.clone(r.uniforms), this.copyUniforms.opacity.value = 1, this.materialCopy = new Pe({ uniforms: this.copyUniforms, vertexShader: r.vertexShader, fragmentShader: r.fragmentShader, blending: 0, depthTest: !1, depthWrite: !1, transparent: !0 }), this.enabled = !0, this.needsSwap = !1, this.oldClearColor = new LA, this.oldClearAlpha = 1, this.camera = new Ka(-1, 1, 1, -1, 0, 1), this.scene = new Y, this.quad = new Ue(new et(2, 2), null), this.quad.frustumCulled = !1, this.scene.add(this.quad), this.textureMatrix = new M, this }; Ey.prototype.dispose = function () { this.renderTargetDepthBuffer.dispose(), this.renderTargetMaskBuffer.dispose(), this.renderTargetMaskDownSampleBuffer.dispose(), this.renderTargetEdgeBuffer.dispose(), this.renderTargetColorBuffer.dispose() }, Ey.prototype.setSize = function (A, e) { this.renderTargetDepthBuffer.setSize(A, e), this.renderTargetMaskBuffer.setSize(A, e), this.renderTargetMaskDownSampleBuffer.setSize(A, e), this.renderTargetEdgeBuffer.setSize(A, e), this.renderTargetColorBuffer.setSize(A, e) }, Ey.prototype.adjustVisibilityOfObjectsWithoutOutline = function (A) { this.modelManager.adjustVisibilityOfObjectsWithoutOutline(A) }, Ey.prototype.adjustVisibility = function (A) { this.modelManager.adjustVisibility(A) }, Ey.prototype.changeVisibilityOfSelectedObjects = function (A) { this.modelManager.changeVisibilityOfSelectedObjects(A) }, Ey.prototype.changeVisibilityOfNonSelectedObjects = function (A) { this.modelManager.changeVisibilityOfNonSelectedObjects(A) }, Ey.prototype.adjustInstanceVisibility = function (A) { this.modelManager.adjustInstanceVisibility(A) }, Ey.prototype.changeInstanceVisibilityOfSelectedObjects = function (A) { this.modelManager.changeInstanceVisibilityOfSelectedObjects(A) }, Ey.prototype.changeInstanceVisibilityOfNonSelectedObjects = function (A) { this.modelManager.changeInstanceVisibilityOfNonSelectedObjects(A) }, Ey.prototype.restoreVisibilityOfObjects = function () { this.modelManager.restoreVisibilityOfObjects() }, Ey.prototype.updateTextureMatrix = function () { this.textureMatrix.set(.5, 0, 0, .5, 0, .5, 0, .5, 0, 0, .5, .5, 0, 0, 0, 1), this.textureMatrix.multiply(this.renderCamera.projectionMatrix), this.textureMatrix.multiply(this.renderCamera.matrixWorldInverse) }, Ey.prototype.render = function (A, e, t, i, o) { this.oldClearColor.copy(A.getClearColor()), this.oldClearAlpha = A.getClearAlpha(); var n = A.autoClear; A.autoClear = !1, o && A.state.buffers.stencil.setTest(!1), A.setClearColor(0, 0), this.adjustVisibilityOfObjectsWithoutOutline(!1), this.adjustInstanceVisibility(!1), this.changeVisibilityOfSelectedObjects(!1), this.renderScene.overrideMaterial = this.depthMaterial, A.setRenderTarget(this.renderTargetDepthBuffer), A.clear(), A.render(this.renderScene, this.renderCamera), this.adjustInstanceVisibility(!0), this.changeVisibilityOfSelectedObjects(!0), this.adjustVisibility(!1), this.changeInstanceVisibilityOfSelectedObjects(!1), this.renderScene.overrideMaterial = this.InstancedDepthMaterial, A.setRenderTarget(this.renderTargetDepthBuffer), A.render(this.renderScene, this.renderCamera), this.adjustVisibility(!0), this.changeInstanceVisibilityOfSelectedObjects(!0), this.updateTextureMatrix(), this.adjustInstanceVisibility(!1), this.changeVisibilityOfNonSelectedObjects(!1), this.adjustVisibilityOfObjectsWithoutOutline(!1), this.renderScene.overrideMaterial = this.prepareMaskMaterial, this.prepareMaskMaterial.uniforms.cameraNearFar.value = new s(this.renderCamera.near, this.renderCamera.far), this.prepareMaskMaterial.uniforms.depthTexture.value = this.renderTargetDepthBuffer.texture, this.prepareMaskMaterial.uniforms.textureMatrix.value = this.textureMatrix, A.setRenderTarget(this.renderTargetMaskBuffer), A.clear(), A.render(this.renderScene, this.renderCamera), this.adjustInstanceVisibility(!0), this.changeVisibilityOfNonSelectedObjects(!0), this.adjustVisibility(!1), this.changeInstanceVisibilityOfNonSelectedObjects(!1), this.adjustVisibilityOfObjectsWithoutOutline(!1), this.renderScene.overrideMaterial = this.prepareMaskInstancedMaterial, this.prepareMaskInstancedMaterial.uniforms.cameraNearFar.value = new s(this.renderCamera.near, this.renderCamera.far), this.prepareMaskInstancedMaterial.uniforms.depthTexture.value = this.renderTargetDepthBuffer.texture, this.prepareMaskInstancedMaterial.uniforms.textureMatrix.value = this.textureMatrix, A.setRenderTarget(this.renderTargetMaskBuffer), A.render(this.renderScene, this.renderCamera), this.renderScene.overrideMaterial = null, this.adjustVisibility(!0), this.changeInstanceVisibilityOfNonSelectedObjects(!0), this.restoreVisibilityOfObjects(), this.quad.material = this.materialCopy, this.copyUniforms.tDiffuse.value = this.renderTargetMaskBuffer.texture, A.setRenderTarget(this.renderTargetMaskDownSampleBuffer), A.clear(), A.render(this.scene, this.camera), this.quad.material = this.edgeDetectionMaterial, this.edgeDetectionMaterial.uniforms.maskTexture.value = this.renderTargetMaskDownSampleBuffer.texture, this.edgeDetectionMaterial.uniforms.texSize.value = new s(this.renderTargetMaskDownSampleBuffer.width, this.renderTargetMaskDownSampleBuffer.height), this.edgeDetectionMaterial.uniforms.edgeColor.value = this.edgeColor, this.edgeDetectionMaterial.uniforms.edgeLength.value = this.edgeLength, A.setRenderTarget(this.renderTargetEdgeBuffer), A.clear(), A.render(this.scene, this.camera), this.quad.material = this.overlayMaterial, this.overlayMaterial.uniforms.colorTexture.value = t.texture, this.overlayMaterial.uniforms.outlineTexture.value = this.renderTargetEdgeBuffer.texture, A.setRenderTarget(this.renderTargetColorBuffer), A.clear(), A.render(this.scene, this.camera), this.quad.material = this.materialCopy, this.copyUniforms.tDiffuse.value = this.renderTargetColorBuffer.texture, o && A.state.buffers.stencil.setTest(!0), A.setRenderTarget(t), A.clear(), this.adjustVisibilityOfObjectsWithoutOutline(!0), A.render(this.scene, this.camera), A.setClearColor(this.oldClearColor, this.oldClearAlpha), A.autoClear = n }, Ey.prototype.getPrepareMaskMaterial = function () { return new Pe({ uniforms: { depthTexture: { value: null }, cameraNearFar: { value: new s(.5, .5) }, textureMatrix: { value: new M } }, vertexShader: "varying vec2 vUv;\n\t\t\t\tvarying vec4 projTexCoord;\n\t\t\t\tvarying vec4 vPosition;\n\t\t\t\tuniform mat4 textureMatrix;\n\t\t\t\tvoid main() {\n\t\t\t\t\tvUv = uv;\n\t\t\t\t\tvPosition = modelViewMatrix * vec4( position, 1.0 );\n\t\t\t\t\tvec4 worldPosition = modelMatrix * vec4( position, 1.0 );\n\t\t\t\t\tprojTexCoord = textureMatrix * worldPosition;\n\t\t\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\t\t\t\t}", fragmentShader: "\n #include \n\t\t\t\tvarying vec2 vUv;\n\t\t\t\tvarying vec4 vPosition;\n\t\t\t\tvarying vec4 projTexCoord;\n\t\t\t\tuniform sampler2D depthTexture;\n\t\t\t\tuniform vec2 cameraNearFar;\n\t\t\t\t\n\t\t\t\tfloat linearDepth(float depth)\n {\n float far = cameraNearFar.y;\n float near = cameraNearFar.x;\n return (2.0 * near) / (far + near - depth * (far - near));\n }\n\t\t\t\t\n\t\t\t\tvoid main() {\n\t\t\t\t\tfloat depth = unpackRGBAToDepth(texture2DProj( depthTexture, projTexCoord ));\t\t\t\t\t\n\t\t\t\t\tgl_FragColor = vec4(depth);\n\t\t\t\t}" }) }, Ey.prototype.getPrepareMaskInstancedMaterial = function () { return new Pe({ uniforms: { depthTexture: { value: null }, cameraNearFar: { value: new s(.5, .5) }, textureMatrix: { value: new M } }, vertexShader: "\n attribute float vState; \n attribute vec4 aColor; \n attribute vec3 mcol0;\n attribute vec3 mcol1;\n attribute vec3 mcol2;\n attribute vec3 mcol3;\n #if defined(USE_MAP)\n attribute vec2 muvCol0;\n attribute vec2 muvCol1;\n attribute vec2 muvCol2;\n #endif\n \n varying float vfState;\n varying vec2 vUv;\n\t\t\t\tvarying vec4 projTexCoord;\n\t\t\t\tvarying vec4 vPosition;\n\t\t\t\tuniform mat4 textureMatrix;\n\t\t\t\t\n\t\t\t\tvec3 getInstancePosition(vec3 position) {\n return vec3(mat4(vec4(mcol0, 0.0),\n vec4(mcol1, 0.0),\n vec4(mcol2, 0.0),\n vec4(mcol3, 1.0)) * vec4(position, 1.0));\n }\n \n vec2 getInstanceUV(vec2 uv) {\n \n #if defined(USE_MAP)\n return vec2(mat3(vec3(muvCol0, 0.0),\n vec3(muvCol1, 0.0), \n vec3(muvCol2, 1.0)) * vec3(uv, 1.0));\n #else\n return uv;\n #endif \n \n }\n \n\t\t\t\tvoid main() {\n\t\t\t\t vfState = vState;\n\t\t\t\t\tvUv = uv;\n\t\t\t\t\tvPosition = vec4(getInstancePosition(position), 1.0);\n\t\t\t\t\tvec4 worldPosition = modelMatrix * vPosition;\n\t\t\t\t\tprojTexCoord = textureMatrix * worldPosition;\n\t\t\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vPosition;\n\t\t\t\t}", fragmentShader: "#include \n varying float vfState;\n varying vec2 vUv;\n varying vec4 vPosition;\n varying vec4 projTexCoord;\n uniform sampler2D depthTexture;\n uniform vec2 cameraNearFar;\n \n float linearDepth(float depth)\n {\n float far = cameraNearFar.y;\n float near = cameraNearFar.x;\n return (2.0 * near) / (far + near - depth * (far - near));\n }\n \n void main() {\n if (vfState <= -0.99 && vfState >= -1.01) discard;\n float depth = unpackRGBAToDepth(texture2DProj( depthTexture, projTexCoord ));\n gl_FragColor = vec4(depth);\n }" }) }, Ey.prototype.getEdgeDetectionMaterial = function () { return new Pe({ uniforms: { maskTexture: { value: null }, texSize: { value: new s(.5, .5) }, edgeColor: { value: new p(1, 1, 1, 1) }, edgeLength: { value: 2 } }, vertexShader: "\n varying vec2 vUv;\n\t\t\t\tvoid main() {\n\t\t\t\t\tvUv = uv;\n\t\t\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\t\t\t\t}", fragmentShader: "\n varying vec2 vUv;\n\t\t\t\tuniform sampler2D maskTexture;\n\t\t\t\tuniform vec2 texSize;\n\t\t\t\tuniform vec4 edgeColor;\n uniform float edgeLength; \n \n void main(void)\n {\n float directions[3];\n directions[0] = -1.0;\n directions[1] = 0.0;\n directions[2] = 1.0;\n \n float scalars[3];\n scalars[0] = 3.0;\n scalars[1] = 10.0;\n scalars[2] = 3.0;\n \n float padx = 1.0 / texSize.x;\n float pady = 1.0 / texSize.y ; \n \n float edgeSize = 0.0; \n float horizEdge = 0.0;\n float vertEdge = 0.0; \n \n for (int i = 0; i < 3; ++i)\n {\n float dir = directions[i];\n float scale = scalars[i];\n \n horizEdge -= texture2D(maskTexture, vUv + vec2(-padx, dir * pady)).x * scale;\n horizEdge += texture2D(maskTexture, vUv + vec2(padx, dir * pady)).x * scale;\n \n vertEdge -= texture2D(maskTexture, vUv + vec2(dir * padx, -pady)).x * scale;\n vertEdge += texture2D(maskTexture, vUv + vec2(dir * padx, pady)).x * scale;\n } \n \n float len = sqrt(horizEdge * horizEdge + vertEdge * vertEdge); \n float alpha = len > edgeLength ? edgeColor.a : (texture2D(maskTexture, vUv).w > 0.1 ? 0.1 : 0.0);\n gl_FragColor = vec4(edgeColor.rgb, alpha);\n }" }) }, Ey.prototype.getOverlayMaterial = function () { return new Pe({ uniforms: { colorTexture: { value: null }, outlineTexture: { value: null } }, vertexShader: "varying vec2 vUv;\n\t\t\t\tvoid main() {\n\t\t\t\t\tvUv = uv;\n\t\t\t\t\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n\t\t\t\t}", fragmentShader: "varying vec2 vUv;\n\t\t\t\tuniform sampler2D colorTexture;\n\t\t\t\tuniform sampler2D outlineTexture;\n\t\t\t\t\n\t\t\t\tvoid main() {\n\t\t\t\t\tvec4 outlineColor = texture2D(outlineTexture, vUv);\t\t\t\t\t\n\t\t\t\t\tgl_FragColor = mix(texture2D(colorTexture, vUv), outlineColor, outlineColor.a);\t\t\t\t\t\n\t\t\t\t}", blending: 2, depthTest: !1, depthWrite: !1, transparent: !0 }) }, Ey.prototype.setOutlineEdgeColor = function (A) { this.edgeColor.fromArray([A.r, A.g, A.b, A.opacity ? A.opacity : 1]) }, Ey.prototype.getOutlineEdgeColor = function (A) { return (new Xh).fromArray(this.edgeColor.toArray()) }; var By = function (A) { this.renderer = A, this.composer = null, this.renderPass = null, this.outlinePass = null, this.effectFXAA = null, this.selectedObjectIds = [] }; By.prototype.destroy = function () { this.renderer = null, this.composer = null, this.renderPass = null, this.outlinePass = null, this.effectFXAA = null, this.selectedObjectIds = null }, By.prototype.init = function (A, e, t, i, o) { this.composer = new Cy(this.renderer), this.renderPass = new Iy(e, t), this.composer.addPass(this.renderPass), this.outlinePass = new Ey(new s(i, o), A, e, t), this.composer.addPass(this.outlinePass), this.effectFXAA = new uy(vy), this.effectFXAA.uniforms.resolution.value.set(1 / i, 1 / o), this.effectFXAA.renderToScreen = !0, this.composer.addPass(this.effectFXAA) }, By.prototype.reinit = function (A, e, t, i, o, n) { this.renderer = A, this.composer = new Cy(this.renderer), this.renderPass = this.renderPass || new Iy(t, i), this.composer.addPass(this.renderPass), this.outlinePass = this.outlinePass || new Ey(new s(o, n), e, t, i), this.composer.addPass(this.outlinePass), this.effectFXAA = this.effectFXAA || new uy(vy), this.effectFXAA.uniforms.resolution.value.set(1 / o, 1 / n), this.effectFXAA.renderToScreen = !0, this.composer.addPass(this.effectFXAA) }, By.prototype.render = function () { this.composer.render() }, By.prototype.setSize = function (A, e) { this.composer.setSize(A, e), this.effectFXAA.uniforms.resolution.value.set(1 / A, 1 / e) }, By.prototype.addSelectedId = function (A) { this.selectedObjectIds.push(A) }, By.prototype.clearSelectedIds = function () { this.selectedObjectIds.length = 0 }, By.prototype.setSelectedIds = function (A) { if (this.outlinePass) { this.clearSelectedIds(); for (var e = 0, t = A.length; t > e; e += 1) this.addSelectedId(A[e]); this.outlinePass.selectedObjectIds = this.selectedObjectIds } }, By.prototype.setOutlineEdgeColor = function (A) { this.outlinePass.setOutlineEdgeColor(A) }, By.prototype.getOutlineEdgeColor = function () { return this.outlinePass.getOutlineEdgeColor() }; var xy = function (A) { jA.call(this, A), this.type = "InstancedMeshBasicMaterial", this.uniforms = it.basic.uniforms, this.vertexShader = function (A) { return A.replace("#include ", "\n vec4 mvPosition = modelViewMatrix * vec4(getInstancePosition(transformed), 1.0);\n gl_Position = projectionMatrix * mvPosition;\n ") }(it.basic.vertexShader.replace("void main() {", "\n attribute float vState; \n attribute vec3 mcol0;\n attribute vec3 mcol1;\n attribute vec3 mcol2;\n attribute vec3 mcol3; \n varying float vfState;\n \n vec3 getInstancePosition(vec3 position) {\n return vec3(mat4(vec4(mcol0, 0.0),\n vec4(mcol1, 0.0),\n vec4(mcol2, 0.0),\n vec4(mcol3, 1.0)) * vec4(position, 1.0));\n }\n \n void main() {\n vfState = vState;\n ")), this.fragmentShader = it.basic.fragmentShader.replace("void main() {", "\n varying float vfState; \n void main() {\n if (vfState <= -0.99 && vfState >= -1.01) discard;\n \n ") }; (xy.prototype = Object.create(jA.prototype)).constructor = xy; var Sy = function (A) { this.viewer = A; var e = vc.SelectionColor.color; this.wireframeMaterial = new jA({ color: e, opacity: 1, transparent: !0, blending: 5, blendSrc: 201, blendDst: 200, blendEquation: 100 }), this.selectedMaterial = new jA({ color: e, opacity: .3, transparent: !0 }), this.skinningWireframeMaterial = new jA({ color: e, opacity: 1, transparent: !0, blending: 5, blendSrc: 201, blendDst: 200, blendEquation: 100, skinning: !0 }), this.skinningSelectedMaterial = new jA({ color: e, opacity: .3, transparent: !0, skinning: !0 }), this.selectedLineMaterial = new YC({ color: e, opacity: 1, transparent: !0, linewidth: 2, dashed: !1 }), this.instancedWireFrameMaterial = new xy({ color: e, opacity: 1, transparent: !0, blending: 5, blendSrc: 201, blendDst: 200, blendEquation: 100 }), this.instancedSelectedMaterial = new xy({ color: e, opacity: .3, transparent: !0 }), this.selectionScene = new Y, this.selectionScene.autoUpdate = !1, this.selectionObjectGroup = new ep, this.selectionObjectGroup.name = "PickingObjectGroup", this.selectionObjectGroup.matrixAutoUpdate = !1, this.selectionScene.add(this.selectionObjectGroup), this.lastSelectedUserIdMap = null, this.lastSelectedUserIds = null }; Sy.prototype.destroy = function () { this.wireframeMaterial.dispose(), this.wireframeMaterial = null, this.selectedMaterial.dispose(), this.selectedMaterial = null, this.skinningWireframeMaterial.dispose(), this.skinningWireframeMaterial = null, this.skinningSelectedMaterial.dispose(), this.skinningSelectedMaterial = null, this.selectedLineMaterial.dispose(), this.selectedLineMaterial = null, this.instancedWireFrameMaterial.dispose(), this.instancedWireFrameMaterial = null, this.instancedSelectedMaterial.dispose(), this.instancedSelectedMaterial = null, this.selectionObjectGroup.clear(), this.selectionObjectGroup = null, this.selectionScene = null, this.lastSelectedUserIdMap = null, this.lastSelectedUserIds = null, this.viewer = null }, Sy.prototype.apply = function (A) { var e = this.viewer, t = e.getSelection(); if (!t || !t.length) return this._clearSelectedUserIdsCache(), void this._clearMeshesFromScene(); (A || this._isSelectionsChanged()) && (this._cacheSelectedUserIds(t), this._updateScene(t)), this._render(e.rendererManager.getRenderer(), e.camera) }, Sy.prototype._isSelectionsChanged = function () { var A = this.lastSelectedUserIds; if (!A) return !0; var e = this.viewer.getSelection(), t = e.length; if (t !== A.length) return !0; for (var i = !1, o = this.lastSelectedUserIdMap, n = t - 1; n >= 0; n -= 1) if (!o[e[n]]) { i = !0; break } return i }, Sy.prototype._cacheSelectedUserIds = function (A) { this.lastSelectedUserIds = A.slice(0), this.lastSelectedUserIdMap = uh.arrayToMap(A) }, Sy.prototype._clearSelectedUserIdsCache = function () { this.lastSelectedUserIds = null, this.lastSelectedUserIdMap = null }, Sy.prototype._render = function (A, e) { var t = A.autoClearColor, i = A.autoClearDepth, o = A.autoClearStencil; A.autoClearColor = !1, A.autoClearDepth = !0, A.autoClearStencil = !1, A.render(this.selectionScene, e), A.autoClearColor = t, A.autoClearDepth = i, A.autoClearStencil = o }, Sy.prototype._updateScene = function (A) { this._clearMeshesFromScene(), this._addMeshesToScene(this._getSelectedMeshes(A)), this._updateMatrixWorldForScene(), this._updateSelectedLineMaterial() }, Sy.prototype._clearMeshesFromScene = function () { this.selectionObjectGroup.clear() }, Sy.prototype._addMeshesToScene = function (A) { for (var e = 0, t = A.length; t > e; e += 1) this.selectionObjectGroup.add(A[e]) }, Sy.prototype._updateMatrixWorldForScene = function () { this.selectionObjectGroup.matrix.copy(this.viewer.getScene().getMatrixGlobal()), this.selectionObjectGroup.updateMatrixWorld(!0) }, Sy.prototype._getSelectedMeshes = function (A) { var e = { meshes: [] }, t = this, i = uh.arrayToMap(A); return this.viewer.getModelManager().traverseLoadedModels((function (o) { o.getPickingMeshes(t, e, A, i) })), e.meshes }, Sy.prototype._updateSelectedLineMaterial = function () { vc.PickingLineWidthEnabled && this.selectedLineMaterial.resolution.set(this.viewer.domElement.offsetWidth, this.viewer.domElement.offsetHeight) }, Sy.prototype.setSelectionColor = function (A, e) { var t = this.selectedMaterial.opacity; e = void 0 === e ? t : e, "0x" + this.selectedMaterial.color.getHexString() === A && t === e || (this.selectedMaterial.color.setHex(A), this.skinningSelectedMaterial.color.setHex(A), this.instancedSelectedMaterial.color.setHex(A), void 0 === e && null === e || (this.selectedMaterial.opacity = e, this.skinningSelectedMaterial.opacity = e, this.instancedSelectedMaterial.opacity = e, 1 > e ? (this.selectedMaterial.transparent = !0, this.skinningSelectedMaterial.transparent = !0, this.instancedSelectedMaterial.transparent = !0) : (this.selectedMaterial.transparent = !1, this.skinningSelectedMaterial.transparent = !1, this.instancedSelectedMaterial.transparent = !1)), this.selectedMaterial.needsUpdate = !0, this.skinningSelectedMaterial.needsUpdate = !0, this.instancedSelectedMaterial.needsUpdate = !0) }, Sy.prototype.getSelectionColor = function (A, e) { var t = this.selectedMaterial.opacity; return new Xh(this.selectedMaterial.color.getHex(), t) }, Sy.prototype.setLineSelectionColor = function (A, e) { var t = this.wireframeMaterial.opacity; e = void 0 === e ? t : e, "0x" + this.wireframeMaterial.color.getHexString() === A && t === e || (this.wireframeMaterial.color.setHex(A), this.skinningWireframeMaterial.color.setHex(A), this.selectedLineMaterial.color.setHex(A), this.instancedWireFrameMaterial.color.setHex(A), void 0 === e && null === e || (this.wireframeMaterial.opacity = e, this.skinningWireframeMaterial.opacity = e, this.selectedLineMaterial.opacity = e, this.instancedWireFrameMaterial.opacity = e, 1 > e ? (this.wireframeMaterial.transparent = !0, this.skinningWireframeMaterial.transparent = !0, this.selectedLineMaterial.transparent = !0, this.instancedWireFrameMaterial.transparent = !0) : (this.wireframeMaterial.transparent = !1, this.skinningWireframeMaterial.transparent = !1, this.selectedLineMaterial.transparent = !1, this.instancedWireFrameMaterial.transparent = !1)), this.wireframeMaterial.needsUpdate = !0, this.skinningWireframeMaterial.needsUpdate = !0, this.selectedLineMaterial.needsUpdate = !0, this.instancedWireFrameMaterial.needsUpdate = !0) }, Sy.prototype.getLineSelectionColor = function () { var A = this.wireframeMaterial.opacity; return new Xh(this.wireframeMaterial.color.getHex(), A) }; var wy = new M, My = function () { function A(e) { cc(this, A), e = e || {}, this.vertices = { near: [new y, new y, new y, new y], far: [new y, new y, new y, new y] }, void 0 !== e.projectionMatrix && this.setFromProjectionMatrix(e.projectionMatrix, e.maxFar || 1e4) } return dc(A, [{ key: "setFromProjectionMatrix", value: function (A, e) { var t = 0 === A.elements[11]; return wy.getInverse(A), this.vertices.near[0].set(1, 1, -1), this.vertices.near[1].set(1, -1, -1), this.vertices.near[2].set(-1, -1, -1), this.vertices.near[3].set(-1, 1, -1), this.vertices.near.forEach((function (A) { A.applyMatrix4(wy) })), this.vertices.far[0].set(1, 1, 1), this.vertices.far[1].set(1, -1, 1), this.vertices.far[2].set(-1, -1, 1), this.vertices.far[3].set(-1, 1, 1), this.vertices.far.forEach((function (A) { A.applyMatrix4(wy); var i = Math.abs(A.z); t ? A.z *= Math.min(e / i, 1) : A.multiplyScalar(Math.min(e / i, 1)) })), this.vertices } }, { key: "split", value: function (e, t) { for (; e.length > t.length;) t.push(new A); t.length = e.length; for (var i = 0; e.length > i; i += 1) { var o = t[i]; if (0 === i) for (var n = 0; 4 > n; n += 1) o.vertices.near[n].copy(this.vertices.near[n]); else for (var r = 0; 4 > r; r += 1) o.vertices.near[r].lerpVectors(this.vertices.near[r], this.vertices.far[r], e[i - 1]); if (i === e - 1) for (var a = 0; 4 > a; a += 1) o.vertices.far[a].copy(this.vertices.far[a]); else for (var s = 0; 4 > s; s += 1) o.vertices.far[s].lerpVectors(this.vertices.near[s], this.vertices.far[s], e[i]) } } }, { key: "toSpace", value: function (A, e) { for (var t = 0; 4 > t; t += 1) e.vertices.near[t].copy(this.vertices.near[t]).applyMatrix4(A), e.vertices.far[t].copy(this.vertices.far[t]).applyMatrix4(A) } }]), A }(), by = { lights_fragment_begin: "\nGeometricContext geometry;\n\ngeometry.position = - vViewPosition;\ngeometry.normal = normal;\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition );\n\n#ifdef CLEARCOAT\n\n\tgeometry.clearcoatNormal = clearcoatNormal;\n\n#endif\n\nIncidentLight directLight;\n\n#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )\n\n\tPointLight pointLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0\n\tPointLightShadow pointLightShadow;\n\t#endif\n\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\n\t\tpointLight = pointLights[ i ];\n\n\t\tgetPointDirectLightIrradiance( pointLight, geometry, directLight );\n\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_POINT_LIGHT_SHADOWS )\n\t\tpointLightShadow = pointLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getPointShadow( pointShadowMap[ i ], pointLightShadow.shadowMapSize, pointLightShadow.shadowBias, pointLightShadow.shadowRadius, vPointShadowCoord[ i ], pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar ) : 1.0;\n\t\t#endif\n\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\n\t}\n\n#endif\n\n#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )\n\n\tSpotLight spotLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0\n\tSpotLightShadow spotLightShadow;\n\t#endif\n\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\n\t\tspotLight = spotLights[ i ];\n\n\t\tgetSpotDirectLightIrradiance( spotLight, geometry, directLight );\n\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_SPOT_LIGHT_SHADOWS )\n\t\tspotLightShadow = spotLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( spotShadowMap[ i ], spotLightShadow.shadowMapSize, spotLightShadow.shadowBias, spotLightShadow.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\n\t}\n\n#endif\n\n#if ( NUM_DIR_LIGHTS > 0) && defined( RE_Direct ) && defined( USE_CSM ) && defined( CSM_CASCADES )\n\n\tDirectionalLight directionalLight;\n\tfloat linearDepth = (vViewPosition.z) / (shadowFar - cameraNear);\n\t#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n\tDirectionalLightShadow directionalLightShadow;\n\t#endif\n\n\t#if defined( USE_SHADOWMAP ) && defined( CSM_FADE )\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\n\t\tdirectionalLight = directionalLights[ i ];\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\n\t\t// NOTE: Depth gets larger away from the camera.\n\t\t// cascade.x is closer, cascade.y is further\n\t\tvec2 cascade = CSM_cascades[ i ];\n\t\tfloat cascadeCenter = ( cascade.x + cascade.y ) / 2.0;\n\t\tfloat closestEdge = linearDepth < cascadeCenter ? cascade.x : cascade.y;\n\t\tfloat margin = 0.25 * pow( closestEdge, 2.0 );\n\t\tfloat csmx = cascade.x - margin / 2.0;\n\t\tfloat csmy = cascade.y + margin / 2.0;\n\t\tif( i < NUM_DIR_LIGHT_SHADOWS && linearDepth >= csmx && ( linearDepth < csmy || i == CSM_CASCADES - 1 ) ) {\n\n\t\t\tfloat dist = min( linearDepth - csmx, csmy - linearDepth );\n\t\t\tfloat ratio = clamp( dist / margin, 0.0, 1.0 );\n\t\t\tif( i < NUM_DIR_LIGHT_SHADOWS ) {\n\n\t\t\t\tvec3 prevColor = directLight.color;\n\t\t\t\tdirectionalLightShadow = directionalLightShadows[ i ];\n\t\t\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\n\t\t\t\tbool shouldFadeLastCascade = i == CSM_CASCADES - 1 && linearDepth > cascadeCenter;\n\t\t\t\tdirectLight.color = mix( prevColor, directLight.color, shouldFadeLastCascade ? ratio : 1.0 );\n\n\t\t\t}\n\n\t\t\tReflectedLight prevLight = reflectedLight;\n\t\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\n\t\t\tbool shouldBlend = i != CSM_CASCADES - 1 || i == CSM_CASCADES - 1 && linearDepth < cascadeCenter;\n\t\t\tfloat blendRatio = shouldBlend ? ratio : 1.0;\n\n\t\t\treflectedLight.directDiffuse = mix( prevLight.directDiffuse, reflectedLight.directDiffuse, blendRatio );\n\t\t\treflectedLight.directSpecular = mix( prevLight.directSpecular, reflectedLight.directSpecular, blendRatio );\n\t\t\treflectedLight.indirectDiffuse = mix( prevLight.indirectDiffuse, reflectedLight.indirectDiffuse, blendRatio );\n\t\t\treflectedLight.indirectSpecular = mix( prevLight.indirectSpecular, reflectedLight.indirectSpecular, blendRatio );\n\n\t\t}\n\n\t}\n\t#else\n\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\n\t\tdirectionalLight = directionalLights[ i ];\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\n\n\t\tdirectionalLightShadow = directionalLightShadows[ i ];\n\t\tif(linearDepth >= CSM_cascades[UNROLLED_LOOP_INDEX].x && linearDepth < CSM_cascades[UNROLLED_LOOP_INDEX].y) directLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\n\t\t#endif\n\n\t\tif(linearDepth >= CSM_cascades[UNROLLED_LOOP_INDEX].x && (linearDepth < CSM_cascades[UNROLLED_LOOP_INDEX].y || UNROLLED_LOOP_INDEX == CSM_CASCADES - 1)) RE_Direct( directLight, geometry, material, reflectedLight );\n\n\t}\n\n\t#endif\n\n#endif\n\n\n#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct ) && !defined( USE_CSM ) && !defined( CSM_CASCADES )\n\n\tDirectionalLight directionalLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n\tDirectionalLightShadow directionalLightShadow;\n\t#endif\n\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\n\t\tdirectionalLight = directionalLights[ i ];\n\n\t\tgetDirectionalDirectLightIrradiance( directionalLight, geometry, directLight );\n\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\n\t\tdirectionalLightShadow = directionalLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\n\t}\n\n#endif\n\n#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )\n\n\tRectAreaLight rectAreaLight;\n\n\t#pragma unroll_loop\n\tfor ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {\n\n\t\trectAreaLight = rectAreaLights[ i ];\n\t\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\n\n\t}\n\n#endif\n\n#if defined( RE_IndirectDiffuse )\n\n\tvec3 iblIrradiance = vec3( 0.0 );\n\n\tvec3 irradiance = getAmbientLightIrradiance( ambientLightColor );\n\n\tirradiance += getLightProbeIrradiance( lightProbe, geometry );\n\n\t#if ( NUM_HEMI_LIGHTS > 0 )\n\n\t\t#pragma unroll_loop\n\t\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\n\n\t\t\tirradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry );\n\n\t\t}\n\n\t#endif\n\n#endif\n\n#if defined( RE_IndirectSpecular )\n\n\tvec3 radiance = vec3( 0.0 );\n\tvec3 clearcoatRadiance = vec3( 0.0 );\n\n#endif\n", lights_pars_begin: "\n#if defined( USE_CSM ) && defined( CSM_CASCADES )\nuniform vec2 CSM_cascades[CSM_CASCADES];\nuniform float cameraNear;\nuniform float shadowFar;\n#endif\n\t" + tt.lights_pars_begin }, Uy = new M, Fy = new My, Ky = new My, Qy = new y, Ry = new aA, Ty = [], ky = [], Dy = function () { function A(e) { cc(this, A), this.camera = (e = e || {}).camera, this.parent = e.parent, this.cascades = e.cascades || 3, this.maxFar = e.maxFar || 1e5, this.mode = e.mode || "practical", this.shadowMapSize = e.shadowMapSize || 2048, this.shadowBias = e.shadowBias || 1e-6, this.lightDirection = e.lightDirection || new y(1, -1, 1).normalize(), this.lightIntensity = e.lightIntensity || 1, this.lightNear = e.lightNear || 1, this.lightFar = e.lightFar || 2e3, this.lightMargin = e.lightMargin || 200, this.customSplitsCallback = e.customSplitsCallback, this.fade = !1, this.mainFrustum = new My, this.frustums = [], this.breaks = [], this.lights = [], this.shaders = new Map, this.createLights(), this.getBreaks(), this.initCascades(), this.injectInclude() } return dc(A, [{ key: "createLights", value: function () { for (var A = 0; this.cascades > A; A++) { var e = new Ra(16777215, this.lightIntensity); e.castShadow = !0, e.intensity = .72, e.distance = 300, e.color.setHex(14800580), e.position.set(-100, 100, 160), e.shadow.mapSize.width = this.shadowMapSize, e.shadow.mapSize.height = this.shadowMapSize, e.shadow.camera.near = this.lightNear, e.shadow.camera.far = this.lightFar, e.shadow.bias = this.shadowBias, e.updateMatrixWorld(), this.parent.add(e), this.parent.add(e.target), this.lights.push(e) } } }, { key: "initCascades", value: function () { var A = this.camera; A.updateProjectionMatrix(), this.mainFrustum.setFromProjectionMatrix(A.projectionMatrix, this.maxFar), this.mainFrustum.split(this.breaks, this.frustums) } }, { key: "getBreaks", value: function () { var A = this.camera, e = Math.min(A.far, this.maxFar); switch (this.breaks.length = 0, this.mode) { case "uniform": t(this.cascades, A.near, e, this.breaks); break; case "logarithmic": i(this.cascades, A.near, e, this.breaks); break; case "practical": ! function (A, e, o, n, r) { Ty.length = 0, ky.length = 0, i(A, e, o, ky), t(A, e, o, Ty); for (var s = 1; A > s; s++) r.push(a.lerp(Ty[s - 1], ky[s - 1], n)); r.push(1) }(this.cascades, A.near, e, .5, this.breaks); break; case "custom": void 0 === this.customSplitsCallback && console.error("CSM: Custom split scheme callback not defined."), this.customSplitsCallback(this.cascades, A.near, e, this.breaks) } function t(A, e, t, i) { for (var o = 1; A > o; o++) i.push((e + (t - e) * o / A) / t); i.push(1) } function i(A, e, t, i) { for (var o = 1; A > o; o++) i.push(e * (t / e) * (o / A) / t); i.push(1) } } }, { key: "update", value: function (A) { for (var e = this.frustums, t = 0; e.length > t; t++) { var i = this.lights[t]; i.shadow.camera.updateMatrixWorld(!0), Uy.multiplyMatrices(i.shadow.camera.matrixWorldInverse, A), e[t].toSpace(Uy, Fy); var o = Fy.vertices.near, n = Fy.vertices.far, r = n[0], a = void 0; a = r.distanceTo(n[2]) > r.distanceTo(o[2]) ? n[2] : o[2]; var s = r.distanceTo(a); Ry.makeEmpty(); for (var l = 0; 4 > l; l++) Ry.expandByPoint(o[l]), Ry.expandByPoint(n[l]); if (this.fade) { var c = this.camera, h = Math.max(c.far, this.maxFar); s += .25 * Math.pow(e[t].vertices.far[0].z / (h - c.near), 2) * (h - c.near) } var d = s / this.shadowMapSize; Ry.getCenter(Qy), Qy.z = Ry.max.z + this.lightMargin, Qy.x = Math.floor(Qy.x / d) * d, Qy.y = Math.floor(Qy.y / d) * d, Qy.applyMatrix4(i.shadow.camera.matrixWorld), i.shadow.camera.left = -s / 2, i.shadow.camera.right = s / 2, i.shadow.camera.top = s / 2, i.shadow.camera.bottom = -s / 2, i.position.copy(Qy), i.target.position.copy(Qy), i.target.position.x += this.lightDirection.x, i.target.position.y += this.lightDirection.y, i.target.position.z += this.lightDirection.z, i.shadow.camera.updateProjectionMatrix(), i.shadow.camera.updateMatrixWorld() } } }, { key: "injectInclude", value: function () { tt.lights_fragment_begin = by.lights_fragment_begin, tt.lights_pars_begin = by.lights_pars_begin } }, { key: "setupMaterial", value: function (A) { A.defines = A.defines || {}, A.defines.USE_CSM = 1, A.defines.CSM_CASCADES = this.cascades, this.fade && (A.defines.CSM_FADE = ""); var e = [], t = this, i = this.shaders; A.onBeforeCompile = function (o) { var n = Math.min(t.camera.far, t.maxFar); t.getExtendedBreaks(e), console.log("www", e, e.length), o.uniforms.CSM_cascades = { value: e }, o.uniforms.cameraNear = { value: t.camera.near }, o.uniforms.shadowFar = { value: n }, i.set(A, o) }, i.set(A, null) } }, { key: "updateUniforms", value: function () { var A = Math.min(this.camera.far, this.maxFar); this.shaders.forEach((function (e, t) { if (null !== e) { var i = e.uniforms; this.getExtendedBreaks(i.CSM_cascades.value), i.cameraNear.value = this.camera.near, i.shadowFar.value = A }!this.fade && "CSM_FADE" in t.defines ? (delete t.defines.CSM_FADE, t.needsUpdate = !0) : this.fade && !("CSM_FADE" in t.defines) && (t.defines.CSM_FADE = "", t.needsUpdate = !0) }), this) } }, { key: "getExtendedBreaks", value: function (A) { for (; this.breaks.length > A.length;) A.push(new s); A.length = this.breaks.length; for (var e = 0; this.cascades > e; e++) { var t = this.breaks[e]; A[e].x = this.breaks[e - 1] || 0, A[e].y = t } } }, { key: "updateFrustums", value: function () { this.getBreaks(), this.initCascades(), this.updateUniforms() } }, { key: "helper", value: function (A) { for (var e, t, i = new ko({ color: 16777215 }), o = new H, n = 0; this.frustums.length > n; n++) { this.frustums[n].toSpace(A, Ky), e = new he, t = []; for (var r = 0; 5 > r; r++) { var a = Ky.vertices.near[4 === r ? 0 : r]; t.push(a.x, a.y, a.z) } e.setAttribute("position", new YA(new Float32Array(t), 3)), o.add(new Go(e, i)), e = new he, t = []; for (var s = 0; 5 > s; s++) { var l = Ky.vertices.far[4 === s ? 0 : s]; t.push(l.x, l.y, l.z) } e.setAttribute("position", new YA(new Float32Array(t), 3)), o.add(new Go(e, i)); for (var c = 0; 4 > c; c++) { e = new he; var h = Ky.vertices.near[c], d = Ky.vertices.far[c]; (t = []).push(h.x, h.y, h.z), t.push(d.x, d.y, d.z), e.setAttribute("position", new YA(new Float32Array(t), 3)), o.add(new Go(e, i)) } } return o } }, { key: "remove", value: function () { for (var A = 0; this.lights.length > A; A++) this.parent.remove(this.lights[A]) } }, { key: "dispose", value: function () { var A = this.shaders; A.forEach((function (A, e) { delete e.onBeforeCompile, delete e.defines.USE_CSM, delete e.defines.CSM_CASCADES, delete e.defines.CSM_FADE, delete A.uniforms.CSM_cascades, delete A.uniforms.cameraNear, delete A.uniforms.shadowFar, e.needsUpdate = !0 })), A.clear() } }]), A }(), Ly = function (A) { this.viewer = A, this.renderer = null, this.countRenderRequest = 0, this.maxCountRenderRequest = 1e4, this.rendering = !1, this.incrementRenderHandle = 0, this.composer = null, this.blinkHandle = 0, this.transparentSort = function (A, e) { return A.groupOrder !== e.groupOrder ? A.groupOrder - e.groupOrder : A.renderOrder !== e.renderOrder ? A.renderOrder - e.renderOrder : A.z !== e.z ? e.z - A.z : A.id - e.id } }; Ly.prototype.destroy = function () { this.incrementRenderHandle > 0 && cancelAnimationFrame(this.incrementRenderHandle), this.blinkHandle > 0 && cancelAnimationFrame(this.blinkHandle), this.composer && (this.composer.destroy(), this.composer = null), this.renderer && (this.renderer.destroy && this.orderedRenderer && (this.renderer.destroy(), this.renderer.setRenderer && this.renderer.setRenderer(null), this.orderedRenderer = null), this.renderer.dispose(), this.renderer.domElement.parentNode && this.renderer.domElement.parentNode.removeChild(this.renderer.domElement)), this.renderer = null, this.pickingEffecter && (this.pickingEffecter.destroy(), this.pickingEffecter = null), this.viewer = null }, Ly.prototype.setupRenderer = function (A) { if (!this.renderer) { var e = this.viewer; this.renderer = new $i(A); var t = e.domElement.offsetWidth, i = e.domElement.offsetHeight; this.renderer.toneMapping = 1, this.renderer.setTransparentSort(this.transparentSort), this.renderer.setClearColor(0, 0), this.renderer.setPixelRatio(window.devicePixelRatio || 1), this.renderer.setSize(t, i), this.renderer.sortObjects = !0, this.renderer.domElement.setAttribute("tabindex", "0"), this.renderer.domElement.setAttribute("class", "main-canvas"), e.domElement.appendChild(this.renderer.domElement), this.composer = new By(this.renderer), this.composer.init(e.modelManager, e.getScene(), e.camera, t, i), this.composer.setOutlineEdgeColor(new Xh(vc.SelectionColor.color, vc.SelectionColor.opacity)) } }, Ly.prototype.resetupRenderer = function (A) { var e = this.viewer; A.context = this.renderer.getContext(); var t = new $i(A); t.setClearColor(this.renderer.getClearColor(), this.renderer.getClearAlpha()), t.setPixelRatio(this.renderer.getPixelRatio()); var i = this.renderer.getSize(new s); t.setSize(i.x, i.y), t.gammaFactor = this.renderer.gammaFactor, t.sortObjects = this.renderer.sortObjects, t.domElement = this.renderer.domElement, t.toneMapping = this.renderer.toneMapping, t.shadowMap.enabled = this.renderer.shadowMap.enabled, t.clippingPlanes = this.renderer.clippingPlanes, t.shadowMap.enabled = this.renderer.shadowMap.enabled, t.shadowMap.type = this.renderer.shadowMap.type, t.shadowMap.autoUpdate = this.renderer.shadowMap.autoUpdate, t.shadowMap.needsUpdate = this.renderer.shadowMap.needsUpdate, t.setTransparentSort(this.transparentSort), this.renderer = t, this.composer.reinit(this.renderer, e.modelManager, e.getScene(), e.camera, i.x, i.y) }, Ly.prototype.setupShadowMap = function (A) { var e = this.viewer, t = new Dy({ maxFar: A.far, cascades: 4, mode: A.mode, parent: e.getScene().getExternalScene(), shadowMapSize: 1024, lightDirection: new y(A.lightX, A.lightY, A.lightZ).normalize(), camera: e.camera }); this.csm = t; var i = new $m; i.add(A, "orthographic").onChange((function (A) {})), i.add(A, "fade").onChange((function (A) { t.fade = A, t.updateFrustums() })), i.add(A, "far", 1, 5e7).step(1).name("shadow far").onChange((function (A) { t.maxFar = A, t.updateFrustums() })), i.add(A, "mode", ["uniform", "logarithmic", "practical"]).name("frustum split mode").onChange((function (A) { t.mode = A, t.updateFrustums() })), i.add(A, "lightX", -1, 1).name("light direction x").onChange((function (A) { t.lightDirection.x = A })), i.add(A, "lightY", -1, 1).name("light direction y").onChange((function (A) { t.lightDirection.y = A })), i.add(A, "lightZ", -1, 1).name("light direction z").onChange((function (A) { t.lightDirection.z = A })), i.add(A, "margin", 0, 2e6).name("light margin").onChange((function (A) { t.lightMargin = A })), i.add(A, "lightNear", 1, 1e7).name("light near").onChange((function (A) { for (var e = 0; t.lights.length > e; e += 1) t.lights[e].shadow.camera.near = A, t.lights[e].shadow.camera.updateProjectionMatrix() })), i.add(A, "lightFar", 1, 1e8).name("light far").onChange((function (A) { for (var e = 0; t.lights.length > e; e += 1) t.lights[e].shadow.camera.far = A, t.lights[e].shadow.camera.updateProjectionMatrix() })) }, Ly.prototype._applyPickingEffectForIncrement = function () { if (this.getPickingEffecter()) { var A = this.viewer.modelManager.isFilterApplied(); this.orderedRenderer.restart(), this.orderedRenderer.setNonBreakingRender(!0), this.pickingEffecter.apply(A), this.orderedRenderer.setNonBreakingRender(!1) } }, Ly.prototype._applyPickingEffect = function () { if (this.getPickingEffecter()) { var A = this.viewer.modelManager.isFilterApplied(); this.pickingEffecter.apply(A) } }, Ly.prototype._forceRenderOneFrame = function () { var A = this.viewer, e = A.camera, t = A.modelManager.getScene(); this.orderedRenderer ? (this.orderedRenderer.restart(), this.orderedRenderer.setNonBreakingRender(!0), this.renderer.render(t, e, null, !0), this.orderedRenderer.setNonBreakingRender(!1)) : (this.renderer.setRenderTarget(null), this.renderer.clear(), this.renderer.render(t, e)) }, Ly.prototype.incrementRender = function (A) { if (this.countRenderRequest += 1, this.countRenderRequest > this.maxCountRenderRequest && (this.countRenderRequest = 0), !this.rendering && !this.pickingEffectRendering) { this.rendering = !0; var e = this, t = this.viewer, i = t.camera, o = t.modelManager, n = t.editorManager, r = t.getScene(), a = this.renderer; o.calculateCameraModelRelation(i.position), t.cameraControl.updateCamera(), t.calculateNearFar(), r.updateLights(i); var s = n.isUpdateRenderList; a.resetIncrementRender(), a.setObjectListUpdateState(s), s && o.prepareScene(i), this.incrementRenderHandle = requestAnimationFrame(function A(s, l) { var c = s; return function () { a.autoClear = l, n.cameraChange ? (a.resetIncrementRender(), a.autoClear = !0, n.cameraChange = !1) : a.autoClear = l, a.render(r, i) || c !== e.countRenderRequest ? (e.rendering = !1, c !== e.countRenderRequest ? t.render() : (e.pickingEffectRendering = !0, e._applyPickingEffectForIncrement(), o.setFilterApplied(!1), t.onRenderFinishedCallback(), o.disposeBufferAfterVbo(), e.pickingEffectRendering = !1)) : e.incrementRenderHandle = requestAnimationFrame(A(c, !1)) } }(e.countRenderRequest, !0)), t.onRenderCallback(), t.cameraControl.setCameraChanging(!1) } }, Ly.prototype.fullRender = function () { var A = this, e = this.viewer, t = e.camera, i = e.modelManager, o = e.getScene(), n = this.renderer; this.blinkHandle > 0 && cancelAnimationFrame(this.blinkHandle), function r() { e.cameraControl.updateCamera(), e.calculateNearFar(), o.updateLights(t), i.getBlinkEnabled() && i.updateBlinkMaterial(); var a = o.fillClipPlane && o.fillClipPlane.visible, s = o.clipPlanes && o.clipPlanes.visible && vc.EnableBoxClippingCaps; if (vc.ClippingCaps && (a || s) && vc.EnableClippingCaps) { if (a || s) { var l = o.getFillClipPlane(), c = o.getClipPlanes(), h = e.modelManager.getModelKeys(); i.prepareCapScene(), n.clear(), n.autoClear = !1, a ? (l.capPlane.planeMesh.visible = !0, l.capPlane.lineMesh.visible = !0, c.boxMesh.visible = !1) : (l.capPlane.planeMesh.visible = !1, l.capPlane.lineMesh.visible = !1, c.boxMesh.visible = !0), l.planeHighLightMatrial.visible = !1, c.planeHighLightMatrial.visible = !1, c.planeMaterial.visible = !1, o.overrideMaterial = o.backMaterial; for (var d = {}, p = 0, g = h.length; g > p; p += 1) { var u = h[p], f = e.modelManager.getModel(u); if (d[u] = {}, f) { var m = f._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); d[u][gp.GEOMETRY] = m.visible, m = f._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 }), d[u][gp.WIREFRAME] = m.visible, m = f._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 }), d[u][gp.INSTANCEGEOMETRY] = m.visible, m.visible = !1, m = f._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 }), d[u][gp.INSTANCEWIREFRAMEGEOMETRY] = m.visible, m.visible = !1 } } n.render(o, t), o.overrideMaterial = o.backInstanceMaterial; for (var C = 0, y = h.length; y > C; C += 1) { var v = h[C], I = e.modelManager.getModel(v); if (I) { var E = I._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); E.visible = !1, (E = I._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = !1, (E = I._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = d[v][gp.INSTANCEGEOMETRY], (E = I._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = d[v][gp.INSTANCEWIREFRAMEGEOMETRY] } } n.render(o, t), o.overrideMaterial = o.frontMaterial; for (var B = 0, x = h.length; x > B; B += 1) { var S = h[B], w = e.modelManager.getModel(S); if (w) { var M = w._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); M.visible = d[S][gp.GEOMETRY], (M = w._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = d[S][gp.WIREFRAME], M = w._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 }), d[S][gp.INSTANCEGEOMETRY] = M.visible, M.visible = !1, M = w._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 }), d[S][gp.INSTANCEWIREFRAMEGEOMETRY] = M.visible, M.visible = !1 } } n.render(o, t), o.overrideMaterial = o.frontInstanceMaterial; for (var b = 0, U = h.length; U > b; b += 1) { var F = h[b], K = e.modelManager.getModel(F); if (K) { var Q = K._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); Q.visible = !1, (Q = K._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = !1, (Q = K._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = d[F][gp.INSTANCEGEOMETRY], (Q = K._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = d[F][gp.INSTANCEWIREFRAMEGEOMETRY] } } n.render(o, t), n.render(i.capsScene, t), o.overrideMaterial = null, l.planeHighLightMatrial.visible = !0, c.planeHighLightMatrial.visible = !0, c.planeMaterial.visible = !0; for (var R = 0, T = h.length; T > R; R += 1) { var k = h[R], D = e.modelManager.getModel(k); if (D) { var L = D._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); L.visible = d[k][gp.GEOMETRY], (L = D._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = d[k][gp.WIREFRAME], (L = D._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = d[k][gp.INSTANCEGEOMETRY], (L = D._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = d[k][gp.INSTANCEWIREFRAMEGEOMETRY] } } d = null, n.render(o, t) } } else !vc.PickingEffect && vc.EnableSelectionOutline && A.composer && e.getSelection().length > 0 ? A.composer.render() : (n.setRenderTarget(null), n.clear(), n.render(o, t)); A._applyPickingEffect(), i.setFilterApplied(!1), e.onRenderListener(), e.onRenderFinishedListener(), e.cameraControl.isCameraChanging() && i.dispatchEvent({ type: Rc.ON_CAMERA_CHANGED_AND_RENDERED }), e.cameraControl.setCameraChanging(!1), i.getBlinkEnabled() && (A.blinkHandle = requestAnimationFrame(r)), i.disposeBufferAfterVbo() }() }, Ly.prototype.fillCavityRender = function (A) { var e = this.viewer, t = e.camera, i = e.modelManager, o = this.renderer, n = e.getScene(); function r(A, e, t, i) { var o = new Xi, n = new jA; n.depthWrite = !1, n.depthTest = !1, n.colorWrite = !1, n.stencilWrite = !0, n.stencilFunc = 519; var r = n.clone(); r.side = 1, r.clippingPlanes = [e], r.stencilFail = 34055, r.stencilZFail = 34055, r.stencilZPass = 34055; var a = new Ue(A, r); a.matrixWorld = i.matrixWorld, a.renderOrder = t, o.add(a); var s = n.clone(); s.side = 0, s.clippingPlanes = [e], s.stencilFail = 34056, s.stencilZFail = 34056, s.stencilZPass = 34056; var l = new Ue(A, s); return l.renderOrder = t, l.matrixWorld = i.matrixWorld, o.add(l), o } this.blinkHandle > 0 && cancelAnimationFrame(this.blinkHandle), function A() { e.cameraControl.updateCamera(), e.calculateNearFar(), n.updateLights(t), i.getBlinkEnabled() && i.updateBlinkMaterial(); var a = n.fillClipPlane && n.fillClipPlane.visible, s = n.clipPlanes && n.clipPlanes.visible, l = o.autoClear, c = o.sortObjects; if (vc.ClippingCaps && (a || s)) { if (a) { var h = n.getFillClipPlane(), d = n.getClipPlanes(), p = e.modelManager.getModelKeys(); i.prepareCapScene(), o.clear(), o.autoClear = !1, a ? (h.capPlane.planeMesh.visible = !0, h.capPlane.lineMesh.visible = !0, d.boxMesh.visible = !1) : (h.capPlane.planeMesh.visible = !1, h.capPlane.lineMesh.visible = !1, d.boxMesh.visible = !0), h.planeHighLightMatrial.visible = !1, d.planeHighLightMatrial.visible = !1, d.planeMaterial.visible = !1, n.overrideMaterial = n.backMaterial; for (var g = {}, u = 0, f = p.length; f > u; u += 1) { var m = p[u], C = e.modelManager.getModel(m); if (g[m] = {}, C) { var y = C._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); g[m][gp.GEOMETRY] = y.visible, y = C._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 }), g[m][gp.WIREFRAME] = y.visible, y = C._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 }), g[m][gp.INSTANCEGEOMETRY] = y.visible, y.visible = !1, y = C._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 }), g[m][gp.INSTANCEWIREFRAMEGEOMETRY] = y.visible, y.visible = !1 } } o.render(n, t), n.overrideMaterial = n.backInstanceMaterial; for (var v = 0, I = p.length; I > v; v += 1) { var E = p[v], B = e.modelManager.getModel(E); if (B) { var x = B._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); x.visible = !1, (x = B._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = !1, (x = B._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = g[E][gp.INSTANCEGEOMETRY], (x = B._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = g[E][gp.INSTANCEWIREFRAMEGEOMETRY] } } o.render(n, t), n.overrideMaterial = n.frontMaterial; for (var S = 0, w = p.length; w > S; S += 1) { var M = p[S], b = e.modelManager.getModel(M); if (b) { var U = b._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); U.visible = g[M][gp.GEOMETRY], (U = b._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = g[M][gp.WIREFRAME], U = b._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 }), g[M][gp.INSTANCEGEOMETRY] = U.visible, U.visible = !1, U = b._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 }), g[M][gp.INSTANCEWIREFRAMEGEOMETRY] = U.visible, U.visible = !1 } } o.render(n, t), n.overrideMaterial = n.frontInstanceMaterial; for (var F = 0, K = p.length; K > F; F += 1) { var Q = p[F], R = e.modelManager.getModel(Q); if (R) { var T = R._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); T.visible = !1, (T = R._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = !1, (T = R._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = g[Q][gp.INSTANCEGEOMETRY], (T = R._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = g[Q][gp.INSTANCEWIREFRAMEGEOMETRY] } } o.render(n, t), o.render(i.capsScene, t), n.overrideMaterial = null, a ? h.planeHighLightMatrial.visible = !0 : (d.planeHighLightMatrial.visible = !0, d.planeMaterial.visible = !0); for (var k = 0, D = p.length; D > k; k += 1) { var L = p[k], N = e.modelManager.getModel(L); if (N) { var O = N._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); O.visible = g[L][gp.GEOMETRY], (O = N._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = g[L][gp.WIREFRAME], (O = N._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = g[L][gp.INSTANCEGEOMETRY], (O = N._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = g[L][gp.INSTANCEWIREFRAMEGEOMETRY] } } g = null, o.render(n, t) } if (s) { o.clear(), o.autoClear = !1, o.sortObjects = !0, o.localClippingEnabled = !0; var V = e.modelManager.getModelKeys(), G = o.clippingPlanes; o.clippingPlanes = []; var P = n.getClipPlanes(), q = new Y; q.autoUpdate = !1; for (var j = 0, H = n.lightArray.length; H > j; j += 1) q.add(n.lightArray[j].clone()); for (var W = [], J = 0; 6 > J; J += 1) W[J] = P.children[J].clone(); for (var z = 0, Z = V.length; Z > z; z += 1) { var X = e.modelManager.getModel(V[z]); if (X) for (var _ = X._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }), $ = 0, AA = _.children.length; AA > $; $ += 1) { var eA = new Xi; eA.name = "object"; var tA = [], iA = []; q.add(eA); var oA = _.children[$]; if (oA.visible) { for (var nA = oA.geometry, rA = [], aA = 0; 6 > aA; aA += 1) rA[aA] = G[aA].clone(); for (var sA = function (A) { (cA = new Xi).name = "poGroup"; var e = rA[A]; (hA = r(nA, e, A + 1, oA)).name = "stencilGroup", dA = new yr({ color: oA.material[0].color, metalness: .1, roughness: .75, clippingPlanes: rA.filter((function (A) { return A !== e })), stencilWrite: !0, stencilRef: 0, stencilFunc: 517, stencilFail: 7681, stencilZFail: 7681, stencilZPass: 7681 }); var t = W[A].clone(); t.material = dA, t.testNumber = A, t.onAfterRender = function () { o.clearStencil() }, t.renderOrder = A + 1.1, eA.add(hA), cA.add(t), tA.push(t), q.add(cA), iA.push(cA) }, lA = 0; 6 > lA; lA += 1) { var cA, hA, dA; sA(lA) } for (var pA = oA.clone(), gA = 0, uA = pA.material.length; uA > gA; gA += 1) pA.material[gA].clippingPlanes = rA; pA.renderOrder = 6, eA.add(pA), o.render(q, t), q.remove(eA); for (var fA = 0, mA = iA.length; mA > fA; fA += 1) q.remove(iA[fA]); tA = null } } } o.sortObjects = c, o.clippingPlanes = G, o.autoClear = l, o.localClippingEnabled = !1 } } else vc.EnableSelectionOutline && e.composer && e.getSelection().length > 0 ? e.composer.render() : (o.setRenderTarget(null), o.clear(), o.render(n, t)); e.onRenderListener(), e.onRenderFinishedListener(), e.cameraControl.setCameraChanging(!1), i.getBlinkEnabled() && (e.blinkHandle = requestAnimationFrame(A)), i.disposeBufferAfterVbo() }() }, Ly.prototype.fillCavityRender2 = function (A) { var e = this.viewer, t = e.camera, i = e.modelManager, o = this.renderer, n = e.getScene(); this.blinkHandle > 0 && cancelAnimationFrame(this.blinkHandle), function A() { e.cameraControl.updateCamera(), e.calculateNearFar(), n.updateLights(t), i.getBlinkEnabled() && i.updateBlinkMaterial(); var r = n.fillClipPlane && n.fillClipPlane.visible, a = n.clipPlanes && n.clipPlanes.visible, s = o.autoClear; if (vc.ClippingCaps && (r || a)) { if (r) { var l = n.getFillClipPlane(), c = n.getClipPlanes(), h = e.modelManager.getModelKeys(); i.prepareCapScene(), o.clear(), o.autoClear = !1, r ? (l.capPlane.planeMesh.visible = !0, l.capPlane.lineMesh.visible = !0, c.boxMesh.visible = !1) : (l.capPlane.planeMesh.visible = !1, l.capPlane.lineMesh.visible = !1, c.boxMesh.visible = !0), l.planeHighLightMatrial.visible = !1, c.planeHighLightMatrial.visible = !1, c.planeMaterial.visible = !1, n.overrideMaterial = n.backMaterial; for (var d = {}, p = 0, g = h.length; g > p; p += 1) { var u = h[p], f = e.modelManager.getModel(u); if (d[u] = {}, f) { var m = f._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); d[u][gp.GEOMETRY] = m.visible, m = f._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 }), d[u][gp.WIREFRAME] = m.visible, m = f._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 }), d[u][gp.INSTANCEGEOMETRY] = m.visible, m.visible = !1, m = f._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 }), d[u][gp.INSTANCEWIREFRAMEGEOMETRY] = m.visible, m.visible = !1 } } o.render(n, t), n.overrideMaterial = n.backInstanceMaterial; for (var C = 0, y = h.length; y > C; C += 1) { var v = h[C], I = e.modelManager.getModel(v); if (I) { var E = I._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); E.visible = !1, (E = I._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = !1, (E = I._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = d[v][gp.INSTANCEGEOMETRY], (E = I._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = d[v][gp.INSTANCEWIREFRAMEGEOMETRY] } } o.render(n, t), n.overrideMaterial = n.frontMaterial; for (var B = 0, x = h.length; x > B; B += 1) { var S = h[B], w = e.modelManager.getModel(S); if (w) { var M = w._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); M.visible = d[S][gp.GEOMETRY], (M = w._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = d[S][gp.WIREFRAME], M = w._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 }), d[S][gp.INSTANCEGEOMETRY] = M.visible, M.visible = !1, M = w._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 }), d[S][gp.INSTANCEWIREFRAMEGEOMETRY] = M.visible, M.visible = !1 } } o.render(n, t), n.overrideMaterial = n.frontInstanceMaterial; for (var b = 0, U = h.length; U > b; b += 1) { var F = h[b], K = e.modelManager.getModel(F); if (K) { var Q = K._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); Q.visible = !1, (Q = K._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = !1, (Q = K._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = d[F][gp.INSTANCEGEOMETRY], (Q = K._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = d[F][gp.INSTANCEWIREFRAMEGEOMETRY] } } o.render(n, t), o.render(i.capsScene, t), n.overrideMaterial = null, r ? l.planeHighLightMatrial.visible = !0 : (c.planeHighLightMatrial.visible = !0, c.planeMaterial.visible = !0); for (var R = 0, T = h.length; T > R; R += 1) { var k = h[R], D = e.modelManager.getModel(k); if (D) { var L = D._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); L.visible = d[k][gp.GEOMETRY], (L = D._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = d[k][gp.WIREFRAME], (L = D._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = d[k][gp.INSTANCEGEOMETRY], (L = D._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = d[k][gp.INSTANCEWIREFRAMEGEOMETRY] } } d = null, o.render(n, t) } if (a) { o.clear(), o.autoClear = !1; for (var N = e.modelManager.getModelKeys(), O = o.clippingPlanes, V = o.tempPlanes || [], G = 0; 6 > G; G += 1) { if (V[G]) { if (V[G].equals(O[G])) continue; V[G] = O[G].clone() } else V[G] = O[G].clone(); for (var P = 0, q = N.length; q > P; P += 1) { var j = e.modelManager.getModel(N[P]); if (j) { var H = j._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }), Y = j._getNodeGroup("sectionFill_" + G); Y.clear(); for (var W = 0, J = H.children.length; J > W; W += 1) { var z = H.children[W]; if (z.visible) { var Z = V[G].clone().applyMatrix4(z.matrixWorld), X = z.geometry; if (X.boundingBox || X.computeBoundingBox(), X.boundingBox.intersectsPlane(Z)) { var _ = Tu.getShapeGeometryFromGeometryAndPlane(X, Z); if (_) { var $ = new Ue(_, z.material[0]); Y.add($), $.matrixWorld.copy(z.matrixWorld) } } } } } } } o.tempPlanes = V, o.autoClear = s, o.setRenderTarget(null), o.clear(), o.render(n, t) } } else vc.EnableSelectionOutline && e.composer && e.getSelection().length > 0 ? e.composer.render() : (o.setRenderTarget(null), o.clear(), o.render(n, t)); e.onRenderListener(), e.onRenderFinishedListener(), e.cameraControl.setCameraChanging(!1), i.getBlinkEnabled() && (e.blinkHandle = requestAnimationFrame(A)), i.disposeBufferAfterVbo() }() }, Ly.prototype.render = function (A) { if (this.renderer) { var e = this.viewer, t = e.modelManager; if (t.isEmpty()) return Bh.log("model not loaded!"), void this._forceRenderOneFrame(); if (!t.checkLayerDataLoading()) { e._checkDataChanged(); e.getScene(); e.camera.updateMatrixWorld(), this.csm && (this.csm.update(e.camera.matrixWorld), this.csm.updateFrustums()), vc.IncrementRender ? this.incrementRender(A) : vc.FillCavity ? this.fillCavityRender2(A) : this.fullRender(A) } } }, Ly.prototype.getRenderer = function () { return this.renderer }, Ly.prototype.setSize = function (A, e) { this.renderer.setSize(A, e), this.composer && this.composer.setSize(A, e) }, Ly.prototype.getRendererSize = function () { return this.renderer ? this.renderer.getSize() : { width: 0, height: 0 } }, Ly.prototype.getPickingEffecter = function () { return vc.PickingEffect ? (this.pickingEffecter || (this.pickingEffecter = new Sy(this.viewer)), this.pickingEffecter) : null }; var Ny = function (A, e) { jo.call(this, A, e), this.type = "SkinnedMesh", this.bindMode = "attached", this.bindMatrix = new M, this.bindMatrixInverse = new M; var t = new bo(this.initBones()); this.bind(t, this.matrixWorld), this.normalizeSkinWeights() }; Ny.prototype = Object.assign(Object.create(jo.prototype), { constructor: Ny, isSkinnedMesh: !0, initBones: function () { var A = [], e = null, t = null, i = null, o = null; if (this.geometry && void 0 !== this.geometry.bones) { for (i = 0, o = this.geometry.bones.length; o > i; i += 1) t = this.geometry.bones[i], e = new Uo, A.push(e), e.name = t.name, e.position.fromArray(t.pos), e.quaternion.fromArray(t.rotq), void 0 !== t.scl && e.scale.fromArray(t.scl); for (i = 0, o = this.geometry.bones.length; o > i; i += 1) - 1 !== (t = this.geometry.bones[i]).parent && null !== t.parent && void 0 !== A[t.parent] ? A[t.parent].add(A[i]) : this.add(A[i]) } return this.updateMatrixWorld(!0), A }, bind: function (A, e) { this.skeleton = A, void 0 === e && (this.updateMatrixWorld(!0), this.skeleton.calculateInverses(), e = this.matrixWorld), this.bindMatrix.copy(e), this.bindMatrixInverse.getInverse(e) }, pose: function () { this.skeleton.pose() }, normalizeSkinWeights: function () { var A = null, e = null; if (this.geometry && this.geometry.isGeometry) for (e = 0; this.geometry.skinWeights.length > e; e += 1) { var t = this.geometry.skinWeights[e]; (A = 1 / t.lengthManhattan()) !== 1 / 0 ? t.multiplyScalar(A) : t.set(1, 0, 0, 0) } else if (this.geometry && this.geometry.isBufferGeometry) { var i = new p, o = this.geometry.attributes.skinWeight; for (e = 0; o.count > e; e += 1) i.x = o.getX(e), i.y = o.getY(e), i.z = o.getZ(e), i.w = o.getW(e), (A = 1 / i.lengthManhattan()) !== 1 / 0 ? i.multiplyScalar(A) : i.set(1, 0, 0, 0), o.setXYZW(e, i.x, i.y, i.z, i.w) } }, updateMatrixWorld: function (A) { jo.prototype.updateMatrixWorld.call(this, A), "attached" === this.bindMode ? this.bindMatrixInverse.getInverse(this.matrixWorld) : "detached" === this.bindMode ? this.bindMatrixInverse.getInverse(this.bindMatrix) : console.warn("THREE.SkinnedMesh: Unrecognized bindMode: " + this.bindMode) }, clone: function () { return new this.constructor(this.geometry, this.material).copy(this) } }); var Oy = function (A) { of .call(this, A), this.nodeGroupName = "PickingExternalMeshGroup", this.pickingEffecter = this.manager.viewer.rendererManager.getPickingEffecter() }; Object.assign(Oy.prototype, of .prototype), eu(Oy, [{ key: "destroy", value: function () { this.pickingEffecter = null } }, { key: "_disposeGeometryByNode", value: function (A) { A.traverseVisible((function (e) { e !== A && (e.isMesh || e.isLine) && (e.material = null, e.geometry.dispose()) })) } }, { key: "disposePickingNodeById", value: function (A) { for (var e = this.pickingNodeMap[A], t = 0, i = e.length; i > t; t += 1) this._disposeGeometryByNode(e[t]), e[t] = null } }, { key: "updatePickingMeshes", value: function (A, e, t) { if (this.pickingNodeMap) { for (var i = Object.keys(this.pickingNodeMap), o = 0, n = i.length; n > o; o += 1) { var r = i[o], a = this.pickingNodeMap[r], s = 0, l = 0; if (t[r] && this.manager.isPickableNode({ userId: r, name: r })) for (s = 0, l = a.length; l > s; s += 1) a[s].visible = !0; else for (s = 0, l = a.length; l > s; s += 1) a[s].visible = !1 } return this.getPickingNodeGroup() } } }, { key: "addNode", value: function (A, e) { this.addToPickingNodeMap(A, e) } }, { key: "removeNodeById", value: function (A) { this.removeFromPickingNodeMap(A) } }, { key: "clearNodes", value: function () { this.clearData() } }, { key: "addToPickingNodeMap", value: function (A, e) { for (var t = [], i = !vc.BatchMergeEnabled, o = 0, n = e.length; n > o; o += 1) { var r = this._createPickingNodeBy(e[o], i); if (r) if (Array.isArray(r)) for (var a = 0, s = r.length; s > a; a += 1) r[a].name = A, t.push(r[a]); else r.name = A, t.push(r) } this.pickingNodeMap || (this.pickingNodeMap = {}), this.pickingNodeMap[A] = t, this.addToPickingNodeGroup(t) } }, { key: "_createPickingNodeBy", value: function (A, e) { var t = this, i = {}, o = {}; if ("Object3D" === A.type || A instanceof Xi || A instanceof ep) { var n = new Xi; n.copy(A, !1), A.animations && (n.animations = A.animations), A.traverseVisible((function (n) { if (n !== A) { var r = null; if ("Object3D" === n.type || n instanceof Xi || n instanceof ep || n instanceof Uo) (r = n instanceof Uo ? new Uo : new Xi).copy(n, !1), i[n.uuid] = { destination: r, source: n }; else { if (!n.isMesh && !n.isLine) return; (r = t._createPickingMeshesBy(n, e)) && (o[n.uuid] = { destination: r, source: n }) } r = null } })); var r = 0, a = 0, s = null, l = Object.keys(i); for (r = 0, a = l.length; a > r; r += 1) { var c = i[l[r]]; c.source.parent !== A ? i[s = c.source.parent.uuid].destination.add(c.destination) : n.add(c.destination) } var h = Object.keys(o); for (r = 0, a = h.length; a > r; r += 1) { var d = o[h[r]], p = 0, g = 0; if (d.source.parent === A) if (Array.isArray(d.destination)) for (p = 0, g = d.destination.length; g > p; p += 1) n.add(d.destination[p]); else n.add(d.destination); else if (s = d.source.parent.uuid, Array.isArray(d.destination)) for (p = 0, g = d.destination.length; g > p; p += 1) i[s].destination.add(d.destination[p]); else i[s].destination.add(d.destination) } return n } return A.isMesh || A.isLine ? t._createPickingMeshesBy(A, e) : null } }, { key: "_createLineMeshBy", value: function (A, e, t) { var i = null, o = null, n = this.pickingEffecter; if (vc.PickingLineWidthEnabled) { i = n.selectedLineMaterial; var r = new JC; A.isLineSegments ? r.fromLineSegments(A) : A.isLineLoop ? r.fromLineLoop(A) : r.fromLine(A), o = new XC(r, i), Tu.copyMeshProperties(o, A), o.renderOrder = t ? 1 : 0 } else i = n.selectedMaterial, o = A.isLineSegments ? new jo(e, i) : A.isLineLoop ? new Ho(e, i) : new Go(e, i), Tu.copyMeshProperties(o, A), o.renderOrder = t ? 1 : 0; return o } }, { key: "_createMeshBy", value: function (A, e, t) { var i = new Ue(e, this.pickingEffecter.selectedMaterial); return Tu.copyMeshProperties(i, A), i.renderOrder = t ? 1 : 0, i } }, { key: "_createSkinnedMeshBy", value: function (A, e, t) { var i = new So(e, this.pickingEffecter.skinningSelectedMaterial); return Tu.copyMeshProperties(i, A), i.renderOrder = t ? 1 : 0, i.bindMatrix.copy(A.bindMatrix), i.bindMatrixInverse.copy(A.bindMatrixInverse), i.bindMode = A.bindMode, i.userData = A.userData, i.skeleton = A.skeleton, i } }, { key: "_createSkinnedWireFrameBy", value: function (A, e, t) { if (!e.index) return null; var i = this.pickingEffecter.skinningWireframeMaterial, o = Up(e.attributes.position.array, e.index.array), n = new he; n.setIndex(new $A(o, 1)), n.setAttribute("position", e.getAttribute("position")), n.setAttribute("skinIndex", e.getAttribute("skinIndex")), n.setAttribute("skinWeight", e.getAttribute("skinWeight")); var r = new Ny(n, i); return Tu.copyMeshProperties(r, A), r.bindMatrix.copy(A.bindMatrix), r.bindMatrixInverse.copy(A.bindMatrixInverse), r.bindMode = A.bindMode, r.userData = A.userData, r.skeleton = A.skeleton, r.renderOrder = t ? 0 : 1, r } }, { key: "_createWireFrameBy", value: function (A, e, t) { if (!e.index) return null; var i = this.pickingEffecter.wireframeMaterial, o = Up(e.attributes.position.array, e.index.array), n = new he; n.setIndex(new $A(o, 1)), n.setAttribute("position", e.getAttribute("position")); var r = new jo(n, i); return Tu.copyMeshProperties(r, A), r.renderOrder = t ? 0 : 1, r } }, { key: "_createPickingMeshesBy", value: function (A, e) { var t = Tu.createBufferGeometryWithPosAndSkin(A.geometry); if (!t) return null; if (A.isLineSegments) return this._createLineMeshBy(A, t, e); var i = null, o = null; return A.isSkinnedMesh ? (i = this._createSkinnedMeshBy(A, t, e), o = this._createSkinnedWireFrameBy(A, t, e)) : (i = this._createMeshBy(A, t, e), o = this._createWireFrameBy(A, t, e)), o ? [i, o] : i } }, { key: "setAccumulateTransform", value: function (A, e, t, i) { if (this.pickingNodeMap && this.pickingNodeMap[A]) for (var o = this.pickingNodeMap[A], n = 0, r = o.length; r > n; n += 1) { var a = o[n]; e && (a.position.x += e.x, a.position.y += e.y, a.position.z += e.z), t && (a.scale.x *= t.x, a.scale.y *= t.y, a.scale.z *= t.z), i && (a.rotation.x += i.x, a.rotation.y += i.y, a.rotation.z += i.z), a.updateMatrixWorld() } } }, { key: "setTransform", value: function (A, e, t, i, o) { if (this.pickingNodeMap && this.pickingNodeMap[A]) for (var n = this.pickingNodeMap[A], r = 0, a = n.length; a > r; r += 1) { var s = n[r]; o ? this.manager.setTransformForClonedMesh(s, e, t, i) : this.manager.setTransformForMesh(s, e, t, i) } } }, { key: "rotateOnBasePoint", value: function (A, e, t, i) { if (this.pickingNodeMap && this.pickingNodeMap[A]) { var o = this.pickingNodeMap[A]; if (o) for (var n = 0, r = o.length; r > n; n += 1) { var a = o[n], s = (new f).setFromAxisAngle(t, i); a.quaternion.premultiply(s), a.position.sub(e), a.position.applyQuaternion(s), a.position.add(e), a.updateMatrixWorld() } } } }, { key: "applyTransform", value: function (A, e, t, i) { if (this.pickingNodeMap && this.pickingNodeMap[A]) { var o = this.manager.getTransformMatrix(e, t, i); this.applyTransformMatrix(A, o) } } }, { key: "applyTransformMatrix", value: function (A, e) { if (this.pickingNodeMap && this.pickingNodeMap[A]) for (var t = this.pickingNodeMap[A], i = 0, o = t.length; o > i; i += 1) this.manager.updateMatrixWorldForMesh(t[i], e) } }]); var Vy = function (A) { this.viewer = A, this.viewer.modelManager.registerPlugin(this), this.meshes = {}, this.customSelectMaterials = {}, this.databagId = "ExternalComponent", this.objectIds = null, this.lastFilteredIds = null, this.firstAnimation = !0, this.animationIds = {}, this.animationLength = 0, this.animationId = 0, this.invalidObjectType = ["invalidPlane"], this.floorExplosion = !1, this.boundingBoxWorld = void 0 }; Vy.prototype.destroy = function () { this.pickingNodeGenerator && (this.pickingNodeGenerator.destroy(), this.pickingNodeGenerator = null), this._removeNodeGroup(), this.meshes = null, this.customSelectMaterials = null, this.objectIds = null, this.lastFilteredIds = null, this._cancelAnimate(), this.firstAnimation = null, this.animationIds = null, this.invalidObjectType = null, this.viewer = null }, Vy.prototype.addExternalObject = function (A) { if (A && (A instanceof Xi || A instanceof Ue)) { var e = uh.createUUID(); this.meshes[e] = [A]; var t = { name: e, userId: e, nodeId: e, state: Lc.Visible, mesh: [A], isExternalComponent: !0, matrix: A.matrixWorld.clone() }, i = new aA; return i.setFromObject(A), t.boundingBox = i, A.key = e, this._getNodeGroup().add(A), this._addToNodeInfoMap(t), this._cacheNodeMaterial(A), this.boundingBoxWorld ? this.boundingBoxWorld.union(i) : this.boundingBoxWorld = i.clone(), this.viewer.modelManager.updateSceneBoundingBox(), this._updateFilterManager(), this.objectIds = Object.keys(this.meshes), { nodeId: e } } }, Vy.prototype.getObjectCenterAndMatrixByNodeId = function (A) { var e = void 0, t = this.getNodeInfosByUserId(A); if (t && t.length > 0) { e = { matrix: [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1], center: [0, 0, 0] }; var i = t[0]; if (i.matrix && (e.matrix = i.matrix.toArray()), i.boundingBox) { var o = new y; i.boundingBox.getCenter(o), e.center = o.toArray() } } return e }, Vy.prototype.addNode = function (A, e, t, i) { if (this.meshes[A]) Bh.error("Warning: name is already exist, please change name "); else if (-1 === this.invalidObjectType.indexOf(e.type)) { e instanceof Array || (e = [e]), this.meshes[A] = e, this._isPickingEffectEnabled() && this.getPickingNodeGenerator().addNode(A, e), void 0 === t && (t = !1), i && (this.customSelectMaterials[A] = i); for (var o = new aA, n = 0, r = e.length; r > n; n += 1) { var a = new aA; a.setFromObject(e[n]), a.isEmpty() && a.min.x === 1 / 0 && e[n].position && (a.min.copy(e[n].position), a.max.copy(e[n].position)), o.union(a), e[n].box = a, e[n].originBox = a.clone(); var s = new M; s.getInverse(e[n].matrix), e[n].originBox.applyMatrix4(s), this._initializeAnimation(e[n], A); var l = e[n]; l.key = A, this._getNodeGroup().add(l), l.updateMatrixWorld(!0), t || this._cacheNodeMaterial(l) } var c = { name: A, userId: A, state: Lc.Visible, boundingBox: o, mesh: e, isExternalComponent: !0 }; 1 === e.length && (c.matrix = e[0].matrixWorld.clone()), this._addToNodeInfoMap(c), this.boundingBoxWorld ? this.boundingBoxWorld.union(o) : this.boundingBoxWorld = o.clone(), this.viewer.modelManager.updateSceneBoundingBox(), this._updateFilterManager(), this.objectIds = Object.keys(this.meshes) } else Bh.error("Warning: the object is invalid") }, Vy.prototype.getNodeById = function (A) { var e = this.meshes[A]; return e && 1 === e.length ? e[0] : e }, Vy.prototype.removeNodeById = function (A) { var e = this.meshes[A]; if (!e) return !1; e[0].autoAnimation && (delete this.animationIds[A], this.animationLength -= 1, 0 === this.animationLength && this._cancelAnimate()), delete this.meshes[A], this._isPickingEffectEnabled() && this.getPickingNodeGenerator().removeNodeById(A), this.customSelectMaterials[A] && delete this.customSelectMaterials[A]; for (var t = this._getNodeGroup(), i = 0, o = e.length; o > i; i += 1) t.remove(e[i]); return this.filteredIds && this.filteredIds[A] && delete this.filteredIds[A], this.lastFilteredIds && this.lastFilteredIds[A] && delete this.lastFilteredIds[A], this.viewer.removeFromSelection([A]), this.viewer.cancelTransformComponentByKey(A), this._removeFromNodeInfoMap(A), this._updateFilterManager(), this.objectIds = Object.keys(this.meshes), !0 }, Vy.prototype.clearNodes = function () { this._isPickingEffectEnabled() && this.getPickingNodeGenerator().clearNodes(), this._getNodeGroup().clear(), this._clearNodeInfoMap(), this.meshes = {}, this.customSelectMaterials = {}, this.objectIds = null, this.animationIds = {}, this.animationLength = 0, this._cancelAnimate() }, Vy.prototype.getAllNodes = function () { return this.meshes }, Vy.prototype.isEmpty = function () { return !this._hasNode() }, Vy.prototype.setTransform = function (A, e, t, i, o) { if (this.floorExplosion && o) o(); else { var n = this.meshes[A]; if (n) { for (var r = 0, a = n.length; a > r; r += 1) { var s = n[r]; s.position.x = (e = e || s.position).x, s.position.y = e.y, s.position.z = e.z, s.scale.x = (t = t || s.scale).x, s.scale.y = t.y, s.scale.z = t.z, s.setRotationFromQuaternion(i = i || s.quaternion), s.updateMatrixWorld(); var l = s.originBox.clone(); s.box = l.applyMatrix4(s.matrix), s.levelName = null } this._isPickingEffectEnabled() && this.getPickingNodeGenerator().setTransform(A, e, t, i) } } }, Vy.prototype.getTransform = function (A) { var e = this.meshes[A]; return e ? { position: e[0].position, scale: e[0].scale, rotate: e[0].quaternion } : null }, Vy.prototype.applyTransform = function (A, e, t, i) { if (this.meshes[A]) { e = e || new y, t = t || new y(1, 1, 1), i = i || new f; var o = new M; o.compose(e, i, t), this.applyTransformMatrix(A, o), this._isPickingEffectEnabled() && this.getPickingNodeGenerator().applyTransformMatrix(A, o) } }, Vy.prototype.applyTransformMatrix = function (A, e) { var t = this.meshes[A]; if (t) for (var i = 0, o = t.length; o > i; i += 1) { var n = t[i]; n._oriMatrix || (n._oriMatrix = n.matrix.clone()), n.matrix.multiplyMatrices(e, n._oriMatrix), n.updateMatrixWorld(!0); var r = n.originBox.clone(); n.box = r.applyMatrix4(n.matrix) } }, Vy.prototype.applyFilter = function () { this._hasNode() && (this._collectFilteredIds(), this._collectSelectedIds(), this._collectHoveredIds(), this._updateNodes()) }, Vy.prototype.applySelection = function () { console.log('applySelection13') this._hasNode() && (this._collectSelectedIds(), this._collectHoveredIds(), this._updateNodes()) }, Vy.prototype.clearSelection = function () { this._hasNode() && (this._clearSelectedIds(), this.applyHover()) }, Vy.prototype.applyHover = function () { this._hasNode() && (this._collectHoveredIds(), this._updateNodes()) }, Vy.prototype.clearHover = function () { this._hasNode() && (this._clearHoveredIds(), this._updateNodes()) }, Vy.prototype.getNodeInfosByUserId = function (A) { if (this.nodeInfoMap) return this.nodeInfoMap[A] }, Vy.prototype.getAllNodeInfos = function (A) { A[this.databagId] = this.nodeInfoMap || {} }, Vy.prototype.calculateBoundingBox = function () { if (this.nodeInfoMap) { var A = new aA, e = new aA; for (var t in this.nodeInfoMap) for (var i = this.nodeInfoMap[t], o = 0, n = i.length; n > o; o += 1) { var r = i[o], a = r.mesh, s = new aA; for (o = 0, n = a.length; n > o; o += 1) e.makeEmpty(), e.setFromObject(a[o]), e.isEmpty() && e.min.x === 1 / 0 && a[o].position && (e.min.copy(a[o].position), e.max.copy(a[o].position)), s.union(e); r.boundingBox.copy(s), A.union(r.boundingBox) } this.boundingBoxWorld ? this.boundingBoxWorld.copy(A) : this.boundingBoxWorld = A } }, Vy.prototype.recalculateComponentBoundingbox = function (A) { var e = this.getNodeInfosByUserId(A); if (e) for (var t = 0, i = e.length; i > t; t += 1) { var o = e[t], n = o.mesh, r = new aA, a = new aA; for (t = 0, i = n.length; i > t; t += 1) a.setFromObject(n[t]), a.isEmpty() && a.min.x === 1 / 0 && n[t].position && (a.min.copy(n[t].position), a.max.copy(n[t].position)), r.union(a); o.boundingBox.copy(r) } }, Vy.prototype.getBoundingBoxWorld = function () { if (this.boundingBoxWorld) return this.boundingBoxWorld.clone() }, Vy.prototype.adjustVisibility = function (A) { this._getNodeGroup().visible = A }, Vy.prototype.changeVisibilityOfSelectedObjects = function (A) { if (this.selectedIds) for (var e = this.viewer.modelManager.filter, t = 0, i = this.selectedIds.length; i > t; t += 1) { var o = this.selectedIds[t], n = this.meshes[o]; if (n && e._isVisible({ userId: o })) for (var r = 0, a = n.length; a > r; r += 1) n[r].visible = A } }, Vy.prototype.changeVisibilityOfNonSelectedObjects = function (A) { if (this.objectIds) { var e = {}; if (this.selectedIds) for (var t = 0, i = this.selectedIds.length; i > t; t += 1) e[this.selectedIds[t]] = !0; for (var o = this.viewer.modelManager.filter, n = 0, r = this.objectIds.length; r > n; n += 1) { var a = this.objectIds[n]; if (!e[a] && o._isVisible({ userId: a })) for (var s = this.meshes[a], l = 0, c = s.length; c > l; l += 1) s[l].visible = A } } }, Vy.prototype.adjustVisibilityOfObjectsWithoutOutline = function (A) { if (this.objectIds) for (var e = this.viewer.modelManager.filter, t = 0, i = this.objectIds.length; i > t; t += 1) { var o = this.objectIds[t]; if (e._isVisible({ userId: o })) for (var n = this.meshes[o], r = 0, a = n.length; a > r; r += 1) n[r].isSprite && (n[r].visible = A) } }, Vy.prototype._addToNodeInfoMap = function (A) { this.nodeInfoMap || (this.nodeInfoMap = {}), this.nodeInfoMap[A.userId] || (this.nodeInfoMap[A.userId] = []), this.nodeInfoMap[A.userId].push(A) }, Vy.prototype._removeFromNodeInfoMap = function (A) { this.nodeInfoMap && this.nodeInfoMap[A] && delete this.nodeInfoMap[A] }, Vy.prototype._clearNodeInfoMap = function () { this.nodeInfoMap = null }, Vy.prototype._updateFilterManager = function () { var A = this.viewer.modelManager; A.filter.reinitFilterManager(A.getNodeInfos()) }, Vy.prototype._canBePick = function (A) { return !!A._oriMaterial }, Vy.prototype._getNodeGroup = function () { return this.viewer.modelManager.scene.getOrCreateGroup(gp.EXTERNALCOMPONENTMANAGER, { pickableType: Qc.Geometry, globalSpace: !0 }) }, Vy.prototype._removeNodeGroup = function () { this.viewer.modelManager.scene.removeGroupByName(gp.EXTERNALCOMPONENTMANAGER) }, Vy.prototype._cacheNodeMaterial = function (A) { uh.isGroupObject(A) ? A.traverse((function (A) { if (uh.isMeshObject(A) && !A._oriMaterial && (A._oriMaterial = A.material, !A.geometry.index && A.geometry.attributes && A.geometry.attributes.position)) { for (var e = [], t = 0, i = A.geometry.attributes.position.array.length / 3; i > t; t += 1) e.push(t); A.geometry.setIndex(new YA(new Uint32Array(e), 1)) } })) : A._oriMaterial || (A._oriMaterial = A.material) }, Vy.prototype._collectFilteredIds = function () { var A = this.filteredIds = {}, e = this.viewer.modelManager.filter, t = e._hasHiddenFileIdFilter(), i = e._hasVisibleFilter(), o = e._hasOverrideMaterialFilter(), n = e._hasTransparentFilter(); if (t || i || o || n) for (var r = this.objectIds, a = zc, s = 0, l = r.length; l > s; s += 1) { var c = r[s], h = { userId: c }; if (i && !1 === e._isVisible(h)) A[c] || (A[c] = {}), A[c][a.HIDDEN] = !0; else if (n && e._isTransparent(h)) A[c] || (A[c] = {}), A[c][a.TRANSPARENT] = !0; else if (o && e._hasOverrideMaterial(h)) { var d = e._getOverrideMaterial(h), p = d ? d.name : ""; A[c] || (A[c] = {}), A[c][a.OVERRIDED] = p } } }, Vy.prototype._collectSelectedIds = function () { var A = this.filteredIds = this.filteredIds || {}, e = zc, t = this.viewer.modelManager.sceneState.getSelection(), i = {}; this._clearSelectedIds(); for (var o = 0, n = t.length; n > o; o += 1) { var r = t[o]; this.canBeSelectedId(r) && (A[r] || (A[r] = {}), A[r][e.SELECTED] = !0, i[r] = !0) } this.selectedIds = Object.keys(i) }, Vy.prototype._clearSelectedIds = function () { if (this.filteredIds && this.selectedIds && this.selectedIds.length) { for (var A = 0, e = this.selectedIds.length; e > A; A += 1) { var t = this.selectedIds[A]; this.filteredIds[t] && delete this.filteredIds[t][zc.SELECTED] } this.selectedIds = null } }, Vy.prototype._collectHoveredIds = function () { var A = this.viewer.modelManager.sceneState.hoverId; if (A && this._hasObjectId(A)) { var e = this.filteredIds = this.filteredIds || {}; this.hoveredId = A, e[A] || (e[A] = {}), e[A][zc.HOVER] = !0 } }, Vy.prototype._clearHoveredIds = function () { this.filteredIds && this.hoveredId && this.filteredIds[this.hoveredId] && (delete this.filteredIds[this.hoveredId][zc.HOVER], this.hoveredId = void 0) }, Vy.prototype._hasObjectId = function (A) { return !!this.meshes[A] }, Vy.prototype.isUserIdExist = function (A) { return this._hasObjectId(A) }, Vy.prototype.canBeSelectedId = function (A) { var e = this.meshes[A]; return !(!e || e[0].disPickable) }, Vy.prototype._hasNode = function () { return !(!this.objectIds || !this.objectIds.length) }, Vy.prototype._traverseNodeById = function (A, e) { if (this._hasObjectId(A)) for (var t = this, i = this.meshes[A], o = 0, n = i.length; n > o; o += 1) { var r = i[o]; uh.isGroupObject(r) ? r.traverseVisible((function (A) { uh.isMeshObject(A) && t._canBePick(A) && e && e(A) })) : (uh.isMeshObject(r) || r.isSprite) && t._canBePick(r) && e && e(r) } }, Vy.prototype._resetNodeMaterial = function () { var A = this.lastFilteredIds; if (A && A.length) for (var e = 0, t = A.length; t > e; e += 1) this._updateNodeVisible(A[e], !0), this._traverseNodeById(A[e], (function (A) { A.material = A._oriMaterial })) }, Vy.prototype._updateNodeVisible = function (A, e) { if (this._hasObjectId(A)) for (var t = this.meshes[A], i = 0, o = t.length; o > i; i += 1) t[i].visible = e }, Vy.prototype._updateNodeById = function (A, e) { if (this._hasObjectId(A)) { var t = this.viewer.modelManager.sceneState, i = zc, o = this.filteredIds[A]; if (o) if (o[i.HIDDEN]) this._updateNodeVisible(A, !1); else { var n = function (A, e) { if (A._oriMaterial instanceof Array) { for (var t = [], i = 0, o = A._oriMaterial.length; o > i; i += 1) { var n = A._oriMaterial[i]; n instanceof ld ? t.push(e) : t.push = Kd.cloneMaterialBaseOnColor(n, e) } A.material = t } else A.material = A._oriMaterial instanceof ld ? e : Kd.cloneMaterialBaseOnColor(A._oriMaterial, e) }; if (o[i.TRANSPARENT]) { var r = e._getMaterialByName("scene"); this._traverseNodeById(A, (function (A) { n(A, r) })) } else if (this._isPickingEffectEnabled() || !o[i.SELECTED]) { if (o[i.HOVER]) if (o[i.OVERRIDED]) { var a = t.getHoverMaterial(e._getMaterialByName(o[i.OVERRIDED])); this._traverseNodeById(A, (function (A) { n(A, a) })) } else this._traverseNodeById(A, (function (A) { var e = t.getHoverMaterial(A._oriMaterial); n(A, e) })); else if (o[i.OVERRIDED]) { var s = e._getMaterialByName(o[i.OVERRIDED]); this._traverseNodeById(A, (function (A) { n(A, s) })) } } else { var l = t.selectionMaterial, c = this.customSelectMaterials[A]; this._traverseNodeById(A, (function (A) { c ? A.material = c : A._oriMaterial.isMeshPhongMaterial ? (A.material = t.phongSelectionMaterial, A.material.skinning = A._oriMaterial.skinning) : n(A, l) })) } } } }, Vy.prototype._updateNodes = function () { var A = this.viewer.modelManager.filter; if (this._resetNodeMaterial(), this.filteredIds) { for (var e in this.filteredIds) this._updateNodeById(e, A); this.lastFilteredIds = Object.keys(this.filteredIds) } }, Vy.prototype._initializeAnimation = function (A, e) { if (A.autoAnimation) { if ("fire" === A.type) { var t = vc.SceneSize, i = this.viewer.getBoundingBoxWorld().getSize(), o = Math.max(i.x, i.y, i.z); A._initializeSizetween(t / o / .01421) } this.firstAnimation && (this._animate(), this.firstAnimation = !1), this.animationIds[e] = !0, this.animationLength += 1 } }, Vy.prototype._animate = function () { var A = this; ! function e() { for (var t in A.animationId = requestAnimationFrame(e), A.animationIds) for (var i = A.meshes[t], o = 0, n = i.length; n > o; o += 1) i[o].autoAnimation && i[o].update && i[o].update(); A.viewer.render() }() }, Vy.prototype._cancelAnimate = function () { this.firstAnimation = !0, cancelAnimationFrame(this.animationId), this.animationId = 0 }, Vy.prototype.isPickableNode = function (A) { if (!this.canBeSelectedId(A.userId)) return !1; var e = this.viewer.modelManager.filter; return !e._isHiddenFileId(A) && !1 !== e._isVisible(A) && !e._isTransparent(A) }, Vy.prototype._isPickingEffectEnabled = function () { return !1 }, Vy.prototype.getPickingNodeGenerator = function () { return this.pickingNodeGenerator || (this.pickingNodeGenerator = new Oy(this)), this.pickingNodeGenerator }, Vy.prototype.setCloneComponentMaterialsByKey = function (A, e, t) { var i = this.meshes[A][0]; if (!i) return { result: !1, message: "mesh isn`t exist", code: -1 }; if (!i.byClone) return { result: !1, message: "mesh isn`t qualified", code: -2 }; var o = 0 === t || Boolean(t); if (Array.isArray(e) || (e = [e]), o && (Array.isArray(t) || (t = [t])), Array.isArray(i.material)) if (o) { var n = 0, r = !0, a = !1, s = void 0; try { for (var l, c = t[Symbol.iterator](); !(r = (l = c.next()).done); r = !0) { var h = l.value; if (!i.material[h] || !e[n]) break; i.material[h] = e[n], n += 1 } } catch (A) { a = !0, s = A } finally { try { r || null == c.return || c.return() } finally { if (a) throw s } } } else { var d = 0, p = !0, g = !1, u = void 0; try { for (var f, m = e[Symbol.iterator](); !(p = (f = m.next()).done); p = !0) { var C = f.value; if (!i.material[d]) break; i.material[d] = C, d += 1 } } catch (A) { g = !0, u = A } finally { try { p || null == m.return || m.return() } finally { if (g) throw u } } } else i.material = e[0] }, Vy.prototype.getModelManager = function () { return this.viewer.modelManager }; var Gy = function () { this.domElement = null, this.camera = null, this.highlightManager = null, this.controller = document.getElementById("viewerController"), this.countRenderRequest = 0, this.maxCountRenderRequest = 1e4, this.rendering = !1, this.incrementRenderHandle = 0, this.callbacks = {}, this.tempBox = new aA, this.tempVector3 = new y, this.enableCameraNearFar = !0, this.currentHomeView = Uc.Home, this.initialView = Uc.Home, this.filter = new xu, this.modelManager = new ly(this.filter, this), this.isRecalculationPlanes = !1, this.calculationPlanesBind = this.calculationPlanes.bind(this), this.addRenderFinishedListener(this.calculationPlanesBind), this.uuid = "", this.transitionAnimationState = !0, this.animator = new dp, this._renderStateChanged = !1; var A = this; this._renderTimer = null, this.blinkHandle = 0, this.needCheckTilesDataChange = !1, this.clock = new as, this.rendererManager = new Ly(this), this.cameraStateWithFrustum = !1, this.checkNeedRender = function () { (A.needRender || A.modelManager.needUpdateAnimation()) && (A.needRender = vc.continueRender || !1, A.modelManager.updateAnimation(), A._render()), A._renderTimer = requestAnimationFrame(A.checkNeedRender) }, this.checkNeedApplyFilter = function () { A.needApplyFilter && (A.needApplyFilter = !1, A.modelManager.applyFilter(), A.render()), A._applyFilterTimer = requestAnimationFrame(A.checkNeedApplyFilter) }, this.blink = {} }; Object.assign(Gy.prototype, Ld.prototype), Object.assign(Gy.prototype, { constructor: Gy, addRenderListener: function (A) { this.addEventListener("render", A) }, removeRenderListener: function (A) { this.removeEventListener("render", A) }, onRenderListener: function () { this.dispatchEvent("render") }, addRenderFinishedListener: function (A) { this.addEventListener("renderFinished", A) }, removeRenderFinishedListener: function (A) { this.removeEventListener("renderFinished", A) }, onRenderFinishedListener: function () { this.dispatchEvent("renderFinished") }, removeAllListeners: function () { this.removeAllEventListener() }, destroy: function () { if (this.stopRedner(), this.stopApplyFilter(), this.removeAllListeners(), this.controlManager.unregisterDomEventListeners(this.domElement), this.renderer) { var A = document.getElementById(this.uuid); this.domElement.contains(this.getRenderer().domElement) && this.domElement.removeChild(A) } this.domElement = null, this.renderSettings.canvas = null, this.renderSettings.context = null, this.renderSettings = null, this.rendererManager.destroy(), this.rendererManager = null, this.camera = null, this.defaultCamera = null, this.cameraControl.destroy(), this.cameraControl = null, this.controlManager.destroy(), this.modelManager.destroy(), this.modelManager = null, this.controlManager = null, this.tmpBox = null, this.filter = null, this.calculationPlanesBind = null, this.animator = null }, init: function (A) { var e = this; e.uuid = a.generateUUID(), this.domElement = A, this.resetBackgroundColor(); var t = { alpha: !0, preserveDrawingBuffer: !0, antialias: !0, depth: !0, maxDrawCacheNum: vc.maxDrawCacheNum, logarithmicDepthBuffer: !1, stencil: !0 }; vc.logarithmicDepthBuffer && (t.logarithmicDepthBuffer = !0), vc.DisableAntialias && (t.antialias = !1); var i = null; try { (i = document.createElement("canvas")).style.outline = "none", i.getContext("webgl", t) || i.getContext("experimental-webgl", t) || (t.antialias = !1) } catch (A) { return !1 } Tu.initializeUnitInstances(); var o = document.createElement("div"); o.setAttribute("id", e.uuid), o.style.width = "100%", o.style.height = "100%", t.canvas = i, this.renderSettings = t, this.camera = this.defaultCamera = new cp(45, A.offsetWidth, A.offsetHeight, .1, 200 * vc.SceneSize), this.camera.up = new y(0, 0, 1), this.camera.realUp = new y(0, 0, 1), this.camera.lookAt(this.camera.target), this.cameraControl = new mp(this, this.camera, A, (function (A) { e.render(A) })), this.controlManager = new Og, this.controlManager.setControlMode(this, "pick"), this.setOrbitButton("left"), this.setReverseWheelDirection(!1), this.registerDomEventListener(Rc.ON_CONTROL_END, (function () { e.needCheckTilesDataChange = !0 })), this.registerDomEventListener(Rc.ON_CONTROL_ZOOM, (function () { e.needCheckTilesDataChange = !0 })), e.rendererManager.setupRenderer(e.renderSettings), o.appendChild(this.getRenderer().domElement), this.domElement.appendChild(o), this.controlManager.registerDomEventListeners(o), this.startRender(), this.startApplyFilter() }, getDomElement: function () { return this.domElement ? this.domElement : null }, getRendererDomElement: function () { return this.getRenderer() && this.getRenderer().domElement ? this.getRenderer().domElement : null }, render: function () { this.needRender = !0 }, startRender: function () { this._renderTimer = requestAnimationFrame(this.checkNeedRender) }, stopRedner: function () { cancelAnimationFrame(this._renderTimer) }, startApplyFilter: function () { this._applyFilterTimer = requestAnimationFrame(this.checkNeedApplyFilter) }, stopApplyFilter: function () { cancelAnimationFrame(this._applyFilterTimer) }, _render: function (A) { this.rendererManager.render(A) }, incrementRender: function (A) { var e = this, t = this.camera, i = this.modelManager, o = this.getRenderer(), n = this.getScene(); if (this.countRenderRequest += 1, this.countRenderRequest > this.maxCountRenderRequest && (this.countRenderRequest = 0), !this.rendering) { this.rendering = !0, i.calculateCameraModelRelation(t.position), this.ar(), this.cameraControl.updateCamera(), n.updateLights(t); var r = this.controlManager.isUpdateRenderList; o.resetIncrementRender(), o.setObjectListUpdateState(r), this.incrementRenderHandle = requestAnimationFrame(function A(i, r) { var a = i; return function () { o.autoClear = r, e.controlManager.cameraChange ? (o.resetIncrementRender(), o.autoClear = !0, e.controlManager.cameraChange = !1) : o.autoClear = r, o.render(n, t) || a !== e.countRenderRequest ? (e.rendering = !1, a !== e.countRenderRequest ? e.render() : e.onRenderFinishedListener()) : e.incrementRenderHandle = requestAnimationFrame(A(a, !1)) } }(e.countRenderRequest, !0)), r && i.prepareScene(t), this.onRenderFinishedListener(), this.cameraControl.setCameraChanging(!1) } }, fullRender: function (A) { var e = this, t = this.camera, i = this.modelManager, o = this.getRenderer(), n = this.getScene(); this.blinkHandle > 0 && cancelAnimationFrame(this.blinkHandle), function A() { e.calculateNearFar(), e.cameraControl.updateCamera(), n.updateLights(t), i.getBlinkEnabled() && i.updateBlinkMaterial(); var r = n.fillClipPlane && n.fillClipPlane.visible, a = n.clipPlanes && n.clipPlanes.visible && vc.EnableBoxClippingCaps; if (vc.ClippingCaps && (r || a) && vc.EnableClippingCaps) { if (r || a) { var s = n.getFillClipPlane(), l = n.getClipPlanes(), c = e.modelManager.getModelKeys(); i.prepareCapScene(), o.clear(), o.autoClear = !1, r ? (s.capPlane.planeMesh.visible = !0, s.capPlane.lineMesh.visible = !0, l.boxMesh.visible = !1) : (s.capPlane.planeMesh.visible = !1, s.capPlane.lineMesh.visible = !1, l.boxMesh.visible = !0), s.planeHighLightMatrial.visible = !1, l.planeHighLightMatrial.visible = !1, l.planeMaterial.visible = !1, n.overrideMaterial = n.backMaterial; for (var h = {}, d = 0, p = c.length; p > d; d += 1) { var g = c[d], u = e.modelManager.getModel(g); if (h[g] = {}, u) { var f = u._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); h[g][gp.GEOMETRY] = f.visible, f = u._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 }), h[g][gp.WIREFRAME] = f.visible, f = u._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 }), h[g][gp.INSTANCEGEOMETRY] = f.visible, f.visible = !1, f = u._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 }), h[g][gp.INSTANCEWIREFRAMEGEOMETRY] = f.visible, f.visible = !1 } } o.render(n, t), n.overrideMaterial = n.backInstanceMaterial; for (var m = 0, C = c.length; C > m; m += 1) { var y = c[m], v = e.modelManager.getModel(y); if (v) { var I = v._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); I.visible = !1, (I = v._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = !1, (I = v._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = h[y][gp.INSTANCEGEOMETRY], (I = v._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = h[y][gp.INSTANCEWIREFRAMEGEOMETRY] } } o.render(n, t), n.overrideMaterial = n.frontMaterial; for (var E = 0, B = c.length; B > E; E += 1) { var x = c[E], S = e.modelManager.getModel(x); if (S) { var w = S._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); w.visible = h[x][gp.GEOMETRY], (w = S._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = h[x][gp.WIREFRAME], w = S._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 }), h[x][gp.INSTANCEGEOMETRY] = w.visible, w.visible = !1, w = S._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 }), h[x][gp.INSTANCEWIREFRAMEGEOMETRY] = w.visible, w.visible = !1 } } o.render(n, t), n.overrideMaterial = n.frontInstanceMaterial; for (var M = 0, b = c.length; b > M; M += 1) { var U = c[M], F = e.modelManager.getModel(U); if (F) { var K = F._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); K.visible = !1, (K = F._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = !1, (K = F._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = h[U][gp.INSTANCEGEOMETRY], (K = F._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = h[U][gp.INSTANCEWIREFRAMEGEOMETRY] } } o.render(n, t), o.render(i.capsScene, t), n.overrideMaterial = null, s.planeHighLightMatrial.visible = !0, l.planeHighLightMatrial.visible = !0, l.planeMaterial.visible = !0; for (var Q = 0, R = c.length; R > Q; Q += 1) { var T = c[Q], k = e.modelManager.getModel(T); if (k) { var D = k._getNodeGroup(gp.GEOMETRY, { globalSpace: !0 }); D.visible = h[T][gp.GEOMETRY], (D = k._getNodeGroup(gp.WIREFRAME, { globalSpace: !0 })).visible = h[T][gp.WIREFRAME], (D = k._getNodeGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 })).visible = h[T][gp.INSTANCEGEOMETRY], (D = k._getNodeGroup(gp.INSTANCEWIREFRAMEGEOMETRY, { globalSpace: !0 })).visible = h[T][gp.INSTANCEWIREFRAMEGEOMETRY] } } h = null, o.render(n, t) } } else vc.EnableSelectionOutline && e.composer && e.getSelection().length > 0 ? e.composer.render() : (o.setRenderTarget(null), o.clear(), o.render(n, t)); e.onRenderListener(), e.onRenderFinishedListener(), e.cameraControl.setCameraChanging(!1), i.getBlinkEnabled() && (e.blinkHandle = requestAnimationFrame(A)), i.disposeBufferAfterVbo() }() }, resize: function (A, e) { if (this.camera && this.getRenderer()) { var t = this.getDomElement(); t && (t.style.height = e + "px", t.style.width = A + "px"), this.camera.setSize(A, e), this.camera.updateProjectionMatrix(), this.rendererManager.setSize(A, e), this.dispatchEvent({ type: "resize", data: { width: A, height: e } }), this.render() } }, resizeByFrustum: function (A, e) { this.camera && this.getRenderer() && (this.camera.updateProjectionMatrixByFrustum = !0, this.camera.setSizeByFrustum(A, e), this.render(), this.camera.updateProjectionMatrixByFrustum = !1) }, calculateNearFar: function () { this.calculateNearFar2() }, calculateNearFar2: function () { var A = this.getScene(), e = A.getBoundingBoxWorld(), t = this.getRenderer(); if (this.enableCameraNearFar) { var i = this.camera, o = i.position.clone().sub(A.getBoundingBoxWorld().getCenter(new y)).length(), n = A.getBoundingBoxWorld().getSize(new y).length(); if (null !== e && !e.isEmpty()) { e.expandByScalar(1.1); e.applyMatrix4(i.matrixWorldInverse); var r = e.getSize(new y).length() / 1e3, a = 100; 1e-4 > r ? a = .001 : .001 > r ? a = .01 : .01 > r ? a = .1 : .1 > r ? a = 1 : 1 > r && (a = 10); var s = 1, l = 0; e.max.z > 0 && 0 > e.min.z ? (l = -e.min.z, s = Math.min(r / 2, a / 2)) : (l = -e.min.z, s = Math.max(Math.min(r, a), -e.max.z)), t.shadowMap.enabled && (l *= 3, s /= 3), l = Math.max(s + 1, l), .1 > (l = Math.min(l, o + n)) - s && (s /= 2), i.setNearFar(s, l) } } }, resetSelectionColor: function (A, e) { this.modelManager.sceneState.setSelectionColor(A, e) }, calculateMinDistance: function (A, e) { if (Bh.time("计算最小距离"), A === e) { var t = this.getBoundingBoxByIds([A]).getCenter(new y); return { start: t, end: t, minDistance: 0 } } function i(A, e) { for (var t = 0, i = 0, o = 0; 3 > o; o += 1) { var n = A.min.getComponent(o), r = A.max.getComponent(o), a = e.min.getComponent(o), s = e.max.getComponent(o), l = 0; n > s ? l = n - s : a > r && (l = a - r), t += l * l; var c = Math.max(s, r) - Math.min(n, a); i += c * c } return { minDis: Math.sqrt(t), maxDis: Math.sqrt(i) } } var o = new y, n = new y, r = new y; function a(A, e, t, i, o, n, r, a, s) { r.fromBufferAttribute(e, t), a.fromBufferAttribute(e, i), s.fromBufferAttribute(e, o), n && (r.applyMatrix4(n), a.applyMatrix4(n), s.applyMatrix4(n)), A.push(r), A.push(a), A.push(s) } function s(A, e, t) { var i = { start: null, end: null, minDistance: t }, s = A.mesh, l = A.indexInfo, c = s.matrix.clone().multiply(A.matrix), h = s.geometry, d = h.attributes.position, p = l ? l.indexStart : 0, g = h.getIndex().array, u = l ? l.indexStart + l.indexCount : g.length, f = e.mesh, m = e.indexInfo, C = f.matrix.clone().multiply(e.matrix), v = f.geometry, I = v.attributes.position, E = m ? m.indexStart : 0, B = v.getIndex().array, x = m ? m.indexStart + m.indexCount : B.length, S = A.boundingBox, w = e.boundingBox; if (S.intersectsBox(w)) { for (var M = p, b = u; b > M; M += 3) { var U = []; a(U, d, g[M], g[M + 1], g[M + 2], c, o, n, r); var F = Tu.minDistanceBetweenTriToMesh(U, f, m, C); i.minDistance > F.minDistance && (i.minDistance = F.minDistance, i.start = F.start, i.end = F.end) } return i } var K = S.getSize(new y), Q = w.getSize(new y), R = S.min.x - w.max.x, T = S.min.y - w.max.y, k = S.min.z - w.max.z, D = w.min.x - S.max.x, L = w.min.y - S.max.y, N = w.min.z - S.max.z, O = w.min.x > S.min.x ? S.min.x : w.min.x, V = w.min.y > S.min.y ? S.min.y : w.min.y, G = w.min.z > S.min.z ? S.min.z : w.min.z, P = S.max.x > w.max.x ? S.max.x : w.max.x, q = S.max.y > w.max.y ? S.max.y : w.max.y, j = S.max.z > w.max.z ? S.max.z : w.max.z, H = R; switch (T > H && (H = T), k > H && (H = k), D > H && (H = D), L > H && (H = L), N > H && (H = N), H) { case R: O += Q.x / 2, P -= K.x / 2; break; case T: V += Q.y / 2, q -= K.y / 2; break; case k: G += Q.z / 2, j -= K.z / 2; break; case D: O += K.x / 2, P -= Q.x / 2; break; case L: V += K.y / 2, q -= Q.y / 2; break; case N: G += K.z / 2, j -= Q.z / 2 } for (var Y = new aA(new y(O, V, G), new y(P, q, j)), W = [], J = [], z = [], Z = [], X = p, _ = u; _ > X; X += 3) { var $ = []; a($, d, g[X], g[X + 1], g[X + 2], c, new y, new y, new y), z.push($); for (var AA = 0, eA = $.length; eA > AA; AA += 1) if (Y.containsPoint($[AA])) { W.push($); break } } for (var tA = E, iA = x; iA > tA; tA += 3) { var oA = []; a(oA, I, B[tA], B[tA + 1], B[tA + 2], C, new y, new y, new y), Z.push(oA); for (var nA = 0, rA = oA.length; rA > nA; nA += 1) if (Y.containsPoint(oA[nA])) { J.push(oA); break } } W.length || (W = z), J.length || (J = Z); var sA = Tu.minDistanceBetweenTriToTri(W, J); return i.minDistance > sA.minDistance && (i.minDistance = sA.minDistance, i.start = sA.start, i.end = sA.end), i } var l = this.modelManager.getMinDistanceObjects(A, e); if (!l) return -1; var c = [], h = { start: null, end: null, minDistance: Number.POSITIVE_INFINITY }; for (var d in l) { if (!l[d].boundingBox) { var p = this.getBoundingBoxByIds([d]); l[d].boundingBox = p } c.push(l[d]) } if (1 > c[0].length || 1 > c[1].length) return Bh.timeEnd("计算最小距离"), -1; var g = c[0], u = c[1], f = g.length, m = u.length, C = null, v = Number.POSITIVE_INFINITY; if (f > 1 || m > 1) { C = {}; for (var I = 0; f > I; I += 1) for (var E = g[I], B = 0; m > B; B += 1) { var x = u[B]; x.boundingBox = u.boundingBox, E.boundingBox = g.boundingBox; var S = i(E.boundingBox, x.boundingBox); v = S.maxDis > v ? v : S.maxDis, C[I + "_" + B] = S } } for (var w = 0; f > w; w += 1) for (var M = g[w], b = 0; m > b; b += 1) { if (C) { var U = C[w + "_" + b].minDis; if (U > v || U > h.minDistance) continue } var F = u[b]; F.boundingBox = u.boundingBox, M.boundingBox = g.boundingBox; var K = s(M, F, h.minDistance); if (h.minDistance > K.minDistance && (h.minDistance = K.minDistance, h.start = K.start, h.end = K.end), 0 === h.minDistance) return Bh.timeEnd("计算最小距离"), h } return C = null, Bh.timeEnd("计算最小距离"), h }, registerDomEventListeners: function () { this.domElement && this.controlManager.registerDomEventListeners(this.domElement) }, unregisterDomEventListeners: function () { this.domElement && this.controlManager.unregisterDomEventListeners(this.domElement) }, registerEventListener: function (A, e) { this.modelManager.addEventListener(A, e) }, unregisterEventListener: function (A, e) { this.modelManager.removeEventListener(A, e) }, registerCameraEventListener: function (A, e) { this.cameraControl.addEventListener(A, e) }, unregisterCameraEventListener: function (A, e) { this.cameraControl.removeEventListener(A, e) }, registerDomEventListener: function (A, e) { this.controlManager.addEventListener(A, e) }, unregisterDomEventListener: function (A, e) { this.controlManager.removeEventListener(A, e) }, load: function (A) { var e = this; return this.modelManager.load(A, (function () {}), (function (A) { Bh.time("Rendering: "), e.camera.dirty = !0, e.camera.dirty ? e.render() : (e.zoomAll(), e.goToInitialView()), Bh.timeEnd("Rendering: ") })) }, loadWithType: function () {}, loadTiles: function (A) { var e = this; return this.modelManager.loadTiles(A, (function () { void 0 === e._useBatchMerge && (e._useBatchMerge = e.modelManager.shouldUseBatchRendering(), vc.MergeComponent = e._useBatchMerge, e._setupRenderer()) }), (function (A) { Bh.time("Rendering: "), e.camera.dirty = !0, e.camera.dirty ? e.render() : (e.zoomAll(), e.goToInitialView()), Bh.timeEnd("Rendering: ") })) }, unload: function (A) { var e = this.modelManager.unload(A); return e && (vc.UserControlView || this.zoomAll(), this.render()), e }, unloadAll: function () { this.modelManager.unloadAll(), this.render() }, showModel: function (A) { this.modelManager.showModel(A) && this.render() }, hideModel: function (A) { this.modelManager.hideModel(A) && this.render() }, translateModel: function (A) { var e = this._transformModelByKey(A); e && e.switchToTranslateMode() }, rotateModel: function (A) { var e = this._transformModelByKey(A); e && e.switchToRotateMode() }, scaleModel: function (A) {}, showScene: function (A, e) { A && (A.setVisible(e), this.render()) }, clearAll: function () { this.getScene().clearAll() }, restore: function () { this.getFilter().clear(), this.getScene().disableClipPlanes(), this.modelManager.dispatchEvent({ type: Rc.ON_VIEWER_RESTORED }) }, getScene: function () { return this.modelManager.scene }, getCapsScene: function () { return this.modelManager.capsScene }, getControlManager: function () { return this.controlManager }, getUserdataByUserId: function (A) { var e = this.modelManager.getNodeInfosByUserId(A); return e && e instanceof Array ? e[0].userData : null }, getFilter: function () { return this.filter }, getCurrentControlName: function () { return this.controlManager.getCurrentControlName() }, getCurrentControlMode: function () { return this.controlManager.getCurrentControlMode() }, setControlMode: function (A) { this.controlManager.setControlMode(this, A), this.render() }, setControlDefault: function () { this.setControlMode(Gc.PICK) }, getBoundingBoxWorld: function () { return this.getScene().getBoundingBoxWorld() }, getBoundingBox: function () { return this.getScene().getBoundingBox() }, getModel: function (A) { return this.modelManager.getModel(A) }, getModelManager: function () { return this.modelManager }, setModelMatrix: function (A, e) { var t = this.getModel(e); t && t.setModelMatrix(A) }, getModelMatrix: function (A) { var e = null, t = this.getModel(A); return t && (e = t.getModelMatrix()), e }, overturnYAndZaxis: function (A) { var e = this.getModel(A); e && e.overturnYAndZaxis() }, zoomIn: function (A) { void 0 === A && (A = .1), 0 > A && (A = 0), this.cameraControl.zoom(A) }, zoomOut: function (A) { void 0 === A && (A = .1), A > 0 ? A *= -1 : A = 0, this.cameraControl.zoom(A) }, zoomAll: function (A, e, t) { var i = this.getScene().getBoundingBox(); this._zoomToLocalBox(i, A, e, t) }, zoomToBuilding: function (A, e, t) { this.zoomAll(A, e, t) }, zoomToSelection: function (A, e, t) { var i = this.getScene(), o = this.getBoundingBoxByIds(this.modelManager.sceneState.getSelection()); o.isEmpty() && (o = i.getBoundingBox()), !0 === this.getTransitionAnimationState() ? this.animator.setStandardView(Uc.Keep, this, o, A) : this._zoomToLocalBox(o, A, e, t) }, _zoomToLocalBox: function (A, e, t, i) { this.camera.zoomToBox(A, e, t, i), this.cameraControl.update(!0, !0), this.cameraControl.dirtyCamera(!0) }, zoomToBox: function (A, e, t, i) { var o = new aA; A ? (o.copy(A), o.applyMatrix4(this.getScene().getMatrixGlobal())) : o.copy(this.getScene().getBoundingBox()), !0 === this.getTransitionAnimationState() ? this.animator.setStandardView(Uc.Keep, this, o, e) : this._zoomToLocalBox(o, e, t, i) }, zoomToBoxByDirection: function (A, e, t, i) { if (e) { if (e && A) { var o = A.clone(), n = o.getCenter(new y).clone().add(e); o.applyMatrix4(this.getScene().getMatrixGlobal()), n.applyMatrix4(this.getScene().getMatrixGlobal()); var r = n.clone().sub(o.getCenter(new y)); r.length() > 1e-4 ? (r.normalize(), this.camera.realUp.copy(H.DefaultUp), this._zoomToLocalBox(o, t, i, r)) : this._zoomToLocalBox(o, t, i) } } else this.zoomToBox(A, t, i) }, zoomToBoxWithOuterBox: function (A, e, t, i) { if (e) { if (e && A) { var o = A.clone(), n = e.getCenter(new y); o.applyMatrix4(this.getScene().getMatrixGlobal()), n.applyMatrix4(this.getScene().getMatrixGlobal()); var r = n.clone().sub(o.getCenter(new y)); r.length() > 1e-4 ? (r.normalize(), this.camera.realUp.copy(H.DefaultUp), this.controlManager.zoomToBox(this, o, t, i, r)) : this.controlManager.zoomToBox(this, o, t, i) } } else this.zoomToBox(A, t, i) }, getObjectsInBox: function (A, e) { var t = new aA; return t.copy(A), t.applyMatrix4(this.getScene().getMatrixGlobal()), wg.getObjectsInBox(this.getScene(), t, this.modelManager, this, e) }, setStandardView: function (A, e, t, i) { var o = this.camera, n = this.getScene().getBoundingBox(); if (this.transitionAnimationState) this.animator.setStandardView(A, this, n, e, t, i); else { o.setStandardView(A, n); this.camera.zoomToBox(n, e); this.cameraControl.update(!0, !0), i && i() } }, rotateCameraByViewCubeSide: function (A) { this._viewCubeAnimator && (this._viewCubeAnimator.cancelAnimation(), this._viewCubeAnimator = void 0); var e = this.camera, t = this.getScene().getGeometryBoundingBox(), i = new Cp, o = this; i.rotateCameraByViewCubeSide(e, t, A, (function (A, e, t, i) { o.camera.position.copy(t); var n = new y(0, 1, 0); n.applyQuaternion(e), o.camera.up = n, o.camera.realUp = n.clone(), o.camera.lookAt(i), o.camera.target = i, 1 > A || o.camera.quaternion.copy(e), o.cameraControl.update(!0) })), this._viewCubeAnimator = i }, cancelCurrentAnimationByViewCube: function () { this._viewCubeAnimator && (this._viewCubeAnimator.cancelAnimation(), this._viewCubeAnimator = void 0) }, getLineSelectRange: function () { return vc.LineSelectRange }, setLineSelectRange: function (A) { vc.LineSelectRange = A }, _setStandardView: function (A, e) { var t = this.camera, i = this.getScene().getBoundingBox(); t.setStandardView(A, i), t.zoomToBox(i, e) }, setStandardViewWithBox: function (A, e, t, i) { if (e ? e.applyMatrix4(this.getScene().getMatrixGlobal()) : e = this.getScene().getBoundingBox(), this.transitionAnimationState) this.animator.setStandardView(A, this, e, t); else { var o = this.camera; o.setStandardView(A, e), o.zoomToBox(e, t, i), this.cameraControl.update(!0, !0) } }, setTopView: function (A, e, t) { this.setStandardViewWithBox(Uc.Top, A, e, t) }, setInitialView: function (A) { this.initialView = A, this._setStandardView(A) }, goToInitialView: function (A) { this.setStandardView(this.initialView, A, null) }, setHomeView: function (A) { this.currentHomeView = A, this._setStandardView(A) }, getHomeView: function () { return this.currentHomeView }, goToHomeView: function (A) { this.setStandardView(this.currentHomeView, A, null) }, rotateByAxis: function (A, e, t) { var i = t || this.cameraControl.calculatePivot(kc.CENTER, null), o = 2 * Math.PI / 60 / 60 * A; if (e && "x" !== e) { if ("y" !== e) return void Bh.warn("Illegal rotation axis for ViewerImpl.rotateByAxis()."); this.cameraControl.handleRotation(0, -o, i) } else this.cameraControl.handleRotation(-o, 0, i); this.cameraControl.update(!0) }, lookAt: function (A, e, t) { var i = new y; i.subVectors(e, A), this.camera.lookAtEx(e, i, t), this.cameraControl.updateCamera(e), this.render() }, setImageResPath: function (A) { vc.TextureResRoot = A }, setLimitFrameTime: function (A) { vc.IncrementRender && (A > 0 || (A = 30), vc.LimitFrameTime = A) }, limitFrameRate: function (A) { vc.IncrementRender && (A > 0 || (A = 4), vc.LimitFrameTime = 1e3 / A) }, transformCamera: function (A) { return Rd.transformCamera(A, this.modelManager.scene) }, getCamera: function () { var A = this.getScene().getMatrixGlobal(), e = this.cameraControl.getCamera(), t = this.cameraControl.getCameraName(), i = new Qd(t, e.position, e.target, e.up); i = cp.drawingToWorld(i, A); var o = {}; if (this.cameraStateWithFrustum) { var n = 2 * (e.near * Math.tan(.5 * a.DEG2RAD * e.fov) / e.zoom); o = new Qd(t, i.position, i.target, i.up, e.fov, void 0, e.aspect * n, n) } else o = new Qd(t, i.position, i.target, i.up, e.fov, void 0); return JSON.stringify(o) }, setCameraStateWithFrustum: function (A) { this.cameraStateWithFrustum = A }, setCamera: function (A, e, t) { this.camera.dirty = !0; var i = this, o = Rd.parseCameraInfo(A); if (null === o) Bh.log("Invalid camera info string. Fail to set camera."); else if (this.switchToCamera(o.name)) { var n = this.getScene().getMatrixGlobal(), r = cp.worldToDrawing(o, n); if (this.transitionAnimationState) { var a = { position: this.camera.position.clone(), target: this.camera.target.clone(), up: this.camera.realUp.clone() || this.camera.up.clone() }; this.animator.active(a, r, this, (function (A) { i.cameraControl.update(!0, !0) }), (function () { o.frustumWidth && o.frustumHeight && i.resizeByFrustum(o.frustumWidth, o.frustumHeight), t && t() })) } else { var s = new y; s.subVectors(r.target, r.position), this.camera.lookAtEx(r.target, s, r.up), e && this.cameraControl.updateCamera(), o.frustumWidth && o.frustumHeight && (i.cameraControl.update(!0, !0), i.resizeByFrustum(o.frustumWidth, o.frustumHeight)), t && t() } } }, getRenderBufferScreenShot: function (A, e, t, i) { this._render(); var o = this.getRenderer().domElement, n = o.toDataURL("image/png"), r = o.width, a = o.height, s = window.devicePixelRatio || 1, l = e || r / s, c = t || a / s; if (!l || !c) return i ? (i(n), null) : n; var h, d = null, p = null, g = 0, u = 0; if (l > c || l / c > r / a ? (d = l, u = c / 2 - (p = a / r * l) / 2) : (p = c, g = l / 2 - (d = r / a * c) / 2), i) return (h = new Image).onload = function () { var e = document.createElement("canvas"), t = e.getContext("2d"); e.width = l, e.height = c, A && (t.fillStyle = A, t.fillRect(0, 0, l, c)), t.drawImage(h, g, u, d, p); var o = e.toDataURL("image/png"); i(o) }, h.src = n, null; (h = new Image).src = n; var f = document.createElement("canvas"), m = f.getContext("2d"); return f.width = l, f.height = c, A && (m.fillStyle = A, m.fillRect(0, 0, l, c)), m.drawImage(h, g, u, d, p), f.toDataURL("image/png") }, screenShot: function (A, e, t) { var i = this; return this._render(), function () { var o = i.getRenderer().domElement, n = o.toDataURL("image/png"), r = o.width, a = o.height, s = (window, A), l = e; if (!s || !l) return t ? (t(n), null) : n; var c = null, h = null, d = 0, p = 0; if (s > l || s / l > r / a ? (c = s, p = l / 2 - (h = a / r * s) / 2) : (h = l, d = s / 2 - (c = r / a * l) / 2), t) { var g = new Image; return g.onload = function () { var A = document.createElement("canvas"), e = A.getContext("2d"); A.width = s, A.height = l, e.drawImage(g, d, p, c, h); var i = A.toDataURL("image/png"); t(i) }, g.src = n, null } }() }, canvas2image: function (A, e, t, i) { var o = null, n = this; return i ? (this.getRenderBufferScreenShot(A, e, t, (function (A) { i(A), n.render() })), null) : (o = this.getRenderBufferScreenShot(A, e, t), this.render(), o) }, lockAxisZ: function (A, e) { var t = this.cameraControl; if (t) { var i = t.getZenith(), o = this.getBoundingBox().getCenter().clone(); if (A && void 0 !== e || (e = null), e) { var n = e[0], r = e[1]; i > r ? t.handleRotation(0, r - i, o) : n > i && t.handleRotation(0, n - i, o), this.render() } this.cameraControl.lockAxisZ(A), this.cameraControl.setLockAxisZRange(e) } }, isLockedAxisZ: function () { return this.cameraControl.isLockedAxisZ() }, enableTranslucentByDClick: function (A) { vc.EnableDemolishByDClick = A }, enableHitDetection: function (A) { vc.EnableHitDetection = A }, enableRotate: function (A) { jh.NoRotate = !A }, rotateCamera: function (A, e) { this.cameraControl.processRotate(A, e), this.cameraControl.update() }, getActiveCameraInfo: function () { var A = {}; A.up = new y, A.dir = new y; var e = this.camera, t = e.getWorldDirection(new y); return A.up.copy(e.realUp || e.up), A.dir.copy(t), A.quaternion = e.quaternion.clone(), A }, calculationPlanes: function () { if (this.isRecalculationPlanes) { this.isRecalculationPlanes = !1; var A = this.getScene(), e = this.getBoundingBoxByIds(); e.isEmpty() && (e = A.getBoundingBox()), A.getClipPlanes().calculationPlanes(e.getSize(new y), e.getCenter(new y)), this.render() } }, recalculationPlanes: function () { this.isRecalculationPlanes = !0 }, setOctantDepth: function (A) { vc.OctantDepth = A }, resizePool: function (A) { vc.maxObjectNumInPool = A, this.modelManager.updateSceneRenderable(), this.render() }, setCategoriesToHighPriority: function (A, e) { this.modelManager.setCategoriesToHighPriority(A, 0 === e ? "inner" : "outer") }, clearCategoriesFromHighPriority: function (A) { this.modelManager.clearCategoriesFromHighPriority(0 === A ? "inner" : "outer") }, clearAllCategoriesFromHighPriority: function () { this.modelManager.clearAllCategoriesFromHighPriority() }, isolate: function (A, e) { var t = this.getFilter(); switch (e) { case "hide": t.setIsolateConditions(A, Nc.HIDDEN_OTHERS); break; case "translucent": t.setIsolateConditions(A, Nc.TRANSLUCENT_OTHERS); break; default: Bh.warn("no this isolate state : " + e) } }, setIsolateMaterial: function (A) { this.getFilter().setIsolateMaterial(A) }, resetIsolateMaterial: function () { this.getFilter().resetIsolateMaterial() }, setOrbitButton: function (A) { var e = this.controlManager._getControlByName(this, Gc.ORBIT), i = this.controlManager._getControlByName(this, Gc.PICK), o = {}; "left" === A ? o = { ORBIT: t.LEFT, PAN2: t.MIDDLE, PAN: t.RIGHT } : "right" === A && (o = { ORBIT: t.RIGHT, PAN2: t.MIDDLE, PAN: t.LEFT }), e && e.updateButtons(o), i && i.updateButtons(o) }, showPickedInformation: function (A) {}, setOrbitEnabled: function (A) { jh.NoRotate = !0 !== A }, getOrbitEnabled: function () { return !jh.NoRotate }, setSelectPadCallback: function (A) { var e = this.controlManager.getCurrentControlMode(); e && e.selectPad && (e.selectPad.callback = A) }, setDeviceMobile: function (A) { vc.IsMobile = A || !1 }, setPointRotateMode: function (A) { jh.RotatePivotMode = A }, worldToDrawing: function (A) { if (!this.cameraControl) return Bh.warn("camera is not initialized!!!"), null; var e = this.getScene().worldToDrawing(A); return { x: e.x, y: e.y, z: e.z } }, drawingToWorld: function (A) { if (!this.cameraControl) return Bh.warn("camera is not initialized!!!"), null; var e = this.getScene().drawingToWorld(A); return { x: e.x, y: e.y, z: e.z } }, worldToCanvas: function (A) { var e = this.cameraControl; if (!e) return Bh.warn("camera is not initialized!!!"), null; var t = e.getContainerDimensions(); if (!t) return null; var i = e.getCamera(), o = this.getScene().worldToDrawing(A); return Rd.drawingToCanvas(i, o, t.width, t.height) }, canvasToWorld: function (A) { var e = this.cameraControl; if (!e) return Bh.warn("camera is not initialized!!!"), null; var t = e.getContainerDimensions(); if (!t) return null; var i = e.getCamera(), o = this.getScene(), n = Rd.canvasToDrawing(i, A, t.width, t.height), r = o.drawingToWorld(n); return { x: r.x, y: r.y, z: r.z } }, worldToClient: function (A) { var e = this.cameraControl; if (!e) return Bh.warn("camera is not initialized!!!"), null; var t = e.getContainerDimensions(); if (!t) return null; var i = e.getCamera(), o = this.getScene().worldToDrawing(A), n = Rd.drawingToCanvas(i, o, t.width, t.height); return n ? (n.x += t.left, n.y += t.top, n) : null }, worldPointsToClient: function (A, e) { var t = this.cameraControl; if (!t) return Bh.warn("camera is not initialized!!!"), null; var i = t.getContainerDimensions(); if (!i) return null; var o = t.getCamera(), n = this.getScene(), r = n.worldToDrawing(A), a = n.worldToDrawing(e), s = Rd.drawingPointsToCanvas(o, r, a, i.width, i.height); return s ? (s.start.x += i.left, s.start.y += i.top, s.end.x += i.left, s.end.y += i.top, s) : null }, clientToWorld: function (A) { var e = this.cameraControl; if (!e) return Bh.warn("camera is not initialized!!!"), null; var t = e.getContainerDimensions(); if (!t) return null; (n = { x: A.x, y: A.y, z: A.z }).x -= t.left, n.y -= t.top; var i = e.getCamera(), o = this.getScene(), n = Rd.canvasToDrawing(i, n, t.width, t.height), r = o.drawingToWorld(n); return { x: r.x, y: r.y, z: r.z } }, insideCamera: function (A) { var e = this.cameraControl; if (!e) return Bh.warn("camera is not initialized!!!"), !1; var t = this.getScene().worldToDrawing(A); return e.getFrustum().containsPoint(t) }, locateToPointWithParallelEye: function (A) { var e = this.cameraControl; if (!e) return Bh.warn("camera is not initialized!!!"), !1; var t = this.getScene().worldToDrawing(A); e.flyToPointWithParallelEye(t) }, locateToPoint: function (A) { var e = this.cameraControl; if (!e) return Bh.warn("camera is not initialized!!!"), !1; var t = this.getScene().worldToDrawing(A); e.flyToPoint(t) }, enableHover: function (A) { vc.Hover = A }, getObjectsByClientCoordinates: function (A) { return new fp(this).getObjectsByClientCoordinates(A) }, getIBLManager: function () { return this.IBLManager }, loadEnvMap: function (A) { for (var e = ["posx.hdr", "negx.hdr", "posy.hdr", "negy.hdr", "posz.hdr", "negz.hdr"], t = [], i = 0; 6 > i; i += 1) t.push("/" + A + "/" + e[i]); var o = this; (new(void 0)).load(1015, t, (function (A) { o.environmentCubeMap = A, o.modelManager.updateMaterialsValue("envMap", A), o.render() })) }, setEnvMapIntensity: function (A) { this.modelManager.updateMaterialsValue("envMapIntensity", A), this.setRenderStateChanged(!0), this.render() }, closeEnvMap: function () { this.modelManager.updateMaterialsValue("envMap", null), this.render() }, enableSSAO: function (A) { return !vc.IncrementRender && (vc.EnableRenderPass = A, vc.SSAO = A, this.setRenderStateChanged(!0), this.render(), !0) }, switchNewStyleMaterial: function (A) { this.modelManager.switchNewStyleMaterial(A), this.setRenderStateChanged(!0), this.render() }, enableColorWithoutLight: function (A) { this.modelManager.enableColorWithoutLight(A), this.setRenderStateChanged(!0), this.render() }, addPlane: function (A, e, t, i) { var o = new y; o.addVectors(new y(A.x, A.y, A.z), new y(e.x, e.y, e.z)), o.multiplyScalar(.5); var n = new Ue(new et(e.x - A.x, e.y - A.y), new jA({ side: 2, transparent: !0, depthTest: !0 })); n.position.copy(o), n.renderOrder = 10, this.getScene().getOrCreateGroup(gp.CUSTOMPLANE, { globalSpace: !0 }).add(n), n.updateMatrixWorld(!0); var r = this; return (new Aa).load(t, (function (A) { n.material.map = A, n.material.needsUpdate = !0, r.setRenderStateChanged(!0), i && i() })), n }, removePlane: function (A) { var e = this.getScene().getGroup(gp.CUSTOMPLANE); e && e.remove(A) }, clearPlane: function () { var A = this.getScene().getGroup(gp.CUSTOMPLANE); A && A.clear() }, enableTextureMapping: function (A) { vc.EnableTextureMapping = A }, enableLightmap: function (A) { vc.EnableLightmap !== A && (vc.EnableLightmap = A) }, setLightmapIntensity: function (A) { vc.LightmapIntensity !== A && (vc.LightmapIntensity = A) }, setReverseWheelDirection: function (A) { jh.ReverseWheelDirection = Boolean(A) }, getReverseWheelDirection: function () { return jh.ReverseWheelDirection }, setMovementSpeedRate: function (A) { void 0 !== A && (jh.MovementSpeedRate = A) }, getMovementSpeedRate: function () { return jh.MovementSpeedRate }, moveTo: function (A, e, t) { var i = this.controlManager.control; i && i.moveTo(A, e, t) }, rotateTo: function (A) { var e = this.controlManager.control; e && e.rotateTo(A) }, enableOcclusionTranslucent: function (A) { vc.OcclusionTranslucentEnabled = Boolean(A) }, setOcclusionOpacity: function (A) { vc.OcclusionOpacity = A }, setOcclusionDistanceToCamera: function (A) { vc.OcclusionDistanceToCamera = A }, fitAndRotateBySelection: function () { this.cameraControl && this.cameraControl.fitAndRotateBySelection() }, setRoamingWalkHeight: function (A, e, t) { if (Array.isArray(A)) { var i = this.cameraControl; if (!i) return Bh.log("camera is not initialized!!!"), !1; if (e > 0 || (e = 1750), void 0 === t && (t = !0), i.setCameraHeight(A, e), t) { var o = this.controlManager.getCurrentControl(); o && o.name === Gc.WALK && o.update && i.flyOnWorld() } } else Bh.log("elevations is not arry") }, setRoamingWalkAbsoluteHeight: function (A, e) { var t = this.cameraControl; if (!t) return Bh.log("camera is not initialized!!!"), !1; if (void 0 === e && (e = !0), t.setCameraAbsoluteHeight(A), e) { var i = this.controlManager.getCurrentControl(); i && i.name === Gc.WALK && i.update && t.flyOnWorld() } }, cameraToWorld: function (A) { return this.camera ? cp.drawingToWorld(A, this.getScene().getMatrixGlobal()) : null }, cameraToDrawing: function (A) { return this.camera ? cp.worldToDrawing(A, this.getScene().getMatrixGlobal()) : null }, clearSelection: function () { this.modelManager.sceneState.clearSelection() }, clearModelSelection: function () { this.modelManager.modelState.clearSelection() }, addToSelection: function (A) { this.modelManager.sceneState.addSelection(A) }, addToModelSelection: function (A) { this.modelManager.modelState.addSelection(A) }, removeFromSelection: function (A) { this.modelManager.sceneState.removeSelection(A) }, removeFromModelSelection: function (A) { this.modelManager.modelState.removeSelection(A) }, setSelection: function (A) { this.modelManager.sceneState.setSelection(A) }, setModelSelection: function (A) { this.modelManager.modelState.setSelection(A) }, getSelection: function () { return this.modelManager.sceneState.getSelection() }, getModelSelection: function () { return this.modelManager.modelState.getSelection() }, setSelectionColor: function (A, e) { var t = A, i = e; A instanceof Xh && (t = A.getHex(), i = A.getAlpha()), this.modelManager.sceneState.setSelectionColor(t, i); var o = this.rendererManager.getPickingEffecter(); o && o.setSelectionColor(t, i) }, getSelectionColor: function () { return this.modelManager.sceneState.getSelectionColor() }, restoreSelectionColor: function () { this.setSelectionColor(new Xh(vc.SelectionColor.color, vc.SelectionColor.opacity)) }, setModelSelectionColor: function (A, e) { this.modelManager.modelState.setSelectionColor(A, e) }, getScreenCoordFromSceneCoordAndCheckCover: function (A) { var e = void 0, t = !1; if ("[object Array]" == Object.prototype.toString.call(A)) e = new y(A[0], A[1], A[2]); else { if ("[object Object]" != Object.prototype.toString.call(A)) return; e = new y(A.x, A.y, A.z) } if (e) { var i = this.camera.position, o = i.distanceTo(e), n = new Ds(i, e.clone().sub(i).normalize()), r = this.cameraControl.getIntersectContext({ x: 100, y: 100 }), a = this.cameraControl.intersector.getIntersectByRay(r, n.ray); if (!a) return; t = o - 300 > i.distanceTo(a.point) } return { screenCoord: this.getScreenCoordFromSceneCoord(e), cover: t } }, pickByPoint: function (A) { var e = this.cameraControl; if (!1 === e.enabled) return !1; var t = new s(A.x, A.y), i = e.getIntersectContext(t), o = e.intersector.pick(i), n = this.getScene(); if (o) { n.intersectToWorld(o, this); var r = {}; return r.faceIndex = o.faceIndex, r.componentKey = o.userId, r.worldPosition = o.worldPosition, r.worldBoundingBox = o.worldBoundingBox, r } return null }, pickByPointWithNormal: function (A) { var e = this.getScene(), t = this.cameraControl; if (!1 === t.enabled) return null; var i = new s(A.x, A.y), o = t.getIntersectContext(i), n = t.intersector.pick(o); if (!n) return null; e.intersectToWorld(n, this), n.cx = i.x, n.cy = i.y; var r = []; r.push(n); var a = e.getMatrixGlobal(), l = n.face.normal.clone(), c = new CA(n.worldPosition.clone(), l); c.applyMatrix4(a); var h = t.intersector.getIntersectByRay(o, c); return h && (e.intersectToWorld(h, this), r.push(h)), r }, toDefaultOrthographicCamera: function (A) { this.switchToCamera(Ec.ORTHOGRAPHIC), (A || void 0 === A) && this.render() }, toDefaultPerspectiveCamera: function (A) { this.switchToCamera(Ec.PERSPECTIVE), (A || void 0 === A) && this.render() }, getCameraNameList: function () { return ["pesp", "orth"].concat(this.modelManager.getCameraNameList()) }, switchToCamera: function (A) { var e = !0; if (A === Ec.PERSPECTIVE) this.camera = this.defaultCamera, this.camera.toPerspective(); else if (A === Ec.ORTHOGRAPHIC) this.camera = this.defaultCamera, this.camera.toOrthographic(); else { var t = this.modelManager.getCamera(A); t ? this.camera = t : (Bh.log("Fail to switch because not found camera '" + A + "'"), e = !1) } return e && this.cameraControl.setCamera(this.camera), this.render(), e }, getNumOfElements: function () { return this.modelManager.getNumOfElements() }, getNumOfRenderables: function () { return this.modelManager.getNumOfRenderables() }, getNumOfTriangles: function () { return this.modelManager.getNumOfTriangles() }, setLightPreset: function (A) { this.getScene().setLightPreset(A), this.setRenderStateChanged(!0) }, getLightPreset: function () { return this.getScene().getLightPreset() }, setLightIntensityFactor: function (A) { this.getScene().setLightIntensityFactor(A), this.render() }, setAmbientLightIntensity: function (A) { this.getScene().setAmbientLightIntensity(A), this.render() }, getAmbientLightIntensity: function () { return this.getScene().getAmbientLightIntensity() }, setWalkHeightLocked: function (A) { var e = this.controlManager.getCurrentControl(); e && e.name === Gc.WALK && e.setHeightLocked(A) }, setWalkLookMousePressed: function (A) { var e = this.controlManager.getCurrentControl(); e && e.name === Gc.WALK && e.setDragLook(A) }, setWalkSpeedRate: function (A) { var e = this.controlManager.getCurrentControl(); e && e.name === Gc.WALK && (jh.MovementSpeedRate = A) }, getWalkSpeedRate: function () { return jh.WalkSpeedRate }, setDrawingStyle: function (A) { vc.DrawingStyle = A, this.modelManager.applyFilter(), this.setRenderStateChanged(!0) }, getWireframeColor: function (A) { var e = this.modelManager; if (A && e.models[A]) return e.models[A].wireframeManager.getWireframeColor(); for (var t in e.models) { return e.models[t].wireframeManager.getWireframeColor() } }, setWireframeColor: function (A, e) { var t = this.modelManager; if (e && t.models[e]) t.models[e].wireframeManager.setWireframeColor(new LA(A), A.a || 1); else for (var i in t.models) t.models[i].wireframeManager.setWireframeColor(new LA(A), A.a || 1); this.setRenderStateChanged(!0) }, restoreWireframeColor: function (A) { var e = this.modelManager; if (A && e.models[A]) e.models[A].wireframeManager.restoreWireframeColor(); else for (var t in e.models) e.models[t].wireframeManager.restoreWireframeColor(); this.setRenderStateChanged(!0) }, setInstanceMode: function (A) { !vc.Instance === A && (vc.Instance = A, this.getScene().getOrCreateGroup(gp.INSTANCEGEOMETRY, { globalSpace: !0 }).visible = !!A) }, setTransitionAnimationState: function (A) { this.transitionAnimationState = A }, getTransitionAnimationState: function () { return this.transitionAnimationState }, clipPoint: function (A) { var e = this.getRenderer().clippingPlanes; if (e && e.length > 0) for (var t = 0; e.length > t; t += 1) { var i = e[t]; if (A.dot(i.normal) < -i.constant) return !0 } return !1 }, setExposureShift: function (A) { vc.ToneMapping = 1, this.modelManager.updateMaterialsValue("shift", A > 0 ? -.4 * A + .5 : -4 * A + .5), this.setRenderStateChanged(!0) }, setRenderStateChanged: function (A) { this.modelManager && this.modelManager.setRenderStateChanged(A) }, isRenderStateChanged: function () { return this.modelManager._renderStateChanged }, getComponentInfoByUserId: function (A) { return this.modelManager.getComponentInfoByUserId(A) }, getBoundingBoxByIds: function (A) { var e = new aA; if (Array.isArray(A)) { for (var t = 0; A.length > t; t += 1) if (!this.modelManager.isHiddenUserId(A[t])) { var i = this.getModelByComponentKey(A[t]), o = this.getComponentInfoByUserId(A[t]); if (o) if (i) { var n = o.boundingBox.clone().applyMatrix4(i.getModelMatrix()); e.union(n) } else e.union(o.boundingBox) } } else for (var r in A) if (!this.modelManager.isHiddenUserId(r)) { var a = this.getModelByComponentKey(r), s = this.getComponentInfoByUserId(r); if (s) if (a) { var l = s.boundingBox.clone().applyMatrix4(a.getModelMatrix()); e.union(l) } else e.union(s.boundingBox) } return e.isEmpty() || e.applyMatrix4(this.getScene().getMatrixGlobal()), e }, setConditionsOnDemandLoad: function (A, e, t, i) { e = e || !0, this.modelManager.setConditionsOnDemandLoad(A), e && this.modelManager.loadGeopkOnDemand(t, i) }, loadGeopkOnDemand: function (A, e, t, i) { var o = this; this.modelManager.loadGeopkOnDemand(A, e, t, (function () { var A = o.modelManager.getNodeInfos(); o.filter.reinitFilterManager(A), o.setRenderStateChanged(!0), o.render(), i && i() })) }, unloadGeopkOnDemand: function (A, e) { var t = this; this.filter._hasVisibleFilter() && (this.filter.showByIds(A), this.filter.removeFromIsolateList(A)), this.filter._hasOverrideMaterialFilter() && (this.filter.addToOverrideListByColor(A, null), this.filter.addToWireframeByWireframe(A, null)), this.filter._hasTransparentFilter() && this.filter.opaqueByIds(A), this.removeFromSelection(A); for (var i = 0, o = A.length; o > i; i += 1) ; this.modelManager.unloadGeopkOnDemand(A, (function () { var A = t.modelManager.getNodeInfos(); t.filter.reinitFilterManager(A), t.setRenderStateChanged(!0), t.render(), e && e() })) }, getBoundingBoxOnDemand: function () { return this.modelManager.getBoundingBoxOnDemand() }, getScreenCoordFromSceneCoord: function (A) { var e = []; if (A.isVector3) { var t = A.clone(); t.applyMatrix4(this.camera.matrixWorldInverse); var i = t.z > 0; return t.applyMatrix4(this.camera.projectionMatrix), e[0] = (t.x + 1) * this.domElement.clientWidth / 2, e[1] = (1 - t.y) * this.domElement.clientHeight / 2, e[2] = i ? 1 : 0, e } if (Array.isArray(A)) { var o = new y(A[0], A[1], A[2]); o.applyMatrix4(this.camera.matrixWorldInverse); i = o.z > 0; return o.applyMatrix4(this.camera.projectionMatrix), e[0] = (o.x + 1) * this.domElement.clientWidth / 2, e[1] = (1 - o.y) * this.domElement.clientHeight / 2, e[2] = i ? 1 : 0, o = null, e } }, _checkDataChanged: function () { var A = this.modelManager; A.hasModelDataReady() && (this.getFilter().isStateChanged() || this.isRenderStateChanged()) && (this.isRenderStateChanged() && this.setRenderStateChanged(!1), this.getFilter().isStateChanged() && this.getFilter().disableStateChanged(), this.needApplyFilter = !0), this.needCheckTilesDataChange && (this.needCheckTilesDataChange = !1, A.checkTilesDataChanged(this.camera, this.getRenderer())) }, _checkLayerDataLoading: function () { return !(!this.modelManager.isLayerData() || !this._layerDataLoading) && (this.getFilter().isStateChanged() && this.getFilter().disableStateChanged(), !0) }, setOutlineEdgeColor: function (A) { this.rendererManager.composer && this.rendererManager.composer.setOutlineEdgeColor(A); var e = this.rendererManager.getPickingEffecter(); e && e.setLineSelectionColor(A.getHex(), A.opacity) }, getOutlineEdgeColor: function () { if (this.rendererManager.composer) return this.rendererManager.composer.getOutlineEdgeColor(); var A = this.rendererManager.getPickingEffecter(); return A ? A.getLineSelectionColor() : void 0 }, restoreOutlineEdgeColor: function (A) { this.setOutlineEdgeColor(new Xh(vc.SelectionColor.color, vc.SelectionColor.opacity)) }, enableSelectedColorIsAffectedByLight: function (A) { vc.InfluencedByLight = A, vc.InfluencedByLight ? delete this.modelManager.getSceneState().selectionMaterial.defines.NOTAFFECTEDBYLIGHT : this.modelManager.getSceneState().selectionMaterial.defines.NOTAFFECTEDBYLIGHT = "" }, enableLogarithmicDepthBuffer: function (A) { vc.logarithmicDepthBuffer !== A && (vc.logarithmicDepthBuffer = A, this.renderSettings.logarithmicDepthBuffer = A, this.rendererManager.resetupRenderer(this.renderSettings || {}), this._render(), this.updateShadowLight()) }, enableBlinkComponents: function (A) { this.modelManager.isBlinkPermited() || (this.modelManager.enableBlink(A), this.render()) }, setBlinkComponentsById: function (A) { this.modelManager.isBlinkPermited() || this.modelManager.sceneState.setBlinkComponentsById(A) }, addBlinkComponentsById: function (A) { this.modelManager.isBlinkPermited() || this.modelManager.sceneState.addBlinkComponentsById(A) }, clearBlinkComponentsById: function (A) { this.modelManager.isBlinkPermited() || this.modelManager.sceneState.clearBlinkComponentsById(A) }, clearAllBlinkComponents: function () { this.modelManager.isBlinkPermited() || this.modelManager.sceneState.clearAllBlinkComponents() }, getBlinkComponents: function () { return this.modelManager.isBlinkPermited() ? null : this.modelManager.sceneState.getBlinkComponents() }, setBlinkColor: function (A) { this.modelManager.isBlinkPermited() || this.modelManager.setBlinkColor(A.color, A.opacity) }, setBlinkIntervalTime: function (A) { this.modelManager.isBlinkPermited() || this.modelManager.setBlinkIntervalTime(A) }, getModelByComponentKey: function (A) { var e = null; for (var t in this.modelManager.models) if (this.modelManager.models.hasOwnProperty(t) && (e = this.modelManager.getModel(t)) && e.isLoaded() && e.hasComponent(A)) return e }, getSceneState: function () { return { state: this.getFilter().saveState(), camera: this.getCamera(), selection: this.getSelection(), modelSelection: this.getModelSelection() } }, setSceneState: function (A) { void 0 !== A.camera && "object" !== lc(A.camera) || (A.camera = JSON.stringify(A.camera)), this.setCamera(A.camera, !1), this.setSelection(A.selection), this.setModelSelection(A.modelSelection), this.getFilter().loadState(A.state) }, setComponentPositionByKey: function (A, e) { var t = (new y).fromArray(e), i = (this.getModelManager(), new M, this.modelManager.getComponent(A)); if (i && i.length >= 1) { for (var o = new aA, n = 0, r = i.length; r > n; n += 1) { o && o.union(i[n].boundingBox) } var a = new y; o.getCenter(a); var s = this.getModelByComponentKey(A); if (s) { var l = s.getModelMatrix(); if (l) { var c = new M; c.getInverse(l), t.applyMatrix4(c) } } t.sub(a); var h = (new M).makeTranslation(t.x, t.y, t.z); this.componentApplyMatrix2(A, h, !0), this.updateTransformControlIfBindingComKeyEqual(A) } }, setBackgroundColor: function (A, e) { if (e) this.setBackgroundColors([{ color: A, stop: "0%" }, { color: e, stop: "100%" }], "180deg"); else { var t = this.getDomElement(); t && (t.style.background = A.getRGBA()) } }, setBackgroundColors: function (A, e) { var t = this.getDomElement(), i = e || "0deg", o = []; if (A && A.length > 0) { 1 === A.length && this.setBackgroundColor(A[0].color || A[0]); for (var n = 0; A.length > n; n += 1) { var r = A[n].color.getRGBA() + " " + A[n].stop; o.push(r) } var a = i + ", " + o.join(","); t && (t.style.background = "linear-gradient(" + a + ")") } }, resetBackgroundColor: function () { this.getDomElement() && (this.domElement.style.background = "linear-gradient(rgb(135,206,250) 0%, rgb(245, 245, 245) 100%)") }, getComponentLocalMatrixByKey: function (A) { if (A) { var e = this.modelManager.getComponent(A); if (e && e.length > 0 && e[0].matrix) return e[0].matrix.clone() } }, getComponentWorldMatrixByKey: function (A) { var e = this.getComponentLocalMatrixByKey(A); if (e) { var t = this.getModelByComponentKey(A); if (t) { var i = t.getModelMatrix(); e.premultiply(i) } return e } }, setComponentLocalMatrixByKey: function (A, e) { if (A) { var t = this.modelManager.getComponent(A); if (t && t.length > 0) { var i = t[0].mesh; return i.matrix.fromArray(e), i.updateMatrixWorld(!0), this.render(), !0 } } return !1 }, _transformComponentByKey: function (A, e, t) { var i = this; if (A) { var o = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); if (o && o.bindingComponentKey === A) return o; var n = this.getModelByComponentKey(A), r = function (A) { i.render() }, a = function (t) { "string" == typeof A && t.matrix && t.object && (i.componentApplyMatrix2(A, t.matrix, !1), i.getScene().expandBoundingBoxWorldBy(t.object)), e && e(A) }; if ("string" != typeof A) { if (A instanceof H) { var s = A; return this.controlManager.enableTool(this, Pc.COMPONENT_TRANSFORM), (o = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM)).transformComponent(s, r, a), o.bindingComponentKey = void 0, o } return } var l = this.modelManager.getComponent(A); if (l && l.length > 0) { var c = i.externalComponentManager; c && c.getNodeInfosByUserId(A) && c.recalculateComponentBoundingbox(A); for (var h = new aA, d = 0, p = l.length; p > d; d += 1) h.union(l[d].transformationOriginalBoundingBox ? l[d].transformationOriginalBoundingBox : l[d].boundingBox); var g = new Ue(Tu.getGeometryFromBox3(h)); if (g.matrixAutoUpdate = !1, l[0].transformation && g.matrix.copy(l[0].applyMatrix), n) { var u = n.getModelMatrix(); if (u) { var f = new Xi; f.matrixAutoUpdate = !1, f.matrix.copy(u), f.updateMatrixWorld(!0), f.add(g) } } return g.updateMatrixWorld(!0), this.controlManager.enableTool(this, Pc.COMPONENT_TRANSFORM), (o = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM)).transformComponent(g, r, a, void 0, (function (e) { if (n) n.calculateBoundingBox(); else { var o = i.externalComponentManager; o && o.getNodeInfosByUserId(A) && o.calculateBoundingBox() } i.modelManager.updateSceneBoundingBox(), t && t(A) })), o.bindingComponentKey = A, this.modelManager.updateTransformComponentList(A), o } } }, _transformModelByKey: function (A) { if (A && "string" == typeof A) { var e = this.getModel(A); if (e && e.isLoaded() && e.isVisible()) { var t = this, i = e.getBoundingBoxWorld(); if (i.isEmpty()) return; var o = new Ue(Tu.getGeometryFromBox3(i)); o.matrixAutoUpdate = !1, o.updateMatrixWorld(!0), this.controlManager.enableTool(this, Pc.COMPONENT_TRANSFORM); var n = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); return n.transformComponent(o, (function (A) { t.render() }), (function (A) { A && A.matrix && e.applyModelMatrix(A.matrix) })), n } } }, translateComponentByKey: function (A, e, t) { var i = this._transformComponentByKey(A, e, t); i && i.switchToTranslateMode() }, scaleComponentByKey: function (A, e, t) { var i = this._transformComponentByKey(A, e, t); i && i.switchToScaleMode() }, rotateComponentByKey: function (A, e, t) { var i = this._transformComponentByKey(A, e, t); i && i.switchToRotateMode() }, cancelTransformComponent: function (A) { var e = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); e && (A && this.restoreComponentTransform(), e.cancelTransformComponent(), this.controlManager.disableTool(e.name)) }, cancelTransformComponentByKey: function (A) { if (A && "string" == typeof A) { var e = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); e && e.bindingComponentKey === A && (e.cancelTransformComponent(), this.controlManager.disableTool(e.name)) } }, restoreComponentTransform: function () { var A = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); A && (A.bindingComponentKey ? this.restoreComponentTransformByKey(A.bindingComponentKey) : A.restoreComponentOriginalTransformState() && this.render()) }, restoreComponentTransformByKey: function (A) { A && "string" == typeof A && (this.resetComponentMatrix(A), this.updateTransformControlIfBindingComKeyEqual(A)) }, updateTransformControlIfBindingComKeyEqual: function (A) { var e = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); e && e.bindingComponentKey === A && (e.cancelTransformComponent(), this._transformComponentByKey(A)) }, increaseComponentTransformControlSize: function () { var A = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); A && A.increaseTransformControlSize() && this.render() }, decreaseComponentTransformControlSize: function () { var A = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); A && A.decreaseTransformControlSize() && this.render() }, setComponentTransformSpaceToLocalSpace: function () { var A = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); A && A.setTransformSpaceToLocalSpace() && this.render() }, setComponentTransformSpaceToWorldSpace: function () { var A = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); A && A.setTransformSpaceToWorldSpace() && this.render() }, switchComponentTransformSpaceBetweenLocalAndWorld: function () { var A = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); A && A.switchTransformSpace() && this.render() }, showComponentTransformOnAxis: function (A) { var e = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); e && e.showTransformOnAxis(A) && this.render() }, hideComponentTransformOnAxis: function (A) { var e = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); e && e.hideTransformOnAxis(A) && this.render() }, disableComponentTransform: function () { var A = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); A && A.disableTransform() && this.render() }, enableComponentTransform: function () { var A = this.controlManager.getToolByName(Pc.COMPONENT_TRANSFORM); A && A.enableTransform() && this.render() }, componentApplyMatrix: function (A, e) { var t = this.getModelManager(), i = this.getModelByComponentKey(A); if (i) { t.explosionList[A] || (t.explosionList[A] = !0); var o = i._getHandler(); if (o instanceof MC) { var n = this.modelManager.getComponent(A); if (n && n[0] && n[0].mesh) { var r = n[0].mesh; if (r) { r.userData.originalMatrix || (r.userData.originalMatrix = r.matrixWorld.clone()); var a = new y(r.userData.originalMatrix.elements[12], r.userData.originalMatrix.elements[13], r.userData.originalMatrix.elements[14]), s = new M; s.setPosition(a); var l = new M; l.setPosition(a.multiplyScalar(-1)), r.matrixWorld.multiply(l).multiply(e).multiply(s) } } } else if (o instanceof Yf) { var c = i.getModelDescriptor(), h = c.mapNodeInfoByCategory[1], d = c.mapNodeInfoByCategory[0]; if (h.hasOwnProperty(A)) for (var p = h[A], g = 0; p.length > g; g += 1) { var u = p[g], f = u.mesh; if (f) { var m = u.index, C = f.geometry.attributes.position; Tu.applyMatrix4ToBuffer(e, C.array, m.positionStart, m.positionStart + m.positionCount), C.needsUpdate = !0 } } if (d.hasOwnProperty(A)) for (var v = d[A], I = o.instancedManager.meshManager, E = 0; v.length > E; E += 1) for (var B = v[E], x = I.getMeshIdByNodeInfo(B), S = I.nodeIdxMapFromUserId[A][x], w = 0, b = S.length; b > w; w += 1) { var U = S[w], F = I.instanceGeometryMap[x][w], K = F.getAttribute("mcol0"), Q = F.getAttribute("mcol1"), R = F.getAttribute("mcol2"), T = F.getAttribute("mcol3"); B.transformation || (B.transformation = !0, B.transformationOriginalMatrix = B.matrix.clone()); var k = (new y).fromArray(B.transformationOriginalMatrix.elements, 12), D = new M; D.setPosition(k); var L = new M; L.setPosition(k.multiplyScalar(-1)); var N = new M; N.fromArray([K.array[3 * U], K.array[3 * U + 1], K.array[3 * U + 2], 0, Q.array[3 * U], Q.array[3 * U + 1], Q.array[3 * U + 2], 0, R.array[3 * U], R.array[3 * U + 1], R.array[3 * U + 2], 0, T.array[3 * U], T.array[3 * U + 1], T.array[3 * U + 2], 1], 0), N.multiply(L).multiply(e).multiply(D), K.array[3 * U] = N.elements[0], K.array[3 * U + 1] = N.elements[1], K.array[3 * U + 2] = N.elements[2], K.needsUpdate = !0, Q.array[3 * U] = N.elements[4], Q.array[3 * U + 1] = N.elements[5], Q.array[3 * U + 2] = N.elements[6], Q.needsUpdate = !0, R.array[3 * U] = N.elements[8], R.array[3 * U + 1] = N.elements[9], R.array[3 * U + 2] = N.elements[10], R.needsUpdate = !0, T.array[3 * U] = N.elements[12], T.array[3 * U + 1] = N.elements[13], T.array[3 * U + 2] = N.elements[14], T.needsUpdate = !0, B.matrix = N } } else Bh.warn("当前模式下暂不支持构件变换") } this.render() }, componentApplyMatrix2: function (A, e, t) { var i = this.getModelByComponentKey(A), o = this.getModelManager().getComponent(A); if (o && o.length > 0) { for (var n = 0; o.length > n; n += 1) { var r = o[n]; if (r.matrix || (r.matrix = new M), r.transformation || (r.transformation = !0, r.transformationOriginalMatrix = r.matrix.clone(), r.applyMatrix = new M, r.boundingBox && (r.transformationOriginalBoundingBox = r.boundingBox.clone())), r.matrix.premultiply(e), r.applyMatrix.premultiply(e), r.boundingBox && r.boundingBox.copy(r.transformationOriginalBoundingBox).applyMatrix4(r.applyMatrix), r.isBatched) { var a = i._getHandler(); if (!0 === r.instanceOrNot) for (var s = a.instancedManager.meshManager, l = s.getMeshIdByNodeInfo(r), c = s.nodeIdxMapFromUserId[A][l], h = 0, d = c.length; d > h; h += 1) { var p = c[h], g = s.instanceGeometryMap[l][h], u = g.getAttribute("mcol0"), f = g.getAttribute("mcol1"), m = g.getAttribute("mcol2"), C = g.getAttribute("mcol3"), y = r.matrix; u.array[3 * p] = y.elements[0], u.array[3 * p + 1] = y.elements[1], u.array[3 * p + 2] = y.elements[2], u.needsUpdate = !0, f.array[3 * p] = y.elements[4], f.array[3 * p + 1] = y.elements[5], f.array[3 * p + 2] = y.elements[6], f.needsUpdate = !0, m.array[3 * p] = y.elements[8], m.array[3 * p + 1] = y.elements[9], m.array[3 * p + 2] = y.elements[10], m.needsUpdate = !0, C.array[3 * p] = y.elements[12], C.array[3 * p + 1] = y.elements[13], C.array[3 * p + 2] = y.elements[14], C.needsUpdate = !0 } else { var v = r.mesh; if (!v) continue; var I = r.index, E = v.geometry; v.geometry.boundingBox = null; var B = E.attributes.position; Tu.applyMatrix4ToBuffer(e, B.array, I.positionStart, I.positionStart + I.positionCount), B.needsUpdate = !0; var x = a.defaultManager.wireframeManager.wireframeLineSegment; if (x) for (var S = x._indicesGroup[A], w = 0, b = S.length; b > w; w += 1) { var U = S[w]; if (S[w].nodeId === r.nodeId) { var F = x.geometry.attributes.position; Tu.applyMatrix4ToBuffer(e, F.array, 3 * U.positionStart, 3 * (U.positionStart + U.positionCount)), F.needsUpdate = !0; break } } } } else { var K = null; if (r.mesh instanceof Array) K = r.mesh; else { if (!(r.mesh instanceof H)) continue; K = [r.mesh] } for (var Q = 0, R = K.length; R > Q; Q += 1) { var T = K[Q]; r.isExternalComponent && (T.userData.originalMatrix || (T.userData.originalMatrix = T.matrix.clone())); var k = T.matrixAutoUpdate; T.matrixAutoUpdate = !1, T.applyMatrix4(e), T.matrixAutoUpdate = k, T.updateMatrixWorld(!0) } var D = r.wireframeMeshs; if (D) for (var L = 0, N = D.length; N > L; L += 1) { var O = D[L]; k = O.matrixAutoUpdate, O.matrixAutoUpdate = !1, O.matrix.copy(r.matrix), O.updateMatrixWorld(!0), O.matrixAutoUpdate = k } } } if (void 0 === t && (t = !0), t) { if (i) i.calculateBoundingBox(); else { var V = this.externalComponentManager; V && V.getNodeInfosByUserId(A) && V.calculateBoundingBox() } this.modelManager.updateSceneBoundingBox() } } this.modelManager.updateTransformComponentList(A), this.render() }, setComponentMatrix: function (A, e) { this.setComponentMatrix2(A, e) }, setComponentMatrix2: function (A, e, t) { var i = this.getModelManager().getComponent(A); if (i && i.length > 0) for (var o = 0; i.length > o; o += 1) { var n = i[o]; n.matrix || (n.matrix = new M); var r = null; n.transformation ? r = (new M).getInverse(n.applyMatrix) : (n.transformation = !0, n.transformationOriginalMatrix = n.matrix.clone(), n.applyMatrix = new M, n.boundingBox && (n.transformationOriginalBoundingBox = n.boundingBox.clone())), n.matrix.copy(n.transformationOriginalMatrix).premultiply(e), n.applyMatrix.copy(e), n.boundingBox && n.boundingBox.copy(n.transformationOriginalBoundingBox).applyMatrix4(n.applyMatrix); var a = this.getModelByComponentKey(A); if (n.isBatched) { var s = a._getHandler(); if (!0 === n.instanceOrNot) for (var l = s.instancedManager.meshManager, c = l.getMeshIdByNodeInfo(n), h = l.nodeIdxMapFromUserId[A][c], d = 0, p = h.length; p > d; d += 1) { var g = h[d], u = l.instanceGeometryMap[c][d], f = u.getAttribute("mcol0"), m = u.getAttribute("mcol1"), C = u.getAttribute("mcol2"), y = u.getAttribute("mcol3"), v = n.matrix; f.array[3 * g] = v.elements[0], f.array[3 * g + 1] = v.elements[1], f.array[3 * g + 2] = v.elements[2], f.needsUpdate = !0, m.array[3 * g] = v.elements[4], m.array[3 * g + 1] = v.elements[5], m.array[3 * g + 2] = v.elements[6], m.needsUpdate = !0, C.array[3 * g] = v.elements[8], C.array[3 * g + 1] = v.elements[9], C.array[3 * g + 2] = v.elements[10], C.needsUpdate = !0, y.array[3 * g] = v.elements[12], y.array[3 * g + 1] = v.elements[13], y.array[3 * g + 2] = v.elements[14], y.needsUpdate = !0 } else { var I = n.mesh; if (!I) continue; var E = n.index, B = I.geometry.attributes.position; r && Tu.applyMatrix4ToBuffer(r, B.array, E.positionStart, E.positionStart + E.positionCount), Tu.applyMatrix4ToBuffer(n.applyMatrix, B.array, E.positionStart, E.positionStart + E.positionCount), B.needsUpdate = !0; var x = s.defaultManager.wireframeManager.wireframeLineSegment; if (x) for (var S = x._indicesGroup[A], w = 0, b = S.length; b > w; w += 1) { var U = S[w]; if (S[w].nodeId === n.nodeId) { var F = x.geometry.attributes.position; r && Tu.applyMatrix4ToBuffer(r, F.array, 3 * U.positionStart, 3 * (U.positionStart + U.positionCount)), Tu.applyMatrix4ToBuffer(e, F.array, 3 * U.positionStart, 3 * (U.positionStart + U.positionCount)), F.needsUpdate = !0; break } } } } else { var K = null; if (n.mesh instanceof Array) K = n.mesh; else { if (!(n.mesh instanceof H)) continue; K = [n.mesh] } for (var Q = 0, R = K.length; R > Q; Q += 1) { var T = K[o]; n.isExternalComponent && (T.userData.originalMatrix || (T.userData.originalMatrix = T.matrix.clone())); var k = T.matrixAutoUpdate; T.matrixAutoUpdate = !1, T.matrix.copy(n.matrix), T.applyMatrix4(new M), T.matrixAutoUpdate = k, T.updateMatrixWorld(!0) } var D = n.wireframeMeshs; if (D) for (var L = 0, N = D.length; N > L; L += 1) { var O = D[L]; k = O.matrixAutoUpdate, O.matrixAutoUpdate = !1, O.matrix.copy(n.matrix), O.updateMatrixWorld(!0), O.matrixAutoUpdate = k } } if (void 0 === t && (t = !0), t) { if (a) a.calculateBoundingBox(); else { var V = this.externalComponentManager; V && V.getNodeInfosByUserId(A) && V.calculateBoundingBox() } this.modelManager.updateSceneBoundingBox() } } this.render() }, resetComponentMatrix: function (A, e) { var t = this.getModelManager().getComponent(A); if (t && t.length > 0) for (var i = 0; t.length > i; i += 1) { var o = t[i]; if (o.transformation) { o.matrix.copy(o.transformationOriginalMatrix), o.transformationOriginalBoundingBox && (o.boundingBox = o.transformationOriginalBoundingBox.clone()); var n = (new M).getInverse(o.applyMatrix), r = this.getModelByComponentKey(A); if (o.isBatched) { var a = r._getHandler(); if (!0 === o.instanceOrNot) for (var s = a.instancedManager.meshManager, l = s.getMeshIdByNodeInfo(o), c = s.nodeIdxMapFromUserId[A][l], h = 0, d = c.length; d > h; h += 1) { var p = c[h], g = s.instanceGeometryMap[l][h], u = g.getAttribute("mcol0"), f = g.getAttribute("mcol1"), m = g.getAttribute("mcol2"), C = g.getAttribute("mcol3"), y = o.matrix; u.array[3 * p] = y.elements[0], u.array[3 * p + 1] = y.elements[1], u.array[3 * p + 2] = y.elements[2], u.needsUpdate = !0, f.array[3 * p] = y.elements[4], f.array[3 * p + 1] = y.elements[5], f.array[3 * p + 2] = y.elements[6], f.needsUpdate = !0, m.array[3 * p] = y.elements[8], m.array[3 * p + 1] = y.elements[9], m.array[3 * p + 2] = y.elements[10], m.needsUpdate = !0, C.array[3 * p] = y.elements[12], C.array[3 * p + 1] = y.elements[13], C.array[3 * p + 2] = y.elements[14], C.needsUpdate = !0 } else { var v = o.mesh; if (!v) continue; var I = o.index, E = v.geometry.attributes.position; n && (Tu.applyMatrix4ToBuffer(n, E.array, I.positionStart, I.positionStart + I.positionCount), E.needsUpdate = !0); var B = a.defaultManager.wireframeManager.wireframeLineSegment; if (B) for (var x = B._indicesGroup[A], S = 0, w = x.length; w > S; S += 1) { var b = x[S]; if (x[S].nodeId === o.nodeId) { var U = B.geometry.attributes.position; n && (Tu.applyMatrix4ToBuffer(n, U.array, 3 * b.positionStart, 3 * (b.positionStart + b.positionCount)), U.needsUpdate = !0); break } } } } else { var F = null; if (o.mesh instanceof Array) F = o.mesh; else { if (!(o.mesh instanceof H)) continue; F = [o.mesh] } for (var K = 0, Q = F.length; Q > K; K += 1) { var R = F[i], T = void 0; if (T = o.isExternalComponent ? R.userData.originalMatrix : o.matrix) { var k = R.matrixAutoUpdate; R.matrixAutoUpdate = !1, R.matrix.copy(T), R.applyMatrix4(new M), R.matrixAutoUpdate = k, R.updateMatrixWorld(!0), R.userData.originalMatrix = void 0 } } var D = o.wireframeMeshs; if (D) for (var L = 0, N = D.length; N > L; L += 1) { var O = D[L]; k = O.matrixAutoUpdate, O.matrixAutoUpdate = !1, O.matrix.copy(o.matrix), O.updateMatrixWorld(!0), O.matrixAutoUpdate = k } } if (void 0 === e && (e = !0), e) { if (r) r.calculateBoundingBox(); else { var V = this.externalComponentManager; V && V.getNodeInfosByUserId(A) && V.calculateBoundingBox() } this.modelManager.updateSceneBoundingBox() } o.transformationOriginalMatrix = void 0, o.transformationOriginalBoundingBox = void 0, o.applyMatrix = void 0, o.transformation = void 0 } } this.render() }, calculateComponentVolume: function (A) { var e = this.modelManager.getComponent(A), t = this.modelManager.getMeshByUserId(A); if (e && e.length > 0) { Bh.time("计算体积"); for (var i = 0, o = 0, n = e.length; n > o; o += 1) { var r = e[o]; if (r.isExternalComponent) for (var a = r.mesh, s = 0, l = a.length; l > s; s += 1) { var c = a[s].geometry, h = Tu.calculateVolumeOfGeometry(c.attributes.position.array, c.index.array); h && (i += h) } else if (t) { var d = r.mesh || t[o].mesh; if (d) { var p = d.geometry, g = d._indicesGroup; if (g && !r.instanceOrNot) for (var u = g[A], f = 0, m = u.length; m > f; f += 1) { var C = u[f], v = Tu.calculateVolumeOfGeometry(p.attributes.position.array, p.index.array, C.indexStart, C.indexCount); v && (i += v) } else { var I = Tu.calculateVolumeOfGeometry(p.attributes.position.array, p.index.array); I && (i += I) } } } } var E = this.getBoundingBoxByIds([A]), B = new y; return E.getCenter(B), Bh.timeEnd("计算体积"), { volume: i, position: B.toArray() } } }, setAxisNetColor: function (A, e) { var t = !1, i = this.modelManager; for (var o in i.models) { var n = i.models[o]; n.axisNetManager && (n.axisNetManager.setupColor(A, e), t = !0) } t && this.render(!0) }, showAxisNet: function () { var A = !1, e = this.modelManager; for (var t in e.models) { var i = e.models[t]; i.axisNetManager && (i.axisNetManager.show(), A = !0) } A && this.render(!0) }, hideAxisNet: function () { var A = !1, e = this.modelManager; for (var t in e.models) { var i = e.models[t]; i.axisNetManager && (i.axisNetManager.hide(), A = !0) } A && this.render(!0) }, enableAxisNetStayInFront: function () { var A = !1, e = this.modelManager; for (var t in e.models) { var i = e.models[t]; i.axisNetManager && (i.axisNetManager.enableStayInFront(), A = !0) } A && this.render(!0) }, disableAxisNetStayInFront: function () { var A = !1, e = this.modelManager; for (var t in e.models) { var i = e.models[t]; i.axisNetManager && (i.axisNetManager.disableStayInFront(), A = !0) } A && this.render(!0) }, enableSnap: function (A) { this.controlManager.getToolByName(Pc.PICK_BY_RECT).enableSnap(A) }, pickToPoint: function (A, e) { return this.controlManager.control.pickHelper.pickToPoint(A, e) }, getViewportSize: function () { return this.rendererManager.getRendererSize() }, getRenderer: function () { return this.rendererManager.getRenderer() }, getExternalComponentManager: function () { return this.externalComponentManager || (this.externalComponentManager = new Vy(this)), this.externalComponentManager }, addExternalObject: function (A, e, t, i) { A = A || uh.createUUID(); this.getExternalComponentManager().addNode(A, e, t, i), this.render() }, addExternalObjects: function (A, e, t) { for (var i = this.getExternalComponentManager(), o = [], n = 0; A.length > n; n += 1) { var r = uh.createUUID(); i.addNode(r, A[n], e, t), o.push(r) } return this.render(), o }, removeExternalObjectByName: function (A) { this.getExternalComponentManager().removeNodeById(A), this.render() }, clearExternalObjects: function () { this.getExternalComponentManager().clearNodes(), this.render() }, getExternalObjectByName: function (A) { return this.getExternalComponentManager().getNodeById(A) }, getAllExternalObjects: function () { return Object.values(this.getExternalComponentManager().getAllNodes()) }, getModelFloorMapsByKey: function (A, e) { var t = this.modelManager.models[A]; if (t && t.floorManager) { if ("function" != typeof e) return t.floorManager.getMimiMaps(); t.floorManager.getServerMimiMaps(e) } }, getReceivingPlane: function (A) { return this.getScene().getReceivingPlane(A) }, enableShadow: function (A) { this.getReceivingPlane(A), A ? this.getScene().lightManager.enableShadowLight() : this.getScene().lightManager.disableShadowLight(); var e = this.getRenderer(); e.shadowMap.enabled = A, e.shadowMap.type = 2, e.shadowMap.autoUpdate = !1, e.shadowMap.needsUpdate = !0; for (var t = this.getScene().getGroups(), i = this.getScene(), o = 0; t.length > o; o += 1) { var n = i.getGroupType(t[o].name); n.groupType !== gp.IBLCUBE && ("ClipPlane" !== n.groupType && this.traverseGroupEnableShadow(t[o], A)) } this.updateShadowLight() }, updateShadowLight: function () { this.getScene().lightManager.updateShadowLight(), this.getRenderer().shadowMap.needsUpdate = !0, this._render(), this.rendererManager.renderer.setClearColor(0, 0), this._render() }, traverseGroupEnableShadow: function (A, e) { var t = this; this.getRenderer(); ! function (A) { if (A instanceof Ue) { var i = A.material; if (i instanceof Array) { var o = null; if ("PhoneLightingMaterial" === i[0].type) return; A.castShadow = e, A.receiveShadow = e; for (var n = 0; i.length > n; n += 1) i[n].needsUpdate = !0, o = i[n].defines; A.customDepthMaterial = e && o && o.hasOwnProperty("USE_INSTANCE") ? t.getInstanceDepthMaterial() : void 0 } else { if ("PhoneLightingMaterial" === i.type) return; A.castShadow = e, A.receiveShadow = e, i.needsUpdate = !0; var r = i.defines; A.customDepthMaterial = e && r && r.hasOwnProperty("USE_INSTANCE") ? t.getInstanceDepthMaterial() : void 0, i.needsUpdate = !0 } } }(A); for (var i = A.children, o = 0, n = i.length; n > o; o += 1) this.traverseGroupEnableShadow(i[o], e) }, getInstanceDepthMaterial: function () { if (this.instanceDepthMaterial) return this.instanceDepthMaterial; var A = new Su; return A.depthPacking = 3201, this.instanceDepthMaterial = A, this.instanceDepthMaterial }, updateShadowMap: function () { 4 === vc.LightPreset && (this.getRenderer().shadowMap.needsUpdate = !0) }, cloneComponent: function (A) { function e(A) { for (var e in A) A.hasOwnProperty(e) && (A[e] instanceof d || A[e] instanceof ut) && (A[e] = A[e].clone(), A[e].needsUpdate = !0) } var t, i = this.modelManager.getComponent(A), o = new he, n = i[0].model, r = n.materialManager, a = this.getExternalComponentManager(), s = []; if (i[0].isBatched && !i[0].instanceOrNot) ! function () { var A = [], n = [], l = [], c = [], h = [], d = 0, p = 0, g = [], u = 0, f = !0, m = !1, C = void 0; try { for (var y, v = function () { var t, i, a, f, m = y.value, C = m.index, v = m.mesh.geometry, I = m.mesh.geometry.attributes, E = I.position.array.slice(C.positionStart, C.positionStart + C.positionCount), B = I.normal.array.slice(C.positionStart, C.positionStart + C.positionCount), x = void 0; if (I.uv) x = I.uv.array.slice(C.positionStart / 3 * 2, (C.positionStart + C.positionCount) / 3 * 2); else { var S = E.length / 3 * 2; (x = new Array(S)).fill(0, 0, S) } var w = void 0; if (I.uv2) w = I.uv2.array.slice(C.positionStart / 3 * 2, (C.positionStart + C.positionCount) / 3 * 2); else { var M = x.length; (w = new Array(M)).fill(0, 0, M) } var b = C.positionStart / 3, U = v.index.array, F = C.indexCount, K = m.originMId; s.push(K); var Q = Kd.getMaterialParameters(r.getMaterialById(K)), R = Kd.createStandardMaterial(Q); e(R), g.push(R), h.push.apply(h, yc(U.slice(C.indexStart, C.indexStart + C.indexCount).map((function (A) { return A - b + p })))), A = (t = A).concat.apply(t, yc(E)), n = (i = n).concat.apply(i, yc(B)), l = (a = l).concat.apply(a, yc(x)), c = (f = c).concat.apply(f, yc(w)), o.groups.push({ start: d, count: F, materialIndex: u }), d += F, p += C.positionCount / 3, u += 1 }, I = i[Symbol.iterator](); !(f = (y = I.next()).done); f = !0) v() } catch (A) { m = !0, C = A } finally { try { f || null == I.return || I.return() } finally { if (m) throw C } } o.setAttribute("position", new YA(new Float32Array(A), 3)), o.setAttribute("uv", new YA(new Float32Array(l), 2)), o.setAttribute("uv2", new YA(new Float32Array(c), 2)), o.setAttribute("normal", new YA(new Float32Array(n), 3)), o.setIndex(new YA(new Uint32Array(h), 1)), t = new Ue(o, g), a.addExternalObject(t) }(); else if (i[0].isBatched && i[0].instanceOrNot) ! function () { var i = n._handler.instancedManager.meshManager, r = i.getNodeIdxMapByUserId(A), l = [], c = [], h = [], d = [], p = i.matrixInfoMapFromUserId[A][Object.keys(i.matrixInfoMapFromUserId[A])[0]][0].matrix, g = 0, u = 0, f = 0, m = [], C = 0; for (var y in r) { var v, I, E, B = i.getInstanceGeometries(y), x = B[0].index.array; if (u = B[0].index.count, l = (v = l).concat.apply(v, yc(B[0].attributes.position.array)), c = (I = c).concat.apply(I, yc(B[0].attributes.normal.array)), B[0].attributes.uv) { var S; h = (S = h).concat.apply(S, yc(B[0].attributes.uv.array)) } else { var w = 2 * u, M = new Array(w); M.fill(0, 0, w), h = h.concat(M) } d = (E = d).concat.apply(E, yc(x.map((function (A) { return A + g })))), g = l.length / 3; var b = i.getMaterialIdByMeshId(y), U = i.manager.model.materialManager.getInstanceMaterialById(b)[0], F = Kd.getMaterialParameters(U), K = Kd.createStandardMaterial(F); s.push(b), e(K), m.push(K), o.groups.push({ start: f, count: u, materialIndex: C }), f += u, C += 1 } o.setAttribute("position", new YA(new Float32Array(l), 3)), o.setAttribute("uv", new YA(new Float32Array(h), 2)), o.setAttribute("normal", new YA(new Float32Array(c), 3)), o.setIndex(new YA(new Uint32Array(d), 1)), (t = new Ue(o, m)).applyMatrix4(p), t.updateMatrixWorld(), a.addExternalObject(t) }(); else { var l = n.getModelDescriptor().getNodeInfosByComponentKey(A)[0].originMId; if (s = l, t = i[0].mesh.clone(), Array.isArray(l)) t.material = l.map((function (A) { var t = r.getMaterialById(A), i = Kd.getMaterialParameters(t), o = Kd.createStandardMaterial(i); return e(o), o })); else { var c = r.getMaterialById(l), h = Kd.getMaterialParameters(c), p = Kd.createStandardMaterial(h); e(p), t.material = p } a.addExternalObject(t) } return t ? (t.byClone = !0, t.originMId = s, t.originComponentKey = A, t) : null }, setComponentsBlink: function () {} }), Object.defineProperties(Gy.prototype, { renderer: { get: function () { return console.warn("EIMMODEL.ViewerImpl: .renderer 现在为 .getRenderer()"), this.getRenderer() } }, composer: { get: function () { return console.warn("EIMMODEL.ViewerImpl: .composer 现在为 .rendererManager.composer"), this.rendererManager.composer } } }); var Py = function (A) { var e = window.performance.timing; Ch.PERFORMANCE > Bh.level || Bh.warn("页面加载时间:", e.domInteractive - e.navigationStart, "ms"); var t = mh.detectWebGL(); if (1 === t) { vc.language = mh.language(), H.DefaultUp.set(0, 0, 1); var i = uh.extend({}, { host: "https://bos3d.bimwinner.com", viewport: "" }, A); this.host = i.host, this.viewerImpl = new Gy; var o = document.getElementById(i.viewport); o.style.position = "relative"; var n = this; this.getViewerImpl().init(o), vc.EnableViewController && !mh.isMobileDevice() && (this.viewController = new lp(this, (function () { return !0 })), this.viewController.init(this.getViewerImpl().getDomElement()), this.viewController.render(), this.getViewerImpl().addRenderFinishedListener((function () { n.viewController.render() }))), this.filter = this.getViewerImpl().filter, this.SVGRect = new tp(this), this.SVGRect.creatSVG(), this.viewport = A.viewport, this.viewportDiv = document.getElementById(A.viewport), this.getViewerImpl().modelManager.addEventListener(Rc.ON_LOAD_CONFIG_FINISH, (function (A) { Bh.time("模型".concat(A.modelKey, "加载时间")); var e = n.getViewerImpl().getBoundingBox(), t = n.getViewerImpl().getModel(A.modelKey), i = t.getConfig(); i.type !== Zc.I_MODEL && i.type !== Zc.OBJ || n.setLightIntensityFactor(1), op(t.dataVersion, "1.0"); var o = e.getCenter(new y), r = e.getSize(new y), a = new y(o.x + r.x, o.y + r.y, o.z + r.z); n.originalView && vc.UserControlView ? n.viewerImpl.lookAt(n.originalView.position, n.originalView.target, n.originalView.up) : (n.viewerImpl.lookAt(a, o, n.viewerImpl.camera.up), n.setOriginalView(a, o, n.viewerImpl.camera.up)) })), this.getViewerImpl().modelManager.addEventListener(Rc.ON_LOAD_PROGRESS, (function (A) { Bh.log(A.progress) })), this.getViewerImpl().modelManager.addEventListener(Rc.ON_LOAD_COMPLETE, (function (A) { Bh.log(A.modelKey, " is load "), Bh.timeEnd("模型".concat(A.modelKey, "加载时间")); var e = n.getViewerImpl().getModel(A.modelKey); for (var t in e.floorManager && vc.EnableCreateMiniMap && (Bh.time("小地图生成"), e.floorManager.generateMiniMap(n.getViewerImpl()), Bh.timeEnd("小地图生成")), e && e.getConfig() && n.getViewerImpl().cameraControl.setSceneUnit(e.getConfig().lengthUnit), bc) if (e && bc.hasOwnProperty(t) && !0 === bc[t]) { var i = t, o = e.getComponentKeysByType(i), r = e.getConfig(), a = []; !r || r.type !== Zc.RVT && r.type !== Zc.MERGE || (a = e.getComponentKeysByProperty("buildInCategory", i)), n.deactivateComponentsByKey(o.concat(a)) } n.getViewerImpl().getBoundingBox().isEmpty() && (n.getViewerImpl().zoomAll(), n.getViewerImpl().goToInitialView()) })), this.getViewerImpl().modelManager.addEventListener(Rc.ON_CLICK_PICK, (function (A) { if (A.intersectInfo) { Bh.log("构件key", A.intersectInfo.selectedObjectId); var e = A.intersectInfo.object; e && Bh.log(e) } })), this.getViewerImpl().getControlManager().addEventListener(Rc.ON_CONTROL_EXIST, (function (A) { if (A.name === Pc.CLIP_BY_BOX) for (var e = n.getViewerImpl().modelManager.getModelKeys(), t = 0, i = e.length; i > t; t += 1) { var o = n.getViewerImpl().modelManager.getModel(e[t]); if (o) for (var r = 0; 6 > r; r += 1) { o._getNodeGroup("sectionFill_" + r).clear() } } })), this.viewerImpl.modelManager.addEventListener(Rc.ON_CONTROL_UPDATEUI, (function (A) { n.SVGRect.creatRect(A) })) } else mh.showWebGLMessage(t) }; Object.assign(Py.prototype, Ld.prototype), Object.assign(Py.prototype, { constructor: Py, addView: function (A, e, t, i) { this.getViewerImpl().load({ serverUrl: this.host, modelKey: A, dbName: e, token: t, share: i || "", notifyProgress: !0, type: A.startsWith("G") ? "GIS" : "" }) }, addViews: function (A, e, t, i) { vc.AutoMergeComponent = !1, vc.MergeComponent = !0, this.getViewerImpl().load({ serverUrl: this.host, modelKey: A, modelKeys: e, dbName: t, token: i, notifyProgress: !0 }) }, addTilesView: function (A, e, t) { this.getViewerImpl().loadTiles({ serverUrl: this.host, modelKey: A, dbName: e, token: t, notifyProgress: !0 }) }, addTilesViewFromLocal: function (A) { this.getViewerImpl().loadTiles({ serverUrl: ".", modelKey: A, dbName: "", token: "", notifyProgress: !0, offLine: !0 }) }, getSSE: function (A) { var e = this.getBoxByComponentsKey(A), t = this.viewerImpl.camera, i = e.getCenter(new y), o = e.getSize().length(), n = this.viewerImpl.getRenderer().domElement.width, r = t.fov; return o * n / (2 * t.position.clone().sub(i).length() * Math.tan(r / 2)) }, removeView: function (A) { return this.getViewerImpl().unload(A) }, removeAllView: function () { this.getViewerImpl().unloadAll() }, addViewFromLocal: function (A) { this.getViewerImpl().load({ serverUrl: ".", modelKey: A, dbName: "", notifyProgress: !0, offLine: !0 }) }, loadComponents: function (A, e, t, i) { Array.isArray(A) || (A = [A]), this.getViewerImpl().loadGeopkOnDemand(A, e, t, i) }, unloadCompomemts: function (A, e) { Array.isArray(A) || (A = [A]), this.getViewerImpl().unloadGeopkOnDemand(A, e) }, getOriginalView: function () { return this.originalView }, setOriginalView: function (A, e, t) { A && e && t ? (this.originalView || (this.originalView = {}), this.originalView.position = Array.isArray(A) ? new y(A[0], A[1], A[2]) : new y(A.x, A.y, A.z), this.originalView.target = Array.isArray(e) ? new y(e[0], e[1], e[2]) : new y(e.x, e.y, e.z), this.originalView.up = Array.isArray(t) ? new y(t[0], t[1], t[2]) : new y(t.x, t.y, t.z)) : this.originalView = void 0 }, getViewerImpl: function () { return this.viewerImpl }, getAllComponents: function () { return this.getViewerImpl().getModelManager().getAllComponents() }, getAllComponentsKey: function () { return this.getViewerImpl().getModelManager().getAllComponentsKey() }, getComponentsKeyByModelKey: function (A) { return this.getViewerImpl().getModelManager().getComponentsKeyByModelKey(A) }, getComponentKeysByName: function (A) { return this.getViewerImpl().getModelManager().getComponentKeysByName(A) }, getComponentKeysByType: function (A) { return this.getViewerImpl().getModelManager().getComponentKeysByType(A) }, getComponentKeysByProperty: function (A, e) { return this.getViewerImpl().getModelManager().getComponentKeysByProperty(A, e) }, getScreenCoordFromSceneCoordAndCheckCover: function (A) { return this.getViewerImpl().getScreenCoordFromSceneCoordAndCheckCover(A) }, pickByPoint: function (A) { return this.getViewerImpl().pickByPoint(A) }, calculateMinDistance: function (A, e) { return this.getViewerImpl().calculateMinDistance(A, e) }, otherObjectsInScene: function (A) {}, getComponentsByKey: function (A) { Array.isArray(A) || (A = [A]); var e = [], t = this; return A.forEach((function (A) { var i = t.getViewerImpl().modelManager.getComponent(A); if (i) { var o = {}; o[A] = i, e.push(o) } })), e }, getModelFloorMapsByKey: function (A, e) { var t = this.getViewerImpl().getModel(A); if (!t) return { msg: "没有此模型" }; var i = t.getConfig().type; return i !== Zc.RVT && i !== Zc.IFC && i !== Zc.MERGE ? { msg: "该模型不支持小地图" } : t.floorManager ? this.getViewerImpl().getModelFloorMapsByKey(A, e) : { msg: "该模型不支持小地图" } }, showComponentsById: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.getViewerImpl().getFilter().showByIds(t), this.render() }, showComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().showByIds(A), this.render() }, hideComponentsById: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.filter.hideByIds(t), this.render() }, hideComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.filter.hideByIds(A), this.render() }, activateComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.filter.activateByIds(A), this.render() }, deactivateComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.filter.deactivateByIds(A), this.render() }, hideAllComponents: function () { this.getViewerImpl().getFilter().hideAll(), this.render() }, showAllComponents: function () { this.getViewerImpl().getFilter().showAll(), this.render() }, highlightComponentsById: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.getViewerImpl().setSelection(t), this.render() }, highlightComponentsByKey: function (A, e) { Array.isArray(A) || (A = [A]), this.getViewerImpl().setSelection(A); var t = e; "boolean" != typeof e && (t = !0), t && this.render() }, addHighlightComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().addToSelection(A), this.render() }, closeHighlightComponentsById: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.getViewerImpl().removeFromSelection(t), this.render() }, closeHighlightComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().removeFromSelection(A), this.render() }, getHighlightComponentsKey: function () { return this.getViewerImpl().getSelection() }, clearHighlightList: function () { this.getViewerImpl().clearSelection(), this.render() }, getHighlightComponents: function () { var A = this.getHighlightComponentsKey(), e = [], t = this; return A.forEach((function (A) { var i = t.getViewerImpl().modelManager.getComponent(A); if (i) { var o = {}; o[A] = i, e.push(o) } })), e }, setComponentsOpacityState: function (A, e) { Array.isArray(A) || (A = [A]), e === Oc.TRANSLUCENT ? this.transparentComponentsByKey(A) : e === Oc.OPAQUE && this.closeTransparentComponentsByKey(A) }, transparentComponentsById: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.getViewerImpl().getFilter().makeTranslucentByIds(t), this.render() }, transparentComponentsByKey: function (A, e) { Array.isArray(A) || (A = [A]); var t = this.getViewerImpl().getFilter(); if (e) { var i = this.getComponentsByKey(A); if (Array.isArray(A) && i.length !== A.length) { i = []; var o = !0, n = !1, r = void 0; try { for (var a, s = A[Symbol.iterator](); !(o = (a = s.next()).done); o = !0) { var l = this.getComponentsByKey(a.value); l.length > 0 && i.push(l[0]) } } catch (A) { n = !0, r = A } finally { try { o || null == s.return || s.return() } finally { if (n) throw r } } } t.transparentComponentsByKey(this.getViewerImpl().getModelManager(), i, e) } else t.makeTranslucentByIds(A); this.render() }, transparentOtherComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().makeTranslucentOthersByIds(A), this.render() }, transparentAllComponents: function () { this.getViewerImpl().getFilter().makeTranslucentOthersByIds([]), this.render() }, closeTransparentComponentsById: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.getViewerImpl().getFilter().opaqueByIds(t), this.render() }, closeTransparentComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().opaqueByIds(A), this.render() }, clearTransparentList: function () { this.clearComponentTransparentList(), this.clearModelTransparentList() }, clearComponentTransparentList: function () { var A = this.getViewerImpl().getFilter(); A.opaqueAll(), A.opaqueByIds([]), this.render() }, colorfulComponentsById: function (A, e, t, i) { Array.isArray(A) || (A = [A]); for (var o = [], n = 0; A.length > n; n += 1) o[n] = e + "_" + A[n]; var r = this.getViewerImpl().getFilter(), a = {}; a.color = t, "number" == typeof i && (a.opacity = i), r.addToOverrideListByColor(o, a), this.render() }, colorfulComponentsByKey: function (A, e, t) { Array.isArray(A) || (A = [A]); var i = this.getViewerImpl().getFilter(), o = {}; o.color = e, "number" == typeof t && (o.opacity = t), i.addToOverrideListByColor(A, o), this.render() }, setComponentsMaterialByKey: function (A, e, t, i) { var o = this.getComponentsByKey(A); if (Array.isArray(e)) { var n = 0, r = !0, a = !1, s = void 0; try { for (var l, c = e[Symbol.iterator](); !(r = (l = c.next()).done); r = !0) { var h = l.value; "" === h.name && (h.name = "custMat_" + (new Date).getTime() + "_" + n, n += 1) } } catch (A) { a = !0, s = A } finally { try { r || null == c.return || c.return() } finally { if (a) throw s } } } else "" === e.name && (e.name = "custMat_" + (new Date).getTime()); var d = this.getViewerImpl().getFilter().addToOverrideListByCustomerMaterial(this.getViewerImpl().getModelManager(), o, e, t, i); return this.render(), d }, closeMaterialByKey: function (A) { var e = this; Array.isArray(A) ? A.forEach((function (A) { var t = e.getComponentsByKey(A)[0][A][0]; if (!t.isBatched && !t.instanceOrNot && !t.RenderTypeChange) { var i = t.originMId; e.getComponentsByKey(A)[0][A][0].materialId = Array.isArray(i) ? [].concat(i) : i } e.closeColorfulComponentsByKey(A) })) : this.closeColorfulComponentsByKey(A) }, closeColorfulComponentsById: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.getViewerImpl().getFilter().addToOverrideListByColor(t, null), this.render() }, closeColorfulComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().addToOverrideListByColor(A, null), this.render() }, clearColorfulList: function () { this.getViewerImpl().getFilter().clearAllOverrideList(), this.render() }, wireFrameComponentsById: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.getViewerImpl().getFilter().addToWireframeByWireframe(t, { wireframe: !0 }), this.render() }, wireFrameComponentsByKey: function (A) { Array.isArray(A) || (A = [A]); this.getViewerImpl().getFilter().addToWireframeByWireframe(A, { wireframe: !0 }), this.render() }, closeWireFrameComponentsById: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.getViewerImpl().getFilter().addToWireframeByWireframe(t, null), this.render() }, closeWireFrameComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().addToWireframeByWireframe(A, null), this.render() }, clearWireframeList: function () { this.getViewerImpl().getFilter().clearAllWireframeList(), this.render() }, isolateComponentsById: function (A, e, t) { Array.isArray(A) || (A = [A]); for (var i = [], o = 0; A.length > o; o += 1) i[o] = e + "_" + A[o]; this.getViewerImpl().getFilter().setIsolateList(i, !1 !== t), this.render() }, isolateComponentsByKey: function (A, e) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().setIsolateList(A, !1 !== e), this.render() }, closeIsolateComponentsById: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.getViewerImpl().getFilter().removeFromIsolateList(t), this.render() }, closeIsolateComponentsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().removeFromIsolateList(A), this.render() }, clearIsolation: function () { this.getViewerImpl().getFilter().clearIsolation() }, showModelsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().showModelByIds(A), this.render() }, hideModelsByKey: function (A) { Array.isArray(A) || (A = [A]), this.filter.hideModelByIds(A), this.render() }, hideAllModels: function () { this.getViewerImpl().getFilter().hideAllModel(), this.render() }, showAllModels: function () { this.getViewerImpl().getFilter().showAllModel(), this.render() }, highlightModelsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().setModelSelection(A), this.render() }, addHighlightModelsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().addToModelSelection(A), this.render() }, closeHighlightModelsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().removeFromModelSelection(A), this.render() }, getHighlightModelsKey: function () { return this.getViewerImpl().getModelSelection() }, clearModelHighlightList: function () { this.getViewerImpl().clearModelSelection(), this.render() }, transparentModelsByKey: function (A, e, t) { var i = this; Array.isArray(A) || (A = [A]), this.closeTransparentModelsByKey(A); var o = this.getViewerImpl().getFilter(); e ? A.forEach((function (A) { o.transparentModelOrigMatByKey(i.getViewerImpl().getModelManager(), A, t) })) : o.makeModelTranslucentByIds(A), this.render() }, transparentOtherModelsByKey: function (A, e, t) { Array.isArray(A) || (A = [A]); for (var i = Object.keys(this.viewerImpl.modelManager.models), o = [], n = 0; i.length > n; n++) { var r = i[n]; A.includes(r) || o.push(r) } (this.closeTransparentModelsByKey(o), e) ? this.transparentModelsByKey(o, e, t): this.getViewerImpl().getFilter().makeTranslucentOthersModelByIds(A); this.render() }, transparentAllModels: function (A, e) { if (this.clearModelTransparentList(), A) { var t = Object.keys(this.viewerImpl.modelManager.models); this.transparentModelsByKey(t, A, e) } else { this.getViewerImpl().getFilter().makeTranslucentOthersModelByIds([]) } this.render() }, closeTransparentModelsByKey: function (A) { var e = this, t = this.getViewerImpl().getFilter(); Array.isArray(A) || (A = [A]), A.forEach((function (A) { t.closeOrigMatModelTransparent(e.viewerImpl.modelManager, A) })), t.opaqueModelByIds(A), this.render() }, clearModelTransparentList: function () { var A = this, e = this.getViewerImpl().getFilter(); Object.keys(this.viewerImpl.modelManager.models).forEach((function (t) { e.closeOrigMatModelTransparent(A.viewerImpl.modelManager, t) })), e.opaqueAllModel(), e.opaqueModelByIds([]), this.render() }, colorfulModelsByKey: function (A, e, t) { Array.isArray(A) || (A = [A]); var i = this.getViewerImpl().getFilter(), o = {}; o.color = e, "number" == typeof t && (o.opacity = t), i.addToModelOverrideListByColor(A, o), this.render() }, closeColorfulModelsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().addToModelOverrideListByColor(A, null), this.render() }, clearModelColorfulList: function () { this.getViewerImpl().getFilter().clearModelAllOverrideList(), this.render() }, isolateModelsByKey: function (A, e) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().setModelIsolateList(A, !1 !== e), this.render() }, closeIsolateModelsByKey: function (A) { Array.isArray(A) || (A = [A]), this.getViewerImpl().getFilter().removeModelFromIsolateList(A), this.render() }, clearModelIsolation: function () { this.getViewerImpl().getFilter().clearModelIsolation(), this.render() }, setModelMatrix: function (A, e) { this.getViewerImpl().setModelMatrix(e, A) }, getModelMatrix: function (A) { return this.getViewerImpl().getModelMatrix(A) }, disableComponentsSelectionByKey: function (A) { Array.isArray(A) || (A = [A]), this.filter.addToFrozenList(A) }, enableComponentsSelectionByKey: function (A) { Array.isArray(A) || (A = [A]), this.filter.removeFromFrozenList(A) }, clearDisableSelectionList: function () { this.filter.clearFrozen() }, overturnYAndZaxis: function (A) { this.getViewerImpl().overturnYAndZaxis(A), this.render() }, translateModel: function (A) { this.getViewerImpl().translateModel(A) }, rotateModel: function (A) { this.getViewerImpl().rotateModel(A) }, scaleModel: function (A) { this.getViewerImpl().scaleModel(A) }, modelsExplosion: function (A) { for (var e = { modelKey: [], coefficientX: 1, coefficientY: 1, coefficientZ: 1, center: this.getViewerImpl().getScene().getBoundingBoxWorld().getCenter(new y).toArray() }, t = uh.extend(!0, {}, e, A), i = Array.isArray(t.modelKey) ? t.modelKey : [t.modelKey], o = 0; i.length > o; o += 1) { var n = this.getViewerImpl().getModel(i[o]); n && n.explosion(t) } this.getViewerImpl().getModelManager().updateSceneBoundingBox(), this.render() }, closeModelsExplosion: function (A) { var e = Array.isArray(A) ? A : [A]; this.modelsExplosion({ modelKey: e }), this.render() }, componentsExplosion: function (A) { var e = { componentKey: [], coefficientX: 1, coefficientY: 1, coefficientZ: 1, offsetX: 0, offsetY: 0, offsetZ: 0, center: this.getViewerImpl().getScene().getBoundingBoxWorld().getCenter(new y).toArray() }, t = uh.extend(!0, {}, e, A), i = this.getViewerImpl().getModelManager(); i.componentsExplosion(t), i.updateSceneBoundingBox(), this.render() }, closeComponentsExplosion: function (A) { var e = Array.isArray(A) ? A : [A]; this.getViewerImpl().getModelManager().componentsExplosion({ componentKey: e }), this.render() }, canFloorExplosion: function () { return this.getViewerImpl().getModelManager().canFloorExplosion() }, floorExplosion: function (A) { return !!this.getViewerImpl().getModelManager().floorExplosion(A) && (this.render(), !0) }, closeFloorExplosion: function () { var A = this.getViewerImpl().getModelManager(); A.closeFloorExplosion(), A.updateSceneBoundingBox(), this.render() }, componentApplyMatrix: function (A, e) { return !(!e || !e.isMatrix4) && (this.getViewerImpl().componentApplyMatrix2(A, e), this.render(), !0) }, getMatrix4FromEuler: function (A, e, t) { var i = 0, o = 0, n = 0; Array.isArray(A) ? (i = A[0], o = A[1], n = A[2]) : (i = A.x, o = A.y, n = A.z); var r = e || [0, 0, 0], a = 0, s = 0, l = 0; Array.isArray(r) ? (a = r[0], s = r[1], l = r[2]) : (a = r.x, s = r.y, l = r.z); var c = new M; c.setPosition(-a, -s, -l); var h = new M, d = new F(i, o, n, t || "XYZ"); h.makeRotationFromEuler(d); var p = new M; return p.setPosition(a, s, l), p.multiply(h).multiply(c), p }, isolateComponentsByIdForJDS: function (A, e) { Array.isArray(A) || (A = [A]); for (var t = [], i = 0; A.length > i; i += 1) t[i] = e + "_" + A[i]; this.filter.addToIsolateList(Nc.HIDDEN_OTHERS, t); for (var o = this.getViewerImpl().modelManager.getScene().pool._pool, n = 0; o.length > n; n += 1) { o[n].visible = !1; for (var r = 0; t.length > r; r += 1) o[n].key === t[r] && (o[n].visible = !0) } return this.render(), !0 }, sortComponentsById: function (A, e, t) { Array.isArray(A) || (A = [A]); for (var i = this.getViewerImpl().getModel(e), o = [], n = 0; A.length > n; n += 1) o[n] = e + "_" + A[n]; return i ? i.getComponentKeysByTypeFromList(o, t) : [] }, sortComponentsByKey: function (A, e) { return Array.isArray(A) || (A = [A]), this.getViewerImpl().modelManager.getComponentKeysByTypeFromList(A, e) }, conditionSortComponentsById: function (A, e, t, i, o) { var n = this.filter.setConditions(A, e); Array.isArray(t) || (t = [t]); for (var r = [], a = 0; t.length > a; a += 1) r[a] = i + "_" + t[a]; var s = this.getComponentsByKey(r), l = []; if (null !== n) switch (A) { case 0: for (var c = 0; s.length > c; c += 1) n.match(s[c]) && l.push(s[c].key); this.isolateComponentsByKey(l); break; case 1: for (var h = 0; s.length > h; h += 1) n.match(s[h]) && l.push(s[h].key); var d = this.otherObjectsInScene(l); this.transparentComponentsByKey(d, .5, !1); break; case 2: for (var p = 0; s.length > p; p += 1) null !== n.getMatchItem(s[p]) && l.push(s[p].key); !0 === o.highLight ? this.highlightComponentsByKey(l) : this.colorfulComponentsByKey(l, o.color) } return l }, conditionSortComponentsByKey: function (A, e, t, i) { var o = this.filter.setConditions(A, e); Array.isArray(t) || (t = [t]); var n = this.getComponentsByKey(t), r = []; if (null !== o) switch (A) { case 0: for (var a = 0; n.length > a; a += 1) o.match(n[a]) && r.push(n[a].key); this.isolateComponentsByKey(r); break; case 1: for (var s = 0; n.length > s; s += 1) o.match(n[s]) && r.push(n[s].key); var l = this.otherObjectsInScene(r); this.transparentComponentsByKey(l, .5, !1); break; case 2: for (var c = 0; n.length > c; c += 1) null !== o.getMatchItem(n[c]) && r.push(n[c].key); !0 === i.highLight ? this.highlightComponentsByKey(r) : this.colorfulComponentsByKey(r, i.color) } return r }, resetScene: function (A) { if (A = A || {}, this.getViewerImpl().getModelManager().dispatchEvent({ type: Rc.BEFORE_RESETSCENE, data: A }), uh.isEmptyObject(A)) { this.clearIsolation(), this.clearModelIsolation(), this.clearHighlightList(), this.clearModelHighlightList(), this.showAllComponents(), this.showAllModels(), this.clearWireframeList(), this.clearTransparentList(), this.clearModelTransparentList(), this.clearColorfulList(), this.clearModelColorfulList(); var e = this.viewerImpl.modelManager.scene.getBoundingBox(), t = e.getCenter(new y), i = e.getSize(new y), o = new y(t.x + i.x, t.y + i.y, t.z + i.z); this.originalView ? this.viewerImpl.lookAt(this.originalView.position, this.originalView.target, this.originalView.up) : this.viewerImpl.lookAt(o, t, new y(0, 0, 1)) } else if (A.visible && (this.clearIsolation(), this.clearModelIsolation(), this.showAllComponents(), this.showAllModels()), A.selected && (this.clearHighlightList(), this.clearModelHighlightList()), A.transparent && (this.clearTransparentList(), this.clearModelTransparentList()), A.wireframed && this.clearWireframeList(), A.colorfully && (this.clearColorfulList(), this.clearModelColorfulList()), A.view) if (this.originalView) this.viewerImpl.lookAt(this.originalView.position, this.originalView.target, this.originalView.up); else { var n = this.viewerImpl.modelManager.scene.getBoundingBox(), r = n.getCenter(new y), a = n.getSize(new y), s = new y(r.x + a.x, r.y + a.y, r.z + a.z); this.viewerImpl.lookAt(s, r, new y(0, 0, 1)) } this.getViewerImpl().getModelManager().dispatchEvent({ type: Rc.AFTER_RESETSCENE, data: A }), this.render() }, getScreenCoordFromSceneCoord: function (A) { return this.getViewerImpl().getScreenCoordFromSceneCoord(A) }, getWorldPositionFromLocalPositionByModelKey: function (A, e) { var t = this.getModelMatrix(e); if (t) { if (A.isVector3) { var i = A.clone(); return i.applyMatrix4(t), i.toArray() } if (Array.isArray(A)) { var o = (new y).fromArray(A); return o.applyMatrix4(t), o.toArray() } } else Bh.error("模型key无效") }, getLocalPositionFromWorldPositionByModelKey: function (A, e) { var t = this.getModelMatrix(e); if (t) { var i = (new M).getInverse(t); if (A.isVector3) { var o = A.clone(); return o.applyMatrix4(i), o.toArray() } if (Array.isArray(A)) { var n = (new y).fromArray(A); return n.applyMatrix4(i), n.toArray() } } else Bh.error("模型key无效") }, getWorldPositionListFromLocalPositionListByModelKey: function (A, e) { var t = this.getModelMatrix(e); if (t) { for (var i = [], o = 0, n = A.length; n > o; o += 1) { var r = A[o]; if (r.isVector3) { var a = r.clone(); a.applyMatrix4(t), i.push(a.toArray()) } else if (Array.isArray(r)) { var s = (new y).fromArray(r); s.applyMatrix4(t), i.push(s.toArray()) } } return i } Bh.error("模型key无效") }, getLocalPositionListFromWorldPositionListByModelKey: function (A, e) { var t = this.getModelMatrix(e); if (t) { for (var i = (new M).getInverse(t), o = [], n = 0, r = A.length; r > n; n += 1) { var a = A[n]; if (a.isVector3) { var s = a.clone(); s.applyMatrix4(i), o.push(s.toArray()) } else if (Array.isArray(a)) { var l = (new y).fromArray(a); l.applyMatrix4(i), o.push(l.toArray()) } } return o } Bh.error("模型key无效") }, getWorldPositionArrayFromLocalPositionArrayByModelKey: function (A, e) { var t = this.getModelMatrix(e); if (t) { for (var i = [], o = 0, n = A.length; n > o; o += 3) { var r = (new y).fromArray(A, o); r.applyMatrix4(t), i.push.apply(i, yc(r.toArray())) } return i } Bh.error("模型key无效") }, getLocalPositionArrayFromWorldPositionArrayByModelKey: function (A, e) { var t = this.getModelMatrix(e); if (t) { for (var i = (new M).getInverse(t), o = [], n = 0, r = A.length; r > n; n += 3) { var a = (new y).fromArray(A, n); a.applyMatrix4(i), o.push.apply(o, yc(a.toArray())) } return o } Bh.error("模型key无效") }, render: function () { this.getViewerImpl().render() }, syncRender: function () { this.getViewerImpl()._render() }, resize: function (A, e) { this.getViewerImpl().resize(A, e) }, autoResize: function () { this.getViewerImpl().resize(window.innerWidth - 5, window.innerHeight - 5) }, setSceneBackGroundColor: function (A, e) { this.getViewerImpl().setBackgroundColor(new Xh(A, e)) }, resetSceneBackgroundColor: function () { this.getViewerImpl().resetBackgroundColor() }, getComponentsAttributeById: function (A, e, t) { this.getComponentsAttributeByKey(e + "_" + A, t) }, getComponentsAttributeByKey: function (A, e) { var t = this.getViewerImpl().getModelByComponentKey(A); if (t) { if (t.offLine) { if (t.attributes && t.attributes[A]) return void e({ attribute: t.attributes[A] }); e(null) } _d({ type: "GET", url: (t.loader.url.serverUrl || this.host) + "/api/" + t.projectKey + "/components?componentKey=" + A + ("" === t.shareKey ? "" : "&share=" + t.shareKey), headers: { Authorization: t.accessToken }, success: function (A) { try { A = JSON.parse(A) } catch (A) { Bh.log("解析属性失败") } e("SUCCESS" === A.code ? A.data : null) }, error: function (A) { e(null) } }) } else e(null) }, mergeMesh: function (A, e) { var t = this.getViewerImpl().modelManager.getModel(e); if (!t) return null; var i = new ep("mergeGroup"); i.modelKey = e; for (var o = new he, n = [], r = [], a = [], s = [], l = [], c = [], h = t.cache, d = [], p = [], g = null, u = 0, f = 0; A.length > f; f += 1) if (t.cache.components.hasOwnProperty(A)) { u += 1; var m = {}, C = r.length, y = n.length / 3; m.start = C; var v = l.length, I = t.cache.components[A], E = h.geometries[I.geoId]; if (!E) continue; var B = E.clone(), x = new M; x.fromArray(I.matrix); var S = B.attributes; B.applyMatrix(x); for (var w = 0; S.position.array.length > w; w += 1) n.push(S.position.array[w]); for (var b = 0; S.normal.array.length > b; b += 1) s.push(S.normal.array[b]); if (S.uv) for (var U = 0; S.uv.array.length > U; U += 1) a.push(S.uv.array[U]); for (var F = 0; B.index.array.length > F; F += 1) r.push(B.index.array[F] + y); if (B.groups.length > 0) for (var K = 0; B.groups.length > K; K += 1) { var Q = {}; Q.start = B.groups[K].start + C, Q.count = B.groups[K].count, -1 !== B.groups[K].materialIndex && (Q.materialIndex = B.groups[K].materialIndex + v), c.push(Q) } else { var R = {}; R.start = C, R.count = B.index.count, R.materialIndex = v, c.push(R) } var T = h.materials[I.matId]; if (!T) continue; for (F = 0; T.materials.length > F; F += 1) l.push(T.materials[F]); if (m.end = r.length / 3, m.guid = I.guid, u > vc.MaxMergeCount) { if (u = 0, o.setAttribute("position", new YA(new Float32Array(n), 3)), o.setAttribute("normal", new YA(new Float32Array(s), 3)), o.setAttribute("uv", new YA(new Float32Array(a), 2)), d = [], Array.fill) d = Array(n.length).fill(1); else for (var k = 0; n.length > k; k += 1) d.push(1); p = new Float32Array(d), o.setAttribute("color", new YA(p, 3, !0)), o.setIndex(r), o.groups = c, g = new Ue(o, l), i.add(g), o = new he, n = [], r = [], a = [], s = [], l = [], c = [] } } if (o.setAttribute("position", new YA(new Float32Array(n), 3)), o.setAttribute("normal", new YA(new Float32Array(s), 3)), o.setAttribute("uv", new YA(new Float32Array(a), 2)), d = [], Array.fill) d = Array(n.length).fill(1); else for (k = 0; n.length > k; k += 1) d.push(1); return p = new Float32Array(d), o.setAttribute("color", new YA(p, 3, !0)), o.setIndex(r), o.groups = c, g = new Ue(o, l), i.add(g), d = null, n = null, r = null, a = null, s = null, l = null, c = null, i }, setComponentPositionByKey: function (A, e) { this.getViewerImpl().setComponentPositionByKey(A, e), this.render() }, setComponentPositionById: function (A, e, t) {}, getBoxByComponentsKey: function (A) { return Array.isArray(A) || (A = [A]), this.getViewerImpl().getBoundingBoxByIds(A) }, getAttributeByComponentKey: function () {}, zoomToBox: function (A, e, t) { this.getViewerImpl().zoomToBox(A, e, t) }, zoomIn: function (A, e, t) { this.getViewerImpl().zoomIn(A, e, t) }, zoomOut: function (A, e, t) { this.getViewerImpl().zoomOut(A, e, t) }, flyToStandardView: function (A, e, t, i) { this.getViewerImpl().setStandardView(A, e, t, i) }, setStandardViewWithBox: function (A, e, t, i) { this.getViewerImpl().setStandardViewWithBox(A, e, t, i) }, adaptiveSize: function () { this.getViewerImpl().zoomToSelection() }, adaptiveSizeByKey: function (A) { Array.isArray(A) || (A = [A]); var e = this.getViewerImpl().getBoundingBoxByIds(A); e && !e.isEmpty() && this.getViewerImpl().zoomToBox(e) }, flyTo: function (A, e) { var t = this; this.getViewerImpl().animator.slerpFlyTo(A, this.viewerImpl, (function (A) { t.viewerImpl.cameraControl.update(!0, !0) }), e) }, linearFlyTo: function (A, e) { var t = this; this.getViewerImpl().animator.linearFlyTo(A, this.viewerImpl, (function (A) { t.viewerImpl.cameraControl.update(!0, !0) }), e) }, slerpFlyTo: function (A, e) { var t = this; this.getViewerImpl().animator.slerpFlyTo(A, this.viewerImpl, (function (A) { t.viewerImpl.cameraControl.update(!0, !0) }), e) }, setAnimatorDuration: function (A) { var e = this.getViewerImpl().animator; return !(!e || "number" != typeof A) && (e.setDuration(A), !0) }, getAnimatorDuration: function () { var A = this.getViewerImpl().animator; if (A) return A.getDuration() }, enableViewController: function () { var A = this; return this.viewController ? (this.viewController.enable(), !0) : (this.viewController = new lp(this.viewerImpl, (function () { return !0 })), this.viewController.init(this.getViewerImpl().getDomElement()), this.viewController.render(), this.getViewerImpl().addRenderFinishedListener((function () { A.viewController.render() })), !0) }, disableViewController: function () { return !!this.viewController && (this.viewController.disable(), !0) }, enabledCameraRotateOfVerticalPolarAngle: function (A) { this.getViewerImpl().cameraControl.enabledPolar(A), Bh.warn("请改用 lockAxisZ 方法") }, lockAxisZ: function (A, e) { this.getViewerImpl().lockAxisZ(A, e) }, setMinPolarAngle: function (A) { this.getViewerImpl().cameraControl.setMinPolarAngle(A), Bh.warn("请改用 lockAxisZ 方法") }, setMaxPolarAngle: function (A) { this.getViewerImpl().cameraControl.setMaxPolarAngle(A), Bh.warn("请改用 lockAxisZ 方法") }, getMinPolarAngle: function () { return this.getViewerImpl().cameraControl.getMinPolarAngle() }, getMaxPolarAngle: function () { return this.getViewerImpl().cameraControl.getMaxPolarAngle() }, enableRotate: function (A) { return jh.NoRotate = !A, !jh.NoRotate }, enablePan: function (A) { return jh.NoPan = !A, !jh.NoPan }, enableZoom: function (A) { return jh.NoZoom = !A, !jh.NoZoom }, setPointRotateMode: function (A) { return this.getViewerImpl().setPointRotateMode(A), jh.RotatePivotMode }, rotateCamera: function (A, e) { var t = new s, i = new y; Array.isArray(A) ? t.set(A[0], A[1]) : t.set(A.x, A.y), e ? Array.isArray(e) ? i.fromArray(e) : i.set(e.x, e.y, e.z) : i = this.getViewerImpl().getScene().getBoundingBoxWorld().getCenter(i), this.getViewerImpl().rotateCamera(t, i) }, requestPointerLock: function () { this.getViewerImpl().getControlManager().requestPointerLock() }, translateComponentByKey: function (A, e, t) { this.getViewerImpl().translateComponentByKey(A, e, t) }, scaleComponentByKey: function (A, e, t) { this.getViewerImpl().scaleComponentByKey(A, e, t) }, rotateComponentByKey: function (A, e, t) { this.getViewerImpl().rotateComponentByKey(A, e, t) }, cancelTransformComponent: function (A) { this.getViewerImpl().cancelTransformComponent(A) }, restoreComponentTransform: function () { this.getViewerImpl().restoreComponentTransform() }, getComponentLocalMatrixByKey: function (A) { return this.getViewerImpl().getComponentLocalMatrixByKey(A) }, getComponentWorldMatrixByKey: function (A) { return this.getViewerImpl().getComponentWorldMatrixByKey(A) }, setComponentLocalMatrixByKey: function (A, e) { return this.getViewerImpl().setComponentLocalMatrixByKey(A, e) }, resetComponentMatrix: function (A, e) { return this.getViewerImpl().resetComponentMatrix(A, e) }, increaseComponentTransformControlSize: function () { this.getViewerImpl().increaseComponentTransformControlSize() }, decreaseComponentTransformControlSize: function () { this.getViewerImpl().decreaseComponentTransformControlSize() }, setComponentTransformSpaceToLocalSpace: function () { this.getViewerImpl().setComponentTransformSpaceToLocalSpace() }, setComponentTransformSpaceToWorldSpace: function () { this.getViewerImpl().setComponentTransformSpaceToWorldSpace() }, switchComponentTransformSpaceBetweenLocalAndWorld: function () { this.getViewerImpl().switchComponentTransformSpaceBetweenLocalAndWorld() }, showComponentTransformOnAxis: function (A) { this.getViewerImpl().showComponentTransformOnAxis(A) }, hideComponentTransformOnAxis: function (A) { this.getViewerImpl().hideComponentTransformOnAxis(A) }, disableComponentTransform: function () { this.getViewerImpl().disableComponentTransform() }, enableComponentTransform: function () { this.getViewerImpl().enableComponentTransform() }, enableSectionBox: function () { var A = this.getViewerImpl(); A.controlManager.enableTool(A, Pc.CLIP_BY_BOX), this._sectionTool = new Ap(A), this._sectionTool.toggle(!0, !0), this._sectionTool.setVisible(!0), this._sectionTool.reset(), this._isSection = !0, this.render() }, disableSectionBox: function () { this.getViewerImpl().controlManager.disableTool(Pc.CLIP_BY_BOX), this._isSection = !1, this.render() }, resetSectionBox: function () { this._isSection ? (this.showSectionBox(), this.setSectionBoxMode(), this._sectionTool.reset("Rotate")) : Bh.log(fh[vc.language].SectionBoxLockHint) }, setSectionBoxMode: function (A) { this._isSection ? this._sectionTool.setRotatable("Rotate" === A) : Bh.log(fh[vc.language].SectionBoxLockHint) }, showSectionBox: function () { this._isSection ? (this._sectionTool.setVisible(!0), this.render()) : Bh.log(fh[vc.language].SectionBoxLockHint) }, hideSectionBox: function () { this._isSection ? (this._sectionTool.setVisible(!1), this.render()) : Bh.log(fh[vc.language].SectionBoxLockHint) }, setSectionBox: function (A) { var e = this.getViewerImpl(), t = e.getScene().getClipPlanes(), i = e.worldToDrawing(A.min), o = e.worldToDrawing(A.max); this.enableSectionBox(), t.setSectionBox(i, o), this.hideSectionBox() }, getSectionBoxState: function () { if (this._isSection) return this._sectionTool.saveState(); Bh.log(fh[vc.language].SectionBoxLockHint) }, setSectionBoxState: function (A) { this._isSection ? (this._sectionTool.loadState(A), this.render()) : Bh.log(fh[vc.language].SectionBoxLockHint) }, getSceneState: function () { return this.getViewerImpl().getSceneState() }, setSceneState: function (A) { this.getViewerImpl().setSceneState(A) }, getScreenShot: function (A) { var e, t, i, o; return A.color && A.color instanceof Xh && (e = A.color.getRGBA()), A.width > 0 && A.height > 0 && (i = A.width, o = A.height), "function" == typeof A.callback && (t = A.callback), this.getViewerImpl().canvas2image(e, i, o, t) }, registerModelEventListener: function (A, e) { this.getViewerImpl().registerEventListener(A, e) }, unregisterModelEventListener: function (A, e) { this.getViewerImpl().unregisterEventListener(A, e) }, registerControlEventListener: function (A, e) { this.getViewerImpl().registerDomEventListener(A, e) }, unregisterControlEventListener: function (A, e) { this.getViewerImpl().unregisterDomEventListener(A, e) }, registerCameraEventListener: function (A, e) { this.getViewerImpl().registerCameraEventListener(A, e) }, unregisterCameraEventListener: function (A, e) { this.getViewerImpl().unregisterCameraEventListener(A, e) }, enableLogarithmicDepthBuffer: function (A) { this.getViewerImpl().enableLogarithmicDepthBuffer(A) }, setSkyBox: function (A, e, t, i) { var o = this.getRootScene(); o && (A ? o.setSkyBox(void 0, A, e, t, i) : o.background = null) }, setDrawingStyle: function (A) { this.getViewerImpl().setDrawingStyle(A), this.render() }, setExposure: function (A) { this.getViewerImpl().setExposureShift(A), this.render() }, getBoardlineColor: function (A) { var e = this.getViewerImpl().getWireframeColor(A); return new Xh(e, e.opacity) }, setBoardlineColor: function (A, e) { var t = null; t = A instanceof Xh ? A : new Xh(A), this.getViewerImpl().setWireframeColor(t, e) }, restoreBoardlineColor: function (A) { this.getViewerImpl().restoreWireframeColor(A) }, getSelectionBoardlineColor: function () { return this.getViewerImpl().getOutlineEdgeColor() || new Xh }, setSelectionBoardlineColor: function (A) { var e = null; e = A instanceof Xh ? A : new Xh(A), this.getViewerImpl().setOutlineEdgeColor(e) }, restoreSelectionBoardlineColor: function () { this.getViewerImpl().restoreOutlineEdgeColor() }, getSelectionColor: function () { return this.getViewerImpl().getSelectionColor() }, setSelectionColor: function (A) { var e = null; e = A instanceof Xh ? A : new Xh(A), this.getViewerImpl().setSelectionColor(e) }, restoreSelectionColor: function () { this.getViewerImpl().restoreSelectionColor() }, setAxisNetColor: function (A, e) { this.viewerImpl.setAxisNetColor(A, e) }, showAxisNet: function () { this.viewerImpl.showAxisNet() }, hideAxisNet: function () { this.viewerImpl.hideAxisNet() }, enableAxisNetStayInFront: function () { this.viewerImpl.enableAxisNetStayInFront() }, disableAxisNetStayInFront: function () { this.viewerImpl.disableAxisNetStayInFront() }, getScene: function () { return this.getViewerImpl().getScene().getExternalScene() }, getRootScene: function () { return this.getViewerImpl().getScene() }, updateSceneBoundingBox: function () { this.getExternalComponentManager().calculateBoundingBox(), this.getViewerImpl().modelManager.updateSceneBoundingBox() }, getCurrentControlName: function () { return this.getViewerImpl().getCurrentControlName() }, setControlMode: function (A) { this.getViewerImpl().setControlMode(A), this.render() }, setControlDefault: function () { this.setControlMode(Gc.PICK) }, setZoomSpeed: function (A) { this.getViewerImpl().cameraControl.setZoomSpeed(A) }, getZoomSpeed: function () { return this.getViewerImpl().cameraControl.getZoomSpeed() }, setZoomOutLimitRate: function (A) { this.getViewerImpl().cameraControl.setZoomOutLimitRate(A) }, getZoomOutLimitRate: function () { return this.getViewerImpl().cameraControl.getZoomOutLimitRate() }, setLightIntensityFactor: function (A) { this.getViewerImpl().setLightIntensityFactor(A) }, enableShadow: function (A) { this.getViewerImpl().enableShadow(A) }, updateShadowLight: function () { this.getViewerImpl().updateShadowLight() }, setShadowLightDir: function (A) { var e; A ? (e = Array.isArray(A) ? (new y).fromArray(A) : A.isVector3 ? A : new y(A.x, A.y, A.z), this.getViewerImpl().getScene().lightManager.shadowLightDir = e) : Bh.error("无效参数") }, getShadowLightDir: function () { return this.getViewerImpl().getScene().lightManager.shadowLightDir.clone() }, getLightDirFromAltitudeAndAzimuth: function (A, e) { if (void 0 !== A && void 0 !== e) return this.getViewerImpl().getScene().lightManager.getLightDirFromAltitudeAndAzimuth(A, e); Bh.error("参数不合法") }, getExternalComponentManager: function () { return this.getViewerImpl().getExternalComponentManager() }, addExternalObject: function (A, e, t, i) { this.getViewerImpl().addExternalObject(A, e, t, i) }, addExternalObjects: function (A, e, t) { return this.getViewerImpl().addExternalObjects(A, e, t) }, removeExternalObjectByName: function (A) { this.getViewerImpl().removeExternalObjectByName(A) }, clearExternalObjects: function () { this.getViewerImpl().clearExternalObjects() }, getExternalObjectByName: function (A) { return this.getViewerImpl().getExternalObjectByName(A) }, getAllExternalObjects: function () { return this.getViewerImpl().getAllExternalObjects() }, showFPS: function () { this.fpsStats = new $d; var A = this; this.viewportDiv.appendChild(this.fpsStats.dom), this.fpsStats.listener = function () { A.fpsStats.update() }, this.getViewerImpl().addRenderListener(this.fpsStats.listener) }, hideFPS: function () { this.fpsStats && (this.viewportDiv.removeChild(this.fpsStats.dom), this.getViewerImpl().removeRenderListener(this.fpsStats.listener)), this.fpsStats = null }, cloneComponentByKey: function (A, e) { var t = this.getViewerImpl().cloneComponent(A); return "translate" === e ? this.translateComponentByKey(t.key) : "scale" === e ? this.scaleComponentByKey(t.key) : "rotate" === e && this.rotateComponentByKey(t.key), null !== t ? { mesh: t, key: t.key } : null }, setCloneComponentMaterialsByKey: function (A, e, t) { return this.getViewerImpl().getExternalComponentManager().setCloneComponentMaterialsByKey(A, e, t) }, createSmoothCurve: function (A) { return this.getViewerImpl().catmullRomCurve(A) }, destroy: function () { this.getViewerImpl().destroy(), this.viewController && (this.viewController.destroy(), this.viewController = null) } }); var qy, jy, Hy, Yy, Wy = function (A) { var e = A.lobibox, t = A.toolId, i = A.Flag, o = document.createElement("div"); return o.className = "tab-body", o.id = "tab-compare-" + t, e.window({ title: ("old" === t ? "新-旧" : "旧-新") + "模型对比结果", width: 334, height: 705, closeOnEsc: !1, closeButton: !0, afterWindowHide: function () { var A = document.getElementById("modelCompares" + t); i.modelCompares = !1, A && (A.style.backgroundColor = "", A.querySelector(".yj-icon").className = "yj-icon modelCompares-icon") }, afterWindowShow: function () { var A = document.getElementById("modelCompares" + t); i.modelCompares = !0, A && (A.style.backgroundColor = "#1f89de", A.querySelector(".yj-icon").className = "yj-icon modelCompares-icon active") }, content: o }) }, Jy = function (A) { var e = A.lobibox, t = A.toolId, i = document.createElement("div"); i.className = "tab-body", i.id = "tab-compare-properties-" + t; var o = document.createElement("table"); o.classList.add("sx-table"), o.classList.add("table-no-top"), i.appendChild(o); var n = document.createElement("thead"); o.appendChild(n); var r = document.createElement("tbody"); o.appendChild(r); var a = document.createElement("tr"); a.className = "noprop", r.appendChild(a); var s = document.createElement("td"); return s.innerText = "尚未选择构件", a.appendChild(s), e.window({ title: "属性对比详情", width: 500, height: 400, closeOnEsc: !1, closeButton: !0, afterWindowHide: function () {}, content: i }) }, zy = { AGGREGATION: "AGGREGATION", SEPARATION: "SEPARATION", MULTIWINDOW: "MULTIWINDOW" }, Zy = { added: "added", deleted: "deleted", changed: "changed", noChanged: "noChanged", oldChanged: "oldChanged", newChanged: "newChanged", oldNoChanged: "oldNoChanged", newNoChanged: "newNoChanged" }, Xy = { addedColor: { color: 32768, opacity: 1 }, deletedColor: { color: 16711680, opacity: 1 }, changedColor: { color: 16753920, opacity: 1 } }, _y = { ACCOUNT_NO_EXIST: "ACCOUNT_NO_EXIST", NO_PERMISSION: "NO_PERMISSION", ON_NETWORK_ERROR: "ON_NETWORK_ERROR", ON_LOAD_INVALID_COMPARES: "ON_LOAD_INVALID_COMPARES", ON_LOAD_INVALID_CONTRASTDETAILS: "ON_LOAD_INVALID_CONTRASTDETAILS", ON_LOAD_INVALID_STATE: "ON_LOAD_INVALID_STATE", ON_LOAD_ERROR: "ON_LOAD_ERROR" }, $y = function (A, e) { var t = this, i = uh.extend({}, { host: "https://bos3d.bimwinner.com", viewport: "", toolbar: !0, coloringImmediately: !1, showPanel: !1 }, A); this.host = i.host, this.coloringImmediately = i.coloringImmediately, this.domElement = document.getElementById(i.viewport), this.domElement.style.position = "relative", this.oldModelKey = "", this.newModelKey = "", this.displayModel = e || zy.SEPARATION, t.oldNoChangedList = [], t.newNoChangedList = [], t.oldChangedList = [], t.newChangedList = [], t.deletedList = [], t.addedList = [], this.useNewUI = Boolean(window.EIMMODELUI); var o = { modelCompares: i.showPanel }, n = { modelCompares: i.showPanel }; switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: if (this.firstViewer = new Py(A), this.secondViewer = this.firstViewer, t.oldLobibox = new bh, t.oldLobibox.viewport = document.querySelector("#" + t.firstViewer.viewport), t.newLobibox = t.oldLobibox, i.toolbar) { this.useNewUI ? this.firstTool = new window.EIMMODELUI({ viewer3D: this.firstViewer, EIM: window.EIM, EIMMODEL: window.EIMMODEL }) : (this.firstTool = new Xd(this.firstViewer), this.firstTool.createTool()), this.secondTool = this.firstTool, this.oldCompareWindow = Wy({ toolId: "old", lobibox: t.oldLobibox, Flag: o }), this.newCompareWindow = this.oldCompareWindow, this.oldContrastDetailsWindow = Jy({ toolId: "old", lobibox: t.oldLobibox }), this.newContrastDetailsWindow = this.oldContrastDetailsWindow, this.oldCompareWindow.setPosition({ left: "", right: 5, top: 60 }), this.oldContrastDetailsWindow.setPosition({ left: t.domElement.offsetWidth / 2 + t.domElement.offsetLeft / 2 - 250, top: 200 }), t.oldContrastDetailsWindow.windowHide(); var r = document.createElement("div"); r.className = "yj-group", this.useNewUI ? this.firstTool.plugin.addIcon("topRight", r) : this.firstTool.toolbarTop.appendChild(r); var a = document.createElement("button"); a.className = "yj-but", a.title = "模型对比结果", a.id = "modelComparesold"; var s = document.createElement("div"); s.classList.add("yj-icon"), s.classList.add("modelCompares-icon"), a.appendChild(s), r.appendChild(a), a.addEventListener("click", (function (A) { o.modelCompares ? t.oldCompareWindow.windowHide() : (o.modelCompares = !o.modelCompares, t.oldCompareWindow.windowShow()) })) } break; case zy.MULTIWINDOW: var l = document.createElement("div"); l.setAttribute("id", "firstViewer"), l.style.width = "50%", l.style.height = "100%", l.style.float = "left", this.domElement.appendChild(l); var c = document.createElement("div"); if (c.setAttribute("id", "secondViewer"), c.style.width = "50%", c.style.height = "100%", c.style.float = "left", this.domElement.appendChild(l), this.domElement.appendChild(c), this.firstViewer = new Py({ host: this.host, viewport: "firstViewer" }), this.secondViewer = new Py({ host: this.host, viewport: "secondViewer" }), t.oldLobibox = new bh, t.oldLobibox.viewport = document.querySelector("#" + t.firstViewer.viewport), t.newLobibox = new bh, t.newLobibox.viewport = document.querySelector("#" + t.secondViewer.viewport), i.toolbar) { this.useNewUI ? (this.firstTool = new window.EIMMODELUI({ viewer3D: this.firstViewer, EIM: window.EIM, EIMMODEL: window.EIMMODEL }), this.secondTool = new window.EIMMODELUI({ viewer3D: this.secondViewer, EIM: window.EIM, EIMMODEL: window.EIMMODEL })) : (this.firstTool = new Xd(this.firstViewer), this.firstTool.createTool(), this.secondTool = new Xd(this.secondViewer), this.secondTool.createTool()), this.oldCompareWindow = Wy({ toolId: "old", lobibox: t.oldLobibox, Flag: o }), this.newCompareWindow = Wy({ toolId: "new", lobibox: t.newLobibox, Flag: n }), this.oldContrastDetailsWindow = Jy({ toolId: "old", lobibox: t.oldLobibox }), this.newContrastDetailsWindow = Jy({ toolId: "new", lobibox: t.newLobibox }), t.oldContrastDetailsWindow.windowHide(), t.newContrastDetailsWindow.windowHide(), this.oldContrastDetailsWindow.setTitle("旧-新属性对比详情"), this.newContrastDetailsWindow.setTitle("新-旧属性对比详情"), this.oldCompareWindow.setPosition({ left: "", right: 5 + t.domElement.offsetWidth / 2 + t.domElement.offsetLeft / 2, top: 60 }), this.oldContrastDetailsWindow.setPosition({ left: t.domElement.offsetWidth / 4 + t.domElement.offsetLeft / 4 - 250, top: 200 }), this.newCompareWindow.setPosition({ left: "", right: 5, top: 60 }), this.newContrastDetailsWindow.setPosition({ left: t.domElement.offsetWidth / 4 * 3 + t.domElement.offsetLeft / 4 * 3 - 250, top: 200 }); var h = document.createElement("div"); h.className = "yj-group", this.useNewUI ? this.firstTool.plugin.addIcon("topRight", h) : this.firstTool.toolbarTop.appendChild(h); var d = document.createElement("button"); d.className = "yj-but", d.title = "模型对比结果", d.id = "modelComparesold"; var p = document.createElement("div"); p.classList.add("yj-icon"), p.classList.add("modelCompares-icon"), d.appendChild(p), h.appendChild(d), d.addEventListener("click", (function (A) { o.modelCompares ? t.oldCompareWindow.windowHide() : (o.modelCompares = !o.modelCompares, t.oldCompareWindow.windowShow()) })); var g = document.createElement("div"); g.className = "yj-group", this.useNewUI ? this.secondTool.plugin.addIcon("topRight", g) : this.secondTool.toolbarTop.appendChild(g); var u = document.createElement("button"); u.className = "yj-but", u.title = "模型对比结果", u.id = "modelComparesnew"; var f = document.createElement("div"); f.classList.add("yj-icon"), f.classList.add("modelCompares-icon"), u.appendChild(f), g.appendChild(u), u.addEventListener("click", (function (A) { n.modelCompares ? t.newCompareWindow.windowHide() : (n.modelCompares = !n.modelCompares, t.newCompareWindow.windowShow()) })) } break; default: Bh.error("无效的显示模式!") } i.showPanel || (t.newCompareWindow && t.newCompareWindow.windowHide(), t.oldCompareWindow && t.oldCompareWindow.windowHide()), this.firstViewer.getViewerImpl().modelManager.addEventListener(Rc.ON_LOAD_COMPLETE, (function (A) { A.modelKey === t.oldModelKey && (t.oldModelLoaded = !0, t._applyCompareData(), t._initCompareResultPlane(t.compareData)) })), this.secondViewer.getViewerImpl().modelManager.addEventListener(Rc.ON_LOAD_COMPLETE, (function (A) { A.modelKey === t.newModelKey && (t.newModelLoaded = !0, t._applyCompareData(), t._initCompareResultPlane(t.compareData)) })) }; Object.assign($y.prototype, Ld.prototype), Object.assign($y.prototype, { resize: function (A, e) { switch (this.domElement && (this.domElement.style.height = e + "px", this.domElement.style.width = A + "px"), this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.resize(A, e); break; case zy.MULTIWINDOW: this.firstViewer.resize(A / 2, e), this.secondViewer.resize(A / 2, e); break; default: this.firstViewer.resize(A, e) } }, autoResize: function () { this.resize(this.getClientWidth(), this.getClientHeight()) }, getClientHeight: function () { return xh.getClientHeight() }, getClientWidth: function () { return xh.getClientWidth() }, resetOldScene: function (A) { this.firstViewer.resetScene(A) }, resetNewScene: function (A) { this.secondViewer.resetScene(A) }, resetScene: function (A) { this.firstViewer.resetScene(A), this.secondViewer.resetScene(A), this._applyCompareData() }, transparentComponentsByType: function (A) { var e = this._getDataByType(A); this.firstViewer.transparentComponentsByKey(e.oldList), this.secondViewer.transparentComponentsByKey(e.newList) }, transparentOtherComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.transparentOtherComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.transparentOtherComponentsByKey(e.oldList), this.secondViewer.transparentOtherComponentsByKey(e.newList) } }, closeTransparentComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.closeTransparentComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.closeTransparentComponentsByKey(e.oldList), this.secondViewer.closeTransparentComponentsByKey(e.newList) } }, clearComponentTransparentList: function () { switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.clearComponentTransparentList(); break; case zy.MULTIWINDOW: this.firstViewer.clearComponentTransparentList(), this.secondViewer.clearComponentTransparentList() } }, showComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.showComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.showComponentsByKey(e.oldList), this.secondViewer.showComponentsByKey(e.newList) } }, hideComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.hideComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.hideComponentsByKey(e.oldList), this.secondViewer.hideComponentsByKey(e.newList) } }, highlightComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.highlightComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.highlightComponentsByKey(e.oldList), this.secondViewer.highlightComponentsByKey(e.newList) } }, addHighlightComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.addHighlightComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.addHighlightComponentsByKey(e.oldList), this.secondViewer.addHighlightComponentsByKey(e.newList) } }, closeHighlightComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.closeHighlightComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.closeHighlightComponentsByKey(e.oldList), this.secondViewer.closeHighlightComponentsByKey(e.newList) } }, getHighlightComponentsKey: function () { switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: return this.firstViewer.getHighlightComponentsKey(); case zy.MULTIWINDOW: return [].concat(this.firstViewer.getHighlightComponentsKey()).concat(this.secondViewer.getHighlightComponentsKey()); default: return [] } }, clearHighlightList: function () { switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.clearHighlightList(); break; case zy.MULTIWINDOW: this.firstViewer.clearHighlightList(), this.secondViewer.clearHighlightList() } }, getHighlightComponents: function () { switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: return this.firstViewer.getHighlightComponents(); case zy.MULTIWINDOW: return [].concat(this.firstViewer.getHighlightComponents()).concat(this.secondViewer.getHighlightComponents()); default: return [] } }, colorfulComponentsByType: function (A, e, t) { var i = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.colorfulComponentsByKey([].concat(i.oldList).concat(i.newList), e, t); break; case zy.MULTIWINDOW: this.firstViewer.colorfulComponentsByKey(i.oldList, e, t), this.secondViewer.colorfulComponentsByKey(i.newList, e, t) } }, closeColorfulComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.closeColorfulComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.closeColorfulComponentsByKey(e.oldList), this.secondViewer.closeColorfulComponentsByKey(e.newList) } }, clearColorfulList: function () { switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.clearColorfulList(); break; case zy.MULTIWINDOW: this.firstViewer.clearColorfulList(), this.secondViewer.clearColorfulList() } }, wireFrameComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.wireFrameComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.wireFrameComponentsByKey(e.oldList), this.secondViewer.wireFrameComponentsByKey(e.newList) } }, closeWireFrameComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.closeWireFrameComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.closeWireFrameComponentsByKey(e.oldList), this.secondViewer.closeWireFrameComponentsByKey(e.newList) } }, clearWireframeList: function () { switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.clearWireframeList(); break; case zy.MULTIWINDOW: this.firstViewer.clearWireframeList(), this.secondViewer.clearWireframeList() } }, isolateComponentsByType: function (A, e) { var t = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.isolateComponentsByKey([].concat(t.oldList).concat(t.newList), e); break; case zy.MULTIWINDOW: this.firstViewer.isolateComponentsByKey(t.oldList, e), this.secondViewer.isolateComponentsByKey(t.newList, e) } }, closeIsolateComponentsByType: function (A) { var e = this._getDataByType(A); switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.closeIsolateComponentsByKey([].concat(e.oldList).concat(e.newList)); break; case zy.MULTIWINDOW: this.firstViewer.closeIsolateComponentsByKey(e.oldList), this.secondViewer.closeIsolateComponentsByKey(e.newList) } }, clearIsolation: function () { switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.clearIsolation(); break; case zy.MULTIWINDOW: this.firstViewer.clearIsolation(), this.secondViewer.clearIsolation() } }, getAddedList: function () { return this.addedList }, getDeletedList: function () { return this.deletedList }, getChangedList: function () { return [].concat(this.oldChangedList).concat(this.newChangedList) }, getNoChangedList: function () { return [].concat(this.oldNoChangedList).concat(this.newNoChangedList) }, getNewChangedList: function () { return this.newChangedList }, getOldChangedList: function () { return this.oldChangedList }, getNewNoChangedList: function () { return this.newNoChangedList }, getOldNoChangedList: function () { return this.oldNoChangedList }, setAddedColor: function (A, e) { Xy.addedColor.color = A, Xy.addedColor.opacity = e }, setChangedColor: function (A, e) { Xy.changedColor.color = A, Xy.changedColor.opacity = e }, setDeletedColor: function (A, e) { Xy.deletedColor.color = A, Xy.deletedColor.opacity = e }, getAddedColor: function () { return Xy.addedColor }, getChangedColor: function () { return Xy.changedColor }, getDeletedColor: function () { return Xy.deletedColor }, getOldViewer: function () { return this.firstViewer }, getNewViewer: function () { return this.secondViewer }, getOldToolbar: function () { return this.firstTool }, getNewToolbar: function () { return this.secondTool }, getComponentAttribute: function (A, e) { var t = this.firstViewer.viewerImpl.getModelByComponentKey(A), i = this.secondViewer.viewerImpl.getModelByComponentKey(A); t ? this.firstViewer.getComponentsAttributeByKey(A, (function (A) { A && e(A.attribute) })) : i && this.secondViewer.getComponentsAttributeByKey(A, (function (A) { A && e(A.attribute) })) }, getContrastDetails: function (A, e, t) { var i = this; _d({ type: "GET", url: this.host + "/api/" + this.projectKey + "/compares/changes?compareKey=" + this.compareKey + "&newComponentKey=" + e + "&oldComponentKey=" + A, headers: { Authorization: this.accessToken }, success: function (A) { var e = {}; if ("string" == typeof A) try { e = JSON.parse(A) } catch (A) { return void i.dispatchEvent({ type: _y.ON_LOAD_INVALID_CONTRASTDETAILS, compareKey: i.compareKey }) } else e = A; e && "SUCCESS" === e.code ? t && t(e.data) : (Bh.log(i.compareKey, "获取对比详情出错! ", e.message), i.dispatchEvent({ type: _y.ON_LOAD_ERROR, compareKey: i.compareKey, code: e.code, message: e.message })) }, error: function (A, e) { switch (A) { case 401: i.dispatchEvent({ type: _y.ACCOUNT_NO_EXIST, compareKey: i.compareKey, data: e }); break; case 403: i.dispatchEvent({ type: _y.NO_PERMISSION, compareKey: i.compareKey, data: e }); break; default: i.dispatchEvent({ type: _y.ON_NETWORK_ERROR, compareKey: i.compareKey, data: A }) } } }) }, showOldContrastDetails: (qy = "", jy = document.getElementById("tab-compare-properties-old"), Hy = function (A, e, t, i, o) { var n = document.createElement("tr"); i.parentNode.appendChild(n), n.classList.add(o); var r = document.createElement("td"); r.innerText = A || "", n.appendChild(r); var a = document.createElement("td"); a.innerText = e || "", n.appendChild(a); var s = document.createElement("td"); s.innerText = t || "", n.appendChild(s) }, Yy = function (A, e, t, i) { var o = document.createElement("tr"); o.className = "sx-active", jy.querySelector("table tbody").appendChild(o); var n = document.createElement("td"); for (var r in n.colSpan = 2, n.style.fontSize = "14px", o.appendChild(n), n.appendChild(document.createElement("b")), n.firstElementChild.innerHTML = A, e) if (e.hasOwnProperty(r)) { if (!(t && t[r] || i && i[r])) { Hy(r, e[r], e[r], o, "compares_noChanged"); continue } if (t && t[r] && i && i[r]) { Hy(r, e[r], i[r], o, "compares_changed"), delete i[r]; continue } if ((!t || !t[r]) && i && i[r]) { Hy(r, "", i[r], o, "compares_added"), delete i[r]; continue }!t || !t[r] || i && i[r] || Hy(r, e[r], "", o, "compares_deleted") } for (var a in i) i.hasOwnProperty(a) && (void 0 !== e[a] ? Hy(a, e[a], i[a], o, "compares_changed") : Hy(a, "", i[a], o, "compares_added")) }, function (A) { var e = this; if ((jy = document.querySelector("#tab-compare-properties-old")) && (e.showOldContrastDetailsWindow(), A !== qy)) { if (void 0 === A) { var t = jy.querySelectorAll("table tbody tr"); jy.querySelector("table tbody").removeChild(t[0]), jy.querySelector("table tbody").innerHTML = ""; var i = document.createElement("tr"); i.className = "noprop"; var o = document.createElement("td"); return o.setAttribute("colspan", "2"), o.innerHTML = "未选中构件", i.appendChild(o), jy.querySelector("table tbody").appendChild(i), void(qy = A) } qy = A; var n = jy.querySelectorAll("table tbody tr"); jy.querySelector("table tbody").removeChild(n[0]), e.getComponentAttribute(qy, (function (A) { if (jy.querySelector("table tbody").innerHTML = "", null === A) { var t = document.createElement("tr"); t.className = "noprop"; var i = document.createElement("td"); return i.innerHTML = "没有属性", t.appendChild(i), void jy.querySelector("table tbody").appendChild(t) } if (void 0 === A) { var o = document.createElement("tr"); o.className = "noprop"; var n = document.createElement("td"); return n.innerHTML = "属性加载失败", o.appendChild(n), void jy.querySelector("table tbody").appendChild(o) } var r = qy.indexOf("_"); if (-1 !== r) { var a = e.newModelKey + qy.slice(r); e.getContrastDetails(qy, a, (function (e) { var t = e.old.attribute, i = e.new.attribute, o = document.createElement("tr"); o.className = "noprop"; var n = document.createElement("th"); o.appendChild(n); var r = document.createElement("span"); r.classList.add("value"), r.classList.add("nonEditable"), r.innerHTML = "属性名", n.appendChild(r); var a = document.createElement("th"); o.appendChild(a); var s = document.createElement("span"); s.classList.add("value"), s.classList.add("nonEditable"), s.innerHTML = "修改前", a.appendChild(s); var l = document.createElement("th"); o.appendChild(l); var c = document.createElement("span"); c.classList.add("value"), c.classList.add("nonEditable"), c.innerHTML = "修改后", l.appendChild(c), jy.querySelector("table tbody").appendChild(o); var h = A; for (var d in h) "object" === lc(h[d]) ? (Yy(d, h[d], t[d], i[d]), delete i[d]) : "string" == typeof h[d] && Hy(d, h[d], i[d], o); for (var p in i) "object" === lc(h[p]) ? Yy(p, h[p], t[p], i[p]) : "string" == typeof h[p] && Hy(p, h[p], i[p], o) })) } })) } } ), showNewContrastDetails: function () { var A = "", e = document.getElementById("tab-compare-properties-new"), t = function (A, e, t, i, o) { var n = document.createElement("tr"); i.parentNode.appendChild(n), n.classList.add(o); var r = document.createElement("td"); r.innerText = A || "", n.appendChild(r); var a = document.createElement("td"); a.innerText = e || "", n.appendChild(a); var s = document.createElement("td"); s.innerText = t || "", n.appendChild(s) }, i = function (A, i, o, n) { var r = document.createElement("tr"); r.className = "sx-active", e.querySelector("table tbody").appendChild(r); var a = document.createElement("td"); for (var s in a.colSpan = 2, a.style.fontSize = "14px", r.appendChild(a), a.appendChild(document.createElement("b")), a.firstElementChild.innerHTML = A, i) if (i.hasOwnProperty(s)) { if (!(o && o[s] || n && n[s])) { t(s, i[s], i[s], r, "compares_noChanged"); continue } if (o && o[s] && n && n[s]) { t(s, i[s], n[s], r, "compares_changed"), delete n[s]; continue } if ((!o || !o[s]) && n && n[s]) { t(s, "", n[s], r, "compares_added"), delete n[s]; continue }!o || !o[s] || n && n[s] || t(s, i[s], "", r, "compares_deleted") } for (var l in n) n.hasOwnProperty(l) && (void 0 !== i[l] ? t(l, i[l], n[l], r, "compares_changed") : t(l, "", n[l], r, "compares_added")) }; return function (o) { var n = this; if ((e = document.querySelector("#tab-compare-properties-new")) && (n.showNewContrastDetailsWindow(), o !== A)) { if (void 0 === o) { var r = e.querySelectorAll("table tbody tr"); e.querySelector("table tbody").removeChild(r[0]), e.querySelector("table tbody").innerHTML = ""; var a = document.createElement("tr"); a.className = "noprop"; var s = document.createElement("td"); return s.setAttribute("colspan", "2"), s.innerHTML = "未选中构件", a.appendChild(s), e.querySelector("table tbody").appendChild(a), void(A = o) } A = o; var l = e.querySelectorAll("table tbody tr"); e.querySelector("table tbody").removeChild(l[0]), n.getComponentAttribute(A, (function (o) { if (e.querySelector("table tbody").innerHTML = "", null === o) { var r = document.createElement("tr"); r.className = "noprop"; var a = document.createElement("td"); return a.innerHTML = "没有属性", r.appendChild(a), void e.querySelector("table tbody").appendChild(r) } if (void 0 === o) { var s = document.createElement("tr"); s.className = "noprop"; var l = document.createElement("td"); return l.innerHTML = "属性加载失败", s.appendChild(l), void e.querySelector("table tbody").appendChild(s) } var c = A.indexOf("_"); if (-1 !== c) { var h = n.oldModelKey + A.slice(c); n.getContrastDetails(h, A, (function (A) { var n = A.new.attribute, r = A.old.attribute, a = document.createElement("tr"); a.className = "noprop"; var s = document.createElement("th"); a.appendChild(s); var l = document.createElement("span"); l.classList.add("value"), l.classList.add("nonEditable"), l.innerHTML = "属性名", s.appendChild(l); var c = document.createElement("th"); a.appendChild(c); var h = document.createElement("span"); h.classList.add("value"), h.classList.add("nonEditable"), h.innerHTML = "修改前", c.appendChild(h); var d = document.createElement("th"); a.appendChild(d); var p = document.createElement("span"); p.classList.add("value"), p.classList.add("nonEditable"), p.innerHTML = "修改后", d.appendChild(p), e.querySelector("table tbody").appendChild(a); var g = o; for (var u in g) "object" === lc(g[u]) ? (i(u, g[u], n[u], r[u]), delete r[u]) : "string" == typeof g[u] && t(u, g[u], r[u], a); for (var f in r) "object" === lc(g[f]) ? i(f, g[f], n[f], r[f]) : "string" == typeof g[f] && t(f, g[f], r[f], a) })) } })) } } }(), showOldContrastDetailsWindow: function () { this.oldContrastDetailsWindow && this.oldContrastDetailsWindow.windowShow && this.oldContrastDetailsWindow.windowShow() }, showNewContrastDetailsWindow: function () { this.newContrastDetailsWindow && this.newContrastDetailsWindow.windowShow && this.newContrastDetailsWindow.windowShow() }, hideOldContrastDetailsWindow: function () { this.oldContrastDetailsWindow && this.oldContrastDetailsWindow.windowHide && this.oldContrastDetailsWindow.windowHide() }, hideNewContrastDetailsWindow: function () { this.newContrastDetailsWindow && this.newContrastDetailsWindow.windowHide() && this.newContrastDetailsWindow.windowHide() }, showContrastDetailsWindow: function () { this.showOldContrastDetailsWindow(), this.showNewContrastDetailsWindow() }, hideContrastDetailsWindow: function () { this.hideOldContrastDetailsWindow(), this.hideNewContrastDetailsWindow() }, showOldCompareWindow: function () { this.oldCompareWindow && this.oldCompareWindow.windowShow && this.oldCompareWindow.windowShow() }, showNewCompareWindow: function () { this.newCompareWindow && this.newCompareWindow.windowShow && this.newCompareWindow.windowShow() }, hideOldCompareWindow: function () { this.oldCompareWindow && this.oldCompareWindow.windowHide && this.oldCompareWindow.windowHide() }, hideNewCompareWindow: function () { this.newCompareWindow && this.newCompareWindow.windowHide() && this.newCompareWindow.windowHide() }, showCompareWindow: function () { this.showOldCompareWindow(), this.showNewCompareWindow() }, hideCompareWindow: function () { this.hideOldCompareWindow(), this.hideNewCompareWindow() } }), $y.prototype.addView = function (A, e, t) { var i = this; this.compareKey = A, this.projectKey = e, this.accessToken = t || "", _d({ type: "GET", url: this.host + "/api/" + e + "/compares/status?compareKey=" + A, headers: { Authorization: this.accessToken }, success: i._loadSuccess.bind(i), error: function (e, t) { switch (e) { case 401: i.dispatchEvent({ type: _y.ACCOUNT_NO_EXIST, compareKey: A, data: t }); break; case 403: i.dispatchEvent({ type: _y.NO_PERMISSION, compareKey: A, data: t }); break; default: i.dispatchEvent({ type: _y.ON_NETWORK_ERROR, compareKey: A, data: e }) } } }), i._loadCompares() }, $y.prototype._loadCompares = function () { var A = this; _d({ type: "GET", url: this.host + "/api/" + this.projectKey + "/compares?compareKey=" + this.compareKey, headers: { Authorization: this.accessToken }, success: A._loadComparesSuccess.bind(A), error: function (e, t) { switch (e) { case 401: A.dispatchEvent({ type: _y.ACCOUNT_NO_EXIST, compareKey: A.compareKey, data: t }); break; case 403: A.dispatchEvent({ type: _y.NO_PERMISSION, compareKey: A.compareKey, data: t }); break; default: A.dispatchEvent({ type: _y.ON_NETWORK_ERROR, compareKey: A.compareKey, data: e }) } } }) }, $y.prototype._loadComparesSuccess = function (A) { var e = {}; if ("string" == typeof A) try { e = JSON.parse(A) } catch (A) { return void this.dispatchEvent({ type: _y.ON_LOAD_INVALID_COMPARES, compareKey: this.compareKey }) } else e = A; if (e && "SUCCESS" === e.code) { this.compareData = e.data, this.compareDataLoaded = !0; for (var t = [], i = [], o = [], n = [], r = null, a = 0, s = this.compareData.changed.categories.length; s > a; a += 1) for (var l = 0, c = this.compareData.changed.categories[a].elements.length; c > l; l += 1) t.push((r = this.compareData.changed.categories[a].elements[l]).oldComponentKey), i.push(r.newComponentKey); for (var h = 0, d = this.compareData.added.categories.length; d > h; h += 1) for (var p = 0, g = this.compareData.added.categories[h].elements.length; g > p; p += 1) o.push((r = this.compareData.added.categories[h].elements[p]).componentKey); for (var u = 0, f = this.compareData.deleted.categories.length; f > u; u += 1) for (var m = 0, C = this.compareData.deleted.categories[u].elements.length; C > m; m += 1) n.push((r = this.compareData.deleted.categories[u].elements[m]).componentKey); this.oldChangedList = t, this.newChangedList = i, this.deletedList = n, this.addedList = o, this._initCompareResultPlane(e.data), this._applyCompareData() } else Bh.log(this.compareKey, "config load error! ", e.message), this.dispatchEvent({ type: _y.ON_LOAD_ERROR, compareKey: this.compareKey, code: e.code, message: e.message }) }, $y.prototype._loadSuccess = function (A) { var e = {}; if ("string" == typeof A) try { e = JSON.parse(A) } catch (A) { return void this.dispatchEvent({ type: _y.ON_LOAD_INVALID_STATE, compareKey: this.compareKey }) } else e = A; if (e && "SUCCESS" === e.code) if ("1" !== e.data.status) ; else switch (this.oldModelKey = e.data.old, this.newModelKey = e.data.new, this.name = e.data.name, this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: this.firstViewer.addView(this.oldModelKey, this.projectKey, this.accessToken), this.firstViewer.addView(this.newModelKey, this.projectKey, this.accessToken); break; case zy.MULTIWINDOW: this.firstViewer.addView(this.oldModelKey, this.projectKey, this.accessToken), this.secondViewer.addView(this.newModelKey, this.projectKey, this.accessToken); break; default: this.firstViewer.addView(this.oldModelKey, this.projectKey, this.accessToken), this.firstViewer.addView(this.newModelKey, this.projectKey, this.accessToken) } else Bh.log(this.compareKey, "config load error! ", e.message), this.dispatchEvent({ type: _y.ON_LOAD_ERROR, compareKey: this.compareKey, code: e.code, message: e.message }) }, $y.prototype._applyCompareData = function () { if (this.oldModelLoaded && this.newModelLoaded && this.compareDataLoaded) { var A = this.firstViewer.getViewerImpl().getModel(this.oldModelKey), e = null, t = null; if (A) { var i = A.getComponentlist(); e = this.firstViewer.getBoxByComponentsKey(i); for (var o = 0, n = this.deletedList.length; n > o; o += 1) i.remove(this.deletedList[o]); for (var r = 0, a = this.oldChangedList.length; a > r; r += 1) i.remove(this.oldChangedList[r]); this.oldNoChangedList = i } var s = this.secondViewer.getViewerImpl().getModel(this.newModelKey); if (s) { var l = s.getComponentlist(); t = this.firstViewer.getBoxByComponentsKey(l); for (var c = 0, h = this.addedList.length; h > c; c += 1) l.remove(this.addedList[c]); for (var d = 0, p = this.newChangedList.length; p > d; d += 1) l.remove(this.newChangedList[d]); this.newNoChangedList = l } if (this.displayModel === zy.SEPARATION && !e.isEmpty() && !t.isEmpty()) { var g = e.getSize(), u = t.getSize(), f = 1, m = 1, C = 0; f = u.x > g.x ? g.x : u.x, m = u.y > g.y ? g.y : u.y; var y = s.getModelMatrix(), v = this.firstViewer.viewerImpl.modelManager.scene.getBoundingBoxWorld(); f > m ? (y.elements[14] += C = 1.5 * m, v.min.y -= C / 2, v.max.y += C / 2) : (y.elements[13] += C = 1.5 * f, v.min.x -= C / 2, v.max.x += C / 2), s.setModelMatrix(y), this.firstViewer.viewerImpl.modelManager.scene.setBoundingBoxWorld(v), this.firstViewer.adaptiveSize() } this.coloringImmediately && (this.firstViewer.colorfulComponentsByKey(this.deletedList, Xy.deletedColor.color, Xy.deletedColor.opacity), this.secondViewer.colorfulComponentsByKey(this.addedList, Xy.addedColor.color, Xy.addedColor.opacity), this.firstViewer.colorfulComponentsByKey(this.oldChangedList, Xy.changedColor.color, Xy.changedColor.opacity), this.secondViewer.colorfulComponentsByKey(this.newChangedList, Xy.changedColor.color, Xy.changedColor.opacity)) } }, $y.prototype._getDataByType = function (A) { var e = [], t = []; switch (A) { case Zy.added: t = this.addedList; break; case Zy.deleted: e = this.deletedList; break; case Zy.changed: e = this.oldChangedList, t = this.newChangedList; break; case Zy.noChanged: e = this.oldNoChangedList, t = this.newNoChangedList; break; case Zy.oldChanged: e = this.oldChangedList; break; case Zy.newChanged: t = this.newChangedList; break; case Zy.oldNoChanged: e = this.oldNoChangedList; break; case Zy.newNoChanged: t = this.newNoChangedList } return { oldList: e, newList: t } }, $y.prototype._addProperty = function (A, e, t) { var i = this, o = document.createElement("tr"); o.classList.add("compares_list_tr"); var n = document.createElement("td"); n.innerText = A || "", o.appendChild(n); var r = document.createElement("td"); if (r.innerText = e || "", o.appendChild(r), void 0 !== t) { var a = document.createElement("td"), s = document.createElement("a"); s.classList.add("showDetails"), t ? (s.innerHTML = "查看详情", s.addEventListener("click", (function (A) { A.stopPropagation(); for (var e = A.target.parentNode.parentNode.oldKey, t = A.target.parentNode.parentNode.newKey, o = 0, n = A.path.length; n > o; o += 1) { if ("tab-compare-old" === A.path[o].id) { i.showOldContrastDetails(e); break } if ("tab-compare-new" === A.path[o].id) { i.showNewContrastDetails(t); break } } }))) : s.innerHTML = "无", a.appendChild(s), o.appendChild(a) } return o }, $y.prototype._initCompareResultPlane = function (A) { if (this.oldModelLoaded && this.newModelLoaded && this.compareDataLoaded) switch (this.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: var e = document.getElementById("tab-compare-old"); if (!e) return; this._createPanel(e, A); break; case zy.MULTIWINDOW: var t = document.getElementById("tab-compare-old"); if (!t) return; this._createInversionPanel(t, A); var i = document.getElementById("tab-compare-new"); if (!i) return; this._createPanel(i, A) } }, $y.prototype._createPanel = function (A, e) { var t = this; if (A) { var i = document.createElement("div"); i.classList.add("compares_list_body"), A.appendChild(i); var o = document.createElement("div"); o.classList.add("compares_list_title"), o.innerText = "新增构件列表(" + t.addedList.length + ")", o.addEventListener("click", (function (A) { for (var e = A.target.parentNode.querySelectorAll("tr"), i = [], o = 0, n = e.length; n > o; o += 1) e[o].newKey && i.push(e[o].newKey); t.secondViewer.adaptiveSizeByKey(i), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(i), t.secondViewer.colorfulComponentsByKey(i, Xy.addedColor.color, Xy.addedColor.opacity) })), i.appendChild(o); var n = document.createElement("table"); n.classList.add("sx-table"), n.classList.add("compares_list_table"), n.classList.add("table-no-top"), i.appendChild(n); var r = document.createElement("thead"); n.appendChild(r); var a = document.createElement("tbody"); n.appendChild(a); var s = document.createElement("tr"); s.style.backgroundColor = "rgba(0, 128, 0, 0.8)", s.className = "noprop"; var l = document.createElement("th"); s.appendChild(l); var c = document.createElement("span"); c.classList.add("value"), c.classList.add("nonEditable"), c.innerHTML = "名称", l.appendChild(c); var h = document.createElement("th"); s.appendChild(h); var d = document.createElement("span"); d.classList.add("value"), d.classList.add("nonEditable"), d.innerHTML = "类型", h.appendChild(d), r.appendChild(s); for (var p = 0, g = t.addedList.length; g > p; p += 1) { var u = t.secondViewer.getComponentsByKey(t.addedList[p]); if (u && u[0] && u[0][t.addedList[p]] && u[0][t.addedList[p]][0]) { var f = t._addProperty(u[0][t.addedList[p]][0].name, u[0][t.addedList[p]][0].type); f.oldKey = "", f.newKey = t.addedList[p], f.addEventListener("click", (function (A) { var e = A.target.parentNode.newKey; e && (t.secondViewer.adaptiveSizeByKey(e), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(e), t.secondViewer.colorfulComponentsByKey(e, Xy.addedColor.color, Xy.addedColor.opacity)) })), a.appendChild(f) } } var m = t.oldChangedList, C = t.newChangedList, y = document.createElement("div"); y.classList.add("compares_list_body"), A.appendChild(y); var v = document.createElement("div"); v.classList.add("compares_list_title"), v.innerText = "变更构件列表(" + m.length + ")", v.addEventListener("click", (function (A) { for (var e = A.target.parentNode.querySelectorAll("tr"), i = [], o = [], n = 0, r = e.length; r > n; n += 1) e[n].oldKey && o.push(e[n].oldKey), e[n].newKey && i.push(e[n].newKey); switch (t.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: t.secondViewer.adaptiveSizeByKey(i.concat(o)), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(i.concat(o)), t.secondViewer.colorfulComponentsByKey(i.concat(o), Xy.changedColor.color, Xy.changedColor.opacity); break; case zy.MULTIWINDOW: t.firstViewer.adaptiveSizeByKey(o), t.firstViewer.clearColorfulList(), t.firstViewer.clearTransparentList(), t.firstViewer.transparentOtherComponentsByKey(o), t.firstViewer.colorfulComponentsByKey(o, Xy.changedColor.color, Xy.changedColor.opacity), t.secondViewer.adaptiveSizeByKey(i), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(i), t.secondViewer.colorfulComponentsByKey(i, Xy.changedColor.color, Xy.changedColor.opacity) } })), y.appendChild(v); var I = document.createElement("table"); I.classList.add("sx-table"), I.classList.add("compares_list_table"), I.classList.add("table-no-top"), y.appendChild(I); var E = document.createElement("thead"); I.appendChild(E); var B = document.createElement("tbody"); I.appendChild(B); var x = document.createElement("tr"); x.style.backgroundColor = "rgba(255, 165, 0, 0.8)", x.className = "noprop"; var S = document.createElement("th"); x.appendChild(S); var w = document.createElement("span"); w.classList.add("value"), w.classList.add("nonEditable"), w.innerHTML = "名称", S.appendChild(w); var M = document.createElement("th"); x.appendChild(M); var b = document.createElement("span"); b.classList.add("value"), b.classList.add("nonEditable"), b.innerHTML = "类型", M.appendChild(b); var U = document.createElement("th"); x.appendChild(U); var F = document.createElement("span"); F.classList.add("value"), F.classList.add("nonEditable"), F.innerHTML = "操作", U.appendChild(F), E.appendChild(x); for (var K = 0, Q = C.length; Q > K; K += 1) { var R = t.secondViewer.getComponentsByKey(C[K]); if (R && R[0] && R[0][C[K]] && R[0][C[K]][0]) { var T = t._addProperty(R[0][C[K]][0].name, R[0][C[K]][0].type, "geometry" !== C[K].type); T.oldKey = m[K], T.newKey = C[K], T.addEventListener("click", (function (A) { var e = A.target.parentNode.oldKey, i = A.target.parentNode.newKey; if (e && i) switch (t.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: t.secondViewer.adaptiveSizeByKey([e, i]), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey([e, i]), t.secondViewer.colorfulComponentsByKey([e, i], Xy.changedColor.color, Xy.changedColor.opacity); break; case zy.MULTIWINDOW: t.firstViewer.adaptiveSizeByKey(e), t.firstViewer.clearColorfulList(), t.firstViewer.clearTransparentList(), t.firstViewer.transparentOtherComponentsByKey(e), t.firstViewer.colorfulComponentsByKey(e, Xy.changedColor.color, Xy.changedColor.opacity), t.secondViewer.adaptiveSizeByKey(i), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(i), t.secondViewer.colorfulComponentsByKey(i, Xy.changedColor.color, Xy.changedColor.opacity) } })), B.appendChild(T) } } var k = document.createElement("div"); k.classList.add("compares_list_body"), A.appendChild(k); var D = document.createElement("div"); D.classList.add("compares_list_title"), D.innerText = "移除构件列表(" + t.deletedList.length + ")", D.addEventListener("click", (function (A) { for (var e = A.target.parentNode.querySelectorAll("tr"), i = [], o = 0, n = e.length; n > o; o += 1) e[o].oldKey && i.push(e[o].oldKey); t.secondViewer.adaptiveSizeByKey(i), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(i), t.secondViewer.colorfulComponentsByKey(i, Xy.deletedColor.color, Xy.deletedColor.opacity) })), k.appendChild(D); var L = document.createElement("table"); L.classList.add("sx-table"), L.classList.add("compares_list_table"), L.classList.add("table-no-top"), k.appendChild(L); var N = document.createElement("thead"); L.appendChild(N); var O = document.createElement("tbody"); L.appendChild(O); var V = document.createElement("tr"); V.style.backgroundColor = "rgba(255, 0, 0, 0.8)", V.className = "noprop"; var G = document.createElement("th"); V.appendChild(G); var P = document.createElement("span"); P.classList.add("value"), P.classList.add("nonEditable"), P.innerHTML = "名称", G.appendChild(P); var q = document.createElement("th"); V.appendChild(q); var j = document.createElement("span"); j.classList.add("value"), j.classList.add("nonEditable"), j.innerHTML = "类型", q.appendChild(j), N.appendChild(V); for (var H = 0, Y = t.deletedList.length; Y > H; H += 1) { var W = t.firstViewer.getComponentsByKey(t.deletedList[H]); if (W && W[0] && W[0][t.deletedList[H]] && W[0][t.deletedList[H]][0]) { var J = t._addProperty(W[0][t.deletedList[H]][0].name, W[0][t.deletedList[H]][0].type); J.oldKey = t.deletedList[H], J.newKey = "", J.addEventListener("click", (function (A) { var e = A.target.parentNode.oldKey; e && (t.firstViewer.adaptiveSizeByKey(e), t.firstViewer.clearColorfulList(), t.firstViewer.clearTransparentList(), t.firstViewer.transparentOtherComponentsByKey(e), t.firstViewer.colorfulComponentsByKey(e, Xy.deletedColor.color, Xy.deletedColor.opacity)) })), O.appendChild(J) } } } }, $y.prototype._createInversionPanel = function (A, e) { var t = this; if (A) { var i = t.deletedList, o = t.addedList, n = document.createElement("div"); n.classList.add("compares_list_body"), A.appendChild(n); var r = document.createElement("div"); r.classList.add("compares_list_title"), r.innerText = "新增构件列表(" + i.length + ")", r.addEventListener("click", (function (A) { for (var e = A.target.parentNode.querySelectorAll("tr"), i = [], o = 0, n = e.length; n > o; o += 1) e[o].newKey && i.push(e[o].newKey); t.firstViewer.adaptiveSizeByKey(i), t.firstViewer.clearColorfulList(), t.firstViewer.clearTransparentList(), t.firstViewer.transparentOtherComponentsByKey(i), t.firstViewer.colorfulComponentsByKey(i, Xy.addedColor.color, Xy.addedColor.opacity) })), n.appendChild(r); var a = document.createElement("table"); a.classList.add("sx-table"), a.classList.add("compares_list_table"), a.classList.add("table-no-top"), n.appendChild(a); var s = document.createElement("thead"); a.appendChild(s); var l = document.createElement("tbody"); a.appendChild(l); var c = document.createElement("tr"); c.style.backgroundColor = "rgba(0, 128, 0, 0.8)", c.className = "noprop"; var h = document.createElement("th"); c.appendChild(h); var d = document.createElement("span"); d.classList.add("value"), d.classList.add("nonEditable"), d.innerHTML = "名称", h.appendChild(d); var p = document.createElement("th"); c.appendChild(p); var g = document.createElement("span"); g.classList.add("value"), g.classList.add("nonEditable"), g.innerHTML = "类型", p.appendChild(g), s.appendChild(c); for (var u = 0, f = i.length; f > u; u += 1) { var m = t.firstViewer.getComponentsByKey(i[u]); if (m && m[0] && m[0][i[u]] && m[0][i[u]][0]) { var C = t._addProperty(m[0][i[u]][0].name, m[0][i[u]][0].type); C.oldKey = "", C.newKey = i[u], C.addEventListener("click", (function (A) { var e = A.target.parentNode.newKey; e && (t.firstViewer.adaptiveSizeByKey(e), t.firstViewer.clearColorfulList(), t.firstViewer.clearTransparentList(), t.firstViewer.transparentOtherComponentsByKey(e), t.firstViewer.colorfulComponentsByKey(e, Xy.addedColor.color, Xy.addedColor.opacity)) })), l.appendChild(C) } } var y = t.oldChangedList, v = t.newChangedList, I = document.createElement("div"); I.classList.add("compares_list_body"), A.appendChild(I); var E = document.createElement("div"); E.classList.add("compares_list_title"), E.innerText = "变更构件列表(" + y.length + ")", E.addEventListener("click", (function (A) { for (var e = A.target.parentNode.querySelectorAll("tr"), i = [], o = [], n = 0, r = e.length; r > n; n += 1) e[n].oldKey && o.push(e[n].oldKey), e[n].newKey && i.push(e[n].newKey); switch (t.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: t.secondViewer.adaptiveSizeByKey(i.concat(o)), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(i.concat(o)), t.secondViewer.colorfulComponentsByKey(i.concat(o), Xy.changedColor.color, Xy.changedColor.opacity); break; case zy.MULTIWINDOW: t.firstViewer.adaptiveSizeByKey(o), t.firstViewer.clearColorfulList(), t.firstViewer.clearTransparentList(), t.firstViewer.transparentOtherComponentsByKey(o), t.firstViewer.colorfulComponentsByKey(o, Xy.changedColor.color, Xy.changedColor.opacity), t.secondViewer.adaptiveSizeByKey(i), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(i), t.secondViewer.colorfulComponentsByKey(i, Xy.changedColor.color, Xy.changedColor.opacity) } })), I.appendChild(E); var B = document.createElement("table"); B.classList.add("sx-table"), B.classList.add("compares_list_table"), B.classList.add("table-no-top"), I.appendChild(B); var x = document.createElement("thead"); B.appendChild(x); var S = document.createElement("tbody"); B.appendChild(S); var w = document.createElement("tr"); w.style.backgroundColor = "rgba(255, 165, 0, 0.8)", w.className = "noprop"; var M = document.createElement("th"); w.appendChild(M); var b = document.createElement("span"); b.classList.add("value"), b.classList.add("nonEditable"), b.innerHTML = "名称", M.appendChild(b); var U = document.createElement("th"); w.appendChild(U); var F = document.createElement("span"); F.classList.add("value"), F.classList.add("nonEditable"), F.innerHTML = "类型", U.appendChild(F); var K = document.createElement("th"); w.appendChild(K); var Q = document.createElement("span"); Q.classList.add("value"), Q.classList.add("nonEditable"), Q.innerHTML = "操作", K.appendChild(Q), x.appendChild(w); for (var R = 0, T = v.length; T > R; R += 1) { var k = t.secondViewer.getComponentsByKey(v[R]); if (k && k[0] && k[0][v[R]] && k[0][v[R]][0]) { var D = t._addProperty(k[0][v[R]][0].name, k[0][v[R]][0].type, "geometry" !== v[R].type); D.oldKey = y[R], D.newKey = v[R], D.addEventListener("click", (function (A) { var e = A.target.parentNode.oldKey, i = A.target.parentNode.newKey; if (e && i) switch (t.displayModel) { case zy.AGGREGATION: case zy.SEPARATION: t.secondViewer.adaptiveSizeByKey([e, i]), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey([e, i]), t.secondViewer.colorfulComponentsByKey([e, i], Xy.changedColor.color, Xy.changedColor.opacity); break; case zy.MULTIWINDOW: t.firstViewer.adaptiveSizeByKey(e), t.firstViewer.clearColorfulList(), t.firstViewer.clearTransparentList(), t.firstViewer.transparentOtherComponentsByKey(e), t.firstViewer.colorfulComponentsByKey(e, Xy.changedColor.color, Xy.changedColor.opacity), t.secondViewer.adaptiveSizeByKey(i), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(i), t.secondViewer.colorfulComponentsByKey(i, Xy.changedColor.color, Xy.changedColor.opacity) } })), S.appendChild(D) } } var L = document.createElement("div"); L.classList.add("compares_list_body"), A.appendChild(L); var N = document.createElement("div"); N.classList.add("compares_list_title"), N.innerText = "移除构件列表(" + o.length + ")", N.addEventListener("click", (function (A) { for (var e = A.target.parentNode.querySelectorAll("tr"), i = [], o = 0, n = e.length; n > o; o += 1) e[o].oldKey && i.push(e[o].oldKey); t.secondViewer.adaptiveSizeByKey(i), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(i), t.secondViewer.colorfulComponentsByKey(i, Xy.deletedColor.color, Xy.deletedColor.opacity) })), L.appendChild(N); var O = document.createElement("table"); O.classList.add("sx-table"), O.classList.add("compares_list_table"), O.classList.add("table-no-top"), L.appendChild(O); var V = document.createElement("thead"); O.appendChild(V); var G = document.createElement("tbody"); O.appendChild(G); var P = document.createElement("tr"); P.style.backgroundColor = "rgba(255, 0, 0, 0.8)", P.className = "noprop"; var q = document.createElement("th"); P.appendChild(q); var j = document.createElement("span"); j.classList.add("value"), j.classList.add("nonEditable"), j.innerHTML = "名称", q.appendChild(j); var H = document.createElement("th"); P.appendChild(H); var Y = document.createElement("span"); Y.classList.add("value"), Y.classList.add("nonEditable"), Y.innerHTML = "类型", H.appendChild(Y), V.appendChild(P); for (var W = 0, J = o.length; J > W; W += 1) { var z = t.secondViewer.getComponentsByKey(o[W]); if (z && z[0] && z[0][o[W]] && z[0][o[W]][0]) { var Z = t._addProperty(z[0][o[W]][0].name, z[0][o[W]][0].type); Z.oldKey = o[W], Z.newKey = "", Z.addEventListener("click", (function (A) { var e = A.target.parentNode.oldKey; e && (t.secondViewer.adaptiveSizeByKey(e), t.secondViewer.clearColorfulList(), t.secondViewer.clearTransparentList(), t.secondViewer.transparentOtherComponentsByKey(e), t.secondViewer.colorfulComponentsByKey(e, Xy.deletedColor.color, Xy.deletedColor.opacity)) })), G.appendChild(Z) } } } }; var Av = "ON_VIEWER3D_CAMERA_CHANGE", ev = function (A, e) { this.viewer2D = e, this.viewer3D = A, this.enableFocus(), this.show3DCameraOn2DViewer() }; ev.prototype.enableFocus = function () { var A = this.viewer2D, e = this.viewer3D; e && A && (A.setOnSelectComponentCallback((function (A) { A && A.length > 0 ? (e.highlightComponentsByKey(A), e.adaptiveSizeByKey(A)) : e.clearHighlightList() })), e.registerModelEventListener(Rc.ON_CLICK_PICK, (function (e) { e.intersectInfo && e.intersectInfo.selectedObjectId && A.focusOnComponentByKey(e.intersectInfo.selectedObjectId, !0) }))) }, ev.prototype.enableMove2DCamera = function () { this.viewer2D.getViewerImpl().controlManager.enableTool(this.viewer2D.getViewerImpl(), "viewer3DCameraControl") }, ev.prototype.disableMove2DCamera = function () { this.viewer2D.getViewerImpl().controlManager.disableTool("viewer3DCameraControl") }, ev.prototype.show3DCameraOn2DViewer = function () { var A = this.viewer2D, e = this.viewer3D; if (e && A) { var t = e.getViewerImpl(); e.registerCameraEventListener(Rc.ON_CAMERA_CHANGE, (function (e) { var t = e.camera, i = t.getWorldPosition(new y), o = t.getWorldDirection(new y); A.show3DCamera([i.x, i.y], [o.x, o.y]) })), A.getViewerImpl().cameraControl.addEventListener(Av, (function (A) { var e = A.position; t.locateToPoint({ x: e[0], y: e[1], z: t.camera.position.z }) })) } }; var tv = function A(e, t) { Ue.call(this, e), this.type = "Reflector"; var i = this, o = new LA(void 0 !== (t = t || {}).color ? t.color : 16777215), n = t.textureWidth || 512, r = t.textureHeight || 512, s = t.clipBias || 0, l = t.shader || A.ReflectorShader, c = void 0 !== t.recursion ? t.recursion : 0, h = new EA, d = new y, u = new y, f = new y, m = new M, C = new y(0, 0, -1), v = new p, I = new y, E = new y, B = new p, x = new M, S = new je, w = new g(n, r, { minFilter: 1006, magFilter: 1006, format: 1022, stencilBuffer: !1 }); a.isPowerOfTwo(n) && a.isPowerOfTwo(r) || (w.texture.generateMipmaps = !1); var b = new Pe({ uniforms: Ge.clone(l.uniforms), fragmentShader: l.fragmentShader, vertexShader: l.vertexShader }); b.uniforms.tDiffuse.value = w.texture, b.uniforms.color.value = o, b.uniforms.textureMatrix.value = x, this.material = b, this.onBeforeRender = function (A, e, t) { if ("recursion" in t.userData) { if (t.userData.recursion === c) return; t.userData.recursion += 1 } if (u.setFromMatrixPosition(i.matrixWorld), f.setFromMatrixPosition(t.matrixWorld), m.extractRotation(i.matrixWorld), d.set(0, 0, 1), d.applyMatrix4(m), I.subVectors(u, f), 0 >= I.dot(d)) { I.reflect(d).negate(), I.add(u), m.extractRotation(t.matrixWorld), C.set(0, 0, -1), C.applyMatrix4(m), C.add(f), E.subVectors(u, C), E.reflect(d).negate(), E.add(u), S.position.copy(I), S.up.set(0, 1, 0), S.up.applyMatrix4(m), S.up.reflect(d), S.lookAt(E), S.far = t.far, S.updateMatrixWorld(), S.matrixWorldInverse.getInverse(S.matrixWorld), S.projectionMatrix.copy(t.projectionMatrix), S.userData.recursion = 0, x.set(.5, 0, 0, .5, 0, .5, 0, .5, 0, 0, .5, .5, 0, 0, 0, 1), x.multiply(S.projectionMatrix), x.multiply(S.matrixWorldInverse), x.multiply(i.matrixWorld), h.setFromNormalAndCoplanarPoint(d, u), h.applyMatrix4(S.matrixWorldInverse), v.set(h.normal.x, h.normal.y, h.normal.z, h.constant); var o = S.projectionMatrix; B.x = (Math.sign(v.x) + o.elements[8]) / o.elements[0], B.y = (Math.sign(v.y) + o.elements[9]) / o.elements[5], B.z = -1, B.w = (1 + o.elements[10]) / o.elements[14], v.multiplyScalar(2 / v.dot(B)), o.elements[2] = v.x, o.elements[6] = v.y, o.elements[10] = v.z + 1 - s, o.elements[14] = v.w, w.texture.encoding = A.outputEncoding, i.visible = !1; var n = A.getRenderTarget(), r = A.xr.enabled, a = A.shadowMap.autoUpdate; A.xr.enabled = !1, A.shadowMap.autoUpdate = !1, A.setRenderTarget(w), A.state.buffers.depth.setMask(!0), !1 === A.autoClear && A.clear(), A.render(e, S), A.xr.enabled = r, A.shadowMap.autoUpdate = a, A.setRenderTarget(n); var l = t.viewport; void 0 !== l && A.state.viewport(l), i.visible = !0 } }, this.getRenderTarget = function () { return w } }; (tv.prototype = Object.create(Ue.prototype)).constructor = tv, tv.ReflectorShader = { uniforms: { color: { value: null }, tDiffuse: { value: null }, textureMatrix: { value: null } }, vertexShader: ["uniform mat4 textureMatrix;", "varying vec4 vUv;", "void main() {", " vUv = textureMatrix * vec4( position, 1.0 );", " gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );", "}"].join("\n"), fragmentShader: ["uniform vec3 color;", "uniform sampler2D tDiffuse;", "varying vec4 vUv;", "float blendOverlay( float base, float blend ) {", " return( base < 0.5 ? ( 2.0 * base * blend ) : ( 1.0 - 2.0 * ( 1.0 - base ) * ( 1.0 - blend ) ) );", "}", "vec3 blendOverlay( vec3 base, vec3 blend ) {", " return vec3( blendOverlay( base.r, blend.r ), blendOverlay( base.g, blend.g ), blendOverlay( base.b, blend.b ) );", "}", "void main() {", " vec4 base = texture2DProj( tDiffuse, vUv );", " gl_FragColor = vec4( blendOverlay( base.rgb, color ), 1.0 );", "}"].join("\n") }; var iv = function A(e, t) { Ue.call(this, e), this.type = "Refractor"; var i = this, o = new LA(void 0 !== (t = t || {}).color ? t.color : 8355711), n = t.textureWidth || 512, r = t.textureHeight || 512, s = t.clipBias || 0, l = t.shader || A.RefractorShader, c = new je; c.matrixAutoUpdate = !1, c.userData.refractor = !0; var h = new EA, d = new M, u = new g(n, r, { minFilter: 1006, magFilter: 1006, format: 1022, stencilBuffer: !1 }); a.isPowerOfTwo(n) && a.isPowerOfTwo(r) || (u.texture.generateMipmaps = !1), this.material = new Pe({ uniforms: Ge.clone(l.uniforms), vertexShader: l.vertexShader, fragmentShader: l.fragmentShader, transparent: !0 }), this.material.uniforms.color.value = o, this.material.uniforms.tDiffuse.value = u.texture, this.material.uniforms.textureMatrix.value = d; var m, C, v, I = function () { var A = new y, e = new y, t = new M, o = new y, n = new y; return function (r) { return A.setFromMatrixPosition(i.matrixWorld), e.setFromMatrixPosition(r.matrixWorld), o.subVectors(A, e), t.extractRotation(i.matrixWorld), n.set(0, 0, 1), n.applyMatrix4(t), 0 > o.dot(n) } }(), E = function () { var A = new y, e = new y, t = new f, o = new y; return function () { i.matrixWorld.decompose(e, t, o), A.set(0, 0, 1).applyQuaternion(t).normalize(), A.negate(), h.setFromNormalAndCoplanarPoint(A, e) } }(), B = (m = new EA, C = new p, v = new p, function (A) { c.matrixWorld.copy(A.matrixWorld), c.matrixWorldInverse.getInverse(c.matrixWorld), c.projectionMatrix.copy(A.projectionMatrix), c.far = A.far, m.copy(h), m.applyMatrix4(c.matrixWorldInverse), C.set(m.normal.x, m.normal.y, m.normal.z, m.constant); var e = c.projectionMatrix; v.x = (Math.sign(C.x) + e.elements[8]) / e.elements[0], v.y = (Math.sign(C.y) + e.elements[9]) / e.elements[5], v.z = -1, v.w = (1 + e.elements[10]) / e.elements[14], C.multiplyScalar(2 / C.dot(v)), e.elements[2] = C.x, e.elements[6] = C.y, e.elements[10] = C.z + 1 - s, e.elements[14] = C.w } ); this.onBeforeRender = function (A, e, t) { u.texture.encoding = A.outputEncoding, !0 !== t.userData.refractor && !0 != !I(t) && (E(), function (A) { d.set(.5, 0, 0, .5, 0, .5, 0, .5, 0, 0, .5, .5, 0, 0, 0, 1), d.multiply(A.projectionMatrix), d.multiply(A.matrixWorldInverse), d.multiply(i.matrixWorld) }(t), B(t), function (A, e, t) { i.visible = !1; var o = A.getRenderTarget(), n = A.xr.enabled, r = A.shadowMap.autoUpdate; A.xr.enabled = !1, A.shadowMap.autoUpdate = !1, A.setRenderTarget(u), !1 === A.autoClear && A.clear(), A.render(e, c), A.xr.enabled = n, A.shadowMap.autoUpdate = r, A.setRenderTarget(o); var a = t.viewport; void 0 !== a && A.state.viewport(a), i.visible = !0 }(A, e, t)) }, this.getRenderTarget = function () { return u } }; (iv.prototype = Object.create(Ue.prototype)).constructor = iv, iv.RefractorShader = { uniforms: { color: { value: null }, tDiffuse: { value: null }, textureMatrix: { value: null } }, vertexShader: ["uniform mat4 textureMatrix;", "varying vec4 vUv;", "void main() {", " vUv = textureMatrix * vec4( position, 1.0 );", " gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );", "}"].join("\n"), fragmentShader: ["uniform vec3 color;", "uniform sampler2D tDiffuse;", "varying vec4 vUv;", "float blendOverlay( float base, float blend ) {", " return( base < 0.5 ? ( 2.0 * base * blend ) : ( 1.0 - 2.0 * ( 1.0 - base ) * ( 1.0 - blend ) ) );", "}", "vec3 blendOverlay( vec3 base, vec3 blend ) {", " return vec3( blendOverlay( base.r, blend.r ), blendOverlay( base.g, blend.g ), blendOverlay( base.b, blend.b ) );", "}", "void main() {", " vec4 base = texture2DProj( tDiffuse, vUv );", " gl_FragColor = vec4( blendOverlay( base.rgb, color ), 1.0 );", "}"].join("\n") }; var ov = function (A) { return he.call(this), this.points = A, this.handlePoints = [], this.minX = 0, this.minY = 0, this.maxX = 0, this.maxY = 0, this.invalid = !1, this._createPlaneGeometry(), this }; (ov.prototype = Object.create(he.prototype)).constructor = he, ov.prototype._createPlaneGeometry = function () { if (this._RemoveDuplicatePoints(this.points)) this.invalid = !0; else { if (3 > this.handlePoints.length) return Bh.warn("Failed to create plane, the number of the points must be more than three."), void(this.invalid = !0); if (3 === this.handlePoints.length && 0 === this._area(this.handlePoints[0], this.handlePoints[1], this.handlePoints[2])) return Bh.warn("Failed to create plane, points are collinear."), void(this.invalid = !0); if (this._checkIntersect()) return Bh.warn("Failed to create plane, the plane border is self-intersecting."), void(this.invalid = !0); this.handlePoints.push(new s(this.points[0].x, this.points[0].y)); var A = new ar(new Ba(this.handlePoints)), e = new Float32Array(this._updateUv(A)); A.setAttribute("uv", new YA(e, 2)), this.attributes = A.attributes, this.groups = A.groups, this.index = A.index } }, ov.prototype._updateUv = function (A) { for (var e = [], t = A.attributes.position.array, i = 0; t.length > i; i += 3) { var o = (t[i + 1] - this.minY) / (this.maxY - this.minY); e.push((t[i] - this.minX) / (this.maxX - this.minX)), e.push(o) } return e }, ov.prototype._RemoveDuplicatePoints = function (A) { var e = new s(A[0].x, A[0].y); this.handlePoints.push(e), this.minX = e.x, this.maxX = e.x, this.minY = e.y, this.maxY = e.y; for (var t = 1; A.length > t; t += 1) { var i = !1; if (void 0 === A[t].x || void 0 === A[t].y) return Bh.log("Failed to create plane, the format of plane is not right, please follow [{x:,y:},...]"), !0; for (var o = 0; this.handlePoints.length > o; o += 1) if (A[t].x === this.handlePoints[o].x && A[t].y === this.handlePoints[o].y) { i = !0; break } if (!1 === i) { e = new s(A[t].x, A[t].y); this.handlePoints.push(e), this.minX > e.x && (this.minX = e.x), this.minY > e.y && (this.minY = e.y), e.x > this.maxX && (this.maxX = e.x), e.y > this.maxY && (this.maxY = e.y) } } return !1 }, ov.prototype._checkIntersect = function () { for (var A = null, e = null, t = this.handlePoints.length, i = 0; t > i; i += 1) { A = this.handlePoints[i], e = this.handlePoints[i === t - 1 ? 0 : i + 1]; for (var o = i + 2; t > o; o += 1) if ((0 !== i || o !== t - 1) && this._intersectSegments(A, e, this.handlePoints[o], this.handlePoints[o === t - 1 ? 0 : o + 1])) return !0 } return !1 }, ov.prototype._area = function (A, e, t) { return (e.x - A.x) * (t.y - A.y) - (t.x - A.x) * (e.y - A.y) }, ov.prototype._collinearIntersectCheck = function (A, e, t, i) { return (Math.min(A.x, e.x) > t.x || t.x > Math.max(A.x, e.x) || Math.min(A.y, e.y) > t.y || t.y > Math.max(A.y, e.y)) && (Math.min(A.x, e.x) > i.x || i.x > Math.max(A.x, e.x) || Math.min(A.y, e.y) > i.y || i.y > Math.max(A.y, e.y)) }, ov.prototype._intersectSegments = function (A, e, t, i) { var o = this._area(A, e, t) * this._area(A, e, i), n = this._area(t, i, A) * this._area(t, i, e); return 0 >= o && (0 >= n && (0 !== o || 0 !== n || !this._collinearIntersectCheck(A, e, t, i))) }; var nv = "", rv = "", av = function A(e, t) { Ue.call(this, e), this.type = "Water"; var i = this, o = t || {}, n = void 0 !== o.color ? o.color : new p(1, 1, 1, 1), r = o.textureWidth || 512, a = o.textureHeight || 512, l = o.clipBias || 0, c = o.flowDirection || new s(1, 0), h = o.flowSpeed || .03, d = o.reflectivity || 1, g = o.scale || 1, u = o.shader || A.WaterShader; this.reflectorTexturePosition = o.reflectorTexturePosition, this.refractorTexturePosition = o.refractorTexturePosition; var f = new Aa, m = o.flowMap || void 0, C = o.normalMap0 || f.load(nv), y = o.normalMap1 || f.load(rv), v = new M, I = new as; if (void 0 !== tv) if (void 0 !== iv) { var E = new tv(e, { textureWidth: r, textureHeight: a, clipBias: l }); E.position.copy(this.reflectorTexturePosition), E.updateMatrixWorld(!0); var B = new iv(e, { textureWidth: r, textureHeight: a, clipBias: l }); B.position.copy(this.refractorTexturePosition), B.updateMatrixWorld(!0), this.material = new Pe({ uniforms: Ge.merge([u.uniforms]), vertexShader: u.vertexShader, fragmentShader: u.fragmentShader, transparent: !0 }), this.material.clipping = !0, this.material.side = 2, void 0 !== m ? (this.material.defines.USE_FLOWMAP = "", this.material.uniforms.tFlowMap = { type: "t", value: m }) : this.material.uniforms.flowDirection = { type: "v2", value: c }, C.wrapS = 1e3, C.wrapT = 1e3, y.wrapS = 1e3, y.wrapT = 1e3, this.material.uniforms.tReflectionMap.value = E.getRenderTarget().texture, this.material.uniforms.tRefractionMap.value = B.getRenderTarget().texture, this.material.uniforms.tNormalMap0.value = C, this.material.uniforms.tNormalMap1.value = y, this.material.uniforms.color.value = n, this.material.uniforms.reflectivity.value = d, this.material.uniforms.textureMatrix.value = v, this.material.uniforms.config.value.x = 0, this.material.uniforms.config.value.y = .075, this.material.uniforms.config.value.z = .075, this.material.uniforms.config.value.w = g, this.onBeforeRender = function (A, e, t) { var o, n; ! function (A) { v.set(.5, 0, 0, .5, 0, .5, 0, .5, 0, 0, .5, .5, 0, 0, 0, 1), v.multiply(A.projectionMatrix), v.multiply(A.matrixWorldInverse), v.multiply(i.matrixWorld) }(t), o = I.getDelta(), (n = i.material.uniforms.config).value.x += h * o, n.value.y = n.value.x + .075, .15 > n.value.x ? .15 > n.value.y || (n.value.y = n.value.y - .15) : (n.value.x = 0, n.value.y = .075), i.visible = !1, E.position.equals(this.reflectorTexturePosition) || (E.position.copy(this.reflectorTexturePosition), E.updateMatrixWorld(!0)), B.position.equals(this.refractorTexturePosition) || (B.position.copy(this.refractorTexturePosition), B.updateMatrixWorld(!0)), i.cameraProjectionMatrix || (i.cameraProjectionMatrix = t.projectionMatrix.clone()), t.projectionMatrix.equals(i.cameraProjectionMatrix) || (i.needUpdate = !0), i.waterMatrixWorld || (i.waterMatrixWorld = i.matrixWorld.clone()), i.matrixWorld.equals(i.waterMatrixWorld) || (i.needUpdate = !0), i.needUpdate && (E.onBeforeRender(A, e, t), B.onBeforeRender(A, e, t), i.needUpdate = !1), i.material.uniforms.tReflectionMap.value = E.getRenderTarget().texture, i.material.uniforms.tRefractionMap.value = B.getRenderTarget().texture, i.visible = !0 } } else Bh.error("THREE.Water: Required component THREE.Refractor not found."); else Bh.error("THREE.Water: Required component THREE.Reflector not found.") }; (av.prototype = Object.create(Ue.prototype)).constructor = av, av.WaterShader = { uniforms: { color: { type: "v4", value: null }, reflectivity: { type: "f", value: 0 }, tReflectionMap: { type: "t", value: null }, tRefractionMap: { type: "t", value: null }, tNormalMap0: { type: "t", value: null }, tNormalMap1: { type: "t", value: null }, textureMatrix: { type: "m4", value: null }, config: { type: "v4", value: new p } }, vertexShader: ["#include ", "uniform mat4 textureMatrix;", "varying vec4 vCoord;", "varying vec2 vUv;", "varying vec3 vToEye;", "#include ", "void main() {", " vUv = uv;", " vCoord = textureMatrix * vec4( position, 1.0 );", " vec4 worldPosition = modelMatrix * vec4( position, 1.0 );", " vToEye = cameraPosition - worldPosition.xyz;", " vec4 mvPosition = viewMatrix * worldPosition;", " gl_Position = projectionMatrix * mvPosition;", " #include ", " #include ", "}"].join("\n"), fragmentShader: ["#include ", "#include ", "uniform sampler2D tReflectionMap;", "uniform sampler2D tRefractionMap;", "uniform sampler2D tNormalMap0;", "uniform sampler2D tNormalMap1;", "#ifdef USE_FLOWMAP", " uniform sampler2D tFlowMap;", "#else", " uniform vec2 flowDirection;", "#endif", "uniform vec4 color;", "uniform float reflectivity;", "uniform vec4 config;", "#include ", "varying vec4 vCoord;", "varying vec2 vUv;", "varying vec3 vToEye;", "void main() {", " #include ", " float flowMapOffset0 = config.x;", " float flowMapOffset1 = config.y;", " float halfCycle = config.z;", " float scale = config.w;", " vec3 toEye = normalize( vToEye );", " vec2 flow;", " #ifdef USE_FLOWMAP", " flow = texture2D( tFlowMap, vUv ).rg * 2.0 - 1.0;", " #else", " flow = flowDirection;", " #endif", " flow.x *= - 1.0;", " vec4 normalColor0 = texture2D( tNormalMap0, ( vUv * scale ) + flow * flowMapOffset0 );", " vec4 normalColor1 = texture2D( tNormalMap1, ( vUv * scale ) + flow * flowMapOffset1 );", " float flowLerp = abs( halfCycle - flowMapOffset0 ) / halfCycle;", " vec4 normalColor = mix( normalColor0, normalColor1, flowLerp );", " vec3 normal = normalize( vec3( normalColor.r * 2.0 - 1.0, normalColor.b, normalColor.g * 2.0 - 1.0 ) );", " float theta = max( dot( toEye, normal ), 0.0 );", " float reflectance = reflectivity + ( 1.0 - reflectivity ) * pow( ( 1.0 - theta ), 5.0 );", " vec3 coord = vCoord.xyz / vCoord.w;", " vec2 uv = coord.xy + coord.z * normal.xz * 0.05;", " vec4 reflectColor = texture2D( tReflectionMap, vec2( 1.0 - uv.x, uv.y ) );", " vec4 refractColor = texture2D( tRefractionMap, uv );", " gl_FragColor = color * mix( refractColor, reflectColor, reflectance );", " #include ", " #include ", " #include ", "}"].join("\n") }; var sv = function (A) { A ? (this.boundary = A.boundary, this.color = A.color, this.viewer = A.viewer, this.scale = A.scale, this.xDirection = A.xDirection, this.yDirection = A.yDirection, this.reflectivity = A.reflectivity, A.reflectorTexturePosition ? "number" == typeof A.reflectorTexturePosition.x ? "number" == typeof A.reflectorTexturePosition.y ? "number" == typeof A.reflectorTexturePosition.z ? (this.reflectorTexturePosition = (new y).copy(A.reflectorTexturePosition), A.refractorTexturePosition ? "number" == typeof A.refractorTexturePosition.x ? "number" == typeof A.refractorTexturePosition.y ? "number" == typeof A.refractorTexturePosition.z ? (this.refractorTexturePosition = (new y).copy(A.refractorTexturePosition), this.viewer && this.viewer instanceof Gy ? (A.geometry || 0 !== this.boundary.length) && (this.geometry = A.geometry || new ov(this.boundary), this.water = new av(this.geometry, { color: new p(this.color.r, this.color.g, this.color.b, this.color.a), scale: this.scale, reflectivity: this.reflectivity, flowDirection: new s(this.xDirection, this.yDirection), textureWidth: 1024, textureHeight: 1024, reflectorTexturePosition: this.reflectorTexturePosition, refractorTexturePosition: this.refractorTexturePosition }), this.height = A.height, this.water.translateZ(this.height), this.water.renderOrder = -1, this.water.disPickable = !0, this.id = uh.createUUID(), this.water.name = this.id, this.water.autoAnimation = !0, this.viewer.addExternalObject(this.id, this.water)) : Bh.log("ERROR::viewer must not support.")) : Bh.error("缺少参数 reflectorTexturePosition.z") : Bh.error("缺少参数 reflectorTexturePosition.y") : Bh.error("缺少参数 reflectorTexturePosition.x") : Bh.error("缺少参数 reflectorTexturePosition")) : Bh.error("缺少参数 reflectorTexturePosition.z") : Bh.error("缺少参数 reflectorTexturePosition.y") : Bh.error("缺少参数 reflectorTexturePosition.x") : Bh.error("缺少参数 reflectorTexturePosition")) : Bh.error("ERROR::waterEffectConfig 不能为空.") }; sv.prototype.getBoundary = function () { return this.boundary }, sv.prototype.getColor = function () { return this.color }, sv.prototype.getScale = function () { return this.scale }, sv.prototype.getXDirection = function () { return this.xDirection }, sv.prototype.getYDirection = function () { return this.yDirection }, sv.prototype.setColor = function (A) { A instanceof Xh ? (this.color = A, this.water.material.uniforms.color.value.set(this.color.r, this.color.g, this.color.b, this.color.a)) : Bh.log("ERROR::color should be instance of EIMMODEL.Color") }, sv.prototype.setScale = function (A) { this.scale = A, this.water.material.uniforms.config.value.w = A }, sv.prototype.setReflectivity = function (A) { this.reflectivity = A, this.water.material.uniforms.reflectivity.value = A }, sv.prototype.getReflectivity = function () { return this.reflectivity }, sv.prototype.getReflectorTexturePosition = function () { return this.reflectorTexturePosition.clone() }, sv.prototype.getRefractorTexturePosition = function () { return this.refractorTexturePosition.clone() }, sv.prototype.setReflectorTexturePosition = function (A) { A ? "number" == typeof A.x ? "number" == typeof A.y ? "number" == typeof A.z ? (this.reflectorTexturePosition = new y(A.x, A.y, A.z), this.water.reflectorTexturePosition = this.reflectorTexturePosition) : Bh.error("缺少参数 position.z") : Bh.error("缺少参数 position.y") : Bh.error("缺少参数 position.x") : Bh.error("缺少参数 position") }, sv.prototype.setRefractorTexturePosition = function (A) { A ? "number" == typeof A.x ? "number" == typeof A.y ? "number" == typeof A.z ? (this.refractorTexturePosition = new y(A.x, A.y, A.z), this.water.refractorTexturePosition = this.refractorTexturePosition) : Bh.error("缺少参数 position.z") : Bh.error("缺少参数 position.y") : Bh.error("缺少参数 position.x") : Bh.error("缺少参数 position") }, sv.prototype.setXDirection = function (A) { this.xDirection = A, this.water.material.uniforms.flowDirection.value.x = A }, sv.prototype.setYDirection = function (A) { this.yDirection = A, this.water.material.uniforms.flowDirection.value.y = A }, sv.prototype.remove = function () { this.viewer.removeExternalObjectByName(this.id) }, sv.prototype.setHeight = function (A) { this.height = A, this.water.translateZ(A), this.water.updateMatrixWorld(!0) }, sv.prototype.getHeight = function () { return this.height }, sv.prototype.setGeometry = function (A) { A.isGeometry || A.isBufferGeometry ? (this.geometry = A, this.water.geometry = A) : Bh.log("ERROR::geometry type not support") }, sv.prototype.getGeometry = function () { return this.geometry }, sv.prototype.getWaterObject = function () { return this.water }; var lv = Symbol("_flowing"), cv = function () { function A(e) { cc(this, A), this.viewer = e.viewer3D; var t = e.opt; this.arrowParameters = t, this.arrowParameters.speed = this.arrowParameters.speed || 5, this.arrowParameters.spacing = this.arrowParameters.spacing || 100, this.arrowArray = [], this.pathNumb = 0, this.totalLength = 0, this.path = [], !0 === t.customizeMesh ? this.geometricModelLength = t.meshLength : t.arrowShape ? (t.arrowShape.rectangleLength = t.arrowShape.rectangleLength || 500, t.arrowShape.triangleBottomHeight = t.arrowShape.triangleBottomHeight || 260, this.geometricModelLength = t.arrowShape.rectangleLength + t.arrowShape.triangleBottomHeight ? t.arrowShape.triangleBottomHeight : 260) : this.geometricModelLength = 760, this.intervalLength = this.geometricModelLength + t.spacing, this.materialObject = {}, this.materialsInit = this.arrowParameters.materialsInit || "default", this.materialsUpdate = this.arrowParameters.materialsUpdate || "fixed", this.isFlowing = !1, t.callback && (t.callback.enter && (this.callbackEnter = t.callback.enter), t.callback.out && (this.callbackOut = t.callback.out)), this.meshGroupId = (new Date).getTime(), this.meshGroup ? this.meshGroup.children = [] : this.meshGroup = new Xi } return dc(A, [{ key: "calculationPathOffset", value: function () { for (var A = this.path, e = 0; A.length > e; e += 1) { var t = (new y).copy(A[e].startingPoint), i = new f, o = new f, n = new y(1, 1, 1); if (A[e].offset) { var r = (new y).copy(A[e].offset.pathDepthAxis).applyQuaternion(i); t.add(r.multiplyScalar(A[e].offset.depth)), o.setFromAxisAngle(A[e].startPoint2EndPointAxis, A[e].angle), i.premultiply(o), o.setFromAxisAngle(A[e].vectorNormalize, A[e].offset.angle), i.premultiply(o) } else o.setFromAxisAngle(A[e].startPoint2EndPointAxis, A[e].angle), i.premultiply(o); A[e].rotationComponent = {}, A[e].rotationComponent.position = t, A[e].rotationComponent.quaternion = i, A[e].rotationComponent.scale = n } } }, { key: "translationPath", value: function () { var A = new y(1, 0, 0), e = this.arrowParameters.points, t = e.length - 1, i = []; this.totalLength = 0; for (var o = 0; t > o; o += 1) { var n = {}; if (n.startingPoint = new y(e[o].x, e[o].y, e[o].z), n.endingPoint = new y(e[o + 1].x, e[o + 1].y, e[o + 1].z), n.length = n.startingPoint.distanceTo(n.endingPoint), n.vector = (new y).subVectors(n.endingPoint, n.startingPoint), n.vectorNormalize = (new y).subVectors(n.endingPoint, n.startingPoint).normalize(), n.startPoint2EndPointAxis = (new y).crossVectors(A, n.vectorNormalize).normalize(), n.numb = o, n.angle = A.angleTo(n.vectorNormalize), this.arrowParameters.offset && this.arrowParameters.offset[o + 1]) { var r = {}, a = this.arrowParameters.offset[o + 1], s = a.depth, l = a.angle, c = void 0 === l ? 0 : l; r.depth = void 0 === s ? 0 : s, r.angle = Math.PI / 180 * c, r.pathDepthAxis = new y(0, 1, 0).applyAxisAngle(n.startPoint2EndPointAxis, n.angle), r.pathDepthAxis.applyAxisAngle(n.vectorNormalize, r.angle).normalize(), n.offset = r } this.totalLength += n.length, i.push(n) } this.path = i, this.pathNumb = this.path.length } }, { key: "calculationArrowAmount", value: function () { var A = this.arrowParameters, e = 0; if (A.createMode && "number" === A.createMode && A.arrowAmount && A.arrowAmount > 0) if (A.intervalMode && "strict" === A.intervalMode) { if (e = Math.floor(this.totalLength / this.intervalLength), A.arrowAmount > e) return { code: "001", message: "Too many arrows,over the length of the path" }; this.arrowAmount = A.arrowAmount, this.CreateMode = "number", this.IntervalMode = "strict" } else { if (e = Math.floor(this.totalLength / this.geometricModelLength), A.arrowAmount > e) return { code: "001", message: "Too many arrows,over the length of the path" }; this.arrowAmount = A.arrowAmount, this.CreateMode = "number"; var t = Math.floor(100 * (this.totalLength - this.intervalLength * A.arrowAmount) / A.arrowAmount) / 100; this.intervalLength += t, this.IntervalMode = "free" } else { if (A.createMode && "number" === A.createMode && A.arrowAmount && 1 > A.arrowAmount) return { code: "002", message: "the number is error" }; if (e = Math.floor(this.totalLength / this.intervalLength), A.intervalMode && "strict" === A.intervalMode) this.IntervalMode = "strict"; else { var i = Math.floor(100 * (this.totalLength % this.intervalLength) / e) / 100; this.intervalLength += i, this.IntervalMode = "free" } this.arrowAmount = e, this.CreateMode = "space" } } }, { key: "createArrowArray", value: function () { var A = this.arrowAmount; if (!0 === this.arrowParameters.customizeMesh) for (var e = 0; A > e; e += 1) { var t = this.arrowParameters.mesh.clone(); t.material = this.materialObject.default, this.arrowArray.push(t), this.meshGroup.add(t) } else for (var i = this.arrowParameters.arrowShape, o = void 0 === i ? {} : i, n = o.triangleBottomLength || 400, r = o.triangleBottomHeight || 260, a = o.rectangleWidth || 180, s = o.rectangleLength || 500, l = o.arrowHeight || 80, c = new Float32Array([r + s, l, 0, s, l, n / 2, s, l, -n / 2, r + s, 0, 0, s, 0, n / 2, s, 0, -n / 2, s, l, -a / 2, s, l, a / 2, 0, l, a / 2, 0, l, -a / 2, s, 0, -a / 2, s, 0, a / 2, 0, 0, a / 2, 0, 0, -a / 2]), h = [2, 1, 0, 3, 4, 5, 0, 1, 4, 0, 4, 3, 1, 2, 4, 4, 2, 5, 5, 2, 0, 3, 5, 0, 8, 7, 6, 9, 8, 6, 13, 9, 6, 10, 13, 6, 12, 8, 9, 9, 13, 12, 12, 13, 10, 12, 10, 11, 7, 8, 12, 11, 7, 12], d = 0; A > d; d += 1) { var p = this.createArrowMesh(c, h); p.arrowID = d, this.arrowArray.push(p), this.meshGroup.add(p) } } }, { key: "createArrowMesh", value: function (A, e) { var t = new he; t.setIndex(e); var i = new YA(A, 3); return t.attributes.position = i, new Ue(t, this.materialObject.default) } }, { key: "createMaterialArray", value: function () { for (var A = this.arrowParameters.colors, e = this.arrowParameters.materials, t = this.path.length, i = 1; t >= i; i += 1) e && e[i] ? this.materialObject[i] = e[i] : A && A[i] && (this.materialObject[i] = new jA({ color: A[i] })); e && e.default ? this.materialObject.default = e.default : A && A.default ? this.materialObject.default = new jA({ color: A.default }) : (this.materialObject.default = new jA({ color: 10606038 }), this.materialObject.default.transparent = !0, this.materialObject.default.opacity = .8) } }, { key: "initPostition", value: function () { var A = this.arrowArray, e = this.path, t = A.length, i = 0, o = this.intervalLength, n = 0, r = new f; if (this.arrowParameters.enterSceMod && "progressive" === this.arrowParameters.enterSceMod) for (var a = 0; t > a; a += 1) { var s = A[a]; s.quaternion.copy(r), s.position.x = e[i].startingPoint.x, s.position.y = e[i].startingPoint.y, s.position.z = e[i].startingPoint.z, s.pathOrder = i, e[i].offset ? (s.translateOnAxis(e[i].vectorNormalize, -o * n), s.translateOnAxis(e[i].offset.pathDepthAxis, e[i].offset.depth), s.rotateOnWorldAxis(e[i].startPoint2EndPointAxis, e[i].angle), s.rotateOnWorldAxis(e[i].vectorNormalize, e[i].offset.angle)) : (s.translateOnAxis(e[i].vectorNormalize, -o * n), s.rotateOnWorldAxis(e[i].startPoint2EndPointAxis, e[i].angle)), s.visible = !1, s.userData.BosArrowExt = {}, s.userData.BosArrowExt.enterState = "unenter", "path" === this.materialsInit && this.materialObject[i + 1] && (s.material = this.materialObject[i + 1]), s.updateMatrixWorld(), n += 1 } else for (var l = 0, c = 0; t > c; c += 1) { var h = A[c]; h.quaternion.copy(r); var d = e[i]; d.offset ? (h.position.x = d.startingPoint.x, h.position.y = d.startingPoint.y, h.position.z = d.startingPoint.z, h.translateOnAxis(d.vectorNormalize, o * n + l), h.translateOnAxis(d.offset.pathDepthAxis, d.offset.depth), h.rotateOnWorldAxis(d.startPoint2EndPointAxis, d.angle), h.rotateOnWorldAxis(d.vectorNormalize, d.offset.angle)) : (h.position.x = d.startingPoint.x, h.position.y = d.startingPoint.y, h.position.z = d.startingPoint.z, h.translateOnAxis(d.vectorNormalize, o * n + l), h.rotateOnWorldAxis(d.startPoint2EndPointAxis, d.angle)), h.pathOrder = i, "path" === this.materialsInit && this.materialObject[i + 1] && (h.material = this.materialObject[i + 1]), d.length - l > o * (n + 1) || (l = o * (n + 1) - d.length + l, i += 1, n = -1), h.updateMatrixWorld(), n += 1 } this.viewer.removeExternalObjectByName(this.meshGroupId), this.viewer.addExternalObject(this.meshGroupId, this.meshGroup) } }, { key: "setSpeed", value: function (A) { this.isFlowing ? (this.stopFlow(), this.arrowParameters.speed = A, this.startFlow()) : this.arrowParameters.speed = A } }, { key: "init", value: function () { this.translationPath(), this.calculationPathOffset(), this.calculationArrowAmount(), this.createMaterialArray(), this.createArrowArray(), this.initPostition() } }, { key: "updatePosition", value: function () { var A = this, e = this.path, t = this.arrowParameters.speed; this.arrowArray.forEach((function (i) { if (!i.lockPosUpDate || !0 !== i.lockPosUpDate) { var o = 0; if (i.userData.BosArrowExt && i.userData.BosArrowExt.enterState && "unenter" === i.userData.BosArrowExt.enterState) { var n = i.position.distanceTo(e[0].endingPoint); return e[0].length > n && ("fixed" !== A.materialsUpdate && A.materialObject[0] ? i.material = A.materialObject[0] : "fixed" === A.materialsUpdate || A.materialObject[0] || (i.material = A.materialObject.default), A.callbackEnter && "function" == typeof A.callbackEnter && A.callbackEnter(i, e[0]), i.visible = !0, i.userData.BosArrowExt.enterState = "enter", "fixed" !== A.materialsUpdate && A.materialObject[1] ? i.material = A.materialObject[1] : "fixed" === A.materialsUpdate || A.materialObject[1] || (i.material = A.materialObject.default)), i.translateX(t + o), void i.updateMatrixWorld() } var r = i.position.distanceTo(e[i.pathOrder].startingPoint); r > e[i.pathOrder].length - A.geometricModelLength && !1 !== i.visible && (i.visible = !1, A.callbackOut && "function" == typeof A.callbackOut && A.callbackOut(i, e[i.pathOrder])), !1 === i.visible && (i.pathOrder + 1 === A.pathNumb ? e[i.pathOrder].length > r || (o = r - e[i.pathOrder].length, i.pathOrder = 0, i.position.copy(e[i.pathOrder].rotationComponent.position), i.scale.copy(e[i.pathOrder].rotationComponent.scale), i.setRotationFromQuaternion(e[i.pathOrder].rotationComponent.quaternion), "fixed" !== A.materialsUpdate && A.materialObject[1] ? i.material = A.materialObject[1] : "fixed" === A.materialsUpdate || A.materialObject[1] || (i.material = A.materialObject.default), A.callbackEnter && "function" == typeof A.callbackEnter && A.callbackEnter(i, e[i.pathOrder]), i.visible = !0) : e[i.pathOrder].length > r || (o = r - e[i.pathOrder].length, i.pathOrder += 1, i.position.copy(e[i.pathOrder].rotationComponent.position), i.scale.copy(e[i.pathOrder].rotationComponent.scale), i.setRotationFromQuaternion(e[i.pathOrder].rotationComponent.quaternion), "fixed" !== A.materialsUpdate && A.materialObject[i.pathOrder + 1] ? i.material = A.materialObject[i.pathOrder + 1] : "fixed" === A.materialsUpdate || A.materialObject[i.pathOrder + 1] || (i.material = A.materialObject.default), i.visible = !0, A.callbackEnter && "function" == typeof A.callbackEnter && A.callbackEnter(i, e[i.pathOrder]))), i.translateX(t + o), i.updateMatrixWorld() } })), this.viewer.render() } }, { key: lv, value: function () { this.requestAnimationFrameID = requestAnimationFrame(this[lv].bind(this)), this.updatePosition() } }, { key: "startFlow", value: function () { if (this.isFlowing) return { code: "003", message: "Do not open repeatedly" }; this.isFlowing = !0, this.requestAnimationFrameID = requestAnimationFrame(this[lv].bind(this)) } }, { key: "stopFlow", value: function () { cancelAnimationFrame(this.requestAnimationFrameID), this.isFlowing = !1 } }, { key: "hide", value: function () { this.viewer.removeExternalObjectByName(this.meshGroupId) } }, { key: "show", value: function () { this.hide(), this.viewer.addExternalObject(this.meshGroupId, this.meshGroup) } }, { key: "clear", value: function () { this.hide(), this.meshGroup.children = [], this.arrowArray = [] } }]), A }(); function hv(A, e) { return A === e || A != A && e != e } function dv(A, e) { for (var t = A.length; t--;) if (hv(A[t][0], e)) return t; return -1 } var pv = Array.prototype.splice; function gv(A) { var e = -1, t = null == A ? 0 : A.length; for (this.clear(); ++e < t;) { var i = A[e]; this.set(i[0], i[1]) } } gv.prototype.clear = function () { this.__data__ = [], this.size = 0 }, gv.prototype.delete = function (A) { var e = this.__data__, t = dv(e, A); return t >= 0 && (t == e.length - 1 ? e.pop() : pv.call(e, t, 1), --this.size, !0) }, gv.prototype.get = function (A) { var e = this.__data__, t = dv(e, A); return 0 > t ? void 0 : e[t][1] }, gv.prototype.has = function (A) { return dv(this.__data__, A) > -1 }, gv.prototype.set = function (A, e) { var t = this.__data__, i = dv(t, A); return 0 > i ? (++this.size, t.push([A, e])) : t[i][1] = e, this }; var uv = "object" == typeof global && global && global.Object === Object && global, fv = "object" == typeof self && self && self.Object === Object && self, mv = uv || fv || Function("return this")(), Cv = mv.Symbol, yv = Object.prototype, vv = yv.hasOwnProperty, Iv = yv.toString, Ev = Cv ? Cv.toStringTag : void 0; var Bv = Object.prototype.toString; var xv = Cv ? Cv.toStringTag : void 0; function Sv(A) { return null == A ? void 0 === A ? "[object Undefined]" : "[object Null]" : xv && xv in Object(A) ? function (A) { var e = vv.call(A, Ev), t = A[Ev]; try { A[Ev] = void 0; var i = !0 } catch (A) {} var o = Iv.call(A); return i && (e ? A[Ev] = t : delete A[Ev]), o }(A) : function (A) { return Bv.call(A) }(A) } function wv(A) { var e = typeof A; return null != A && ("object" == e || "function" == e) } function Mv(A) { if (!wv(A)) return !1; var e = Sv(A); return "[object Function]" == e || "[object GeneratorFunction]" == e || "[object AsyncFunction]" == e || "[object Proxy]" == e } var bv, Uv = mv["__core-js_shared__"], Fv = (bv = /[^.]+$/.exec(Uv && Uv.keys && Uv.keys.IE_PROTO || "")) ? "Symbol(src)_1." + bv : ""; var Kv = Function.prototype.toString; function Qv(A) { if (null != A) { try { return Kv.call(A) } catch (A) {} try { return A + "" } catch (A) {} } return "" } var Rv = /^\[object .+?Constructor\]$/, Tv = RegExp("^" + Function.prototype.toString.call(Object.prototype.hasOwnProperty).replace(/[\\^$.*+?()[\]{}|]/g, "\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, "$1.*?") + "$"); function kv(A) { return !(!wv(A) || (e = A, Fv && Fv in e)) && (Mv(A) ? Tv : Rv).test(Qv(A)); var e } function Dv(A, e) { var t = function (A, e) { return null == A ? void 0 : A[e] }(A, e); return kv(t) ? t : void 0 } var Lv = Dv(mv, "Map"), Nv = Dv(Object, "create"); var Ov = Object.prototype.hasOwnProperty; var Vv = Object.prototype.hasOwnProperty; function Gv(A) { var e = -1, t = null == A ? 0 : A.length; for (this.clear(); ++e < t;) { var i = A[e]; this.set(i[0], i[1]) } } function Pv(A, e) { var t, i, o = A.__data__; return ("string" == (i = typeof (t = e)) || "number" == i || "symbol" == i || "boolean" == i ? "__proto__" !== t : null === t) ? o["string" == typeof e ? "string" : "hash"] : o.map } function qv(A) { var e = -1, t = null == A ? 0 : A.length; for (this.clear(); ++e < t;) { var i = A[e]; this.set(i[0], i[1]) } } Gv.prototype.clear = function () { this.__data__ = Nv ? Nv(null) : {}, this.size = 0 }, Gv.prototype.delete = function (A) { var e = this.has(A) && delete this.__data__[A]; return this.size -= e ? 1 : 0, e }, Gv.prototype.get = function (A) { var e = this.__data__; if (Nv) { var t = e[A]; return "__lodash_hash_undefined__" === t ? void 0 : t } return Ov.call(e, A) ? e[A] : void 0 }, Gv.prototype.has = function (A) { var e = this.__data__; return Nv ? void 0 !== e[A] : Vv.call(e, A) }, Gv.prototype.set = function (A, e) { var t = this.__data__; return this.size += this.has(A) ? 0 : 1, t[A] = Nv && void 0 === e ? "__lodash_hash_undefined__" : e, this }, qv.prototype.clear = function () { this.size = 0, this.__data__ = { hash: new Gv, map: new(Lv || gv), string: new Gv } }, qv.prototype.delete = function (A) { var e = Pv(this, A).delete(A); return this.size -= e ? 1 : 0, e }, qv.prototype.get = function (A) { return Pv(this, A).get(A) }, qv.prototype.has = function (A) { return Pv(this, A).has(A) }, qv.prototype.set = function (A, e) { var t = Pv(this, A), i = t.size; return t.set(A, e), this.size += t.size == i ? 0 : 1, this }; function jv(A) { var e = this.__data__ = new gv(A); this.size = e.size } jv.prototype.clear = function () { this.__data__ = new gv, this.size = 0 }, jv.prototype.delete = function (A) { var e = this.__data__, t = e.delete(A); return this.size = e.size, t }, jv.prototype.get = function (A) { return this.__data__.get(A) }, jv.prototype.has = function (A) { return this.__data__.has(A) }, jv.prototype.set = function (A, e) { var t = this.__data__; if (t instanceof gv) { var i = t.__data__; if (!Lv || 199 > i.length) return i.push([A, e]), this.size = ++t.size, this; t = this.__data__ = new qv(i) } return t.set(A, e), this.size = t.size, this }; var Hv = function () { try { var A = Dv(Object, "defineProperty"); return A({}, "", {}), A } catch (A) {} }(); function Yv(A, e, t) { "__proto__" == e && Hv ? Hv(A, e, { configurable: !0, enumerable: !0, value: t, writable: !0 }) : A[e] = t } var Wv = Object.prototype.hasOwnProperty; function Jv(A, e, t) { var i = A[e]; Wv.call(A, e) && hv(i, t) && (void 0 !== t || e in A) || Yv(A, e, t) } function zv(A, e, t, i) { var o = !t; t || (t = {}); for (var n = -1, r = e.length; ++n < r;) { var a = e[n], s = i ? i(t[a], A[a], a, t, A) : void 0; void 0 === s && (s = A[a]), o ? Yv(t, a, s) : Jv(t, a, s) } return t } function Zv(A) { return null != A && "object" == typeof A } function Xv(A) { return Zv(A) && "[object Arguments]" == Sv(A) } var _v = Object.prototype, $v = _v.hasOwnProperty, AI = _v.propertyIsEnumerable, eI = Xv(function () { return arguments }()) ? Xv : function (A) { return Zv(A) && $v.call(A, "callee") && !AI.call(A, "callee") }, tI = Array.isArray; var iI = "object" == typeof A && A && !A.nodeType && A, oI = iI && "object" == typeof module && module && !module.nodeType && module, nI = oI && oI.exports === iI ? mv.Buffer : void 0, rI = (nI ? nI.isBuffer : void 0) || function () { return !1 }, aI = /^(?:0|[1-9]\d*)$/; function sI(A, e) { var t = typeof A; return !!(e = null == e ? 9007199254740991 : e) && ("number" == t || "symbol" != t && aI.test(A)) && A > -1 && A % 1 == 0 && e > A } function lI(A) { return "number" == typeof A && A > -1 && A % 1 == 0 && 9007199254740991 >= A } var cI = {}; function hI(A) { return function (e) { return A(e) } } cI["[object Float32Array]"] = cI["[object Float64Array]"] = cI["[object Int8Array]"] = cI["[object Int16Array]"] = cI["[object Int32Array]"] = cI["[object Uint8Array]"] = cI["[object Uint8ClampedArray]"] = cI["[object Uint16Array]"] = cI["[object Uint32Array]"] = !0, cI["[object Arguments]"] = cI["[object Array]"] = cI["[object ArrayBuffer]"] = cI["[object Boolean]"] = cI["[object DataView]"] = cI["[object Date]"] = cI["[object Error]"] = cI["[object Function]"] = cI["[object Map]"] = cI["[object Number]"] = cI["[object Object]"] = cI["[object RegExp]"] = cI["[object Set]"] = cI["[object String]"] = cI["[object WeakMap]"] = !1; var dI = "object" == typeof A && A && !A.nodeType && A, pI = dI && "object" == typeof module && module && !module.nodeType && module, gI = pI && pI.exports === dI && uv.process, uI = function () { try { var A = pI && pI.require && pI.require("util").types; return A || gI && gI.binding && gI.binding("util") } catch (A) {} }(), fI = uI && uI.isTypedArray, mI = fI ? hI(fI) : function (A) { return Zv(A) && lI(A.length) && !!cI[Sv(A)] }, CI = Object.prototype.hasOwnProperty; function yI(A, e) { var t = tI(A), i = !t && eI(A), o = !t && !i && rI(A), n = !t && !i && !o && mI(A), r = t || i || o || n, a = r ? function (A, e) { for (var t = -1, i = Array(A); ++t < A;) i[t] = e(t); return i }(A.length, String) : [], s = a.length; for (var l in A) !e && !CI.call(A, l) || r && ("length" == l || o && ("offset" == l || "parent" == l) || n && ("buffer" == l || "byteLength" == l || "byteOffset" == l) || sI(l, s)) || a.push(l); return a } var vI = Object.prototype; function II(A) { var e = A && A.constructor; return A === ("function" == typeof e && e.prototype || vI) } function EI(A, e) { return function (t) { return A(e(t)) } } var BI = EI(Object.keys, Object), xI = Object.prototype.hasOwnProperty; function SI(A) { return null != A && lI(A.length) && !Mv(A) } function wI(A) { return SI(A) ? yI(A) : function (A) { if (!II(A)) return BI(A); var e = []; for (var t in Object(A)) xI.call(A, t) && "constructor" != t && e.push(t); return e }(A) } var MI = Object.prototype.hasOwnProperty; function bI(A) { if (!wv(A)) return function (A) { var e = []; if (null != A) for (var t in Object(A)) e.push(t); return e }(A); var e = II(A), t = []; for (var i in A) ("constructor" != i || !e && MI.call(A, i)) && t.push(i); return t } function UI(A) { return SI(A) ? yI(A, !0) : bI(A) } var FI = "object" == typeof A && A && !A.nodeType && A, KI = FI && "object" == typeof module && module && !module.nodeType && module, QI = KI && KI.exports === FI ? mv.Buffer : void 0, RI = QI ? QI.allocUnsafe : void 0; function TI() { return [] } var kI = Object.prototype.propertyIsEnumerable, DI = Object.getOwnPropertySymbols, LI = DI ? function (A) { return null == A ? [] : (A = Object(A), function (A, e) { for (var t = -1, i = null == A ? 0 : A.length, o = 0, n = []; ++t < i;) { var r = A[t]; e(r, t, A) && (n[o++] = r) } return n }(DI(A), (function (e) { return kI.call(A, e) }))) } : TI; function NI(A, e) { for (var t = -1, i = e.length, o = A.length; ++t < i;) A[o + t] = e[t]; return A } var OI = EI(Object.getPrototypeOf, Object), VI = Object.getOwnPropertySymbols ? function (A) { for (var e = []; A;) NI(e, LI(A)), A = OI(A); return e } : TI; function GI(A, e, t) { var i = e(A); return tI(A) ? i : NI(i, t(A)) } function PI(A) { return GI(A, wI, LI) } function qI(A) { return GI(A, UI, VI) } var jI = Dv(mv, "DataView"), HI = Dv(mv, "Promise"), YI = Dv(mv, "Set"), WI = Dv(mv, "WeakMap"), JI = Qv(jI), zI = Qv(Lv), ZI = Qv(HI), XI = Qv(YI), _I = Qv(WI), $I = Sv; (jI && "[object DataView]" != $I(new jI(new ArrayBuffer(1))) || Lv && "[object Map]" != $I(new Lv) || HI && "[object Promise]" != $I(HI.resolve()) || YI && "[object Set]" != $I(new YI) || WI && "[object WeakMap]" != $I(new WI)) && ($I = function (A) { var e = Sv(A), t = "[object Object]" == e ? A.constructor : void 0, i = t ? Qv(t) : ""; if (i) switch (i) { case JI: return "[object DataView]"; case zI: return "[object Map]"; case ZI: return "[object Promise]"; case XI: return "[object Set]"; case _I: return "[object WeakMap]" } return e }); var AE = $I, eE = Object.prototype.hasOwnProperty; var tE = mv.Uint8Array; function iE(A) { var e = new A.constructor(A.byteLength); return new tE(e).set(new tE(A)), e } var oE = /\w*$/; var nE = Cv ? Cv.prototype : void 0, rE = nE ? nE.valueOf : void 0; function aE(A, e, t) { var i, o = A.constructor; switch (e) { case "[object ArrayBuffer]": return iE(A); case "[object Boolean]": case "[object Date]": return new o(+A); case "[object DataView]": return function (A, e) { var t = e ? iE(A.buffer) : A.buffer; return new A.constructor(t, A.byteOffset, A.byteLength) }(A, t); case "[object Float32Array]": case "[object Float64Array]": case "[object Int8Array]": case "[object Int16Array]": case "[object Int32Array]": case "[object Uint8Array]": case "[object Uint8ClampedArray]": case "[object Uint16Array]": case "[object Uint32Array]": return function (A, e) { var t = e ? iE(A.buffer) : A.buffer; return new A.constructor(t, A.byteOffset, A.length) }(A, t); case "[object Map]": return new o; case "[object Number]": case "[object String]": return new o(A); case "[object RegExp]": return function (A) { var e = new A.constructor(A.source, oE.exec(A)); return e.lastIndex = A.lastIndex, e }(A); case "[object Set]": return new o; case "[object Symbol]": return i = A, rE ? Object(rE.call(i)) : {} } } var sE = Object.create, lE = function () { function A() {} return function (e) { if (!wv(e)) return {}; if (sE) return sE(e); A.prototype = e; var t = new A; return A.prototype = void 0, t } }(); var cE = uI && uI.isMap, hE = cE ? hI(cE) : function (A) { return Zv(A) && "[object Map]" == AE(A) }; var dE = uI && uI.isSet, pE = dE ? hI(dE) : function (A) { return Zv(A) && "[object Set]" == AE(A) }, gE = {}; function uE(A, e, t, i, o, n) { var r, a = 1 & e, s = 2 & e, l = 4 & e; if (t && (r = o ? t(A, i, o, n) : t(A)), void 0 !== r) return r; if (!wv(A)) return A; var c = tI(A); if (c) { if (r = function (A) { var e = A.length, t = new A.constructor(e); return e && "string" == typeof A[0] && eE.call(A, "index") && (t.index = A.index, t.input = A.input), t }(A), !a) return function (A, e) { var t = -1, i = A.length; for (e || (e = Array(i)); ++t < i;) e[t] = A[t]; return e }(A, r) } else { var h = AE(A), d = "[object Function]" == h || "[object GeneratorFunction]" == h; if (rI(A)) return function (A, e) { if (e) return A.slice(); var t = A.length, i = RI ? RI(t) : new A.constructor(t); return A.copy(i), i }(A, a); if ("[object Object]" == h || "[object Arguments]" == h || d && !o) { if (r = s || d ? {} : function (A) { return "function" != typeof A.constructor || II(A) ? {} : lE(OI(A)) }(A), !a) return s ? function (A, e) { return zv(A, VI(A), e) }(A, function (A, e) { return A && zv(e, UI(e), A) }(r, A)) : function (A, e) { return zv(A, LI(A), e) }(A, function (A, e) { return A && zv(e, wI(e), A) }(r, A)) } else { if (!gE[h]) return o ? A : {}; r = aE(A, h, a) } } n || (n = new jv); var p = n.get(A); if (p) return p; n.set(A, r), pE(A) ? A.forEach((function (i) { r.add(uE(i, e, t, i, A, n)) })) : hE(A) && A.forEach((function (i, o) { r.set(o, uE(i, e, t, o, A, n)) })); var g = l ? s ? qI : PI : s ? keysIn : wI, u = c ? void 0 : g(A); return function (A, e) { for (var t = -1, i = null == A ? 0 : A.length; ++t < i && !1 !== e(A[t], t, A);) ; }(u || A, (function (i, o) { u && (i = A[o = i]), Jv(r, o, uE(i, e, t, o, A, n)) })), r } gE["[object Arguments]"] = gE["[object Array]"] = gE["[object ArrayBuffer]"] = gE["[object DataView]"] = gE["[object Boolean]"] = gE["[object Date]"] = gE["[object Float32Array]"] = gE["[object Float64Array]"] = gE["[object Int8Array]"] = gE["[object Int16Array]"] = gE["[object Int32Array]"] = gE["[object Map]"] = gE["[object Number]"] = gE["[object Object]"] = gE["[object RegExp]"] = gE["[object Set]"] = gE["[object String]"] = gE["[object Symbol]"] = gE["[object Uint8Array]"] = gE["[object Uint8ClampedArray]"] = gE["[object Uint16Array]"] = gE["[object Uint32Array]"] = !0, gE["[object Error]"] = gE["[object Function]"] = gE["[object WeakMap]"] = !1; function fE(A) { return uE(A, 5) } var mE = function () { var A, e = { defaultRadius: 40, defaultRenderer: "canvas2d", defaultGradient: { .25: "rgb(0,0,255)", .55: "rgb(0,255,0)", .85: "yellow", 1: "rgb(255,0,0)" }, defaultMaxOpacity: 1, defaultMinOpacity: 0, defaultBlur: .85, defaultXField: "x", defaultYField: "y", defaultValueField: "value", plugins: {} }, t = function () { var A = function (A) { this._coordinator = {}, this._data = [], this._radi = [], this._min = 10, this._max = 1, this._xField = A.xField || A.defaultXField, this._yField = A.yField || A.defaultYField, this._valueField = A.valueField || A.defaultValueField, A.radius && (this._cfgRadius = A.radius) }, t = e.defaultRadius; return A.prototype = { _organiseData: function (A, e) { var i = A[this._xField], o = A[this._yField], n = this._radi, r = this._data, a = this._max, s = this._min, l = A[this._valueField] || 1, c = A.radius || this._cfgRadius || t; r[i] || (r[i] = [], n[i] = []), r[i][o] ? r[i][o] += l : (r[i][o] = l, n[i][o] = c); var h = r[i][o]; return h > a ? (e ? this.setDataMax(h) : this._max = h, !1) : s > h ? (e ? this.setDataMin(h) : this._min = h, !1) : { x: i, y: o, value: l, radius: c, min: s, max: a } }, _unOrganizeData: function () { var A = [], e = this._data, t = this._radi; for (var i in e) for (var o in e[i]) A.push({ x: i, y: o, radius: t[i][o], value: e[i][o] }); return { min: this._min, max: this._max, data: A } }, _onExtremaChange: function () { this._coordinator.emit("extremachange", { min: this._min, max: this._max }) }, addData: function () { if (arguments[0].length > 0) for (var A = arguments[0], e = A.length; e--;) this.addData.call(this, A[e]); else { var t = this._organiseData(arguments[0], !0); t && (0 === this._data.length && (this._min = this._max = t.value), this._coordinator.emit("renderpartial", { min: this._min, max: this._max, data: [t] })) } return this }, setData: function (A) { var e = A.data, t = e.length; this._data = [], this._radi = []; for (var i = 0; t > i; i++) this._organiseData(e[i], !1); return this._max = A.max, this._min = A.min || 0, this._onExtremaChange(), this._coordinator.emit("renderall", this._getInternalData()), this }, removeData: function () {}, setDataMax: function (A) { return this._max = A, this._onExtremaChange(), this._coordinator.emit("renderall", this._getInternalData()), this }, setDataMin: function (A) { return this._min = A, this._onExtremaChange(), this._coordinator.emit("renderall", this._getInternalData()), this }, setCoordinator: function (A) { this._coordinator = A }, _getInternalData: function () { return { max: this._max, min: this._min, data: this._data, radi: this._radi } }, getData: function () { return this._unOrganizeData() } }, A }(), i = function () { var A = function (A) { var e = A.gradient || A.defaultGradient, t = document.createElement("canvas"), i = t.getContext("2d"); t.width = 256, t.height = 1; var o = i.createLinearGradient(0, 0, 256, 1); for (var n in e) o.addColorStop(n, e[n]); return i.fillStyle = o, i.fillRect(0, 0, 256, 1), i.getImageData(0, 0, 256, 1).data }, e = function (A, e) { var t = document.createElement("canvas"), i = t.getContext("2d"), o = A, n = A; if (t.width = t.height = 2 * A, 1 == e) i.beginPath(), i.arc(o, n, A, 0, 2 * Math.PI, !1), i.fillStyle = "rgba(0,0,0,1)", i.fill(); else { var r = i.createRadialGradient(o, n, A * e, o, n, A); r.addColorStop(0, "rgba(0,0,0,1)"), r.addColorStop(1, "rgba(0,0,0,0)"), i.fillStyle = r, i.fillRect(0, 0, 2 * A, 2 * A) } return t }; function t(e) { var t = e.container, i = this.shadowCanvas = document.createElement("canvas"), o = this.canvas = e.canvas || document.createElement("canvas"), n = (this._renderBoundaries = [1e4, 1e4, 0, 0], getComputedStyle(e.container) || {}); o.className = "heatmap-canvas", this._width = o.width = i.width = e.width || +n.width.replace(/px/, ""), this._height = o.height = i.height = e.height || +n.height.replace(/px/, ""), this.shadowCtx = i.getContext("2d"), this.ctx = o.getContext("2d"), o.style.cssText = i.style.cssText = "position:absolute;left:0;top:0;", t.style.position = "relative", t.appendChild(o), this._palette = A(e), this._templates = {}, this._setStyles(e) } return t.prototype = { renderPartial: function (A) { A.data.length > 0 && (this._drawAlpha(A), this._colorize()) }, renderAll: function (A) { this._clear(), A.data.length > 0 && (this._drawAlpha(function (A) { for (var e = [], t = A.min, i = A.max, o = A.radi, n = (A = A.data, Object.keys(A)), r = n.length; r--;) for (var a = n[r], s = Object.keys(A[a]), l = s.length; l--;) { var c = s[l]; e.push({ x: a, y: c, value: A[a][c], radius: o[a][c] }) } return { min: t, max: i, data: e } }(A)), this._colorize()) }, _updateGradient: function (e) { this._palette = A(e) }, updateConfig: function (A) { A.gradient && this._updateGradient(A), this._setStyles(A) }, setDimensions: function (A, e) { this._width = A, this._height = e, this.canvas.width = this.shadowCanvas.width = A, this.canvas.height = this.shadowCanvas.height = e }, _clear: function () { this.shadowCtx.clearRect(0, 0, this._width, this._height), this.ctx.clearRect(0, 0, this._width, this._height) }, _setStyles: function (A) { this._blur = 0 == A.blur ? 0 : A.blur || A.defaultBlur, A.backgroundColor && (this.canvas.style.backgroundColor = A.backgroundColor), this._width = this.canvas.width = this.shadowCanvas.width = A.width || this._width, this._height = this.canvas.height = this.shadowCanvas.height = A.height || this._height, this._opacity = 255 * (A.opacity || 0), this._maxOpacity = 255 * (A.maxOpacity || A.defaultMaxOpacity), this._minOpacity = 255 * (A.minOpacity || A.defaultMinOpacity), this._useGradientOpacity = !!A.useGradientOpacity }, _drawAlpha: function (A) { for (var t = this._min = A.min, i = this._max = A.max, o = (A = A.data || []).length, n = 1 - this._blur; o--;) { var r, a = A[o], s = a.x, l = a.y, c = a.radius, h = Math.min(a.value, i), d = s - c, p = l - c, g = this.shadowCtx; this._templates[c] ? r = this._templates[c] : this._templates[c] = r = e(c, n); var u = (h - t) / (i - t); g.globalAlpha = .01 > u ? .01 : u, g.drawImage(r, d, p), this._renderBoundaries[0] > d && (this._renderBoundaries[0] = d), this._renderBoundaries[1] > p && (this._renderBoundaries[1] = p), d + 2 * c > this._renderBoundaries[2] && (this._renderBoundaries[2] = d + 2 * c), p + 2 * c > this._renderBoundaries[3] && (this._renderBoundaries[3] = p + 2 * c) } }, _colorize: function () { var A = this._renderBoundaries[0], e = this._renderBoundaries[1], t = this._renderBoundaries[2] - A, i = this._renderBoundaries[3] - e, o = this._width, n = this._height, r = this._opacity, a = this._maxOpacity, s = this._minOpacity, l = this._useGradientOpacity; 0 > A && (A = 0), 0 > e && (e = 0), A + t > o && (t = o - A), e + i > n && (i = n - e); for (var c = this.shadowCtx.getImageData(A, e, t, i), h = c.data, d = h.length, p = this._palette, g = 3; d > g; g += 4) { var u, f = h[g], m = 4 * f; if (m) u = r > 0 ? r : a > f ? s > f ? s : f : a, h[g - 3] = p[m], h[g - 2] = p[m + 1], h[g - 1] = p[m + 2], h[g] = l ? p[m + 3] : u } this.shadowCtx.putImageData(c, A, e), this.ctx.putImageData(c, A, e), this._renderBoundaries = [1e3, 1e3, 0, 0] }, getValueAt: function (A) { var e = this.shadowCtx.getImageData(A.x, A.y, 1, 1).data[3]; return Math.abs(this._max - this._min) * (e / 255) >> 0 }, getDataURL: function () { return this.canvas.toDataURL() } }, t }(), o = (A = !1, "canvas2d" === e.defaultRenderer && (A = i), A), n = function () { for (var A = {}, e = arguments.length, t = 0; e > t; t++) { var i = arguments[t]; for (var o in i) A[o] = i[o] } return A }, r = function () { var A = function () { function A() { this.cStore = {} } return A.prototype = { on: function (A, e, t) { var i = this.cStore; i[A] || (i[A] = []), i[A].push((function (A) { return e.call(t, A) })) }, emit: function (A, e) { var t = this.cStore; if (t[A]) for (var i = t[A].length, o = 0; i > o; o++) { (0, t[A][o])(e) } } }, A }(), i = function (A) { var e = A._renderer, t = A._coordinator, i = A._store; t.on("renderpartial", e.renderPartial, e), t.on("renderall", e.renderAll, e), t.on("extremachange", (function (e) { A._config.onExtremaChange && A._config.onExtremaChange({ min: e.min, max: e.max, gradient: A._config.gradient || A._config.defaultGradient }) })), i.setCoordinator(t) }; function r() { var r = this._config = n(e, arguments[0] || {}); if (this._coordinator = new A, r.plugin) { var a = r.plugin; if (!e.plugins[a]) throw new Error("Plugin '" + a + "' not found. Maybe it was not registered."); var s = e.plugins[a]; this._renderer = new s.renderer(r), this._store = new s.store(r) } else this._renderer = new o(r), this._store = new t(r); i(this) } return r.prototype = { addData: function () { return this._store.addData.apply(this._store, arguments), this }, removeData: function () { return this._store.removeData && this._store.removeData.apply(this._store, arguments), this }, setData: function () { return this._store.setData.apply(this._store, arguments), this }, setDataMax: function () { return this._store.setDataMax.apply(this._store, arguments), this }, setDataMin: function () { return this._store.setDataMin.apply(this._store, arguments), this }, configure: function (A) { return this._config = n(this._config, A), this._renderer.updateConfig(this._config), this._coordinator.emit("renderall", this._store._getInternalData()), this }, repaint: function () { return this._coordinator.emit("renderall", this._store._getInternalData()), this }, getData: function () { return this._store.getData() }, getDataURL: function () { return this._renderer.getDataURL() }, getValueAt: function (A) { return this._store.getValueAt ? this._store.getValueAt(A) : this._renderer.getValueAt ? this._renderer.getValueAt(A) : null } }, r }(); return { create: function (A) { return new r(A) }, register: function (A, t) { e.plugins[A] = t } } }(), CE = function () { function A(e) { cc(this, A), this.viewer = e.viewer3D, this.id = e.id, this.boundary = [], this.quaternion = new f, this.xMin = 1 / 0, this.yMax = -1 / 0, this.zoomRate = .05 } return dc(A, [{ key: "createInstance", value: function (A, e) { var t = document.createElement("div"); t.id = "heatmap-" + this.id || (new Date).getTime(), t.style.width = "10px", t.style.height = "10px", t.style.position = "absolute", t.style.top = "0", t.style.left = "0", t.style.zIndex = "-10", t.style.overflow = "scroll"; var i = document.createElement("div"); i.style.width = A + "px", i.style.height = e + "px", t.appendChild(i), this.viewer.viewportDiv.appendChild(t), this.container = t, this.heatmap = mE.create({ container: i }) } }, { key: "getHeatmap", value: function () { return this.heatmap } }, { key: "isPlane", value: function (A) { if (3 > A.length) return !1; if (3 === A.length) return !0; for (var e = !0, t = (new y).subVectors(A[0], A[1]), i = (new y).subVectors(A[1], A[2]), o = t.cross(i).normalize(), n = 3; A.length > n; n++) { var r = (new y).subVectors(A[n - 1], A[n]).cross(i).normalize(), a = .001; if (Math.abs(Math.abs(o.x) - Math.abs(r.x)) > a || Math.abs(Math.abs(o.y) - Math.abs(r.y)) > a || Math.abs(Math.abs(o.z) - Math.abs(r.z)) > a) { e = !1; break } } return e } }, { key: "addHeatmap", value: function (A, e) { var t = fE(e.boundary); if (e.data.data.forEach((function (A) { t.push(A.point) })), this.isPlane(t)) { this.boundary = fE(e.boundary); var i = new f, o = (new y).subVectors(e.boundary[1], e.boundary[0]).cross((new y).subVectors(e.boundary[2], e.boundary[1])); i.setFromUnitVectors(o.normalize(), new y(0, 0, 1)); var n = fE(e.boundary).map((function (A) { return A.applyQuaternion(i) })); this.quaternion = i.clone(); var r = 1 / 0, a = -1 / 0, s = 1 / 0, l = -1 / 0; n.forEach((function (A) { r > A.x && (r = A.x), A.x > a && (a = A.x), s > A.y && (s = A.y), A.y > l && (l = A.y) })); var c = a - r, h = l - s; this.xMin = r, this.yMax = l; var d = e.quality || .05; this.zoomRate = d, this.createInstance(Math.round(c * d), Math.round(h * d)); var p = e.data.data.map((function (A) { return A.point.applyQuaternion(i) })), g = []; e.data.data.forEach((function (A, e) { var t = p[e]; g.push({ x: Math.round((t.x - r) * d), y: Math.round((l - t.y) * d), value: A.value, radius: (A.radius || 1e3) * d }) })), this.heatmap.setData({ min: e.data.min, max: e.data.max, data: g }); var u = new ov(n), m = new jA({ map: new en(this.container.querySelector("canvas")), side: 2, transparent: !0, polygonOffset: !0, polygonOffsetFactor: -1, polygonOffsetUnits: -1 }), C = new Kf(u, m); C.visible = !0; var v = new M; v.elements[14] = n[0].z; var I = new M; return I.makeRotationFromQuaternion(i.inverse()), C.applyMatrix4(I.multiply(v)), this.viewer.addExternalObject(A, C), C.disPickable = !0, this.viewer.disableComponentsSelectionByKey(A), !0 } return !1 } }, { key: "updateHeatmap", value: function (A) { var e = this, t = fE(this.boundary); if (A.data.data.forEach((function (A) { t.push(A.point) })), this.isPlane(t)) { var i = [], o = A.data.data.map((function (A) { return new y(A.point.x, A.point.y, A.point.z).applyQuaternion(e.quaternion) })), n = this.zoomRate; return A.data.data.forEach((function (A, t) { var r = o[t]; i.push({ x: Math.round((r.x - e.xMin) * n), y: Math.round((e.yMax - r.y) * n), value: A.value, radius: (A.radius || 1e3) * n }) })), this.heatmap.setData({ min: A.data.min, max: A.data.max, data: i }), this.viewer.getExternalObjectByName(A.id).material.map.needsUpdate = !0, this.viewer.render(), !0 } return !1 } }, { key: "removeHeatmap", value: function (A) { this.viewer.removeExternalObjectByName(A), this.viewer.viewportDiv.removeChild(this.container) } }]), A }(), yE = function (A) { this.maxEdgeLength = A }; yE.prototype.modify = function (A) { for (var e, t = [], i = [], o = this.maxEdgeLength * this.maxEdgeLength, n = 0, r = A.faceVertexUvs.length; r > n; n++) i[n] = []; for (n = 0, r = A.faces.length; r > n; n++) { var a = A.faces[n]; if (a instanceof GA) { var s = a.a, l = a.b, c = a.c, h = A.vertices[s], d = A.vertices[l], p = A.vertices[c], g = h.distanceToSquared(d), u = d.distanceToSquared(p), f = h.distanceToSquared(p); if (g > o || u > o || f > o) { var m = A.vertices.length, C = a.clone(), y = a.clone(); if (g < u || g < f) if (u < g || u < f) { if ((v = h.clone()).lerp(p, .5), C.a = s, C.b = l, C.c = m, y.a = m, y.b = l, y.c = c, 3 === a.vertexNormals.length) (I = a.vertexNormals[0].clone()).lerp(a.vertexNormals[2], .5), C.vertexNormals[2].copy(I), y.vertexNormals[0].copy(I); if (3 === a.vertexColors.length) (E = a.vertexColors[0].clone()).lerp(a.vertexColors[2], .5), C.vertexColors[2].copy(E), y.vertexColors[0].copy(E); e = 2 } else { if ((v = d.clone()).lerp(p, .5), C.a = s, C.b = l, C.c = m, y.a = m, y.b = c, y.c = s, 3 === a.vertexNormals.length) (I = a.vertexNormals[1].clone()).lerp(a.vertexNormals[2], .5), C.vertexNormals[2].copy(I), y.vertexNormals[0].copy(I), y.vertexNormals[1].copy(a.vertexNormals[2]), y.vertexNormals[2].copy(a.vertexNormals[0]); if (3 === a.vertexColors.length) (E = a.vertexColors[1].clone()).lerp(a.vertexColors[2], .5), C.vertexColors[2].copy(E), y.vertexColors[0].copy(E), y.vertexColors[1].copy(a.vertexColors[2]), y.vertexColors[2].copy(a.vertexColors[0]); e = 1 } else { var v, I, E; if ((v = h.clone()).lerp(d, .5), C.a = s, C.b = m, C.c = c, y.a = m, y.b = l, y.c = c, 3 === a.vertexNormals.length) (I = a.vertexNormals[0].clone()).lerp(a.vertexNormals[1], .5), C.vertexNormals[1].copy(I), y.vertexNormals[0].copy(I); if (3 === a.vertexColors.length) (E = a.vertexColors[0].clone()).lerp(a.vertexColors[1], .5), C.vertexColors[1].copy(E), y.vertexColors[0].copy(E); e = 0 } t.push(C, y), A.vertices.push(v); for (var B = 0, x = A.faceVertexUvs.length; x > B; B++) if (A.faceVertexUvs[B].length) { var S = A.faceVertexUvs[B][n], w = S[0], M = S[1], b = S[2]; if (0 === e) { (K = w.clone()).lerp(M, .5); var U = [w.clone(), K.clone(), b.clone()], F = [K.clone(), M.clone(), b.clone()] } else if (1 === e) { (K = M.clone()).lerp(b, .5); U = [w.clone(), M.clone(), K.clone()], F = [K.clone(), b.clone(), w.clone()] } else { var K; (K = w.clone()).lerp(b, .5); U = [w.clone(), M.clone(), K.clone()], F = [K.clone(), M.clone(), b.clone()] } i[B].push(U, F) } } else { t.push(a); for (B = 0, x = A.faceVertexUvs.length; x > B; B++) i[B].push(A.faceVertexUvs[B][n]) } } } A.faces = t, A.faceVertexUvs = i }; var vE = function () { function A(e) { cc(this, A), this.viewer = e.viewer3D, this.id = e.id, this.boundary = [], this.quaternion = new f, this.xMin = 1 / 0, this.yMax = -1 / 0, this.zoomRate = .05, this._canvasSize = new s, this.detailFactor = .5, this._offsetToNagZ = !1, this._mesh = void 0, this._originalGeo = void 0, this._currentGeo = void 0 } return dc(A, [{ key: "createInstance", value: function (A, e) { var t = document.createElement("div"); t.id = "heatmap-" + this.id || (new Date).getTime(), t.style.width = "10px", t.style.height = "10px", t.style.position = "absolute", t.style.top = "0", t.style.left = "0", t.style.zIndex = "-10", t.style.overflow = "scroll"; var i = document.createElement("div"); i.style.width = A + "px", i.style.height = e + "px", this._canvas = i, t.appendChild(i), this.viewer.viewportDiv.appendChild(t), this.container = t, this.heatmap = mE.create({ container: i }), this._canvasSize.set(A, e) } }, { key: "getHeatmap", value: function () { return this.heatmap } }, { key: "isPlane", value: function (A) { if (3 > A.length) return !1; if (3 === A.length) return !0; for (var e = !0, t = (new y).subVectors(A[0], A[1]), i = (new y).subVectors(A[1], A[2]), o = t.cross(i).normalize(), n = 3; A.length > n; n += 1) { var r = (new y).subVectors(A[n - 1], A[n]).cross(i).normalize(), a = .001; if (Math.abs(Math.abs(o.x) - Math.abs(r.x)) > a || Math.abs(Math.abs(o.y) - Math.abs(r.y)) > a || Math.abs(Math.abs(o.z) - Math.abs(r.z)) > a) { e = !1; break } } return e } }, { key: "addHeatmap", value: function (A, e) { var t = fE(e.boundary); if (e.data.data.forEach((function (A) { t.push(A.point) })), this.isPlane(t)) { this.boundary = fE(e.boundary); var i = new f, o = (new y).subVectors(e.boundary[1], e.boundary[0]).cross((new y).subVectors(e.boundary[2], e.boundary[1])); i.setFromUnitVectors(o.normalize(), new y(0, 0, 1)), 2 * o.angleTo(new y(0, 0, 1)) > Math.PI && (this._offsetToNagZ = !0); var n = fE(e.boundary).map((function (A) { return A.applyQuaternion(i) })); this.quaternion = i.clone(); var r = 1 / 0, a = -1 / 0, s = 1 / 0, l = -1 / 0; n.forEach((function (A) { r > A.x && (r = A.x), A.x > a && (a = A.x), s > A.y && (s = A.y), A.y > l && (l = A.y) })); var c = a - r, h = l - s; this.xMin = r, this.yMax = l; var d = e.quality || .05; this.zoomRate = d, this.createInstance(Math.round(c * d), Math.round(h * d)); var p = e.data.data.map((function (A) { return A.point.applyQuaternion(i) })), g = []; e.data.data.forEach((function (A, e) { var t = p[e]; g.push({ x: Math.round((t.x - r) * d), y: Math.round((l - t.y) * d), value: A.value, radius: (A.radius || 1e3) * d }) })), this.heatmap.setData({ min: e.data.min, max: e.data.max, data: g }); var u = new ov(n), m = new De; m.fromBufferGeometry(u), this._originalGeo = m.clone(); var C = this._tessellateGeometry(m); u = (new he).fromGeometry(C), this._offsetZ(u); var v = new jA({ map: new en(this.container.querySelector("canvas")), transparent: !0, side: 2, polygonOffset: !0, polygonOffsetFactor: -1, polygonOffsetUnits: -1, wireframe: !1 }), I = new Kf(u, v); I.visible = !0; var E = new M; E.elements[14] = n[0].z; var B = new M; return B.makeRotationFromQuaternion(i.inverse()), I.applyMatrix4(B.multiply(E)), this.viewer.addExternalObject(A, I), I.disPickable = !0, this.viewer.disableComponentsSelectionByKey(A), this._mesh = I, !0 } return !1 } }, { key: "updateHeatmap", value: function (A) { var e = this, t = fE(this.boundary); if (A.data.data.forEach((function (A) { t.push(A.point) })), this.isPlane(t)) { var i = [], o = A.data.data.map((function (A) { return new y(A.point.x, A.point.y, A.point.z).applyQuaternion(e.quaternion) })), n = this.zoomRate; A.data.data.forEach((function (A, t) { var r = o[t]; i.push({ x: Math.round((r.x - e.xMin) * n), y: Math.round((e.yMax - r.y) * n), value: A.value, radius: (A.radius || 1e3) * n }) })), this.heatmap.setData({ min: A.data.min, max: A.data.max, data: i }); var r = this.viewer.getExternalObjectByName(A.id); if (r) return r.material.map.needsUpdate = !0, this.viewer.render(), !0 } return !1 } }, { key: "removeHeatmap", value: function (A) { this.viewer.removeExternalObjectByName(A), this.viewer.viewportDiv.removeChild(this.container) } }, { key: "setDetailFactor", value: function (A) { if (this.detailFactor !== A && (this.detailFactor = A, this._originalGeo && this._mesh)) { var e = this._originalGeo.clone(), t = this._tessellateGeometry(e), i = (new he).fromGeometry(t); this._offsetZ(i), this._mesh.geometry = i } } }, { key: "_tessellateGeometry", value: function (A) { for (var e = new yE(100), t = 10 + Math.round(10 * this.detailFactor), i = 0; t > i; i += 1) e.modify(A); return A } }, { key: "_easeInOutQuad", value: function (A) { return 1 - (1 - A) * (1 - A) } }, { key: "_offsetZ", value: function (A) { for (var e = A.getAttribute("uv").array, t = A.getAttribute("position").array, i = this.heatmap.getData(), o = 0, n = e.length; n > o; o += 2) { var r = (this.heatmap.getValueAt({ x: e[o] * this._canvasSize.x, y: (1 - e[o + 1]) * this._canvasSize.y }) - i.min) / (i.max - i.min); r = this._easeInOutQuad(r), t[o / 2 * 3 + 2] = 1e3 * r * (this._offsetToNagZ ? -1 : 1) } A.getAttribute("position").needsUpdate = !0 } }]), A }(), IE = function () { function A(e, t) { cc(this, A), this.viewer = t, this.maxHeatValue = 1 / 0, this.minHeatValue = -1 / 0, this._init(e) } return dc(A, [{ key: "show", value: function (A) { var e = this; function t(A) { if (0 === A.uniforms.heatmapPoints.value.length) A.fragmentShader = "#define HEATMAPPOINTSCOUNT " + e.shaderData.heatmapPoints.length + "\n" + A.fragmentShader, A.vertexShader = "#define HEATMAPPOINTSCOUNT " + e.shaderData.heatmapPoints.length + "\n" + A.vertexShader; else { var t = "#define HEATMAPPOINTSCOUNT " + A.uniforms.heatmapPoints.value.length; A.fragmentShader = A.fragmentShader.replace(t, "#define HEATMAPPOINTSCOUNT " + e.shaderData.heatmapPoints.length), A.vertexShader = A.vertexShader.replace(t, "#define HEATMAPPOINTSCOUNT " + e.shaderData.heatmapPoints.length) } A.uniforms.heatmapPoints.value = e.shaderData.heatmapPoints, A.uniforms.heatmapTexture.value = e.shaderData.heatmapTexture, A.needsUpdate = !0 } if (A) { if (!this.viewer.getViewerImpl().getModelByComponentKey(A)) return; var i = this.viewer.getViewerImpl().modelManager.getComponent(A); if (i && i.length > 0) for (var o = i[0].mesh.material, n = 0, r = o.length; r > n; n += 1) o[n] = o[n].clone(), t(o[n]) } else this.shaderData.heatmapPoints && this.shaderData.heatmapTexture && (this.viewer.getViewerImpl().getModelManager().traverseModels((function (A) { var e = A.materialManager.materials; for (var i in e) { t(e[i]) } })), this.viewer.syncRender()) } }, { key: "hide", value: function () { var A = this; this.shaderData.heatmapPoints && this.shaderData.heatmapTexture && (this.viewer.getViewerImpl().getModelManager().traverseModels((function (e) { var t = e.materialManager.materials; for (var i in t) { var o = t[i]; if (o.uniforms.heatmapPoints.value.length > 0) { o.uniforms.heatmapPoints.value = [], o.uniforms.heatmapTexture.value = null; var n = "#define HEATMAPPOINTSCOUNT " + A.shaderData.heatmapPoints.length; o.fragmentShader = o.fragmentShader.replace(n, ""), o.vertexShader = o.vertexShader.replace(n, ""), o.needsUpdate = !0 } } })), this.viewer.render()) } }, { key: "removeHeatmap", value: function () { this.hide(), this.shaderData.heatmapPoints && delete this.shaderData.heatmapPoints, this.shaderData.heatmapTexture && delete this.shaderData.heatmapTexture } }, { key: "updateHeatmap", value: function (A) { var e = A.data; this.maxHeatValue = e.max ? e.max : 1 / 0, this.minHeatValue = e.min ? e.min : -1 / 0, this.shaderData.heatmapPoints = this._createHeatmapBuffer(A.data), this.show() } }, { key: "_init", value: function (A) { var e = A.data; this.maxHeatValue = e.max ? e.max : 1 / 0, this.minHeatValue = e.min ? e.min : -1 / 0, this.shaderData = { heatmapPoints: this._createHeatmapBuffer(e), heatmapTexture: this._createHeatmapTexture() } } }, { key: "_createHeatmapBuffer", value: function (A) { if (A.data && 0 !== A.data.length) { if (this.maxHeatValue === 1 / 0 || this.minHeatValue === -1 / 0) for (var e = 0, t = A.data.length; t > e; e += 1) { var i = A.data[e]; i.value > this.maxHeatValue && (this.maxHeatValue = i.value), this.minHeatValue > i.value && (this.minHeatValue = i.value) } for (var o = [], n = 0, r = A.data.length; r > n; n += 1) { var a = A.data[n], s = Math.max(this.minHeatValue, Math.min(a.value, this.maxHeatValue)); o.push(a.point.x, a.point.y, a.point.z, (s - this.minHeatValue) / (this.maxHeatValue - this.minHeatValue), a.radius ? a.radius : 1e3) } return new Float32Array(o) } } }, { key: "_createHeatmapTexture", value: function () { var A = document.createElement("canvas"); A.width = 256, A.height = 1; var e = A.getContext("2d"), t = e.createLinearGradient(0, 0, 256, 1), i = { 0: "#44f", .1: "#0ff", .2: "#0f0", .4: "#ff0", 1: "#f00" }; for (var o in i) t.addColorStop(o, i[o]); return e.fillStyle = t, e.fillRect(0, 0, 256, 1), new en(A) } }]), A }(), EE = function () { function A(e, t) { cc(this, A), this.heatSpheres = [], this.viewer = t, this.maxHeatValue = 1 / 0, this.minHeatValue = -1 / 0, this._animating = !1, this._lastAnimateTime = void 0, this._localTime = 0, this._duration = 2e3, this._init(e) } return dc(A, [{ key: "getColorIndexAndValueOfHeatValue", value: function (e) { A.colorBoard || (A.colorBoard = this._createColorBoard()); var t = (Math.max(this.minHeatValue, Math.min(e, this.maxHeatValue)) - this.minHeatValue) / (this.maxHeatValue - this.minHeatValue) * 255, i = 4 * (t = Math.round(t)); return { color: new LA(A.colorBoard[i] / 255, A.colorBoard[i + 1] / 255, A.colorBoard[i + 2] / 255), index: t } } }, { key: "updateHeatmap", value: function (A) { this.removeHeatmap(), this._init(A), this.startAnimation(this._duration) } }, { key: "startAnimation", value: function (A) { var e = this; this._animating || (this._animating = !0, A && (this._duration = A), requestAnimationFrame((function (A) { return e._animate(A) }))) } }, { key: "stopAnimation", value: function () { this._animating = !1, this._lastAnimateTime = void 0, this._localTime = 0 } }, { key: "removeHeatmap", value: function () { var A = this; this.stopAnimation(), this.heatSpheres.forEach((function (e) { A.viewer.removeExternalObjectByName(e.uuid) })) } }, { key: "_animate", value: function (e) { var t = this, i = this._lastAnimateTime ? e - this._lastAnimateTime : 0; if (!this._lastAnimateTime || i > 100) { this._localTime += i / this._duration, 1 > this._localTime || (this._localTime = 0); var o = this._easeOutSine(this._localTime); this.heatSpheres.forEach((function (e) { e.scale.set(o, o, o), e.updateMatrixWorld(!0); var i = e.userData._heatColorIndex; i = 4 * Math.round(i * (1 - t._localTime)), e.material.color.setRGB(A.colorBoard[i] / 255, A.colorBoard[i + 1] / 255, A.colorBoard[i + 2] / 255), e.material.needsUpdate = !0 })), this.viewer.render(), this._lastAnimateTime = e } this._animating && requestAnimationFrame((function (A) { return t._animate(A) })) } }, { key: "_init", value: function (A) { var e = A.data; if (this.maxHeatValue = e.max ? e.max : 1 / 0, this.minHeatValue = e.min ? e.min : -1 / 0, this._sphereOpacity = e.alpha ? e.alpha : .7, this.maxHeatValue === 1 / 0 || this.minHeatValue === -1 / 0) for (var t = 0, i = e.data.length; i > t; t += 1) { var o = e.data[t]; o.value > this.maxHeatValue && (this.maxHeatValue = o.value), this.minHeatValue > o.value && (this.minHeatValue = o.value) } for (var n = 0, r = e.data.length; r > n; n += 1) this._addHeatPoint(e.data[n]) } }, { key: "_addHeatPoint", value: function (A) { var e = A, t = e.radius ? e.radius : 1e3, i = 10 * Math.log10(t), o = new er(t, i, i), n = this.getColorIndexAndValueOfHeatValue(e.value), r = n.index, a = new Ue(o, new xr({ color: n.color, depthTest: !0, transparent: !0, opacity: this._sphereOpacity })); a.position.set(e.point.x, e.point.y, e.point.z), a.updateMatrixWorld(!0), a.userData._heatValue = e.value, a.userData._heatColorIndex = r, a.disPickable = !0, this.viewer.disableComponentsSelectionByKey(a.uuid), this.heatSpheres.push(a), this.viewer.addExternalObject(a.uuid, a) } }, { key: "_createColorBoard", value: function () { var A = document.createElement("canvas"); A.width = 256, A.height = 1; var e = A.getContext("2d"), t = e.createLinearGradient(0, 0, 256, 1), i = { 0: "#44f", .1: "#0ff", .2: "#0f0", .4: "#ff0", 1: "#f00" }; for (var o in i) t.addColorStop(o, i[o]); return e.fillStyle = t, e.fillRect(0, 0, 256, 1), e.getImageData(0, 0, 256, 1).data } }, { key: "_easeOutCubic", value: function (A) { return 1 - Math.pow(1 - A, 3) } }, { key: "_easeOutSine", value: function (A) { return Math.sin(A * Math.PI / 2) } }, { key: "_easeInCubic", value: function (A) { return A * A * A } }]), A }(), BE = function () { function A(e) { cc(this, A), this.viewer = e.viewer3D, this.mapCollection = {} } return dc(A, [{ key: "createHeatmap", value: function (A) { var e = ((new Date).getTime() * (Math.random() + 1)).toString(36).slice(0, 8), t = new CE({ viewer3D: this.viewer, id: e }), i = fE(A); return i.data.data.forEach((function (A) { A.point = new y(A.point.x, A.point.y, A.point.z) })), i.boundary = i.boundary.map((function (A) { return new y(A.x, A.y, A.z) })), t.addHeatmap(e, i) ? (this.mapCollection[e] = t, { code: "success", id: e }) : { code: "error", message: "输入的点不共面" } } }, { key: "updateHeatmap", value: function (A) { var e = this.mapCollection[A.id]; if (e && e.updateHeatmap) return e.updateHeatmap(A) } }, { key: "removeHeatmap", value: function (A) { return !!this.mapCollection[A] && (this.mapCollection[A].removeHeatmap(A), delete this.mapCollection[A], !0) } }, { key: "createHeatmap3D", value: function (A) { var e = ((new Date).getTime() * (Math.random() + 1)).toString(36).slice(0, 8), t = new vE({ viewer3D: this.viewer, id: e }), i = fE(A); return i.data.data.forEach((function (A) { A.point = new y(A.point.x, A.point.y, A.point.z) })), i.boundary = i.boundary.map((function (A) { return new y(A.x, A.y, A.z) })), t.addHeatmap(e, i) ? (this.mapCollection[e] = t, { code: "success", id: e, map: t }) : { code: "error", message: "输入的点不共面" } } }, { key: "createSphereHeatmap", value: function (A) { if (A.data && A.data.data) { var e = ((new Date).getTime() * (Math.random() + 1)).toString(36).slice(0, 8), t = new EE(A, this.viewer); return t.startAnimation(5e3), this.mapCollection[e] = t, { code: "success", id: e, map: t } } return { code: "error", message: "参数错误" } } }, { key: "createSphereColorOverrideHeatmap", value: function (A) { if (A.data && A.data.data) { if (A.data.data.length > 150) return { code: "error", message: "热力源个数不能超过150" }; var e = new IE(A, this.viewer), t = ((new Date).getTime() * (Math.random() + 1)).toString(36).slice(0, 8); return this.mapCollection[t] = e, e.show(), { code: "success", id: t, map: e } } return { code: "error", message: "参数错误" } } }]), A }(), xE = function (A, e) { Xo.call(this, A, e), this.pointIds = [] }; (xE.prototype = Object.create(Xo.prototype)).constructor = xE, xE.prototype.raycast = function () { var A = new M, e = new CA, t = new cA; return function (i, o) { var n = this, r = this.geometry, a = this.matrixWorld, s = this.size, l = i.camera || i._camera, c = i.viewportSize.height, h = this.pointIds; function d(e, t) { var i = e.clone(); return i.applyMatrix4(a), i.project(l), i.y += t / c, i.unproject(l), i.applyMatrix4(A), i } A.getInverse(a), null === r.boundingSphere && r.computeBoundingSphere(), t.copy(r.boundingSphere); var p = t.center, g = d(p, s), u = g.distanceToSquared(p); if (t.radius += u, t.center.copy(g), t.applyMatrix4(a), !1 !== i.ray.intersectsSphere(t)) { e.copy(i.ray).applyMatrix4(A); var f = new y, m = s; if (r.isBufferGeometry) { var C = r.index, v = r.attributes, I = v.position.array, E = !1, B = null; if (v.attrSize && (E = !0, B = v.attrSize.array), null !== C) for (var x = C.array, S = 0, w = x.length; w > S; S += 1) { var M = x[S]; f.fromArray(I, 3 * M), E && (m = B[M]), F(f, m, M) } else { S = 0; for (var b = I.length / 3; b > S; S += 1) f.fromArray(I, 3 * S), E && (m = B[S]), F(f, m, S) } } else { var U = r.vertices; for (S = 0, b = U.length; b > S; S += 1) F(U[S], m, S) } } function F(A, t, r) { var s = d(A, t), l = s.distanceToSquared(A), c = e.distanceSqToPoint(s); if (l > c) { var p = e.closestPointToPoint(s); p.applyMatrix4(a); var g = i.ray.origin.distanceTo(p); if (i.near > g || g > i.far) return; o.push({ id: h[r], distance: g, distanceToRay: Math.sqrt(c), point: p.clone(), index: r, face: null, object: n }) } } } }(), xE.prototype.setAttributeSize = function (A, e) { var t = this.geometry.attributes; t.attrSize && (t.attrSize.array[A] = e, t.attrSize.needsUpdate = !0) }, xE.prototype.getAttributeSize = function (A) { var e = this.geometry.attributes, t = this.size; return e.attrSize && (t = e.attrSize.array[A]), t }; var SE = ["attribute vec3 customColor;", "attribute float customOpacity;", "attribute float customSize;", "attribute float customAngle;", "attribute float customVisible;", "varying vec4 vColor;", "varying float vAngle;", "void main()", "{", "if ( customVisible > 0.5 )", "vColor = vec4( customColor, customOpacity );", "else", "vColor = vec4(0.0, 0.0, 0.0, 0.0);", "vAngle = customAngle;", "vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );", "gl_PointSize = customSize * ( 3000.0 / length( mvPosition.xyz ) );", "gl_Position = projectionMatrix * mvPosition;", "}"].join("\n"), wE = ["uniform sampler2D texture;", "varying vec4 vColor;", "varying float vAngle;", "void main()", "{", "gl_FragColor = vColor;", "float c = cos(vAngle);", "float s = sin(vAngle);", "vec2 rotatedUV = vec2(c * (gl_PointCoord.x - 0.5) + s * (gl_PointCoord.y - 0.5) + 0.5,", "c * (gl_PointCoord.y - 0.5) - s * (gl_PointCoord.x - 0.5) + 0.5);", "vec4 rotatedTexture = texture2D( texture, rotatedUV );", "gl_FragColor = gl_FragColor * rotatedTexture;", "}"].join("\n"); function ME(A, e) { this.times = A || [], this.values = e || [] } function bE() { this.position = new y, this.velocity = new y, this.acceleration = new y, this.angle = 0, this.angleVelocity = 0, this.angleAcceleration = 0, this.size = 16, this.color = new LA, this.opacity = 1, this.age = 0, this.alive = 0 } function UE() { this.positionStyle = 1, this.positionBase = new y, this.positionSpread = new y, this.positionRadius = 0, this.velocityStyle = 1, this.velocityBase = new y, this.velocitySpread = new y, this.speedBase = 0, this.speedSpread = 0, this.accelerationBase = new y, this.accelerationSpread = new y, this.angleBase = 0, this.angleSpread = 0, this.angleVelocityBase = 0, this.angleVelocitySpread = 0, this.angleAccelerationBase = 0, this.angleAccelerationSpread = 0, this.sizeBase = 0, this.sizeSpread = 0, this.sizeTween = new ME, this.colorBase = new y(0, 1, .5), this.colorSpread = new y(0, 0, 0), this.colorTween = new ME, this.opacityBase = 1, this.opacitySpread = 0, this.opacityTween = new ME, this.blendStyle = 1, this.particleArray = [], this.particlesPerSecond = 100, this.particleDeathAge = 1, this.emitterAge = 0, this.emitterAlive = !0, this.emitterDeathAge = 60, this.particleCount = this.particlesPerSecond * Math.min(this.particleDeathAge, this.emitterDeathAge) } ME.prototype.lerp = function (A) { for (var e = 0, t = this.times.length; t > e && A > this.times[e];) e += 1; if (0 === e) return this.values[0]; if (e === t) return this.values[t - 1]; var i = (A - this.times[e - 1]) / (this.times[e] - this.times[e - 1]); return this.values[0] instanceof y ? this.values[e - 1].clone().lerp(this.values[e], i) : this.values[e - 1] + i * (this.values[e] - this.values[e - 1]) }, bE.prototype.update = function (A) { if (this.position.add(this.velocity.clone().multiplyScalar(A)), this.velocity.add(this.acceleration.clone().multiplyScalar(A)), this.angle += .01745329251 * this.angleVelocity * A, this.angleVelocity += .01745329251 * this.angleAcceleration * A, this.age += A, this.sizeTween.times.length > 0 && (this.size = this.sizeTween.lerp(this.age)), this.colorTween.times.length > 0) { var e = this.colorTween.lerp(this.age); this.color = (new LA).setHSL(e.x, e.y, e.z) } this.opacityTween.times.length > 0 && (this.opacity = this.opacityTween.lerp(this.age)) }, UE.prototype.setValues = function (A) { if (void 0 !== A) { for (var e in this.sizeTween = new ME, this.colorTween = new ME, this.opacityTween = new ME, A) this[e] = A[e]; this.particleArray = [], this.emitterAlive = !0, this.particleCount = this.particlesPerSecond * Math.min(this.particleDeathAge, this.emitterDeathAge), this.particleGeometry = new he, this.particleMaterial = new Pe({ uniforms: { texture: { value: this.particleTexture } }, vertexShader: SE, fragmentShader: wE, transparent: !0, blending: 1, depthWrite: !1 }), this.particleMesh = new xE } }, UE.prototype.randomValue = function (A, e) { return A + e * (Math.random() - .5) }, UE.prototype.randomVector3 = function (A, e) { var t = new y(Math.random() - .5, Math.random() - .5, Math.random() - .5); return (new y).addVectors(A, t.multiplyVectors(e, t)) }, UE.prototype.updateVector3 = function (A, e, t) { var i = new y(Math.random() - .5, Math.random() - .5, Math.random() - .5); A.set(0, 0, 0), A.addVectors(e, i.multiplyVectors(t, i)) }, UE.prototype.createParticle = function () { var A = new bE; if (1 === this.positionStyle && (A.position = this.randomVector3(this.positionBase, this.positionSpread)), 2 === this.positionStyle) { var e = 2 * Math.random() - 1, t = 6.2832 * Math.random(), i = Math.sqrt(1 - e * e), o = new y(i * Math.cos(t), i * Math.sin(t), e); A.position = (new y).addVectors(this.positionBase, o.multiplyScalar(this.positionRadius)) } if (1 === this.velocityStyle && (A.velocity = this.randomVector3(this.velocityBase, this.velocitySpread)), 2 === this.velocityStyle) { var n = (new y).subVectors(A.position, this.positionBase), r = this.randomValue(this.speedBase, this.speedSpread); A.velocity = n.normalize().multiplyScalar(r) } A.acceleration = this.randomVector3(this.accelerationBase, this.accelerationSpread), A.angle = this.randomValue(this.angleBase, this.angleSpread), A.angleVelocity = this.randomValue(this.angleVelocityBase, this.angleVelocitySpread), A.angleAcceleration = this.randomValue(this.angleAccelerationBase, this.angleAccelerationSpread), A.size = this.randomValue(this.sizeBase, this.sizeSpread); var a = this.randomVector3(this.colorBase, this.colorSpread); return A.color = (new LA).setHSL(a.x, a.y, a.z), A.opacity = this.randomValue(this.opacityBase, this.opacitySpread), A.age = 0, A.alive = 0, A.sizeTween = this.sizeTween, A.colorTween = this.colorTween, A.opacityTween = this.opacityTween, A }, UE.prototype.updateParticle = function (A) { if (1 === this.positionStyle && this.updateVector3(A.position, this.positionBase, this.positionSpread), 2 === this.positionStyle) { var e = 2 * Math.random() - 1, t = 6.2832 * Math.random(), i = Math.sqrt(1 - e * e), o = new y(i * Math.cos(t), i * Math.sin(t), e); A.position = (new y).addVectors(this.positionBase, o.multiplyScalar(this.positionRadius)) } if (1 === this.velocityStyle && this.updateVector3(A.velocity, this.velocityBase, this.velocitySpread), 2 === this.velocityStyle) { var n = (new y).subVectors(A.position, this.positionBase), r = this.randomValue(this.speedBase, this.speedSpread); A.velocity = n.normalize().multiplyScalar(r) } this.updateVector3(A.acceleration, this.accelerationBase, this.accelerationSpread), A.angle = this.randomValue(this.angleBase, this.angleSpread), A.angleVelocity = this.randomValue(this.angleVelocityBase, this.angleVelocitySpread), A.angleAcceleration = this.randomValue(this.angleAccelerationBase, this.angleAccelerationSpread), A.size = this.randomValue(this.sizeBase, this.sizeSpread); var a = this.randomVector3(this.colorBase, this.colorSpread); A.color = A.color.setHSL(a.x, a.y, a.z), A.opacity = this.randomValue(this.opacityBase, this.opacitySpread), A.age = 0, A.alive = 0 }, UE.prototype.initialize = function () { this.sortArray = [], this.positions = new Float32Array(3 * this.particleCount), this.customVisible = new Float32Array(this.particleCount), this.customSize = new Float32Array(this.particleCount), this.customColor = new Float32Array(3 * this.particleCount), this.customOpacity = new Float32Array(this.particleCount), this.maxSize = 200; for (var A = 0; this.particleCount > A; A += 1) this.particleArray[A] = this.createParticle(), this.positions[3 * A] = this.particleArray[A].position.x, this.positions[3 * A + 1] = this.particleArray[A].position.y, this.positions[3 * A + 2] = this.particleArray[A].position.z, this.customVisible[A] = this.particleArray[A].alive, this.customColor[3 * A] = this.particleArray[A].color.r, this.customColor[3 * A + 1] = this.particleArray[A].color.g, this.customColor[3 * A + 2] = this.particleArray[A].color.b, this.customOpacity[A] = this.particleArray[A].opacity, this.customSize[A] = this.particleArray[A].size, this.maxSize = this.maxSize > this.customSize[A] ? this.maxSize : this.customSize[A]; this.particleMaterial.blending = this.blendStyle, this.particleGeometry.setAttribute("position", new YA(this.positions, 3)), this.particleGeometry.setAttribute("customColor", new YA(this.customColor, 3)), this.particleGeometry.setAttribute("customVisible", new YA(this.customVisible, 1)), this.particleGeometry.setAttribute("customSize", new YA(this.customSize, 1)), this.particleGeometry.setAttribute("customOpacity", new YA(this.customOpacity, 1)), this.particleMesh = new xE(this.particleGeometry, this.particleMaterial), this.particleMesh.dynamic = !0, this.particleMesh.size = this.maxSize, this.particleMesh.renderOrder = -1 }, UE.prototype.update = function (A) { A = void 0 === A ? .015 : A; for (var e = [], t = 0; this.particleCount > t; t += 1) this.particleArray[t].alive && (this.particleArray[t].update(A), this.particleArray[t].age > this.particleDeathAge && (this.particleArray[t].alive = 0, e.push(t)), this.customVisible[t] = this.particleArray[t].alive, this.customOpacity[t] = this.particleArray[t].opacity, this.customSize[t] = this.particleArray[t].size, this.customColor[3 * t] = this.particleArray[t].color.r, this.customColor[3 * t + 1] = this.particleArray[t].color.g, this.customColor[3 * t + 2] = this.particleArray[t].color.b, this.positions[3 * t] = this.particleArray[t].position.x, this.positions[3 * t + 1] = this.particleArray[t].position.y, this.positions[3 * t + 2] = this.particleArray[t].position.z, this.maxSize = this.maxSize > this.customSize[t] ? this.maxSize : this.customSize[t]); if (this.particleGeometry.getAttribute("customVisible").needsUpdate = !0, this.particleGeometry.getAttribute("customOpacity").needsUpdate = !0, this.particleGeometry.getAttribute("customSize").needsUpdate = !0, this.particleGeometry.getAttribute("customColor").needsUpdate = !0, this.particleGeometry.getAttribute("position").needsUpdate = !0, this.emitterAlive) { var i = Math.round(this.particlesPerSecond * (this.emitterAge + 0)), o = Math.round(this.particlesPerSecond * (this.emitterAge + A)); o > this.particleCount && (o = this.particleCount); for (t = i; o > t; t += 1) this.particleArray[t].alive = 1; for (var n = 0; e.length > n; n += 1) { this.updateParticle(this.particleArray[t = e[n]]), this.particleArray[t].alive = 1, this.positions[3 * t] = this.particleArray[t].position.x, this.positions[3 * t + 1] = this.particleArray[t].position.y, this.positions[3 * t + 2] = this.particleArray[t].position.z } this.emitterAge += A } }, UE.prototype.setScale = function (A) { for (var e = 0, t = this.sizeTween.values.length; t > e; e += 1) this.sizeTween.values[e] = this.sizeTween.values[e] * A; this.maxSize *= A }, UE.prototype.initializeSizetween = function (A) { for (var e = 0, t = this.sizeTween.values.length; t > e; e += 1) this.sizeTween.values[e] = this.sizeTween.values[e] * A; for (e = 0; this.particleCount > e; e += 1) this.particleArray[e].size *= A, this.customSize[e] = this.particleArray[e].size, this.maxSize = this.maxSize > this.customSize[e] ? this.maxSize : this.customSize[e]; this.particleGeometry.getAttribute("customSize").needsUpdate = !0 }, UE.prototype.destroy = function () {}; var FE = function () { return Xi.call(this), this.firePosition = { x: 0, y: 0, z: 0 }, this.position.set(this.firePosition.x, this.firePosition.y, this.firePosition.z), this.fireScale = 1, this.type = "fire", this.disPickable = !0, this.autoAnimation = !0, this._loadTexture(), this._initialize(), this }; (FE.prototype = Object.create(Xi.prototype)).constructor = Xi.prototype, FE.prototype._initialize = function () { this.fire = new UE, this.fire.setValues({ positionStyle: 1, positionBase: new y(0, 0, 600), positionSpread: new y(1500, 1500, 600), velocityStyle: 1, velocityBase: new y(0, 0, 4600), velocitySpread: new y(1e3, 1e3, 4600), accelerationBase: new y(0, 0, 2600), particleTexture: this.fireParticle, sizeTween: new ME([0, .1], [32, 200]), opacityTween: new ME([.7, 1], [.8, 0]), colorBase: new y(.04, 1, .4), blendStyle: 2, particlesPerSecond: 80, particleDeathAge: 1.5 }), this.fire.initialize(), this.smoke = new UE, this.smoke.setValues({ positionStyle: 1, positionBase: new y(0, 0, 2600), positionSpread: new y(1500, 1500, 600), velocityStyle: 1, velocityBase: new y(0, 0, 3600), velocitySpread: new y(1800, 1800, 1100), accelerationBase: new y(0, 0, 2600), particleTexture: this.smokeParticle, sizeTween: new ME([0, 1], [32, 200]), opacityTween: new ME([.5, 1, 1.7], [0, .3, 0]), colorTween: new ME([.4, 1], [new y(0, 0, 0), new y(0, 0, .2)]), blendStyle: 1, particlesPerSecond: 40, particleDeathAge: 2 }), this.smoke.initialize(), this.add(this.fire.particleMesh), this.add(this.smoke.particleMesh) }, FE.prototype._initializeSizetween = function (A) { this.fire.initializeSizetween(A), this.smoke.initializeSizetween(A) }, FE.prototype.update = function () { this.fire.update(), this.smoke.update() }, FE.prototype.getPosition = function () { return this.firePosition }, FE.prototype.setPosition = function (A) { if (A) if ("number" == typeof A.x) if ("number" == typeof A.y) if ("number" == typeof A.z) { if (this.firePosition = A, this.position.set(this.firePosition.x, this.firePosition.y, this.firePosition.z), this.updateMatrixWorld(), this.originBox) { var e = this.originBox.clone(); this.box = e.applyMatrix4(this.matrix), this.levelName = null } } else Bh.error("缺少参数 position.z"); else Bh.error("缺少参数 position.y"); else Bh.error("缺少参数 position.x"); else Bh.error("缺少参数 position") }, FE.prototype.getScale = function () { return this.fireScale }, FE.prototype.setScale = function (A) { this.scale.set(A, A, A), this.updateMatrixWorld(), this.fire.setScale(A / this.fireScale), this.smoke.setScale(A / this.fireScale), this.fireScale = A }, FE.prototype._loadTexture = function () { var A = new Aa; this.fireParticle = A.load(""), this.smokeParticle = A.load("") }; var KE = function () { JC.call(this), this.type = "LineGeometry" }; KE.prototype = Object.assign(Object.create(JC.prototype), { constructor: KE, isLineGeometry: !0, setPositions: function (A) { for (var e = A.length - 3, t = new Float32Array(2 * e), i = 0; e > i; i += 3) t[2 * i] = A[i], t[2 * i + 1] = A[i + 1], t[2 * i + 2] = A[i + 2], t[2 * i + 3] = A[i + 3], t[2 * i + 4] = A[i + 4], t[2 * i + 5] = A[i + 5]; return JC.prototype.setPositions.call(this, t), this }, setColors: function (A) { for (var e = A.length - 3, t = new Float32Array(2 * e), i = 0; e > i; i += 3) t[2 * i] = A[i], t[2 * i + 1] = A[i + 1], t[2 * i + 2] = A[i + 2], t[2 * i + 3] = A[i + 3], t[2 * i + 4] = A[i + 4], t[2 * i + 5] = A[i + 5]; return JC.prototype.setColors.call(this, t), this }, fromLine: function (A) { var e = A.geometry; return e.isGeometry ? this.setPositions(e.vertices) : e.isBufferGeometry && this.setPositions(e.position.array), this }, copy: function () { return this } }); var QE = function (A, e) { XC.call(this), this.type = "Line2", this.geometry = void 0 !== A ? A : new KE, this.material = void 0 !== e ? e : new YC({ color: 16777215 * Math.random() }) }; QE.prototype = Object.assign(Object.create(XC.prototype), { constructor: QE, isLine2: !0, copy: function () { return this } }); function RE(A) { return "symbol" == typeof A || Zv(A) && "[object Symbol]" == Sv(A) } var TE = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, kE = /^\w*$/; function DE(A, e) { if ("function" != typeof A || null != e && "function" != typeof e) throw new TypeError("Expected a function"); var t = function () { var i = arguments, o = e ? e.apply(this, i) : i[0], n = t.cache; if (n.has(o)) return n.get(o); var r = A.apply(this, i); return t.cache = n.set(o, r) || n, r }; return t.cache = new(DE.Cache || qv), t } DE.Cache = qv; var LE = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g, NE = /\\(\\)?/g, OE = function (A) { var e = DE(A, (function (A) { return 500 === t.size && t.clear(), A })), t = e.cache; return e }((function (A) { var e = []; return 46 === A.charCodeAt(0) && e.push(""), A.replace(LE, (function (A, t, i, o) { e.push(i ? o.replace(NE, "$1") : t || A) })), e })); var VE = Cv ? Cv.prototype : void 0, GE = VE ? VE.toString : void 0; function PE(A) { if ("string" == typeof A) return A; if (tI(A)) return function (A, e) { for (var t = -1, i = null == A ? 0 : A.length, o = Array(i); ++t < i;) o[t] = e(A[t], t, A); return o }(A, PE) + ""; if (RE(A)) return GE ? GE.call(A) : ""; var e = A + ""; return "0" == e && 1 / A == -1 / 0 ? "-0" : e } function qE(A, e) { return tI(A) ? A : function (A, e) { if (tI(A)) return !1; var t = typeof A; return !("number" != t && "symbol" != t && "boolean" != t && null != A && !RE(A)) || (kE.test(A) || !TE.test(A) || null != e && A in Object(e)) }(A, e) ? [A] : OE(function (A) { return null == A ? "" : PE(A) }(A)) } function jE(A) { if ("string" == typeof A || RE(A)) return A; var e = A + ""; return "0" == e && 1 / A == -1 / 0 ? "-0" : e } function HE(A, e, t) { var i = null == A ? void 0 : function (A, e) { for (var t = 0, i = (e = qE(e, A)).length; null != A && i > t;) A = A[jE(e[t++])]; return t && t == i ? A : void 0 }(A, e); return void 0 === i ? t : i } var YE = { height: 0, speed: 1e3, frameTime: 14 }, WE = new hp, JE = function () { function A(e) { cc(this, A), this.roadnet = {}, this.shortestPathLineMap = {}, this.roadNetLineMap = {}, this.roadNetPointMap = {}, this.roadNetInfoMap = {}, this.roadNetEdgeMap = {}, this.roadNetPointMap = {}, this.mapRoadNetListByModelKey = {}, this.mapModelKeyByRoadNetKey = {}, this.modelInfo = {}, this.viewer3D = e } return dc(A, [{ key: "_getRoadNetListByModelKey", value: function (A) { var e = this, t = this; return new Promise((function (i, o) { (function (A) { var e = A.viewer3D.getViewerImpl().getModel(A.modelKey), t = HE(e, ["loader", "url", "serverUrl"]) || HE(A, ["viewer3D", "host"], ""), i = e.projectKey, o = e.accessToken, n = ""; e.share && (n = "&share=" + e.share); var r = { url: "".concat(t, "/").concat(A.apiVersion || "api", "/").concat(i, "/routes/list?modelKey=").concat(A.modelKey).concat(n) }; return o && (r.headers = { Authorization: o }), _d(r) })({ viewer3D: e.viewer3D, modelKey: A }).then((function (e) { var n, r = t.viewer3D.getViewerImpl().getModel(A); if (!r) return Bh.error(A + "模型不存在"), void o(A + "模型不存在"); if (t.modelInfo[A] = r, "SUCCESS" === (n = "string" == typeof e ? JSON.parse(e) : e).code) { var a = t.mapRoadNetListByModelKey; a[A] = {}; for (var s = 0, l = n.data.length; l > s; s += 1) { var c = n.data[s], h = c.key; a[A][h] = c, t.roadNetInfoMap[h] = c, t.mapModelKeyByRoadNetKey[h] = A } i() } else o(n.message) })).catch((function () { Bh.error("获取模型路网列表失败"), o("获取模型路网列表失败") })) })) } }, { key: "_getRoadNetDataByRouteKey", value: function (A, e, t) { var i = this, o = this, n = [], r = this.mapModelKeyByRoadNetKey[A]; if (r) return n.push(new Promise((function (e, t) { (function (A) { var e = A.viewer3D.getViewerImpl().getModel(A.modelKey), t = HE(e, ["loader", "url", "serverUrl"]) || HE(A, ["viewer3D", "host"], ""), i = e.projectKey, o = e.accessToken, n = ""; e.share && (n = "&share=" + e.share); var r = { url: "".concat(t, "/").concat(A.apiVersion || "api", "/").concat(i, "/routes/points?routeKey=").concat(A.routeKey).concat(n) }; return o && (r.headers = { Authorization: o }), _d(r) })({ viewer3D: i.viewer3D, routeKey: A, modelKey: r }).then((function (i) { var n; if ("SUCCESS" === (n = "string" == typeof i ? JSON.parse(i) : i).code) { var r = o.roadNetPointMap; r[A] = {}; for (var a = 0, s = n.data.length; s > a; a += 1) { var l = n.data[a]; r[A][l.key] = l } e() } else t(n.message) })).catch((function () { Bh.error("获取模型路网列表失败"), t("获取模型路网列表失败") })) }))), n.push(new Promise((function (e, t) { (function (A) { var e = A.viewer3D.getViewerImpl().getModel(A.modelKey), t = HE(e, ["loader", "url", "serverUrl"]) || HE(A, ["viewer3D", "host"], ""), i = e.projectKey, o = e.accessToken, n = ""; e.share && (n = "&share=" + e.share); var r = { url: "".concat(t, "/").concat(A.apiVersion || "api", "/").concat(i, "/routes/edges?routeKey=").concat(A.routeKey).concat(n) }; return o && (r.headers = { Authorization: o }), _d(r) })({ viewer3D: i.viewer3D, routeKey: A, modelKey: r }).then((function (i) { var n; "SUCCESS" === (n = "string" == typeof i ? JSON.parse(i) : i).code ? (o.roadNetEdgeMap[A] = n.data, e()) : t(n.message) })).catch((function () { Bh.error("获取模型路网列表失败"), t("获取模型路网列表失败") })) }))), Promise.all(n); Bh.error("模型路网未初始化") } }, { key: "initRoadNetByModelKey", value: function (A) { var e = this; return new Promise((function (t, i) { e._getRoadNetListByModelKey(A).then(t).catch(i) })) } }, { key: "getRoadNetInfoListByModelKey", value: function (A) { return this.mapRoadNetListByModelKey[A] } }, { key: "addRoadNetByKey", value: function (A, e) { var t = this, i = this, o = e.color, n = e.width, r = void 0 === n ? 1 : n, a = e.block, s = void 0 === a || a; return new Promise((function (e, n) { return o instanceof Xh ? "number" != typeof r ? (Bh.error("width 参数非法"), void n("width 参数非法")) : void(i.roadNetLineMap[A] ? e() : t._getRoadNetDataByRouteKey(A).then((function () { for (var t = i.roadNetEdgeMap[A], a = i.roadNetPointMap[A], l = [], c = 0, h = t.length; h > c; c += 1) { var d = t[c], p = d._from.split("/")[1], g = d._to.split("/")[1], u = a[p].xyz; u || (Bh.error("点", p, "不存在"), n("点" + p + "不存在")), l.push.apply(l, yc(u)); var f = a[g].xyz; f || (Bh.error("点", g, "不存在"), n("点" + g + "不存在")), l.push.apply(l, yc(f)) } var m = new JC; m.setPositions(l); var C = new YC({ color: o.getHex(), linewidth: r / 1e3 }); s || (C.depthTest = !1, C.transparent = !0); var y = new XC(m, C); y.matrixAutoUpdate = !1; var v = i.mapModelKeyByRoadNetKey[A]; if (!v) return Bh.error("模型路网未初始化"), void n("模型路网未初始化"); var I = i.viewer3D.getModelMatrix(v); y.matrix.copy(I), i.viewer3D.getScene().add(y), y.updateMatrixWorld(!0), i.roadNetLineMap[A] = y, i.viewer3D.render(), e() })).catch((function (A) { n(A) }))) : (Bh.error("color 参数非法"), void n("color 参数非法")) })) } }, { key: "removeRoadNetByKey", value: function (A) { this.roadNetLineMap[A] ? (this.viewer3D.getScene().remove(this.roadNetLineMap[A]), delete this.roadNetLineMap[A], this.viewer3D.render()) : Bh.warn("路网", A, "不存在") } }, { key: "showRoadNetByKey", value: function (A) { this.roadNetLineMap[A] ? (this.roadNetLineMap[A].visible = !0, this.viewer3D.render()) : Bh.warn("路网", A, "不存在") } }, { key: "hideRoadNetByKey", value: function (A) { this.roadNetLineMap[A] ? (this.roadNetLineMap[A].visible = !1, this.viewer3D.render()) : Bh.warn("路网", A, "不存在") } }, { key: "setRoadNetColorByKey", value: function (A, e) { if (this.roadNetLineMap[A]) { if (!(e instanceof Xh)) return void Bh.warn("color 参数非法"); this.roadNetLineMap[A].material.color = e.getHex(), this.viewer3D.render() } else Bh.warn("路网", A, "不存在") } }, { key: "setRoadNetBlockByKey", value: function (A, e) { this.roadNetLineMap[A] ? (e ? (this.roadNetLineMap[A].material.depthTest = !0, this.roadNetLineMap[A].material.transparent = !1) : (this.roadNetLineMap[A].material.depthTest = !1, this.roadNetLineMap[A].material.transparent = !0), this.viewer3D.render()) : Bh.warn("路网", A, "不存在") } }, { key: "setRoadNetLineWidthByKey", value: function (A, e) { this.roadNetLineMap[A] ? (this.roadNetLineMap[A].material.linewidth = e / 1e3, this.viewer3D.render()) : Bh.warn("路网", A, "不存在") } }, { key: "update", value: function () { for (var A in this.roadNetLineMap) if (this.roadNetLineMap.hasOwnProperty(A)) { var e = this.roadNetLineMap[A], t = this.viewer3D.getModelMatrix(this.mapModelKeyByRoadNetKey[A]); e.matrix.copy(t), e.updateMatrixWorld(!0) } for (var i in this.shortestPathLineMap) if (this.shortestPathLineMap.hasOwnProperty(i)) { var o = this.shortestPathLineMap[i], n = this.viewer3D.getModelMatrix(o.userData.modelKey); o.matrix.copy(n), o.updateMatrixWorld(!0) } this.viewer3D.render() } }, { key: "getShortestPath", value: function (A, e, t, i) { var o = this, n = this; return new Promise((function (i, r) { o.roadNetInfoMap[A] || r({ code: "error", detail: "路网".concat(A, "未初始化"), start: e, end: t }); var a = o.mapModelKeyByRoadNetKey[A]; if (!a) return Bh.error("模型路网未初始化"), void r("模型路网未初始化"); (function (A) { var e = A.viewer3D.getViewerImpl().getModel(A.modelKey), t = HE(e, ["loader", "url", "serverUrl"]) || HE(A, ["viewer3D", "host"], ""), i = e.projectKey, o = e.accessToken, n = ""; e.share && (n = "&share=" + e.share); var r = { url: "".concat(t, "/").concat(A.apiVersion || "api", "/").concat(i, "/routes/shortestPath?routeKey=").concat(A.routeKey, "&start=").concat(A.start.toString(), "&end=").concat(A.end.toString()).concat(n) }; return o && (r.headers = { Authorization: o }), _d(r) })({ modelKey: a, viewer3D: n.viewer3D, routeKey: A, start: e, end: t }).then((function (o) { var n; "SUCCESS" === (n = "string" == typeof o ? JSON.parse(o) : o).code && i({ code: "success", data: { routeKey: A, points: n.data }, start: e, end: t }) })).catch((function (A) { r({ code: "error", detail: A, start: e, end: t }) })) })) } }, { key: "addShortestPathByPoints", value: function (A, e) { var t = this, i = e.color, o = e.width, n = void 0 === o ? 1 : o, r = e.block, a = void 0 === r || r; return new Promise((function (e, o) { if (!A.routeKey) return Bh.error("缺少参数routeKey"), void o("缺少参数routeKey"); if (!A.points) return Bh.error("缺少参数points"), void o("缺少参数points"); if (!(i instanceof Xh)) return Bh.error("color 参数非法"), void o("color 参数非法"); if ("number" != typeof n) return Bh.error("width 参数非法"), void o("width 参数非法"); A.key || (A.key = uh.createUUID()); for (var r = [], s = 0, l = A.points.length; l > s; s += 1) r.push.apply(r, yc(A.points[s])); var c = new KE; c.setPositions(r); var h = new YC({ color: i.getHex(), linewidth: n / 1e3 }); a || (h.depthTest = !1, h.transparent = !0); var d = new QE(c, h); d.matrixAutoUpdate = !1; var p = t.mapModelKeyByRoadNetKey[A.routeKey]; if (!p) return Bh.error("模型路网未初始化"), void o("模型路网未初始化"); var g = t.viewer3D.getModelMatrix(p); d.matrix.copy(g), d.userData.modelKey = p, d.userData.routeKey = A.routeKey, t.viewer3D.getScene().add(d), d.updateMatrixWorld(!0), t.shortestPathLineMap[A.key] = d, t.viewer3D.render(), e(A) })) } }, { key: "showShortestPathByKey", value: function (A) { this.shortestPathLineMap[A] ? (this.shortestPathLineMap[A].visible = !0, this.viewer3D.render()) : Bh.warn("最短路径", A, "不存在") } }, { key: "hideShortestPathByKey", value: function (A) { this.shortestPathLineMap[A] ? (this.shortestPathLineMap[A].visible = !1, this.viewer3D.render()) : Bh.warn("最短路径", A, "不存在") } }, { key: "removeShortestPathByKey", value: function (A) { this.shortestPathLineMap[A] ? (this.viewer3D.getScene().remove(this.shortestPathLineMap[A]), delete this.shortestPathLineMap[A], this.viewer3D.render()) : Bh.warn("最短路径", A, "不存在") } }, { key: "setShortestPathColorByKey", value: function (A, e) { if (this.shortestPathLineMap[A]) { if (!(e instanceof Xh)) return void Bh.warn("color 参数非法"); this.shortestPathLineMap[A].material.color = e.getHex(), this.viewer3D.render() } else Bh.warn("最短路径", A, "不存在") } }, { key: "setShortestPathBlockByKey", value: function (A, e) { this.shortestPathLineMap[A] ? (e ? (this.shortestPathLineMap[A].material.depthTest = !0, this.shortestPathLineMap[A].material.transparent = !1) : (this.shortestPathLineMap[A].material.depthTest = !1, this.shortestPathLineMap[A].material.transparent = !0), this.viewer3D.render()) : Bh.warn("最短路径", A, "不存在") } }, { key: "setShortestPathLineWidthByKey", value: function (A, e) { this.shortestPathLineMap[A] ? (this.shortestPathLineMap[A].material.linewidth = e / 1e3, this.viewer3D.render()) : Bh.warn("最短路径", A, "不存在") } }, { key: "roamByShortestPathData", value: function (A, e) { var t = this, i = uh.extend({}, YE, e); if (A.routeKey) if (A.points) if (i.speed) { var o = t.viewer3D.getModelMatrix(t.mapModelKeyByRoadNetKey[A.routeKey]); if (o) { var n = this.viewer3D.getViewerImpl().camera; ! function A(e, r) { if (e.length - 1 > r) { var a, s = new y(e[r][0], e[r][1], e[r][2] + i.height).applyMatrix4(o), l = new y(e[r + 1][0], e[r + 1][1], e[r + 1][2] + i.height).applyMatrix4(o), c = new y(e[r + 1][0], e[r + 1][1], e[r + 1][2] + i.height).applyMatrix4(o); if (r > e.length - 3 || (a = new y(e[r + 2][0], e[r + 2][1], e[r + 2][2] + i.height).applyMatrix4(o)), r === e.length - 2) { var h = new y(e[r + 1][0], e[r + 1][1], e[r + 1][2] + i.height).sub(new y(e[r][0], e[r][1], e[r][2] + i.height)).setLength(.1); a = new y(e[r + 1][0], e[r + 1][1], e[r + 1][2] + i.height).add(h).applyMatrix4(o) } var d = s.distanceTo(c) / i.speed * 1e3; t.viewer3D.getViewerImpl().getControlManager().setInteractiveState(!1), WE.from({ animPosition: s, animTarget: l, animUp: n.up }).to({ animPosition: c, animTarget: a, animUp: n.up }, d).onUpdate((function (A) { var e = A.animPosition; n.lookAtEXForTargetPositionUp(A.animTarget, e, n.up), t.viewer3D.getViewerImpl().cameraControl.update(!0, !0), i.callbackProcess && i.callbackProcess(e) })).onComplete((function () { n.lookAtEXForTargetPositionUp(a, c, n.up), t.viewer3D.getViewerImpl().cameraControl.update(!0, !0), i.callbackProcess && i.callbackProcess(c), i.callbackFinish && i.callbackFinish(), t.viewer3D.getViewerImpl().getControlManager().setInteractiveState(!0), A(e, r += 1) })).start(i.frameTime, !0) } else i.callbackAllFinish && i.callbackAllFinish() }(A.points, 0) } else Bh.error("无法获取路径对应的模型矩阵") } else Bh.error("speed参数非法"); else Bh.error("缺少参数points"); else Bh.error("缺少参数routeKey") } }]), A }(), zE = { fontSize: 100, color: "#ff0000", opacity: 1, side: 2, transparent: !0 }, ZE = function () { function A() { cc(this, A) } return dc(A, [{ key: "createMesh", value: function (A, e) { var t = Object.assign({}, zE, e), i = A.generateShapes(t.text, t.fontSize), o = new jA(t), n = new Ue(new ar(i), o); return t.position && this.setPos(n, t.position), t.rotation && this.setRotation(n, t.rotation), t.matrix && this.setMat(n, t.matrix), n } }, { key: "setPos", value: function (A, e) { var t; (t = A.position).set.apply(t, yc(e)), A.updateMatrixWorld(!0) } }, { key: "setMat", value: function (A, e) { A.applyMatrix4(e), A.updateMatrixWorld(!0) } }, { key: "setRotation", value: function (A, e) { var t; (t = A.rotation).set.apply(t, yc(e)), A.updateMatrixWorld(!0) } }]), A }(), XE = function () { function A(e) { cc(this, A), this.fonts = {}, this.host = e.host } return dc(A, [{ key: "loadFont", value: function (A, e) { var t = this; return new Promise((function (i, o) { _d({ type: "POST", url: "".concat(t.host, "/api/fonts"), headers: { "Content-type": "application/json;charset=UTF-8" }, data: JSON.stringify({ font: A, text: e }), responseType: "json", success: function (e) { "success" === e.code.toLowerCase() ? (t.fonts[A] ? Object.assign(t.fonts[A].data.glyphs, e.data.glyphs) : (t.fonts[A] = {}, t.fonts[A].data = e.data), t.fonts[A].font = new za(t.fonts[A].data), i(t.fonts[A].font)) : o(e) }, error: function (A, e) { o(e) } }) })) } }, { key: "getFont", value: function (A, e) { var t = this; return new Promise((function (i, o) { if (t.fonts[A]) { for (var n = e.length, r = "", a = 0; n > a; a += 1) t.fonts[A].data.glyphs[e[a]] || (r += e[a]); r ? t.loadFont(A, r).then(i).catch(o) : i(t.fonts[A].font) } else t.loadFont(A, e).then(i).catch(o) })) } }]), A }(), _E = function () { function A(e) { cc(this, A), this.viewer = e.viewer.getViewerImpl(), this.meshes = {}, this.fontLib = new XE({ host: e.viewer.host }), this.text = new ZE, this.draggingId = "" } return dc(A, [{ key: "addText", value: function (A) { var e = this; return this.fontLib.getFont(A.fontName, A.text).then((function (t) { var i = e.text.createMesh(t, A), o = uh.createUUID(); return e.meshes[o] = i, e.viewer.getScene().add(i), e.viewer.render(), { code: "success", id: o } })).catch((function (A) { return { code: "error", err: A } })) } }, { key: "removeText", value: function (A) { if (this.draggingId !== A) { var e = this.meshes[A]; e && (this.viewer.getScene().remove(e), delete this.meshes[A], this.viewer.render()) } } }, { key: "setPosition", value: function (A, e) { if (this.draggingId !== A) { var t = this.meshes[A]; t && (this.text.setPos(t, e), this.viewer.render()) } } }, { key: "setMatrix", value: function (A, e) { if (this.draggingId !== A) { var t = this.meshes[A]; t && (this.text.setMat(t, e), this.viewer.render()) } } }, { key: "setRotation", value: function (A, e) { if (this.draggingId !== A) { var t = this.meshes[A]; t && (this.text.setRotation(t, e), this.viewer.render()) } } }, { key: "getTextIDs", value: function () { return Object.keys(this.meshes) } }, { key: "dragText", value: function (A) { if ("" === this.draggingId) { var e = this.meshes[A]; e && (this.viewer.translateComponentByKey(e), this.draggingId = A) } } }, { key: "saveDragText", value: function () { "" !== this.draggingId && (this.viewer.cancelTransformComponent(!1), this.draggingId = "") } }]), A }(), $E = function () { function A(e) { cc(this, A), this.curves = {}, this.viewer = e.viewer3D, this.modelKey = e.modelKey } return dc(A, [{ key: "getId", value: function (A) { return Bd(JSON.stringify(A)).slice(0, 8) } }, { key: "getCurve", value: function (A) { return this.curves[A] } }, { key: "_setCurve", value: function (A, e) { this.curves[A] = e } }, { key: "_rmCurve", value: function (A) { delete this.curves[A] } }, { key: "genTHREELine", value: function (A) { var e = A.num, t = void 0 === e ? 100 : e, i = A.debug, o = void 0 !== i && i, n = new la(A.points, A.closed, A.curveType, A.tension), r = this.getId(A), a = new De; a.vertices = n.getSpacedPoints(t); var s = new Go(a, new ko({ color: A.color || 16777215 * Math.random(), linewidth: 6.18, depthTest: !0, transparent: !1 })); o && (this.viewer.getViewerImpl().modelManager.getModel(this.modelKey).group.add(s), s.updateMatrixWorld(), this.viewer.render()); return this._setCurve(r, { curve: n, num: t, line: s }), r } }, { key: "rmCurve", value: function (A) { var e = this.getCurve(A).line; this.viewer.getViewerImpl().modelManager.getModel(this.modelKey).group.remove(e), e.updateMatrixWorld(), this.viewer.render(), this._rmCurve(A) } }]), A }(), AB = function () { function A(e) { cc(this, A), this.trackSet = {}, this.lineManager = new $E(e), this.viewer = e.viewer3D } return dc(A, [{ key: "_genLine", value: function (A) { return this.lineManager.genTHREELine(A) } }, { key: "addTrack", value: function (A) { var e = ((new Date).getTime() * (Math.random() + 1)).toString(36).slice(0, 8), t = this._genLine(A); return this.trackSet[e] = { componentKey: A.componentKey, lineId: [t] }, e } }, { key: "appendTrack", value: function (A) { var e = this.trackSet[A.trackId]; if (e) { var t = this._genLine(A); e.lineId.push(t) } } }, { key: "removeTrack", value: function (A) { var e = this, t = this.trackSet[A]; t && (t.lineId.forEach((function (A) { e.lineManager.rmCurve(A) })), delete this.trackSet[A]) } }, { key: "startMove", value: function (A) { var e = this, t = A.trackId, i = A.startDir, o = A.pointFn; return new Promise((function (A, n) { var r = e.trackSet[t]; if (r) { var a = r.lineId, s = r.componentKey, l = new M, c = a.length, h = e.lineManager.getCurve(a[0]).curve.getPoint(0), d = e.viewer.getBoxByComponentsKey(s), p = d.min, g = d.max, u = (new y).addVectors(p, g).divideScalar(2); l.elements[12] = h.x - u.x, l.elements[13] = h.y - u.y, l.elements[14] = h.z - u.z, e.viewer.componentApplyMatrix(s, l); var m = 0, C = new M, v = i.clone().normalize(), I = function i(n) { var r = e.lineManager.getCurve(a[Math.trunc(m)]).curve.getPoint(m - Math.trunc(m)), h = c > n ? e.lineManager.getCurve(a[Math.trunc(n)]).curve.getPoint(n - Math.trunc(n)) : e.lineManager.getCurve(a[c - 1]).curve.getPoint(1), d = new M; d.elements[12] = -r.x, d.elements[13] = -r.y, d.elements[14] = -r.z; var p = new f, g = new y(h.x - r.x, h.y - r.y, h.z - r.z).normalize(); p.setFromUnitVectors(v, g), v.applyQuaternion(p); var u = (new M).makeRotationFromQuaternion(p), I = new M; I.elements[12] = h.x, I.elements[13] = h.y, I.elements[14] = h.z, l.elements = C.elements, e.viewer.componentApplyMatrix(s, I.multiply(u).multiply(d)), m = n, c > n ? "function" == typeof o ? requestAnimationFrame((function () { i(o(t, n, h)) })) : requestAnimationFrame((function () { return i(parseFloat((n + .01).toFixed(2))) })) : A({ code: "success", trackId: t }) }; "function" == typeof o ? requestAnimationFrame((function () { I(o(t, 0, h)) })) : requestAnimationFrame((function () { return I(.01) })) } else n({ code: "error", message: "找不到指定轨迹" }) })) } }]), A }(), eB = function (A, e) { Ue.call(this, A); var t = this, i = void 0 !== (e = e || {}).textureWidth ? e.textureWidth : 512, o = void 0 !== e.textureHeight ? e.textureHeight : 512, n = void 0 !== e.clipBias ? e.clipBias : 0, r = void 0 !== e.alpha ? e.alpha : 1, s = void 0 !== e.time ? e.time : 0, l = void 0 !== e.waterNormals ? e.waterNormals : null, c = void 0 !== e.sunDirection ? e.sunDirection : new y(.70707, .70707, 0), h = new LA(void 0 !== e.sunColor ? e.sunColor : 16777215), d = new LA(void 0 !== e.waterColor ? e.waterColor : 8355711), u = void 0 !== e.eye ? e.eye : new y(0, 0, 0), f = void 0 !== e.distortionScale ? e.distortionScale : 20, m = void 0 !== e.side ? e.side : 0, C = void 0 !== e.fog && e.fog, v = new EA, I = new y, E = new y, B = new y, x = new M, S = new y(0, 0, -1), w = new p, b = new y, U = new y, F = new p, K = new M, Q = new je, R = new g(i, o, { minFilter: 1006, magFilter: 1006, format: 1022, stencilBuffer: !1 }); a.isPowerOfTwo(i) && a.isPowerOfTwo(o) || (R.texture.generateMipmaps = !1); var T = { uniforms: Ge.merge([Xe.fog, Xe.lights, { normalSampler: { value: null }, mirrorSampler: { value: null }, alpha: { value: 1 }, time: { value: 0 }, size: { value: 1 }, distortionScale: { value: 20 }, textureMatrix: { value: new M }, sunColor: { value: new LA(8355711) }, sunDirection: { value: new y(.70707, .70707, 0) }, eye: { value: new y }, waterColor: { value: new LA(5592405) } }]), vertexShader: ["uniform mat4 textureMatrix;", "uniform float time;", "varying vec4 mirrorCoord;", "varying vec4 worldPosition;", tt.fog_pars_vertex, tt.shadowmap_pars_vertex, "void main() {", " mirrorCoord = modelMatrix * vec4( position, 1.0 );", " worldPosition = mirrorCoord.xyzw;", " mirrorCoord = textureMatrix * mirrorCoord;", " vec4 mvPosition = modelViewMatrix * vec4( position, 1.0 );", " gl_Position = projectionMatrix * mvPosition;", tt.fog_vertex, tt.shadowmap_vertex, "}"].join("\n"), fragmentShader: ["uniform sampler2D mirrorSampler;", "uniform float alpha;", "uniform float time;", "uniform float size;", "uniform float distortionScale;", "uniform sampler2D normalSampler;", "uniform vec3 sunColor;", "uniform vec3 sunDirection;", "uniform vec3 eye;", "uniform vec3 waterColor;", "varying vec4 mirrorCoord;", "varying vec4 worldPosition;", "vec4 getNoise( vec2 uv ) {", " vec2 uv0 = ( uv / 103.0 ) + vec2(time / 17.0, time / 29.0);", " vec2 uv1 = uv / 107.0-vec2( time / -19.0, time / 31.0 );", " vec2 uv2 = uv / vec2( 8907.0, 9803.0 ) + vec2( time / 101.0, time / 97.0 );", " vec2 uv3 = uv / vec2( 1091.0, 1027.0 ) - vec2( time / 109.0, time / -113.0 );", " vec4 noise = texture2D( normalSampler, uv0 ) +", " texture2D( normalSampler, uv1 ) +", " texture2D( normalSampler, uv2 ) +", " texture2D( normalSampler, uv3 );", " return noise * 0.5 - 1.0;", "}", "void sunLight( const vec3 surfaceNormal, const vec3 eyeDirection, float shiny, float spec, float diffuse, inout vec3 diffuseColor, inout vec3 specularColor ) {", " vec3 reflection = normalize( reflect( -sunDirection, surfaceNormal ) );", " float direction = max( 0.0, dot( eyeDirection, reflection ) );", " specularColor += pow( direction, shiny ) * sunColor * spec;", " diffuseColor += max( dot( sunDirection, surfaceNormal ), 0.0 ) * sunColor * diffuse;", "}", tt.common, tt.packing, tt.bsdfs, tt.fog_pars_fragment, tt.lights_pars_begin, tt.shadowmap_pars_fragment, tt.shadowmask_pars_fragment, "void main() {", " vec4 noise = getNoise( worldPosition.xz * size );", " vec3 surfaceNormal = normalize( noise.xzy * vec3( 1.5, 1.0, 1.5 ) );", " vec3 diffuseLight = vec3(0.0);", " vec3 specularLight = vec3(0.0);", " vec3 worldToEye = eye-worldPosition.xyz;", " vec3 eyeDirection = normalize( worldToEye );", " sunLight( surfaceNormal, eyeDirection, 100.0, 2.0, 0.5, diffuseLight, specularLight );", " float distance = length(worldToEye);", " vec2 distortion = surfaceNormal.xz * ( 0.001 + 1.0 / distance ) * distortionScale;", " vec3 reflectionSample = vec3( texture2D( mirrorSampler, mirrorCoord.xy / mirrorCoord.w + distortion ) );", " float theta = max( dot( eyeDirection, surfaceNormal ), 0.0 );", " float rf0 = 0.3;", " float reflectance = rf0 + ( 1.0 - rf0 ) * pow( ( 1.0 - theta ), 5.0 );", " vec3 scatter = max( 0.0, dot( surfaceNormal, eyeDirection ) ) * waterColor;", " vec3 albedo = mix( ( sunColor * diffuseLight * 0.3 + scatter ) * getShadowMask(), ( vec3( 0.1 ) + reflectionSample * 0.9 + reflectionSample * specularLight ), reflectance);", " vec3 outgoingLight = albedo;", " gl_FragColor = vec4( outgoingLight, alpha );", tt.tonemapping_fragment, tt.fog_fragment, "}"].join("\n") }, k = new Pe({ fragmentShader: T.fragmentShader, vertexShader: T.vertexShader, uniforms: Ge.clone(T.uniforms), transparent: 1 > r, lights: !0, side: m, fog: C }); k.uniforms.mirrorSampler.value = R.texture, k.uniforms.textureMatrix.value = K, k.uniforms.alpha.value = r, k.uniforms.time.value = s, k.uniforms.normalSampler.value = l, k.uniforms.sunColor.value = h, k.uniforms.waterColor.value = d, k.uniforms.sunDirection.value = c, k.uniforms.distortionScale.value = f, k.uniforms.eye.value = u, t.material = k, t.onBeforeRender = function (A, e, i) { if (E.setFromMatrixPosition(t.matrixWorld), B.setFromMatrixPosition(i.matrixWorld), x.extractRotation(t.matrixWorld), I.set(0, 0, 1), I.applyMatrix4(x), b.subVectors(E, B), 0 >= b.dot(I)) { b.reflect(I).negate(), b.add(E), x.extractRotation(i.matrixWorld), S.set(0, 0, -1), S.applyMatrix4(x), S.add(B), U.subVectors(E, S), U.reflect(I).negate(), U.add(E), Q.position.copy(b), Q.up.set(0, 1, 0), Q.up.applyMatrix4(x), Q.up.reflect(I), Q.lookAt(U), Q.far = i.far, Q.updateMatrixWorld(), Q.projectionMatrix.copy(i.projectionMatrix), K.set(.5, 0, 0, .5, 0, .5, 0, .5, 0, 0, .5, .5, 0, 0, 0, 1), K.multiply(Q.projectionMatrix), K.multiply(Q.matrixWorldInverse), v.setFromNormalAndCoplanarPoint(I, E), v.applyMatrix4(Q.matrixWorldInverse), w.set(v.normal.x, v.normal.y, v.normal.z, v.constant); var o = Q.projectionMatrix; F.x = (Math.sign(w.x) + o.elements[8]) / o.elements[0], F.y = (Math.sign(w.y) + o.elements[9]) / o.elements[5], F.z = -1, F.w = (1 + o.elements[10]) / o.elements[14], w.multiplyScalar(2 / w.dot(F)), o.elements[2] = w.x, o.elements[6] = w.y, o.elements[10] = w.z + 1 - n, o.elements[14] = w.w, u.setFromMatrixPosition(i.matrixWorld); var r = A.getRenderTarget(), a = A.xr.enabled, s = A.shadowMap.autoUpdate; t.visible = !1, A.xr.enabled = !1, A.shadowMap.autoUpdate = !1, A.setRenderTarget(R), A.clear(), A.render(e, Q), t.visible = !0, A.xr.enabled = a, A.shadowMap.autoUpdate = s, A.setRenderTarget(r) } } }; (eB.prototype = Object.create(Ue.prototype)).constructor = eB; var tB = function (A) { this.name = A.name || "", this.id = A.id || "", this.keyFrameList = [], this.roamTime = 5, this.interpolateType = 1, this.fps = 50, this.parts = 100, this.rotateSpeed = Math.PI / this.roamTime / this.fps / 4, this.parameters = { segments: this.roamTime * this.fps * this.parts, closed: !1, curveType: "centripetal", tension: .25 }, this.modificationId = 0, this.mapDeltaAngle = {}, this.mapDeltaOffset = {}, this.allocateSegmentList = null, this.positionCurve = void 0, this.init(A) }; tB.prototype.init = function (A) { this.setKeyFrameList(A.keyFrameList), this.setParameters(A.parameters), this.setInterpolateType(A.type), this.setFps(A.fps), this.setRoamTime(A.roamTime) }, tB.prototype.addKeyFrame = function (A) { var e = new y(A.position.x, A.position.y, A.position.z), t = new y(A.target.x, A.target.y, A.target.z), i = new y(A.up.x, A.up.y, A.up.z), o = null; if (A.quaternion) o = new f(A.quaternion.x, A.quaternion.y, A.quaternion.z, A.quaternion.w); else { var n = new M; n.lookAt(e, t, i), o = (new f).setFromRotationMatrix(n) } this.keyFrameList.push({ position: e, target: t, up: i, id: A.id, quaternion: o, curve: A.curve }), this.modificationId += 1 }, tB.prototype.setKeyFrameList = function (A) { this.keyFrameList = []; for (var e = 0, t = A.length; t > e; e += 1) this.addKeyFrame(A[e]); this.calRotateSpeed() }, tB.prototype.removeKeyFrame = function (A) { A >= 0 && this.keyFrameList.length > A && (this.keyFrameList.splice(A, 1), this.modificationId += 1) }, tB.prototype.getKeyFrames = function () { return this.keyFrameList }, tB.prototype.getKeyFrameCount = function () { return this.keyFrameList.length }, tB.prototype.clearFrames = function () { this.keyFrameList = [] }, tB.prototype.getJumpCounts = function (A) { var e = A / (1e3 / this.fps) * this.parts; return e = parseInt(e, 0) }, tB.prototype.setRoamTime = function (A) { this.roamTime = A, this.setSegments(A * this.fps * this.parts), this.calRotateSpeed() }, tB.prototype.calRotateSpeed = function () { var A = this.getKeyFrames().length; A > 1 && (this.rotateSpeed = Math.PI * (A - 1) / this.roamTime / this.fps / 4) }, tB.prototype.setInterpolateType = function (A) { this.interpolateType = A || 1, 1 === this.interpolateType && this.setSplineTension(0) }, tB.prototype.getInterpolateType = function () { return this.interpolateType }, tB.prototype.setName = function (A) { this.name = A }, tB.prototype.getName = function () { return this.name }, tB.prototype.getId = function () { return this.id }, tB.prototype.getKeyFramePositions = function () { for (var A = [], e = 0, t = this.keyFrameList.length; t > e; e += 1) { A.push(this.keyFrameList[e].position) } return A }, tB.prototype.getKeyFramePosition = function (A) { return this.keyFrameList[A].position }, tB.prototype.getKeyFrameDirection = function (A) { var e = this.keyFrameList[A]; return e.target.clone().sub(e.position) }, tB.prototype.getKeyFrameTarget = function (A) { return this.keyFrameList[A].target }, tB.prototype.getKeyFrameUp = function (A) { return this.keyFrameList[A].up }, tB.prototype.allocateSegments = function () { for (var A = [], e = 0, t = this.keyFrameList.length; t - 1 > e; e += 1) { var i = this.keyFrameList[e].position; A.push(this.keyFrameList[e + 1].position.clone().sub(i).length()) } for (var o = 0, n = 0, r = A.length; r > n; n += 1) o += A[n]; for (var a = this.getSegments(), s = 0, l = A.length; 0 !== o && l > s; s += 1) A[s] /= o, A[s] *= this.getSegments(), A[s] = Math.floor(A[s]), a -= A[s]; for (var c = 0; a > c; c += 1) A[c] > 0 && (A[c] += 1); this.allocateSegmentList = A }, tB.prototype.getAllocateSegmentCount = function (A) { return null === this.allocateSegmentList && this.allocateSegments(), this.allocateSegmentList[A] }, tB.prototype.getSplineParam = function (A, e) { return null === this.allocateSegmentList && this.allocateSegments(), (A + e / this.allocateSegmentList[A]) / this.allocateSegmentList.length }, tB.prototype.getDeltaAngle = function (A) { return this.mapDeltaAngle[A] }, tB.prototype.calculateDeltaAngle = function () { for (var A = this.allocateSegmentList, e = 0; A.length > e; e += 1) { var t = 0; if (this.keyFrameList[e].quaternion && this.keyFrameList[e + 1].quaternion) { var i = this.keyFrameList[e].quaternion, o = this.keyFrameList[e + 1].quaternion, n = (new f).multiplyQuaternions(o, i.clone().inverse()); n.normalize(), t = 2 * Math.acos(n.w) } else { var r = this.getKeyFrameDirection(e), a = this.getKeyFrameDirection(e + 1); t = r.angleTo(a) } var s = A[e]; if (0 === s) { var l = Math.floor(t / this.rotateSpeed) * this.parts; A[e] = l, this.mapDeltaAngle[e] = t / l } else this.mapDeltaAngle[e] = t / s } }, tB.prototype.getRotateAxis = function (A) { var e = this.keyFrameList[A].quaternion, t = this.keyFrameList[A + 1].quaternion; if (e && t) { var i = (new f).multiplyQuaternions(t, e.clone().inverse()); return i.normalize(), new y(i.x, i.y, i.z).normalize() } var o = this.getKeyFrameDirection(A), n = this.getKeyFrameDirection(A + 1); return o.clone().cross(n.clone()).normalize() }, tB.prototype.getDeltaOffset = function (A) { return this.mapDeltaOffset[A] }, tB.prototype.getPositionAtCurve = function (A, e) { var t = this.keyFrameList[A + 1]; if (t && t.curve) return t.curve.getPointAt(e) }, tB.prototype.getPositionAtCurve = function (A, e) { var t = this.keyFrameList[A + 1]; if (t && t.curve) return t.curve.getPointAt(e) }, tB.prototype.getLatestPositionAtCurve = function (A) { var e = this.keyFrameList[A]; if (e && e.curve) return e.position }, tB.prototype.calculateDeltaOffset = function () { for (var A = this.allocateSegmentList, e = this.getKeyFramePositions(), t = 0; A.length > t; t += 1) { var i = e[t], o = e[t + 1], n = this.allocateSegmentList[t]; this.mapDeltaOffset[t] = 0 === n ? new y : o.clone().sub(i).divideScalar(n) } }, tB.prototype.setSplineTension = function (A) { 0 > A || A > 1 || (this.parameters.tension = A, this.modificationId += 1) }, tB.prototype.setSegments = function (A) { this.parameters.segments = A, this.modificationId += 1 }, tB.prototype.getSegments = function () { return this.parameters.segments }, tB.prototype.setParameters = function (A) { A && (this.parameters = A, this.modificationId += 1) }, tB.prototype.getParameters = function () { return this.parameters }, tB.prototype.setFps = function (A) { this.fps = A || 50, this.calRotateSpeed(), this.modificationId += 1 }, tB.prototype.getFps = function () { return this.fps }, tB.prototype.getModificationId = function () { return this.modificationId }, tB.prototype.export = function () { return { name: this.name, id: this.id, fps: this.fps, roamTime: this.roamTime, type: this.interpolateType, keyFrameList: this.keyFrameList } }; var iB = function (A) { this.viewer = A.viewer, this.roam = null, this.bPause = !1, this.bContinue = !1, this.spline = null, this.reqid = 0, this.playBinded = this._play.bind(this), this.recordId = -1, this.keyFrameIdx = 0, this.count = -1, this.camera = this.viewer.cameraControl.camera, this.pausePlayCallback = [], this.stopPlayCallback = [], this.keyFrameCallback = [], this.timeRecorder = { last: 0, pause: 0, deltaTime: 0 }, this.setRoam(A.roamData) }; iB.prototype.setRoam = function (A) { this.roam = A, this.bPause = !1, this.recordId = -1, this.spline = null, this.keyFrameIdx = 0, this.count = -1 }, iB.prototype.updateCamera = function (A, e, t) { this.camera.position.add(A), this.camera.target.addVectors(this.camera.position, e), this.camera.up.copy(t) }, iB.prototype.updateCameraToFrame = function (A) { var e = this.roam.getKeyFramePosition(A), t = this.roam.getKeyFrameTarget(A), i = this.roam.getKeyFrameUp(A); this.camera.position.copy(e), this.camera.target.copy(t), this.camera.up.copy(i) }, iB.prototype.reAllocate = function () { this.recordId !== this.roam.getModificationId() && (this.roam.allocateSegments(), this.roam.calculateDeltaOffset(), this.roam.calculateDeltaAngle(), this.recordId = this.roam.getModificationId()) }, iB.prototype._play = function () { var A = new f, e = new f, t = new y, i = new y(0, 1, 0), o = new y; return function () { this.reqid = setTimeout(this.playBinded, this.roam.getFps()), !1 === this.bContinue ? (this.bContinue = !0, this.timeRecorder.deltaTime = this.timeRecorder.pause - this.timeRecorder.last) : this.timeRecorder.deltaTime = performance.now() - this.timeRecorder.last, this.timeRecorder.last = performance.now(); var n = this.roam.getJumpCounts(this.timeRecorder.deltaTime); if (this.reAllocate(), this.bPause) return this.timeRecorder.pause = performance.now(), clearTimeout(this.reqid), this.triggerPausePlayCallback(), this.bPause = !1, void(this.bContinue = !1); var r = this.roam.getKeyFrameCount(), a = this.roam.getAllocateSegmentCount(this.keyFrameIdx); if (0 === a) this.keyFrameIdx += 1, this.triggerKeyFrameCallback(this.keyFrameIdx), this.count = -1; else if (this.keyFrameIdx === r - 1) this.updateCameraToFrame(this.keyFrameIdx), this.stop(); else if (-1 === this.count) this.timeStart = performance.now(), 0 === this.keyFrameIdx && this.triggerKeyFrameCallback(0), this.updateCameraToFrame(this.keyFrameIdx), this.count = 0; else if (a > this.count) { this.count + n > a && (n = a - this.count); var s = this.count / a, l = this.roam.keyFrameList[this.keyFrameIdx].quaternion, c = this.roam.keyFrameList[this.keyFrameIdx + 1].quaternion; A.copy(c), l.equals(c) || f.slerp(l, c, A, s); var h = this.roam.keyFrameList[this.keyFrameIdx]; t.subVectors(h.target, h.position), t.applyQuaternion(e.copy(l).inverse()), t.applyQuaternion(A), i.set(0, 1, 0), i.applyQuaternion(A); var d = this.roam.getPositionAtCurve(this.keyFrameIdx, s); if (d) this.camera.position.copy(d); else { var p = this.roam.getDeltaOffset(this.keyFrameIdx); o.copy(p).multiplyScalar(n), this.camera.position.add(o) } if (this.camera.target.addVectors(this.camera.position, t), this.camera.up.copy(i), a > this.count + n) this.count += n; else { this.keyFrameIdx += 1; var g = this.roam.getLatestPositionAtCurve(this.keyFrameIdx); g && this.camera.position.copy(g), this.triggerKeyFrameCallback(this.keyFrameIdx), this.count = 0 } } this.viewer.render() } }(), iB.prototype.play = function () { this.bPause = !1, this._play() }, iB.prototype.pause = function () { this.bPause = !0 }, iB.prototype.continue = function () { this.bContinue = !0, this.bPause = !1, this._play() }, iB.prototype.stop = function () { this.bPause = !1, this.keyFrameIdx = 0, this.count = -1, clearTimeout(this.reqid), this.triggerStopPlayCallback() }, iB.prototype.startFrom = function (A) { for (var e = this.roam, t = e.getKeyFrameCount(), i = e.getKeyFrames(), o = 0; t > o; o += 1) if (i[o].id === A) return this.keyFrameIdx = o, void(this.count = -1) }, iB.prototype.addKeyFrameCallback = function (A) { this.keyFrameCallback.push(A) }, iB.prototype.addPausePlayCallback = function (A) { this.pausePlayCallback.push(A) }, iB.prototype.addStopPlayCallback = function (A) { this.stopPlayCallback.push(A) }, iB.prototype.triggerKeyFrameCallback = function (A) { this.keyFrameCallback.forEach((function (e) { e(A) })) }, iB.prototype.triggerPausePlayCallback = function () { this.pausePlayCallback.forEach((function (A) { A() })) }, iB.prototype.triggerStopPlayCallback = function () { this.stopPlayCallback.forEach((function (A) { A() })) }, iB.prototype.updataSpline = function () { var A = this.roam.getKeyFramePositions(), e = this.roam.getParameters(); this.spline = new la(A, e.closed, e.curveType, e.tension) }; var oB = function () { this.roamList = [] }; oB.prototype.clear = function () { this.roamList = [] }, oB.prototype.add = function (A) { this.roamList.push(A) }, oB.prototype.remove = function (A) { for (var e = 0, t = this.roamList.length; t > e; e += 1) { if (this.roamList[e].getName() === A) return void this.roamList.splice(e, 1) } }, oB.prototype.save = function () { return JSON.stringify(this.roamList) }, oB.prototype.load = function (A) { this.clear(); for (var e = JSON.parse(A), t = 0, i = e.length; i > t; t += 1) { var o = new tB({ name: e[t].name, keyFrameList: e[t].keyFrameList, parameters: e[t].parameters, roamTime: e[t].roamTime, type: e[t].type, fps: e[t].fps }); this.add(o) } return this.roamList }; var nB = function (A, e) { this.coordinateSystem = A, this.viewer = A.viewer, this.drawingImpl = e, this.viewportOffset = this.viewer.domElement.getBoundingClientRect(), this.cameraControl = this.viewer.cameraControl, this.fillClipPlane = this.viewer.getScene().getFillClipPlane(), this.initialize() }; nB.prototype.initialize = function () { this.arrowMouseDown = !1, this.circleXMouseDown = !1, this.circleYMouseDown = !1, this.firstClickDown = !0, this.firstRotate = !0, this.lineOut = !0, this.arrowOut = !0, this.translateStartPt = new s, this.translateEndPt = new s, this.rotateAngleA = 0, this.rotateAngleB = 0, this.config = this.coordinateSystem.config }, nB.prototype.registerArrowEvents = function () { var A = this.drawingImpl.getDrawable("axisZ"), e = this, t = this.config.colors; A.onmouseover = function () { !0 !== e.circleXMouseDown && !0 !== e.circleYMouseDown && (e.drawingImpl.setColor("axisZ", t.highLight), e.drawingImpl.fill("arrow", t.highLight), e.drawingImpl.setColor("tipArcX", t.default), e.drawingImpl.fill("cubeX", t.default), e.drawingImpl.setColor("tipArcY", t.default), e.drawingImpl.fill("cubeY", t.default), e.lineOut = !1) }, A.onmouseout = function () { !0 !== e.circleXMouseDown && !0 !== e.circleYMouseDown && !1 === e.arrowMouseDown && !0 === e.arrowOut && (e.drawingImpl.setColor("axisZ", t.arrow), e.drawingImpl.fill("arrow", t.arrow), e.drawingImpl.setColor("tipArcX", t.tipArcX), e.drawingImpl.fill("cubeX", t.cubeX), e.drawingImpl.setColor("tipArcY", t.tipArcY), e.drawingImpl.fill("cubeY", t.cubeY), e.lineOut = !0) }, A.onmousedown = function (A) { e.arrowMouseDown = !0, e.lineOut = !1; var t = e.config.colors; e.drawingImpl.setColor("axisZ", t.highLight), e.drawingImpl.fill("arrow", t.highLight), e.coordinateSystem.colorUpdate = !1, e.translateStartPt.set(A.clientX, A.clientY) }; var i = this.drawingImpl.getDrawable("arrow"); i.onmouseover = function () { if (!0 !== e.circleXMouseDown && !0 !== e.circleYMouseDown) { e.arrowOut = !1; var A = e.config.colors; e.drawingImpl.fill("arrow", A.highLight), e.drawingImpl.setColor("axisZ", A.highLight), e.drawingImpl.setColor("tipArcX", A.default), e.drawingImpl.fill("cubeX", A.default), e.drawingImpl.setColor("tipArcY", A.default), e.drawingImpl.fill("cubeY", A.default) } }, i.onmouseout = function () { if (!0 !== e.circleXMouseDown && !0 !== e.circleYMouseDown && !1 === e.arrowMouseDown && !0 === e.lineOut) { e.arrowOut = !0; var A = e.config.colors; e.drawingImpl.setColor("axisZ", A.arrow), e.drawingImpl.fill("arrow", A.arrow), e.drawingImpl.setColor("tipArcX", A.tipArcX), e.drawingImpl.fill("cubeX", A.cubeX), e.drawingImpl.setColor("tipArcY", A.tipArcY), e.drawingImpl.fill("cubeY", A.cubeY) } }, i.onmousedown = function (A) { e.arrowMouseDown = !0, e.arrowOut = !1; var t = e.config.colors; e.drawingImpl.setColor("axisZ", t.highLight), e.drawingImpl.fill("arrow", t.highLight), e.translateStartPt.set(A.clientX, A.clientY) }, document.onmousemove = function (A) { if (!0 === e.arrowMouseDown) { if (!(A.clientX === e.translateStartPt.x && A.clientY === e.translateStartPt.y)) { var t = e.fillClipPlane.renderClipPlane, i = t.normal.clone(); i.w = t.constant; var o = e.cameraControl.movePlane(i, A, e.translateStartPt, !1, e.fillClipPlane.position.clone()); null !== o && e.fillClipPlane.offset(o), e.translateStartPt.set(A.clientX, A.clientY), e.cameraControl.update(!0) } e.coordinateSystem.update(); var n = e.config.colors; e.drawingImpl.setColor("axisZ", n.highLight), e.drawingImpl.fill("arrow", n.highLight), e.drawingImpl.setColor("tipArcX", n.default), e.drawingImpl.fill("cubeX", n.default), e.drawingImpl.setColor("tipArcY", n.default), e.drawingImpl.fill("cubeY", n.default), A.preventDefault(), A.stopPropagation() } }, document.onmouseup = function () { if (!1 !== e.arrowMouseDown) { e.arrowMouseDown = !1, e.coordinateSystem.colorUpdate = !0; var A = e.config.colors; e.drawingImpl.setColor("axisZ", A.arrow), e.drawingImpl.fill("arrow", A.arrow), e.drawingImpl.setColor("tipArcX", A.tipArcX), e.drawingImpl.fill("cubeX", A.cubeX), e.drawingImpl.setColor("tipArcY", A.tipArcY), e.drawingImpl.fill("cubeY", A.cubeY), vc.ClippingCaps = !0, e.viewer.render() } } }, nB.prototype.registerCircleXEvents = function () { var A = this, e = this.config.colors, t = this.drawingImpl.getDrawable("tipArcX"); t.onmousedown = function () { A.circleXMouseDown = !0, A.drawingImpl.setColor("axisZ", e.default), A.drawingImpl.fill("arrow", e.default), A.enableCircleXMovement() }, t.onmouseout = function () { !1 === A.circleXMouseDown && (A.drawingImpl.setColor("axisZ", e.arrow), A.drawingImpl.fill("arrow", e.arrow), A.drawingImpl.setColor("tipArcY", e.tipArcY), A.drawingImpl.fill("cubeY", e.cubeY), A.coordinateSystem.circleToArc("tipArcX")) }, document.addEventListener("mouseup", (function () { !0 === A.circleXMouseDown && (vc.ClippingCaps = !0, A.viewer.render()), A.circleXMouseDown = !1, A.firstClickDown = !0, A.firstRotate = !1, A.lastRotateX = 0, A.lastRotateY = 0, A.drawingImpl.show("tipArcY", !0), A.drawingImpl.show("axisY", !0), A.drawingImpl.show("axisZ", !0), A.drawingImpl.show("cubeY", !0), A.coordinateSystem.update(), A.drawingImpl.show("dashLineX", !1), A.drawingImpl.setColor("axisZ", e.arrow), A.drawingImpl.fill("arrow", e.arrow) })) }, nB.prototype.registerCircleYEvents = function () { var A = this, e = this.config.colors, t = this.drawingImpl.getDrawable("tipArcY"); t.onmousedown = function () { A.circleYMouseDown = !0, A.drawingImpl.setColor("axisZ", e.default), A.drawingImpl.fill("arrow", e.default), A.enableCircleYMovement() }, t.onmouseout = function () { !1 === A.circleYMouseDown && (A.drawingImpl.setColor("axisZ", e.arrow), A.drawingImpl.fill("arrow", e.arrow), A.coordinateSystem.circleToArc("tipArcY"), A.drawingImpl.setColor("tipArcX", e.tipArcX), A.drawingImpl.fill("cubeX", e.cubeX)) }, document.addEventListener("mouseup", (function () { !0 === A.circleYMouseDown && (vc.ClippingCaps = !0, A.viewer.render()), A.circleYMouseDown = !1, A.drawingImpl.show("tipArcX", !0), A.drawingImpl.show("cubeX", !0), A.coordinateSystem.update(), A.drawingImpl.show("dashLineY", !1), A.drawingImpl.setColor("axisZ", e.arrow), A.drawingImpl.fill("arrow", e.arrow) })) }, nB.prototype.enableCircleXMovement = function () { var A = this, e = this.config.colors; document.addEventListener("mousemove", (function (t) { if (!0 === A.circleXMouseDown) { A.drawingImpl.show("dashLineX", !0), A.drawingImpl.setColor("axisZ", e.default), A.drawingImpl.fill("arrow", e.default), vc.ClippingCaps = !1; var i = A.fillClipPlane.normalIndex, o = A.viewportOffset, n = new s(t.clientX - o.left, t.clientY - o.top), r = A.calcRotateAngleIndex(n, A.coordinateSystem.discretePointsX); !0 === A.firstClickDown && (A.lastIndex = r); var a = 2 * (r - A.lastIndex); i > 3 && (a = -a), A.drawingImpl.show("tipArcY", !1), A.coordinateSystem.updateAxisZ(); var l = A.fillClipPlane.renderClipPlane.normal.clone(), c = A.coordinateSystem.getCoordinateAxis(), h = A.config.styles; A.coordinateSystem.drawClipPlaneCircle("tipArcZ", c.start.clone(), h.auxCircleRadius, A.coordinateSystem.dirX, l); var d = A.coordinateSystem.drawingToCanvas(c.start.clone()), p = A.coordinateSystem.drawingToCanvas(c.endY.clone()); A.coordinateSystem.drawAxisY(d, p, e.highLight), A.coordinateSystem.drawCubeX("cubeX", p, h.cubeRadius), A.drawingImpl.show("cubeY", !1); var g = "x"; 2 > i && (g = "y"), A.fillClipPlane.rotateAngleOffset(a, g), A.coordinateSystem.backwardCoordinate(), !0 === A.firstClickDown ? A.firstClickDown = !1 : A.lastIndex = r, A.translateStartPt.set(t.clientX, t.clientY), A.viewer.render(), t.preventDefault(), t.stopPropagation() } })) }, nB.prototype.enableCircleYMovement = function () { var A = this, e = this.config.colors; document.addEventListener("mousemove", (function (t) { if (!0 === A.circleYMouseDown) { A.drawingImpl.show("dashLineY", !0), A.drawingImpl.setColor("axisZ", e.default), A.drawingImpl.fill("arrow", e.default), vc.ClippingCaps = !1; var i = A.fillClipPlane.normalIndex, o = A.viewportOffset, n = new s(t.clientX - o.left, t.clientY - o.top), r = A.calcRotateAngleIndex(n, A.coordinateSystem.discretePointsY); !0 === A.firstClickDown && (A.lastIndex = r); var a = 2 * (r - A.lastIndex); i > 3 && (a = -a), A.drawingImpl.show("tipArcX", !1), A.coordinateSystem.updateAxisZ(); var l = A.fillClipPlane.renderClipPlane.normal.clone(), c = A.coordinateSystem.getCoordinateAxis(), h = A.config.styles; A.coordinateSystem.drawClipPlaneCircle("tipArcZ", c.start.clone(), h.auxCircleRadius, A.coordinateSystem.dirX.clone(), l.clone()); var d = A.coordinateSystem.drawingToCanvas(c.start.clone()), p = A.coordinateSystem.drawingToCanvas(c.endX.clone()); A.coordinateSystem.drawAxisX(d, p, e.highLight), A.coordinateSystem.drawCubeY("cubeY", p, h.cubeRadius), A.drawingImpl.show("cubeX", !1); var g = "z"; i > 3 && (g = "y"), A.fillClipPlane.rotateAngleOffset(a, g), A.coordinateSystem.backwardCoordinate(), !0 === A.firstClickDown ? A.firstClickDown = !1 : A.lastIndex = r, A.translateStartPt.set(t.clientX, t.clientY), A.viewer.render(), t.preventDefault(), t.stopPropagation() } })) }, nB.prototype.registerTipArcXEvents = function () { var A = this, e = this.config.colors, t = this.drawingImpl.getDrawable("tipArcX"); t.onmouseover = function () { !1 === A.circleYMouseDown && (A.coordinateSystem.arcToCircle("tipArcX"), A.drawingImpl.setColor("tipArcY", e.default), A.drawingImpl.fill("cubeY", e.default), A.drawingImpl.setColor("axisZ", e.default), A.drawingImpl.fill("arrow", e.default), A.registerCircleXEvents()) }, t.onmouseout = function () { !1 === A.circleXMouseDown && A.coordinateSystem.circleToArc("tipArcX") } }, nB.prototype.registerTipArcYEvents = function () { var A = this, e = this.config.colors, t = this.drawingImpl.getDrawable("tipArcY"); t.onmouseover = function () { !1 === A.circleXMouseDown && (A.coordinateSystem.arcToCircle("tipArcY"), A.drawingImpl.setColor("tipArcX", e.default), A.drawingImpl.fill("cubeX", e.default), A.drawingImpl.setColor("axisZ", e.default), A.drawingImpl.fill("arrow", e.default), A.registerCircleYEvents()) }, t.onmouseout = function () { !1 === A.circleYMouseDown && A.coordinateSystem.circleToArc("tipArcY") } }, nB.prototype.calcRotateAngleIndex = function (A, e) { for (var t = this.createLine(A, this.coordinateSystem.cOrigin), i = -1, o = Number.POSITIVE_INFINITY, n = 0; 90 > n; n += 1) { var r = e[n].clone(), a = this.disPointToLine(r, t); o > a && (o = a, i = n) } var s = 90 + i, l = e[i].clone().distanceTo(A); return e[s].clone().distanceTo(A) > l ? i : s }, nB.prototype.createLine = function (A, e) { var t = {}; if (A.x === e.x) t.A = 1, t.B = 0, t.C = -A.x; else { var i = (e.y - A.y) / (e.x - A.x), o = e.y - i * e.x; t.A = i, t.B = -1, t.C = o } return t }, nB.prototype.disPointToLine = function (A, e) { return Math.abs(e.A * A.x + e.B * A.y + e.C) / Math.sqrt(e.A * e.A + e.B * e.B) }; var rB = function () { return { colors: { tipArcX: "#0000FF", cubeX: "#0000FF", tipArcY: "#FF0000", cubeY: "#FF0000", highLight: "#FFFF00", tipLine: "#4dc0ff", arrow: "#4dc0ff", default: "#A9A9A9" }, styles: { dashArray: "10 8", originRadius: 5, auxCircleRadius: .1, tipLineLength: .1, cubeRadius: 5, axisXWidth: 2, axisYWidth: 2, axisZWidth: 3, axisXLength: .1, axisYLength: .1, axisZLength: .14, segments: 180, tipArcLeftCounts: 45, tipArcRightCounts: 45 } } }, aB = function (A, e) { this.coordinateSystem = A, this.viewer = e, this.container = this.viewer.domElement.querySelector("div:first-child"), this.mapDrawables = {}, this.initialize() }; aB.prototype.initialize = function () { this.xmlns = "http://www.w3.org/2000/svg"; var A = document.createElement("div"); A.style.left = "0px", A.style.top = "0px", A.style.width = this.container.offsetWidth + "px", A.style.height = this.container.offsetHeight + "px", A.style.position = "absolute", this.group = document.createElementNS(this.xmlns, "svg"), this.group.setAttribute("width", String(this.container.offsetWidth)), this.group.setAttribute("height", String(this.container.offsetHeight)), A.appendChild(this.group), this.container.appendChild(A) }, aB.prototype.makeCircle = function (A, e) { var t = this.mapDrawables; void 0 === t[A] && (t[A] = document.createElementNS(this.xmlns, "circle"), this.group.appendChild(t[A])); var i = t[A]; i.style.fill = e.color || "#FF0000", i.setAttribute("r", String(e.radius)), i.setAttribute("transform", "translate(" + e.center.x + "," + e.center.y + ")") }, aB.prototype.show = function (A, e) { var t = this.getDrawable(A); t && (t.style.display = e ? "block" : "none") }, aB.prototype.fill = function (A, e) { this.getDrawable(A).style.fill = e ? "block" : "none" }, aB.prototype.makeLine = function (A, e) { var t = this.mapDrawables; void 0 === t[A] && (t[A] = document.createElementNS(this.xmlns, "line"), this.group.appendChild(t[A])); var i = t[A]; i.setAttribute("stroke", e.color || "#000000"), i.setAttribute("stroke-width", e.width || 3), i.setAttribute("x1", String(e.start.x)), i.setAttribute("y1", String(e.start.y)), i.setAttribute("x2", String(e.end.x)), i.setAttribute("y2", String(e.end.y)) }, aB.prototype.makeDashLine = function (A, e) { this.makeLine(A, e), this.mapDrawables[A].setAttribute("stroke-dasharray", e.dashArray) }, aB.prototype.makePolyline = function (A, e) { var t = null, i = this.mapDrawables; void 0 === i[A] && (i[A] = document.createElementNS(this.xmlns, "polyline"), this.group.appendChild(i[A])), (t = i[A]).setAttribute("stroke", e.color || "#A9A9A9"), t.setAttribute("stroke-width", e.width || 3), t.style.fill = "none", t.setAttribute("points", e.points) }, aB.prototype.makeDefs = function (A) { var e = this.mapDrawables; void 0 === e[A] && (e[A] = document.createElementNS(this.xmlns, "defs"), void 0 === e.marker && (e.marker = this.makeMarker(), e[A].appendChild(e.marker)), this.group.appendChild(e[A])) }, aB.prototype.makeMarker = function () { var A = document.createElementNS(this.xmlns, "marker"); A.setAttribute("id", "arrow"), A.setAttribute("viewBox", "0 0 10 10"), A.setAttribute("refX", "5"), A.setAttribute("refY", "5"), A.setAttribute("markerWidth", "6"), A.setAttribute("markerHeight", "6"), A.setAttribute("orient", "auto-start-reverse"); var e = document.createElementNS(this.xmlns, "path"); return e.setAttribute("d", "M 0 0 L 10 5 L 0 10 z"), e.style.fill = "#11DAB7", this.mapDrawables.arrow = e, A.appendChild(e), A }, aB.prototype.getDrawable = function (A) { return this.mapDrawables[A] }, aB.prototype.attach = function () { this.getDrawable("axisZ").setAttribute("marker-end", "url(#arrow)") }, aB.prototype.setColor = function (A, e) { this.getDrawable(A).setAttribute("stroke", e) }, aB.prototype.fill = function (A, e) { this.getDrawable(A).style.fill = e }, aB.prototype.hideAll = function (A) { this.group.style.display = !0 === A ? "none" : "block" }, aB.prototype.destroy = function () { for (var A = this.group.children, e = 0; A.length > e; e += 1) this.group.removeChild(A[e]); this.group.parentNode.removeChild(this.group) }; var sB = function (A) { this.viewer = A, this.enable = !0, this.cameraControl = A.cameraControl, this.fillClipPlane = A.getScene().getFillClipPlane(), this.container = A.domElement.querySelector("div:first-child"), this.config = new rB, this.drawingImpl = new aB(this, A), this.coordinateAction = new nB(this, this.drawingImpl), this.initialize() }; sB.prototype.initialize = function () { this.enable = !0, this.boundingBox = new Ps, this.bRegisterArrowEvent = !1, this.bRegisterAuxCircleEvent = !1, this.mapDrawableName = { ORIGIN: "origin", AXISX: "axisX", AXISY: "axisY", CUBEX: "cubeX", CUBEY: "cubeY", AXISZ: "axisZ", ARROW: "arrow", DASHLINE: "dashLine", TIPARC_X: "tipArcX", TIPARC_Y: "tipArcY", TIPARC_Z: "tipArcZ", DASHLINE_X: "dashLineX", DASHLINE_Y: "dashLineY" } }, sB.prototype.saveTransform = function (A) { this.savedCamera = A.clone() }, sB.prototype.drawingToCanvas = function (A) { var e = Rd.drawingToCanvas(this.cameraControl.camera, A, this.container.offsetWidth, this.container.offsetHeight); return new s(e.x, e.y) }, sB.prototype.getCoordinateAxis = function () { var A = this.fillClipPlane.renderClipPlane.normal.clone(), e = this.fillClipPlane.getCoordinate(), t = e.axisY.clone(), i = A.clone().cross(t.clone()); this.fillClipPlane.normalIndex > 3 && (t = (i = e.axisX.clone()).clone().cross(A.clone())); var o = this.config.styles, n = this.fillClipPlane.position.clone(), r = this.cameraControl.getCamera().position.clone().sub(n).length(), a = n.clone().add(i.clone().multiplyScalar(o.axisXLength * r)), s = n.clone().add(t.clone().multiplyScalar(o.axisYLength * r)), l = n.clone().add(A.clone().multiplyScalar(o.axisZLength * r)); return this.dirX = i, this.dirY = t, { start: n, endX: a, endY: s, endZ: l } }, sB.prototype.drawOrigin = function (A, e) { this.drawingImpl.makeCircle(this.mapDrawableName.ORIGIN, { center: A, radius: e, color: this.config.colors.default }) }, sB.prototype.drawAxisX = function (A, e, t) { this.drawingImpl.makeLine(this.mapDrawableName.AXISX, { start: A, end: e, width: this.config.styles.axisXWidth, color: t || this.config.colors.default }) }, sB.prototype.drawAxisY = function (A, e, t) { var i = this.config; this.drawingImpl.makeLine(this.mapDrawableName.AXISY, { start: A, end: e, width: i.styles.axisYWidth, color: t || i.colors.default }) }, sB.prototype.drawAxisZ = function (A, e) { var t = this.config; this.drawingImpl.makeLine(this.mapDrawableName.AXISZ, { start: A, end: e, width: t.styles.axisZWidth, color: t.colors.arrow }), this.drawingImpl.attach(), !1 === this.bRegisterArrowEvent && (this.coordinateAction.registerArrowEvents(), this.bRegisterArrowEvent = !0) }, sB.prototype.updateAxisZ = function () { var A = this.getCoordinateAxis(), e = this.drawingToCanvas(A.start.clone()), t = this.drawingToCanvas(A.endZ.clone()); this.drawingImpl.makeLine(this.mapDrawableName.AXISZ, { start: e, end: t, color: this.config.colors.default }) }, sB.prototype.drawArrow = function (A, e) { var t = this.mapDrawableName; this.drawingImpl.makeLine(t.AXISZ, { start: A, end: e }), this.drawingImpl.attach(), this.drawingImpl.setColor(t.AXISZ, this.config.colors.default), !1 === this.bRegisterArrowEvent && (this.coordinateAction.registerArrowEvents(), this.bRegisterArrowEvent = !0) }, sB.prototype.drawClipPlaneCircle = function (A, e, t, i, o) { for (var n = { center: e.clone(), radius: t, normal: i.clone(), rotateAxis: o.clone() }, r = this.config.styles.segments, a = this.discreteCircle(n, r), s = "", l = 0; r > l; l += 1) s += a[l].x + "," + a[l].y, s += " "; s += a[0].x + "," + a[0].y, this.drawingImpl.makePolyline(A, { points: s += " ", color: this.config.colors.default, width: 2 }) }, sB.prototype.drawTipArc = function (A, e, t, i, o) { var n = { center: e.clone(), radius: t, normal: i.clone(), rotateAxis: o.clone() }, r = this.config.styles, a = r.tipArcRightCounts, s = r.tipArcLeftCounts, l = r.segments, c = this.discreteCircle(n, l); A === this.mapDrawableName.TIPARC_X ? (this.discretePointsX = c, a = r.tipArcLeftCounts, s = r.tipArcRightCounts) : this.discretePointsY = c; for (var h = "", d = l - a - 1; l > d; d += 1) h += c[d].x + "," + c[d].y, h += " "; for (var p = 0; s >= p; p += 1) h += c[p].x + "," + c[p].y, h += " "; var g = { points: h, color: this.config.colors.tipArcX }; A === this.mapDrawableName.TIPARC_X ? (this.drawingImpl.makePolyline(A, g), this.coordinateAction.registerTipArcXEvents()) : A === this.mapDrawableName.TIPARC_Y && (g.color = this.config.colors.tipArcY, this.drawingImpl.makePolyline(A, g), this.coordinateAction.registerTipArcYEvents()) }, sB.prototype.drawTipLine = function (A, e, t) { var i = this.drawingToCanvas(e.clone()), o = this.drawingToCanvas(t.clone()), n = this.config; this.drawingImpl.makeDashLine(A, { start: i, end: o, color: n.colors.tipLine, dashArray: n.styles.dashArray }), this.drawingImpl.show(A, !1) }, sB.prototype.drawCubeX = function (A, e, t) { this.drawingImpl.makeCircle(A, { center: e, radius: t, color: this.config.colors.cubeX }) }, sB.prototype.drawCubeY = function (A, e, t, i) { this.drawingImpl.makeCircle(A, { center: e, radius: t, color: i || this.config.colors.cubeY }) }, sB.prototype.discreteCircle = function (A, e) { for (var t = A.center.clone(), i = A.radius, o = A.rotateAxis.clone(), n = A.normal.clone(), r = [], a = 0; e > a; a += 1) { n.applyAxisAngle(o, 2 * Math.PI / e); var s = t.clone().add(n.clone().multiplyScalar(i)), l = this.drawingToCanvas(s.clone()); r.push(l) } return r }, sB.prototype.arcToCircle = function (A) { var e = "", t = this.discretePointsX; A === this.mapDrawableName.TIPARC_Y && (t = this.discretePointsY); for (var i = 0, o = t.length; o > i; i += 1) e += t[i].x + "," + t[i].y, e += " "; e += t[0].x + "," + t[0].y, this.drawingImpl.makePolyline(A, { points: e += " ", color: this.config.colors.highLight }) }, sB.prototype.circleToArc = function (A) { var e = this.config.styles, t = e.tipArcLeftCounts, i = e.tipArcRightCounts, o = e.segments, n = this.discretePointsX, r = { color: this.config.colors.tipArcX }; A === this.mapDrawableName.TIPARC_Y && (n = this.discretePointsY, r.color = this.config.colors.tipArcY, t = e.tipArcRightCounts, i = e.tipArcLeftCounts); for (var a = "", s = o - t - 1; o > s; s += 1) a += n[s].x + "," + n[s].y, a += " "; for (var l = 0; i >= l; l += 1) a += n[l].x + "," + n[l].y, a += " "; r.points = a, this.drawingImpl.makePolyline(A, r) }, sB.prototype.update = function () { if (this.enable) { var A = this.fillClipPlane.position.clone(), e = this.cameraControl.getCamera().position.clone().sub(A).length(), t = this.getCoordinateAxis(), i = this.drawingToCanvas(t.start.clone()), o = this.drawingToCanvas(t.endX.clone()), n = this.drawingToCanvas(t.endY.clone()), r = this.drawingToCanvas(t.endZ.clone()); void 0 === this.createRefs && (this.drawingImpl.makeDefs("refs"), this.createRefs = !0), this.cOrigin = i.clone(), this.drawAxisZ(i, r), this.drawAxisX(i, o), this.drawAxisY(i, n); var a = this.config.styles, s = this.mapDrawableName, l = this.fillClipPlane.renderClipPlane.normal.clone(); this.drawClipPlaneCircle(s.TIPARC_Z, t.start.clone(), a.auxCircleRadius * e, this.dirX, l), this.drawTipArc(s.TIPARC_X, t.start.clone(), a.auxCircleRadius * e, l, this.dirX), this.drawTipArc(s.TIPARC_Y, t.start.clone(), a.auxCircleRadius * e, l, this.dirY); var c = t.start.clone().add(this.dirX.clone().multiplyScalar(a.tipLineLength * e)), h = t.start.clone().sub(this.dirX.clone().multiplyScalar(a.tipLineLength * e)); this.drawTipLine(s.DASHLINE_X, c, h); var d = t.start.clone().add(this.dirY.clone().multiplyScalar(a.tipLineLength * e)), p = t.start.clone().sub(this.dirY.clone().multiplyScalar(a.tipLineLength * e)); this.drawTipLine(s.DASHLINE_Y, d, p), this.drawOrigin(i, a.originRadius); var g = this.discretePointsX[44].clone(); this.drawCubeX(s.CUBEX, g, a.cubeRadius); var u = this.discretePointsY[134].clone(); this.drawCubeY(s.CUBEY, u, a.cubeRadius), this.updateBbox() } else this.hide(!0) }, sB.prototype.hide = function (A) { this.drawingImpl.hideAll(A) }, sB.prototype.enabled = function (A) { this.enable = A }, sB.prototype.destroy = function () { this.drawingImpl.destroy() }, sB.prototype.updateBbox = function () { this.boundingBox.makeEmpty(); for (var A = 0; this.discretePointsX.length > A; A += 1) { var e = this.discretePointsX[A].clone(); this.boundingBox.expandByPoint(e) } for (A = 0; this.discretePointsY.length > A; A += 1) { e = this.discretePointsY[A].clone(); this.boundingBox.expandByPoint(e) } var t = this.getCoordinateAxis(), i = this.drawingToCanvas(t.start.clone()), o = this.drawingToCanvas(t.endZ.clone()); this.boundingBox.expandByPoint(i), this.boundingBox.expandByPoint(o), this.boundingBox.expandByScalar(5) }, sB.prototype.insideBoundingBox = function (A) { return this.boundingBox.containsPoint(A.clone()) }, sB.prototype.backwardCoordinate = function () { var A = this.cameraControl.camera.position, e = this.cameraControl.camera.target.clone().sub(A.clone()).normalize(), t = this.fillClipPlane.renderClipPlane.normal.clone(); e.angleTo(t); Math }; var lB = { Forward: 0, Reverse: 1 }, cB = { X: 0, Y: 4, Z: 2 }, hB = function (A) { var e = A.viewer; if (e) { if (e._sectionBox && e._sectionBox.exit(), e._sectionPlane) return e._sectionPlane; e._sectionPlane = this, this.id = A.id, this._opt = A, this.mode = A.mode, this._plane = A.plane, this._direction = A.direction, this._progress = A.progress, this.init(), this.setPlane(A.plane) } else Bh.log("domElement must not be empty.") }; hB.prototype = { init: function () { this.enableCoordinate = !0; var A = this._opt.viewer.getViewerImpl(); this.coordinateSystem = new sB(A), A.controlManager.enableTool(A, Pc.CLIP_FILL), this._sectionTool = A.getScene().getFillClipPlane(), this._sectionTool.enable(!0, !0), this.hookEvens() }, hookEvens: function () { var A = this, e = this.coordinateSystem, t = this._opt.viewer.getViewerImpl(); t.getDomElement(); t.registerEventListener(Rc.ON_CLIP_HOVER, (function (t) { if (!1 !== A.enableCoordinate) if (t.onClipPlane) e.enable && (e.update(), e.hide(!1)); else { var i = new s(t.event.clientX, t.event.clientY); e.insideBoundingBox(i) ? e.hide(!1) : e.hide(!0) } })), t.registerEventListener(Rc.ON_CLIP_MOUSE_DOWN, (function (A) {})), t.registerEventListener(Rc.ON_CLIP_MOUSE_MOVE, (function (A) { e.update() })), t.registerDomEventListener(Rc.ON_CONTROL_ZOOM, (function (A) { e.update() })) }, exit: function () { var A = this._opt.viewer.getViewerImpl(), e = A.getScene().getFillClipPlane(); A.controlManager.disableTool(Pc.CLIP_FILL), e.enable(!1, !1), this.coordinateSystem.destroy(), this._sectionTool = null, this._opt.viewer._sectionPlane = null }, setProgress: function (A) { var e = 1 - A / 50; this._progress = A, this._sectionTool.setProcess(e) }, getProgress: function () { return 50 * (1 - this._sectionTool.getProcess()) }, setPlane: function (A) { var e = lB[this._direction] + cB[A]; this._plane = A, this._sectionTool.changeNormal(e), this.setProgress(this._opt.progress) }, getPlane: function () { return this._plane }, setDirection: function (A) { var e = lB[A] + cB[this._plane]; this._direction = A, this._sectionTool.changeNormal(e), this.setProgress(this._opt.progress) }, getDirection: function () { return this._direction }, setRotateAngle: function (A, e) { this._sectionTool.setRotateAngle(A, e) }, getRotateAngle: function () { return this._sectionTool.getRotateAngle() }, hidePlane: function () { this._sectionTool.visible = !1, this.enableCoordinate = !1, this.coordinateSystem.hide(!0) }, showPlane: function () { this._sectionTool.visible = !0, this.enableCoordinate = !0 }, reset: function () { this.setPlane(this._opt.plane), this.setDirection(this._opt.direction), this.setProgress(this._opt.progress) }, getState: function () { return this._sectionTool.store() }, setState: function (A) { this._sectionTool.restore(A) } }; var dB = function (A) { var e = this, t = A; "function" == typeof A.getViewerImpl && (t = A.getViewerImpl()), this.marks = {}, this.SelectedMark = {}, this.components = {}, this.allOids = []; var i = { id: "", name: "mark", scale: 20, alwaysVisible: !1, color: [99, 99, 99], wordColor: [0, 0, 0], position: [0, 0, 0] }, o = new s, n = 0, r = 0; function a(A) { var e = [0, 0]; if (A) { for (var t = A.target, i = 0, o = 0; t.offsetParent;) i += t.offsetLeft, o += t.offsetTop, t = t.offsetParent; e[0] = A.pageX - i, e[1] = A.pageY - o } else A = window.event, e.x = A.x, e.y = A.y; return e } function l(A) { var i = new Dd, n = new y(o.x / t.domElement.clientWidth * 2 - 1, -o.y / t.domElement.clientHeight * 2 + 1, .5); i.setFromCamera(n, t.camera), i.camera = t.camera, i._camera = t.camera; var r = Object.values(e.components), a = i.intersectObjects(r); a && a.length > 0 && e.SelectedMark !== a[0].object ? (e.SelectedMark = a[0].object, e.dispatchEvent("updated", { added: { objects: e.SelectedMark } })) : (e.SelectedMark = {}, e.dispatchEvent("updated", { removed: { objects: e.SelectedMark } })) } function c(A) { var e = a(A); o.x = n = e[0], o.y = r = e[1] } function h(A) { var e = a(A); (e[0] > n ? 5 > e[0] - n : 5 > n - e[0]) && (e[1] > r ? 5 > e[1] - r : 5 > r - e[1]) && (o.x = n = e[0], o.y = r = e[1], l()) } function p(A) { o.x = n = A.changedTouches[0].clientX, o.y = r = A.changedTouches[0].clientY } function g(A) { (A.changedTouches[0].clientX > n ? 5 > A.changedTouches[0].clientX - n : 5 > n - A.changedTouches[0].clientX) && (A.changedTouches[0].clientY > r ? 5 > A.changedTouches[0].clientY - r : 5 > r - A.changedTouches[0].clientY) && (o.x = n = A.changedTouches[0].clientX, o.y = r = A.changedTouches[0].clientY, l()) } this.active = !0, e.domElement = t.domElement, this.enabled = function () { this.mousedown = t.domElement.addEventListener("mousedown", c, !1), this.mouseup = t.domElement.addEventListener("mouseup", h, !1) }, this.disabled = function () { this.mousedown = t.domElement.removeEventListener("mousedown", c, !1), this.mouseup = t.domElement.removeEventListener("mouseup", h, !1) }, this.touchEnabled = function () { this.touchstart = t.domElement.addEventListener("touchstart", p, !1), this.touchend = t.domElement.addEventListener("touchend", g, !1) }, this.touchDisabled = function () { this.touchstart = t.domElement.removeEventListener("touchstart", p, !1), this.touchend = t.domElement.removeEventListener("touchend", g, !1) }, this.enabled(), this.add = function (A, t) { var o = Object.assign({}, i, A); if ("" !== o.id) for (var n = 0; e.allOids.length > n; n += 1) if (o.id === e.allOids[n]) return { data: "标签id重复" }; (o.position.isVector3 || (o.position = new y(o.position[0], o.position[1], o.position[2])), Array.isArray(o.color)) && (o.color = "rgb(" + o.color[0] + "," + o.color[1] + "," + o.color[2] + ")"); Array.isArray(o.wordColor) && (o.wordColor = "rgb(" + o.wordColor[0] + "," + o.wordColor[1] + "," + o.wordColor[2] + ")"); var r = document.createElement("canvas"); r.width = 28 * o.name.length, r.height = 150; var a = r.getContext("2d"); a.fillStyle = "rgba(255, 255, 255, 0)", a.lineWidth = 2, a.strokeStyle = o.color, a.strokeRect(5, 0, r.width - 5, 30), a.moveTo(5, 141), a.lineTo(5, 30), a.stroke(), a.fillStyle = o.color, a.beginPath(), a.arc(5, 145, 4, 0, 2 * Math.PI), a.fill(), a.fillRect(10, 5, r.width - 15, 20), a.font = "bold 18px Arial", a.fillStyle = o.wordColor, a.textAlign = "center", a.fillText(o.name, r.width / 2, 20); var s = new d(r); s.needsUpdate = !0; var l = new ro({ map: s, color: 16777215, depthTest: o.alwaysVisible }), c = new vo(l); c.center.x = 0, c.center.y = 0, c.scale.set(o.scale * l.map.image.width, o.scale * l.map.image.height, 1), c.position.copy(o.position), c.updateMatrixWorld(), c.key = "" !== o.id ? o.id : c.uuid, e.addObjectToScene(o, c), "function" == typeof t && t(c.key) }, this.addObjectToScene = function (A, e) { A && A.id && e && (this.components[A.id] = e, this.allOids.push(A.id), this.marks[A.id] = A, t.addExternalObject(A.id, e)) }, this.updateMark = function (A, i) { if (e.marks[A]) { var o = Object.assign({}, e.marks[A], i), n = this.components[A]; if (n) { if (o.position.isVector3 || (o.position = new y(o.position[0], o.position[1], o.position[2])), Array.isArray(o.color)) o.color = "rgb(" + o.color[0] + "," + o.color[1] + "," + o.color[2] + ")"; if (Array.isArray(o.wordColor)) o.wordColor = "rgb(" + o.color[0] + "," + o.color[1] + "," + o.color[2] + ")"; var r = document.createElement("canvas"); r.width = 28 * o.name.length, r.height = 150; var a = r.getContext("2d"); a.fillStyle = "rgba(255, 255, 255, 0)", a.lineWidth = 2, a.strokeStyle = o.color, a.strokeRect(5, 0, r.width - 5, 30), a.moveTo(5, 141), a.lineTo(5, 30), a.stroke(), a.fillStyle = o.color, a.beginPath(), a.arc(5, 145, 4, 0, 2 * Math.PI), a.fill(), a.fillRect(10, 5, r.width - 15, 20), a.font = "bold 18px Arial", a.fillStyle = o.wordColor, a.textAlign = "center", a.fillText(o.name, r.width / 2, 20); var s = new d(r); s.needsUpdate = !0; var l = new ro({ map: s, color: 16777215, depthTest: o.alwaysVisible }); n.material = l, n.scale.set(o.scale * n.material.map.image.width, o.scale * n.material.map.image.height, 1), n.position.copy(o.position), n.updateMatrixWorld(), t.render(), e.marks[A] = o } } }, this.remove = function (A) { if (null == A) return { data: "未选中mark" }; Array.isArray(A) || (A = [A]); for (var i = 0; A.length > i; i += 1) { var o = e.allOids.indexOf(A[i]); e.allOids.splice(o, 1), delete e.components[A[i]], t.removeExternalObjectByName(A[i]) } }, this.hide = function (A) { if (null == A) return { data: "未选中mark" }; Array.isArray(A) || (A = [A]); for (var e = null, t = 0; A.length > t; t += 1) (e = this.components[A[t]]) && (e.visible = !1) }, this.show = function (A) { var t = null; if (A) { Array.isArray(A) || (A = [A]); for (var i = 0; A.length > i; i += 1) (t = this.components[A[i]]) && (t.visible = !0) } else for (var o in e.components) (t = e.components[o]) && (t.visible = !0) }, this.isolation = function (A) { if (null == A) return { data: "未选中mark" }; if (e.show(), e.allOids.length > 0) { var t = e.allOids.concat(); Array.isArray(A) || (A = [A]); for (var i = 0; A.length > i; i += 1) { var o = A[i]; if (-1 === e.allOids.indexOf(o)) return { data: "mark不存在" }; for (var n = 0; t.length > n; n += 1) if (o === t[n]) { t.splice(n, 1); break } } var r = null; for (n = 0; t.length > n; n += 1) (r = e.components[t[n]]) && (r.visible = !1) } }, this.listentoSelectMarks = function (A) { e.addEventListener("updated", (function () { e.SelectedMark !== {} ? A(e.SelectedMark.key ? e.SelectedMark.key : e.SelectedMark.uuid, e.SelectedMark) : A(null, null) })) } }; Object.assign(dB.prototype, Ld.prototype); var pB = function (A) { var e = this; this.Marks = new H, A.modelManager.scene.add(e.Marks), this.SelectedMark = {}, this.components = {}, this.allOids = []; var t = { id: "", name: "mark", scale: 20, width: 1, height: 1, alwaysVisible: !1, useImageSize: !0, color: "#000000", position: [0, 0, 0] }, i = new s, o = 0, n = 0; function r(A) { var e = [0, 0]; if (A) { for (var t = A.target, i = 0, o = 0; t.offsetParent;) i += t.offsetLeft, o += t.offsetTop, t = t.offsetParent; e[0] = A.pageX - i, e[1] = A.pageY - o } else A = window.event, e.x = A.x, e.y = A.y; return e } function a(t) { var o = new Dd, n = new y(i.x / A.domElement.clientWidth * 2 - 1, -i.y / A.domElement.clientHeight * 2 + 1, .5); o.setFromCamera(n, A.camera); var r = o.intersectObjects(e.Marks.children); r && r.length > 0 && e.SelectedMark !== r[0].object ? (e.SelectedMark = r[0].object, e.dispatchEvent("updated", { added: { objects: e.SelectedMark } })) : (e.SelectedMark = {}, e.dispatchEvent("updated", { removed: { objects: e.SelectedMark } })) } function l(A) { var e = r(A); i.x = o = e[0], i.y = n = e[1] } function c(A) { var e = r(A); (e[0] > o ? 5 > e[0] - o : 5 > o - e[0]) && (e[1] > n ? 5 > e[1] - n : 5 > n - e[1]) && (i.x = o = e[0], i.y = n = e[1], a()) } function h(A) { i.x = o = A.changedTouches[0].clientX, i.y = n = A.changedTouches[0].clientY } function p(A) { (A.changedTouches[0].clientX > o ? 5 > A.changedTouches[0].clientX - o : 5 > o - A.changedTouches[0].clientX) && (A.changedTouches[0].clientY > n ? 5 > A.changedTouches[0].clientY - n : 5 > n - A.changedTouches[0].clientY) && (i.x = o = A.changedTouches[0].clientX, i.y = n = A.changedTouches[0].clientY, a()) } this.active = !0, e.domElement = A.domElement, this.enabled = function () { this.mousedown = A.domElement.addEventListener("mousedown", l, !1), this.mouseup = A.domElement.addEventListener("mouseup", c, !1) }, this.disabled = function () { this.mousedown = A.domElement.removeEventListener("mousedown", l, !1), this.mouseup = A.domElement.removeEventListener("mouseup", c, !1) }, this.touchEnabled = function () { this.touchstart = A.domElement.addEventListener("touchstart", h, !1), this.touchend = A.domElement.addEventListener("touchend", p, !1) }, this.touchDisabled = function () { this.touchstart = A.domElement.removeEventListener("touchstart", h, !1), this.touchend = A.domElement.removeEventListener("touchend", p, !1) }, this.enabled(), this.add = function (i, o) { var n = Object.assign({}, t, i); if ("" !== n.id) for (var r = 0; e.allOids.length > r; r += 1) if (n.id === e.allOids[r]) return { data: "标签id重复" }; var a = document.createElement("canvas"); a.width = 24 * n.name.length, a.height = 32; var s = a.getContext("2d"); s.lineWidth = 3, s.strokeStyle = "#0000FF", s.strokeRect(0, 0, a.width, 32), s.fillStyle = "#FFFFFF", s.fillRect(3, 3, a.width - 6, 26), s.font = " bold 24px Arial", s.fillStyle = n.color, s.textAlign = "center", s.fillText(n.name, a.width / 2, 26), console.log(a.width); var l = new d(a); l.needsUpdate = !0; var c = new ro({ map: l, color: 16777215, depthTest: n.alwaysVisible }), h = new vo(c); h.scale.set(n.scale * c.map.image.width, n.scale * c.map.image.height, 1), n.position.isVector3 ? h.position.copy(n.position) : h.position.set(n.position[0], n.position[1], n.position[2]), h.updateMatrixWorld(), e.Marks.add(h), A.render(), "" !== n.id ? (h.key = n.id, e.components[n.id] = h, e.allOids.push(n.id)) : (h.key = h.uuid, e.components[h.uuid] = h, e.allOids.push(h.uuid)), "function" == typeof o && o(h.key) }, this.updateMark = function (i, o) { var n = Object.assign({}, t, o), r = null; if (e.components[i]) { r = e.components[i]; var a = document.createElement("canvas"); a.width = 24 * n.name.length, a.height = 32; var s = a.getContext("2d"); s.lineWidth = 3, s.strokeStyle = "#0000FF", s.strokeRect(0, 0, a.width, 32), s.fillStyle = "#FFFFFF", s.fillRect(3, 3, a.width - 6, 26), s.font = " bold 24px Arial", s.fillStyle = n.color, s.textAlign = "center", s.fillText(n.name, a.width / 2, 26); var l = new d(a); l.needsUpdate = !0; var c = new ro({ map: l, color: 16777215, depthTest: n.alwaysVisible }); r.material = c, r.scale.set(n.scale * r.material.map.image.width, n.scale * r.material.map.image.height, 1), n.position.isVector3 ? r.position.copy(n.position) : r.position.set(n.position[0], n.position[1], n.position[2]), r.updateMatrixWorld(), A.render() } }, this.remove = function (A) { if (null == A) return { data: "未选中mark" }; Array.isArray(A) || (A = [A]); for (var t = null, i = 0; A.length > i; i += 1) { t = e.components[A[i]]; var o = e.allOids.indexOf(A[i]); e.allOids.splice(o, 1), e.Marks.remove(t) } }, this.hide = function (A) { if (null == A) return { data: "未选中mark" }; Array.isArray(A) || (A = [A]); for (var t = null, i = 0; A.length > i; i += 1) (t = e.components[A[i]]) && (t.visible = !1) }, this.show = function (A) { var t = null; if (A) { Array.isArray(A) || (A = [A]); for (var i = 0; A.length > i; i += 1) (t = e.components[A[i]]) && (t.visible = !0) } else for (var o in e.components) (t = e.components[o]) && (t.visible = !0) }, this.isolation = function (A) { if (null == A) return { data: "未选中mark" }; if (e.show(), e.allOids.length > 0) { var t = e.allOids.concat(); Array.isArray(A) || (A = [A]); for (var i = 0; A.length > i; i += 1) { var o = A[i]; if (-1 === e.allOids.indexOf(o)) return { data: "mark不存在" }; for (var n = 0; t.length > n; n += 1) if (o === t[n]) { t.splice(n, 1); break } } var r = null; for (n = 0; t.length > n; n += 1) (r = e.components[t[n]]) && (r.visible = !1) } }, this.listentoSelectMarks = function (A) { e.addEventListener("updated", (function () { e.SelectedMark !== {} ? A(e.SelectedMark.key ? e.SelectedMark.key : e.SelectedMark.uuid, e.SelectedMark) : A(null, null) })) } }; Object.assign(pB.prototype, Ld.prototype); var gB = function A() { cc(this, A), this.type = "circle", this.lineHeight = 2, this.color = "#ff0000", this.titleColor = "#000000", this.titleBackgroundColor = "#ff0000", this.lineTitleBackgroundColor = "#ffffff" }, uB = function () { function A(e, t, i, o, n, r) { cc(this, A), this.lineTitle = t, this.icon = o, this.title = i, this.type = e.type, this.lineHeight = e.lineHeight, this.color = e.color, this.titleBackgroundColor = e.titleBackgroundColor, this.titleColor = e.titleColor, this.lineTitleBackgroundColor = e.lineTitleBackgroundColor, this.id = n, this.scenePoint = r, this.rootDiv = void 0, this.lineTitleDiv = void 0, this.contentDiv = void 0, this.lineStartPosition = { x: 0, y: 0 }, this.lineEndPosition = { x: 100, y: 100 }, this._iconSize = 30, this._marginLeft = 10, this._dragStart = this._dragStart.bind(this), this._dragMove = this._dragMove.bind(this), this._dragEnd = this._dragEnd.bind(this), this._lastDragPoint = void 0, this._init() } return dc(A, [{ key: "_init", value: function () { this.rootDiv = document.createElement("div"), this.rootDiv.style.cssText = "position:absolute; left: 0px; top: 0px;-moz-user-select: none; -webkit-user-select: none; -ms-user-select: none; -khtml-user-select: none; user-select: none;"; var A = document.createElementNS("http://www.w3.org/2000/svg", "svg"); A.setAttribute("xmlns", "http://www.w3.org/2000/svg"), A.style.overflow = "visible", this.svg = A; var e = document.createElementNS("http://www.w3.org/2000/svg", "path"); e.style.fill = this.color, this.arrow = e, this.svg.appendChild(e), this.rootDiv.appendChild(A); var t = document.createElement("div"); t.style.position = "absolute", t.style.backgroundColor = "#ffffff", t.style.color = this.titleColor, t.innerText = this.lineTitle, this.lineTitleDiv = t, this.rootDiv.appendChild(t); var i = document.createElement("div"); this.contentDiv = i, this.contentDiv.addEventListener("mousedown", this._dragStart); var o = document.createElement("div"); if (this.titleDiv = o, o.style.display = "inline-block", o.style.color = this.titleColor, o.style.whiteSpace = "nowrap", o.style.overflow = "hidden", o.style.textOverflow = "ellipsis", o.style.maxWidth = "150px", o.style.position = "absolute", o.style.top = "50%", this.icon ? "circle" === this.type ? (o.style.left = "50%", o.style.transform = "translate(-50%, 5px)") : (o.style.left = "".concat(this._marginLeft + this._iconSize + 5, "px"), o.style.transform = "translate(0px, -50%)") : (o.style.left = "50%", o.style.transform = "translate(-50%, -50%)"), o.innerText = this.title, this.contentDiv.appendChild(o), this.icon) { var n = document.createElement("img"); n.style.width = "".concat(this._iconSize, "px"), n.style.height = "".concat(this._iconSize, "px"), n.style.position = "absolute", n.style.pointerEvents = "none", "circle" === this.type ? (n.style.left = "50%", n.style.top = "50%", n.style.transform = "translate(-50%, -100%)") : (n.style.left = "".concat(this._marginLeft, "px"), n.style.top = "50%", n.style.transform = "translate(0px, -50%)"), n.src = this.icon, this.contentDiv.appendChild(n) } this.rootDiv.appendChild(i) } }, { key: "setLineStartPosition", value: function (A, e) { this.lineStartPosition.x = A, this.lineStartPosition.y = e, this.update() } }, { key: "setLineEndPosition", value: function (A, e) { this.lineEndPosition.x = A, this.lineEndPosition.y = e, this.update() } }, { key: "setLineStartAndEndPoint", value: function (A, e, t, i) { this.lineStartPosition.x = A, this.lineStartPosition.y = e, this.lineEndPosition.x = t, this.lineEndPosition.y = i, this.update() } }, { key: "update", value: function () { var A = this.titleDiv.getBoundingClientRect(); A.width += 2 * this._marginLeft, "rectangle" === this.type && (this.icon && (A.width += this._iconSize, A.width += 5), A.height = 40); var e = this.lineEndPosition.x - this.lineStartPosition.x, t = this.lineEndPosition.y - this.lineStartPosition.y, i = Math.atan2(t, e); i > 0 || (i += 2 * Math.PI); var o = i / Math.PI * 180, n = Math.sqrt(e * e + t * t); if ("circle" === this.type) n -= A.width / 2; else { var r = Math.tan(i); Math.abs(r) > A.height / A.width ? n -= A.height / 2 / Math.abs(Math.sin(i)) : n -= A.width / 2 / Math.abs(Math.cos(i)) } n = Math.max(15, n); var a = 0, s = 0, l = "M".concat(a, " ").concat(s); l += "L".concat(a, " ").concat(s - this.lineHeight / 2), l += "L".concat(a + n - 10, " ").concat(s - this.lineHeight / 2), l += "A".concat(20, " ").concat(20, " 0 0 0 ").concat(a + n - 15, " ").concat(s - this.lineHeight / 2 - 10), l += "L".concat(a + n, " ").concat(s), l += "L".concat(a + n - 15, " ").concat(s + this.lineHeight / 2 + 10), l += "A".concat(20, " ").concat(20, " 0 0 0 ").concat(a + n - 10, " ").concat(s + this.lineHeight / 2), l += "L".concat(a, " ").concat(s + this.lineHeight / 2, "Z"), this.arrow.setAttributeNS(null, "d", l); var c = "translate(".concat(this.lineStartPosition.x, ", ").concat(this.lineStartPosition.y, ") rotate(").concat(o, ")"); this.arrow.setAttributeNS(null, "transform", c); var h = (this.lineStartPosition.y + this.lineEndPosition.y) / 2, d = "\n left:".concat((this.lineStartPosition.x + this.lineEndPosition.x) / 2, "px;top:").concat(h, "px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n max-width:150px;\n position:absolute;\n transform:translate(-50%, -50%);\n background-color: ").concat(this.lineTitleBackgroundColor, ";\n "); this.lineTitleDiv.style.cssText = d; var p = this.lineEndPosition.x, g = this.lineEndPosition.y; d = "\n background-color:".concat(this.titleBackgroundColor, ";\n position: absolute;\n left:").concat(p, "px;\n top:").concat(g, "px;\n transform:translate(-50%,-50%);\n width:").concat(A.width, "px;\n cursor: move;\n "), d += "circle" === this.type ? "\n height:".concat(A.width, "px;\n border-radius:").concat(A.width, "px;\n ") : "\n height:".concat(A.height, "px;\n border-radius:4px;\n "), this.contentDiv.style.cssText = d } }, { key: "_dragStart", value: function (A) { 0 === A.button && (document.addEventListener("mousemove", this._dragMove), document.addEventListener("mouseup", this._dragEnd), this._lastDragPoint = { x: A.clientX, y: A.clientY }) } }, { key: "_dragMove", value: function (A) { if (this._lastDragPoint) { var e = A.clientY - this._lastDragPoint.y; this.lineEndPosition.x += A.clientX - this._lastDragPoint.x, this.lineEndPosition.y += e, this.update(), this._lastDragPoint.x = A.clientX, this._lastDragPoint.y = A.clientY } else this._lastDragPoint = { x: A.clientX, y: A.clientY } } }, { key: "_dragEnd", value: function (A) { this._lastDragPoint = void 0, document.removeEventListener("mousemove", this._dragMove), document.removeEventListener("mouseup", this._dragEnd) } }]), A }(), fB = function () { function A(e, t) { cc(this, A), this.viewer3D = e, this.EIMMODEL = t, this.THREE = t.THREE, this.marks = {}, this.arrowConfig = new gB, this.flag = 1, this.update = this.update.bind(this), e.registerCameraEventListener(this.EIMMODEL.EVENTS.ON_CAMERA_CHANGE, this.update) } return dc(A, [{ key: "testData", value: function () { return [{ lineTitle: "测试1", title: "测试1胜利大街发", icon: "", type: "rectangle" }, { lineTitle: "测试2", title: "测试2胜利大街发", icon: void 0, type: "rectangle" }, { lineTitle: "测试3", title: "测试3胜利大街发", icon: void 0, type: "rectangle" }, { lineTitle: "测试4", title: "测试4胜利大街发", icon: "", type: "circle" }, { lineTitle: "测试5", title: "测试5胜利大街发", icon: void 0, type: "rectangle" }, { lineTitle: "测试6", title: "测试6胜利大街发", icon: void 0, type: "circle" }, { lineTitle: "测试7", title: "测试7胜利大街发", icon: "", type: "rectangle" }] } }, { key: "addMarksAtComponent", value: function (A, e, t) { var i = this.viewer3D.getBoxByComponentsKey(A), o = new this.THREE.Vector3; i.getCenter(o); var n = o.toArray(), r = this.viewer3D.getViewerImpl().domElement, a = r.getBoundingClientRect(), s = this.viewer3D.getScreenCoordFromSceneCoord(o), l = e || this.arrowConfig, c = l.type, h = 0, d = [s[0] + 250, s[1]], p = 250, g = 0, u = 0; this.marks[A] || (this.marks[A] = []); for (var f = 0, m = t.length; m > f; f += 1) { var C = t[f]; l.type = C.type || c; var y = new uB(l, C.lineTitle, C.title, C.icon, this.flag, n); r.appendChild(y.rootDiv), y.setLineStartAndEndPoint(s[0], s[1], d[0], d[1]); var v = y.contentDiv.getBoundingClientRect(); if (f > 0) { u += 2 * Math.asin((v.height / 2 + h / 2) / 2 / 250), u += .1; var I = Math.cos(u), E = Math.sin(u), B = p * I + g * -E + s[0], x = p * E + g * I + s[1]; 0 > B ? B = v.width / 2 : B > a.width && (B = a.width - v.width / 2), 0 > x ? x = v.height / 2 : x > a.height && (x = a.height - v.height / 2), y.setLineEndPosition(B, x) } h = v.height, this.flag += 1, this.marks[A].push(y) } } }, { key: "addMarkAt", value: function (A, e, t, i, o) { var n = parseInt(A.x, 10).toString() + "_" + parseInt(A.y, 10).toString() + "_" + parseInt(A.z, 10).toString(), r = new uB(o || this.arrowConfig, e, t, i, this.flag, A), a = this.viewer3D.getViewerImpl().domElement; a.appendChild(r.rootDiv); var s = a.getBoundingClientRect(), l = this.viewer3D.getScreenCoordFromSceneCoord(A), c = [l[0], l[1]]; return l.x > s.width / 2 ? c[0] -= 250 : c[0] += 250, r.setLineStartAndEndPoint(l[0], l[1], c[0], c[1]), this.flag += 1, this.marks[n] || (this.marks[n] = []), this.marks[n].push(r), r } }, { key: "update", value: function () { var A = this, e = (new Date).getTime(); this._lastTime && e - this._lastTime < 25 || (this._lastTime = e, Object.keys(this.marks).forEach((function (e) { var t = A.marks[e], i = A.viewer3D.getScreenCoordFromSceneCoord(t[0].scenePoint); t.forEach((function (A) { A.setLineStartPosition(i[0], i[1]) })) }))) } }, { key: "destroy", value: function () { this.viewer3D.unregisterCameraEventListener(this.EIMMODEL.EVENTS.ON_CAMERA_CHANGE, this.update) } }]), A }(), mB = function (A) { this.Measurement = { pointMove: new y, pointPick: [], pointPickToScreen: [], pointAssist: [], pointAssistToScreen: [], needUpdatedObjects: [], pickLineP1: new y, pickLineP2: new y, planeSquare: {}, planeVolume: {}, measureWindow: {} }, this.renderer = A.viewerImpl.modelManager.renderer, this.scene = A.viewerImpl.modelManager.scene, this.camera = A.viewerImpl.camera.cameraPerspective, this.cameraControl = A.viewerImpl.cameraControl, this.intersect = null, this.domElement = A.viewerImpl.domElement, this.viewer = A.viewerImpl, this.SVG = document.getElementById("svgid" + A.getViewerImpl().uuid), this.SVGRect = A.SVGRect; var e = this; function t() { e.updatePos() } function i() { var t = A.getScreenCoordFromSceneCoord(e.Measurement.pickLineP1), i = A.getScreenCoordFromSceneCoord(e.Measurement.pickLineP2), o = new s(t[0], t[1]), n = new s(i[0], i[1]); e.SVGRect.createMoveLine(o, n) } this.movePoint = function (t) { if (t.pickLine || t.pickPlane || t.pickPoint) { e.SVGRect.deleteCircle(); var i = A.viewerImpl.cameraControl.screenToCanvas(t.event.clientX, t.event.clientY); e.SVGRect.creatMoveCircle(i); var o = e.cameraControl.getIntersectContext(new s(t.event.clientX, t.event.clientY)); if (e.cameraControl.intersector.pick(o, (function (t) { for (var o = t.object.geometry, n = o.attributes.position.array, r = o.attributes.position.count, a = 0; r > a; a += 1) { var s = new y(n[3 * a], n[3 * a + 1], n[3 * a + 2]); s.applyMatrix4(t.object.matrixWorld); var l = A.getScreenCoordFromSceneCoord(s); 15 > Math.sqrt((l[0] - i.x) * (l[0] - i.x) + (l[1] - i.y) * (l[1] - i.y)) && (e.Measurement.pointMove = s, e.SVGRect.changeMoveCircleStyle(l)) } })), t.pickLine) { e.Measurement.pickLineP1 = t.pickLine[0], e.Measurement.pickLineP2 = t.pickLine[1]; var n = A.getScreenCoordFromSceneCoord(t.pickLine[0].clone()), r = A.getScreenCoordFromSceneCoord(t.pickLine[1].clone()), a = new s(n[0], n[1]), l = new s(r[0], r[1]); e.SVGRect.createMoveLine(a, l) } } }, this.pickPoint = function (t) { if (t.pickLine || t.pickPlane || t.pickPoint) { 1 > e.Measurement.needUpdatedObjects.length || (e.SVGRect.deleteCircle(), e.SVGRect.deleteMoveLine(), e.SVGRect.deleteLineAndCircle(), e.Measurement.pointPick = [], e.Measurement.pointPickToScreen = [], e.Measurement.pointAssist = [], e.Measurement.pointAssistToScreen = [], e.Measurement.needUpdatedObjects = [], e.updatePos()); new y, new y, new y, new y; var i = null, o = t.pickPoint, n = (new s).fromArray(A.getScreenCoordFromSceneCoord(o)); e.Measurement.pointPick.push(o), e.Measurement.pointPickToScreen.push(n); var r = e.Measurement.pointPickToScreen.length; if (e.SVGRect.creatPickCircle(n, r - 1), r % 2 == 0 && r > 0) { var a = new y(e.Measurement.pointPick[r - 1].x, e.Measurement.pointPick[r - 2].y, e.Measurement.pointPick[r - 2].z), l = new y(e.Measurement.pointPick[r - 1].x, e.Measurement.pointPick[r - 2].y, e.Measurement.pointPick[r - 1].z); e.Measurement.pointAssist.push(a), e.Measurement.pointAssist.push(l); var c = A.getScreenCoordFromSceneCoord(a), h = A.getScreenCoordFromSceneCoord(l), d = new s(c[0], c[1]), p = new s(h[0], h[1]); e.SVGRect.creatLine(e.Measurement.pointPickToScreen[r - 2], d, "red", "red" + (r - 1)), e.SVGRect.creatLine(p, e.Measurement.pointPickToScreen[r - 1], "green", "green" + (r - 1)), e.SVGRect.creatLine(d, p, "blue", "blue" + (r - 1)), e.SVGRect.creatLine(e.Measurement.pointPickToScreen[r - 1], e.Measurement.pointPickToScreen[r - 2], "yellow", "yellow" + (r - 1)), e.Measurement.needUpdatedObjects.push({ point1: e.Measurement.pointPick[r - 2], point2: e.Measurement.pointPick[r - 1], asPot1: e.Measurement.pointAssist[r - 2], asPot2: e.Measurement.pointAssist[r - 1] }); var g = Math.abs(e.Measurement.pointPick[r - 1].x - e.Measurement.pointPick[r - 2].x), u = Math.abs(e.Measurement.pointPick[r - 1].y - e.Measurement.pointPick[r - 2].y), f = Math.abs(e.Measurement.pointPick[r - 1].z - e.Measurement.pointPick[r - 2].z), m = e.Measurement.pointPick[r - 1].distanceTo(e.Measurement.pointPick[r - 2]); i = { dx: g.toFixed(3), dy: u.toFixed(3), dz: f.toFixed(3), dis: m.toFixed(3) } } return i } }, this.clear = function () { e.SVGRect.deleteCircle(), e.SVGRect.deleteMoveLine(), e.SVGRect.deleteLineAndCircle(), e.Measurement.pointPick = [], e.Measurement.pointPickToScreen = [], e.Measurement.pointAssist = [], e.Measurement.pointAssistToScreen = [], e.Measurement.needUpdatedObjects = [], e.cameraControl.removeEventListener(Rc.ON_CAMERA_CHANGE, t), e.cameraControl.removeEventListener(Rc.ON_CAMERA_CHANGE, i) }, this.updatePos = function () { var t = e.Measurement.pointPick.length, i = e.Measurement.pointAssist.length, o = e.Measurement.needUpdatedObjects; if (i) for (var n = 0; o.length > n; n += 1) { var r = 2 * n, a = A.getScreenCoordFromSceneCoord(o[n].point1), l = A.getScreenCoordFromSceneCoord(o[n].point2), c = new s(a[0], a[1]), h = new s(l[0], l[1]); e.Measurement.pointPickToScreen[r] = c, e.Measurement.pointPickToScreen[r + 1] = h; var d = A.getScreenCoordFromSceneCoord(o[n].asPot1), p = A.getScreenCoordFromSceneCoord(o[n].asPot2), g = new s(d[0], d[1]), u = new s(p[0], p[1]); e.Measurement.pointAssistToScreen[r] = g, e.Measurement.pointAssistToScreen[r + 1] = u; var f = e.Measurement.pointPickToScreen[r].x, m = e.Measurement.pointPickToScreen[r].y, C = e.Measurement.pointPickToScreen[r + 1].x, y = e.Measurement.pointPickToScreen[r + 1].y, v = e.Measurement.pointAssistToScreen[r].x, I = e.Measurement.pointAssistToScreen[r].y, E = e.Measurement.pointAssistToScreen[r + 1].x, B = e.Measurement.pointAssistToScreen[r + 1].y, x = document.getElementById("circlePick" + A.getViewerImpl().uuid + r), S = document.getElementById("circlePick" + A.getViewerImpl().uuid + (r + 1)); x.setAttribute("cx", f), x.setAttribute("cy", m), S.setAttribute("cx", C), S.setAttribute("cy", y); var w = document.getElementById("pickline" + A.getViewerImpl().uuid + "red" + (r + 1)), M = document.getElementById("pickline" + A.getViewerImpl().uuid + "green" + (r + 1)), b = document.getElementById("pickline" + A.getViewerImpl().uuid + "blue" + (r + 1)), U = document.getElementById("pickline" + A.getViewerImpl().uuid + "yellow" + (r + 1)); w.setAttribute("x1", f), w.setAttribute("y1", m), w.setAttribute("x2", v), w.setAttribute("y2", I), M.setAttribute("x1", E), M.setAttribute("y1", B), M.setAttribute("x2", C), M.setAttribute("y2", y), b.setAttribute("x1", v), b.setAttribute("y1", I), b.setAttribute("x2", E), b.setAttribute("y2", B), U.setAttribute("x1", f), U.setAttribute("y1", m), U.setAttribute("x2", C), U.setAttribute("y2", y) } if (t % 2 == 1 && t !== i) { var F = A.getScreenCoordFromSceneCoord(e.Measurement.pointPick[t - 1]), K = new s(F[0], F[1]); e.Measurement.pointPickToScreen[t - 1] = K; f = K.x, m = K.y; (x = document.getElementById("circlePick" + A.getViewerImpl().uuid + (t - 1))).setAttribute("cx", f), x.setAttribute("cy", m) } }, this.addEventListener = function () { e.cameraControl.addEventListener(Rc.ON_CAMERA_CHANGE, t), e.cameraControl.addEventListener(Rc.ON_CAMERA_CHANGE, i) } }; Object.assign(mB.prototype, Ld.prototype); var CB = function () { function A(e) { cc(this, A), this.coef = e.coef || .5, this.controlPoints = e.controlPoints || [], this.pointCountRecord = e.pointCountRecord, this.formatConPoints = [], this.matrix = [], this.update = !0, this.points = [], this.controlPointsIndex = [], this.straightLineDistance = 0, this.curveLength = 0, this.updateCurveLength = !0, this.updateList = [], this.setCoef(this.coef), this._forMatConPoints() } return dc(A, [{ key: "setControlPoints", value: function (A) { this.controlPoints = A, this._forMatConPoints(), this.update = !0, this.updateList.push("controlPoints"), this.updateStraightLineDistance = !0 } }, { key: "getPoints", value: function () { return this.update && this._createPoints(this.pointCountRecord), this.points } }, { key: "setPointsCount", value: function (A) { this.updateList.push("count"), this.update = !0, this.pointCountRecord = A } }, { key: "getCurveLength", value: function () { return this.update ? { info: "参数已修改,请先更新曲线", code: -1, updateList: this.updateList } : (this.updateCurveLength && function () { var A = this.points, e = A.length; this.curveLength = A.reduce((function (A, t, i, o) { return e > i + 1 && (A += o[i].distanceTo(o[i + 1])), A }), 0), this.updateCurveLength = !1 } .bind(this)(), this.curveLength) } }, { key: "getStraightLineDistance", value: function () { return this.updateStraightLineDistance && function () { var A = this.controlPoints, e = A.length; this.straightLineDistance = A.reduce((function (A, t, i, o) { return e > i + 1 && (A += o[i].distanceTo(o[i + 1])), A }), 0), this.updateStraightLineDistance = !1 } .bind(this)(), this.straightLineDistance } }, { key: "setCoef", value: function (A) { this.updateList.push("coef"), this.update = !0, this.matrix = [ [-A, 2 - A, A - 2, A], [2 * A, A - 3, 3 - 2 * A, -A], [-A, 0, A, 0], [0, 1, 0, 0] ] } }, { key: "updateCurve", value: function () { return this.getPoints() } }, { key: "getPointsInfo", value: function () { return this.update ? { info: "参数已修改,请先更新曲线", code: -1, updateList: this.updateList } : { points: this.getPoints(), controlPointsIndex: this.controlPointsIndex, curveLength: this.getCurveLength(), straightLineDistance: this.getStraightLineDistance() } } }, { key: "_forMatConPoints", value: function () { var A = this.controlPoints; this.formatConPoints = []; for (var e = 0, t = A.length; t > e; e += 1) 0 === e ? this.formatConPoints.push(A[e].clone(), A[e].clone()) : t > e + 1 ? this.formatConPoints.push(A[e].clone()) : this.formatConPoints.push(A[e].clone(), A[e].clone()) } }, { key: "_createPoints", value: function (A) { var e = [], t = this.matrix; function i(A) { e[0] = new y, e[1] = new y, e[2] = new y, e[3] = new y; var i = []; i[0] = [], i[1] = [], i[2] = [], i[3] = [], i[0][0] = A[0].clone().multiplyScalar(t[0][0]), i[0][1] = A[1].clone().multiplyScalar(t[0][1]), i[0][2] = A[2].clone().multiplyScalar(t[0][2]), i[0][3] = A[3].clone().multiplyScalar(t[0][3]), i[1][0] = A[0].clone().multiplyScalar(t[1][0]), i[1][1] = A[1].clone().multiplyScalar(t[1][1]), i[1][2] = A[2].clone().multiplyScalar(t[1][2]), i[1][3] = A[3].clone().multiplyScalar(t[1][3]), i[2][0] = A[0].clone().multiplyScalar(t[2][0]), i[2][1] = A[1].clone().multiplyScalar(t[2][1]), i[2][2] = A[2].clone().multiplyScalar(t[2][2]), i[2][3] = A[3].clone().multiplyScalar(t[2][3]), i[3][0] = A[0].clone().multiplyScalar(t[3][0]), i[3][1] = A[1].clone().multiplyScalar(t[3][1]), i[3][2] = A[2].clone().multiplyScalar(t[3][2]), i[3][3] = A[3].clone().multiplyScalar(t[3][3]); for (var o = 0; 4 > o; o += 1) for (var n = 0; 4 > n; n += 1) e[o].add(i[o][n]) } function o(A) { var t = A * A, i = t * A; return e[0].clone().multiplyScalar(i).add(e[1].clone().multiplyScalar(t)).add(e[2].clone().multiplyScalar(A)).add(e[3].clone()) } var n = this.formatConPoints, r = this.points = [], a = this.controlPointsIndex = [], s = this.controlPoints; if (A) { for (var l = this.getStraightLineDistance(), c = 1 / A, h = 0, d = 0, p = 0, g = s.length - 1; g > p; p += 1) { h += s[p].distanceTo(s[p + 1]); var u = Math.floor(h / l / c) - d; i([n[p], n[p + 1], n[p + 2], n[p + 3]]); for (var f = 1 / u, m = 0; u > m; m += 1) { r.push(o(f * m)) } d += u } r.push(s[s.length - 1]) } else for (var C = 0, v = n.length; v > C; C += 1) { var I = 0 === C ? 0 : 1; if (C + 3 >= v) { r.push(n[C + 2]), a.push({ j: n[C + 1], order: -1 }); break } r.push(n[C + 1]), a.push({ j: n[C + 1], order: 100 * C + I }), i([n[C], n[C + 1], n[C + 2], n[C + 3]]); for (var E = 1; 100 > E; E += 1) r.push(o(E / 100)) } this.update = !1, this.updateCurveLength = !0, this.updateList = [] } }]), A }(), yB = function () { function A(e) { cc(this, A), this.coef = e.coef || .5, this.points = e.controlPoints || [], this.pointCountRecord = e.pointCountRecord, this.formatConPoints = [], this.matrix = [], this._points = [], this.controlPointsIndex = [], this.straightLineDistance = 0, this.count = 0, this.setCoef(this.coef), this._forMatConPoints(), this._calCount(), this.update = !0 } return dc(A, [{ key: "setControlPoints", value: function (A) { this.points = A, this._forMatConPoints(), this._calCount(), this._createPoints(), this.update = !0 } }, { key: "getPointAt", value: function (A) { this.update && this.getPoints(); var e = Math.ceil(A * this.count); return this._points[e > this.count ? this.count : e] } }, { key: "getPoints", value: function () { return this.update && this._createPoints(this.pointCountRecord), this._points } }, { key: "setCoef", value: function (A) { this.update = !0, this.matrix = [ [-A, 2 - A, A - 2, A], [2 * A, A - 3, 3 - 2 * A, -A], [-A, 0, A, 0], [0, 1, 0, 0] ] } }, { key: "getPointsInfo", value: function () { return { points: this.getPoints(), controlPointsIndex: this.controlPointsIndex } } }, { key: "_forMatConPoints", value: function () { var A = this.points; this.formatConPoints = []; for (var e = 0, t = A.length; t > e; e += 1) 0 === e ? this.formatConPoints.push(A[e].clone(), A[e].clone()) : t > e + 1 ? this.formatConPoints.push(A[e].clone()) : this.formatConPoints.push(A[e].clone(), A[e].clone()) } }, { key: "_calCount", value: function () { var A, e, t = this, i = 1 / 0; e = (A = t.points).length, t.straightLineDistance = A.reduce((function (A, t, o, n) { if (e > o + 1) { var r = n[o].distanceTo(n[o + 1]); i = r > i ? i : r, A += r } return A }), 0), t.updateStraightLineDistance = !1; var o = Math.ceil(t.straightLineDistance / i); this.count = o > 100 ? o : 100 } }, { key: "_createPoints", value: function () { var A = [], e = this.matrix; function t(t) { A[0] = new y, A[1] = new y, A[2] = new y, A[3] = new y; var i = []; i[0] = [], i[1] = [], i[2] = [], i[3] = [], i[0][0] = t[0].clone().multiplyScalar(e[0][0]), i[0][1] = t[1].clone().multiplyScalar(e[0][1]), i[0][2] = t[2].clone().multiplyScalar(e[0][2]), i[0][3] = t[3].clone().multiplyScalar(e[0][3]), i[1][0] = t[0].clone().multiplyScalar(e[1][0]), i[1][1] = t[1].clone().multiplyScalar(e[1][1]), i[1][2] = t[2].clone().multiplyScalar(e[1][2]), i[1][3] = t[3].clone().multiplyScalar(e[1][3]), i[2][0] = t[0].clone().multiplyScalar(e[2][0]), i[2][1] = t[1].clone().multiplyScalar(e[2][1]), i[2][2] = t[2].clone().multiplyScalar(e[2][2]), i[2][3] = t[3].clone().multiplyScalar(e[2][3]), i[3][0] = t[0].clone().multiplyScalar(e[3][0]), i[3][1] = t[1].clone().multiplyScalar(e[3][1]), i[3][2] = t[2].clone().multiplyScalar(e[3][2]), i[3][3] = t[3].clone().multiplyScalar(e[3][3]); for (var o = 0; 4 > o; o += 1) for (var n = 0; 4 > n; n += 1) A[o].add(i[o][n]) } for (var i, o, n, r = this.formatConPoints, a = this._points = [], s = this.controlPointsIndex = [], l = this.points, c = this.straightLineDistance, h = 0, d = 0, p = 0, g = l.length - 1; g > p; p += 1) { var u = (h += l[p].distanceTo(l[p + 1])) / c * this.count - d; t([r[p], r[p + 1], r[p + 2], r[p + 3]]), a.push(r[p + 1]), s.push({ j: r[p + 1], order: d }), d += 1; for (var f = 1; u > f; f += 1) a.push((o = void 0, n = void 0, n = (o = (i = f / u) * i) * i, A[0].clone().multiplyScalar(n).add(A[1].clone().multiplyScalar(o)).add(A[2].clone().multiplyScalar(i)).add(A[3].clone()))), d += 1 } a.push(l[l.length - 1]), s.push({ to: r[l.length - 1], order: -1 }), this.update = !1 } }]), A }(), vB = function () { function A(e) { return cc(this, A), A.shareInstance || (A.shareInstance = this, this.maxRequestCount = e || 300, this.currentPendingCount = 0, this._requests = [], this._requestDidLoad = this._requestDidLoad.bind(this), this._requestDidError = this._requestDidError.bind(this), this._requestDidAbort = this._requestDidAbort.bind(this), this._requestDidTimeout = this._requestDidTimeout.bind(this)), A.shareInstance } return dc(A, [{ key: "addRequest", value: function (A, e) { A.addEventListener("load", this._requestDidLoad), A.addEventListener("error", this._requestDidError), A.addEventListener("abort", this._requestDidAbort), A.addEventListener("timeout", this._requestDidTimeout), this.maxRequestCount > this.currentPendingCount ? (A.send(e), this.currentPendingCount += 1) : this._requests.push({ request: A, dataToSend: e }) } }, { key: "_sendNextRequest", value: function () { if (this._requests.length > 0) { var A = this._requests.shift(); A.request.send(A.dataToSend), this.currentPendingCount += 1 } } }, { key: "_requestDidLoad", value: function () { this.currentPendingCount -= 1, this._sendNextRequest() } }, { key: "_requestDidError", value: function () { this.currentPendingCount -= 1, this._sendNextRequest() } }, { key: "_requestDidAbort", value: function () { this.currentPendingCount -= 1, this._sendNextRequest() } }, { key: "_requestDidTimeout", value: function () { this.currentPendingCount -= 1, this._sendNextRequest() } }]), A }(), IB = { group: "group", model: "model", component: "component", components: "components" }, EB = function A() { cc(this, A), this.type = void 0, this.nodeId = void 0, this.matrix = void 0, this.center = void 0, this.modelKey = void 0, this.componentKey = void 0, this.componentsKey = void 0, this.children = void 0 }, BB = function () { function A(e, t, i, o) { cc(this, A), this.host = e, this.projectUrl = t, this.accessToken = i, this._cachedComponents = {}, this._cachedMaterials = {}, this._cachedGeometries = {}, this._cachedFile = {}, this._requestQueue = new vB(o) } return dc(A, [{ key: "destroy", value: function () { delete this._cachedComponents, delete this._cachedMaterials, delete this._cachedGeometries, delete this._cachedFile } }, { key: "getExternalObjectByModelKey", value: function (A) { var e = this; return "string" != typeof A ? Promise.reject("参数不合法") : this._loadModelInfo(A).then((function () { return e._loadComponentsListIn(A) })).then((function (A) { return e.getExternalObjectByComponentsKey(A) })) } }, { key: "getExternalObjectByComponentKey", value: function (A) { var e = this; if ("string" != typeof A) return Promise.reject("参数不合法"); var t = this._cachedComponents[A]; return t ? Promise.resolve(this._createMesh(t, !0)) : this._loadComponentsInfo([A]).then((function (A) { return e._generateMeshByComponentInfo(A[0]) })).then((function (A) { return A })) } }, { key: "getExternalObjectByComponentsKeyBackup", value: function (A) { var e = this; if (A instanceof Array == !1) return Promise.reject("参数不合法"); for (var t = [], i = [], o = {}, n = function (n, r) { var a = e.getExternalObjectByComponentKey(A[n]).then((function (A) { i.push(A) })).catch((function (e) { o[A[n]] = e })); t.push(a) }, r = 0, a = A.length; a > r; r += 1) n(r); return Promise.all(t).then((function () { if (i.length > 0) { i.length !== A.length && Bh.error(o); for (var e = new Xi, t = 0, n = i.length; n > t; t += 1) e.add(i[t]); return e } return Promise.reject(o) })) } }, { key: "getExternalObjectByComponentsKey", value: function (A) { var e = this; if (A instanceof Array == !1) return Promise.reject("参数不合法"); for (var t = [], i = {}, o = [], n = 0, r = A.length; r > n; n += 1) { var a = A[n], s = this._cachedComponents[a]; s ? t.push(this._createMesh(s, !0)) : o.push(a) } if (o.length > 0) return this._loadComponentsInfo(o).then((function (o) { for (var n = [], r = 0, a = o.length; a > r; r += 1) { var s = e._generateMeshByComponentInfo(o[r]).then((function (A) { t.push(A) })).catch((function (A) { i[A.componentKey] = A.message })); n.push(s) } return Promise.all(n).then((function () { if (t.length > 0) { t.length !== A.length && Bh.error(i); for (var e = new Xi, o = 0, n = t.length; n > o; o += 1) e.add(t[o]); return e } return Promise.reject(i) })) })); for (var l = new Xi, c = 0, h = t.length; h > c; c += 1) l.add(t[c]); return Promise.resolve(l) } }, { key: "testData", value: function () { var A = new EB; A.type = IB.group; var e = new EB; e.type = IB.component, e.componentKey = "M1577676674083_265272"; var t = new EB; t.type = IB.component, t.componentKey = "M1577676674083_265916"; var i = new EB; i.type = IB.component, i.componentKey = "M1577676674083_244449"; var o = (new M).makeTranslation(0, 0, 5e3); i.matrix = o.toArray(); var n = new EB; n.type = IB.group; var r = new EB; r.type = IB.component, r.componentKey = "M1577676674083_246705"; var a = new EB; a.type = IB.component, a.componentKey = "M1577676674083_247372", a.matrix = o.makeTranslation(0, 0, 7e3).toArray(); var s = new EB; return s.type = IB.component, s.componentKey = "M1577676674083_244910", A.children = [e, t, i, n], n.children = [r, a, s], A } }, { key: "getExternalObjectByNodeInfo", value: function (A) { var e = this, t = void 0; return A.type === IB.component && A.componentKey ? t = this.getExternalObjectByComponentKey(A.componentKey) : A.type === IB.components && A.componentsKey && A.componentsKey instanceof Array && A.componentsKey.length > 0 ? t = this.getExternalObjectByComponentsKey(A.componentsKey) : A.type === IB.model && A.modelKey ? t = this.getExternalObjectByModelKey(A.modelKey) : A.type === IB.group && A.children && A.children.length > 0 ? function () { for (var i = new Xi, o = [], n = function (t, n) { var r = A.children[t], a = e.getExternalObjectByNodeInfo(r).then((function (A) { i.add(A) })).catch((function (A) { return Bh.error(r, A), A })); o.push(a) }, r = 0, a = A.children.length; a > r; r += 1) n(r); t = Promise.all(o).then((function () { return i })) }() : t = Promise.reject("参数不合法"), t.then((function (e) { if (A.matrix) { var t = (new M).fromArray(A.matrix); e.matrix.identity(), e.applyMatrix4(t), e.updateMatrixWorld(!0) } if (A.center) { var i = (new aA).setFromObject(e), o = new y; if (i.getCenter(o), parseInt(A.center[0], 10) !== parseInt(o.x, 10) || parseInt(A.center[1], 10) !== parseInt(o.y, 10) || parseInt(A.center[2], 10) !== parseInt(o.z, 10)) { var n = (new y).fromArray(A.center).sub(o), r = (new M).makeTranslation(n.x, n.y, n.z); e.applyMatrix4(r), e.updateMatrixWorld(!0) } } return e })) } }, { key: "exportNodeInfoByComponents", value: function (A, e) { if (e) { var t = new EB; return 1 === e.length ? (t.type = IB.component, t.componentKey = e[0]) : (t.type = IB.components, t.componentsKey = e), t.nodeId = A, t } } }, { key: "exportNodeInfoByModelKey", value: function (A, e) { if (e) { var t = new EB; return t.type = IB.model, t.modelKey = e, t.nodeId = A, t } } }, { key: "_loadModelInfo", value: function (A) { return this._httpGet(this.host + "/api/" + this.projectUrl + "/models?modelKey=" + A) } }, { key: "_loadComponentsListIn", value: function (A) { return this._httpGet(this.host + "/api/" + this.projectUrl + "/components/keys?modelKey=" + A) } }, { key: "_loadComponentsInfo", value: function (A, e, t) { return this._httpPost(this.host + "/api/" + this.projectUrl + "/components/geometry", { components: A }) } }, { key: "_generateMeshByComponentInfo", value: function (A) { var e = this; if (!A.geometry) return Promise.reject({ componentKey: A.component, message: "几何为空" }); var t = {}; if (t.componentKey = A.component, A.matrix) { var i = (new M).fromArray(A.matrix); t.matrix = i } var o = A.materials, n = [], r = []; if (A.materials.length > 0) for (var a = function (t, i) { n.push(e._loadMaterial(o[t]).then((function (A) { r[t] = A })).catch((function (i) { Bh.error(i, "用默认材质代替"), r[t] = e._loadMaterialByType(A.type) }))) }, s = 0, l = o.length; l > s; s += 1) a(s); else { var c = this._loadMaterialByType(A.type); r.push(c), n.push(Promise.resolve(c)) } return Promise.all(n).then((function () { return t.materials = r, e._loadGeometry(A.geometry) })).then((function (A) { t.geometry = A; for (var i = 0, o = t.materials.length; o > i; i += 1) { var n = t.materials[i]; if (n.aoMap || n.lightMap) { t.geometry.setAttribute("uv2", new YA(t.geometry.attributes.uv.array, 2)); break } } return e._cachedComponents[t.componentKey] = t, e._createMesh(t, !1) })) } }, { key: "_loadMaterial", value: function (A) { var e = this, t = this._cachedMaterials[A.key]; if (t) return Promise.resolve(t.clone()); var i = A.data; return this._loadAllTextures(i).then((function (t) { var o = e._createMaterial(i, t); return e._cachedMaterials[A.key] = o, o })) } }, { key: "_loadMaterialByType", value: function (A) { var e = _u[A] ? _u[A].color : void 0; e || (e = _u.DEFAULT.color); var t = new LA(e[0], e[1], e[2]), i = t.getHexString() + "_" + e[3], o = this._cachedMaterials[i]; return o || ((o = Kd.createStandardMaterial({ color: t })).side = 2, this._cachedMaterials[i] = o), o } }, { key: "_loadGeometry", value: function (A) { var e = this, t = this._cachedGeometries[A]; return t ? Promise.resolve(t) : this._loadFile(A).then((function (t) { try { var i = new TextDecoder("utf-8").decode(t), o = JSON.parse(i), n = e._createGeometry(o); return n ? (e._cachedGeometries[A] = n, n) : Promise.reject("几何为空") } catch (A) { return Promise.reject(A.message) } })) } }, { key: "_loadAllTextures", value: function (A) { for (var e = this, t = [], i = this._getAllTextureFileKey(A), o = {}, n = function (A, n) { var r = i[A]; t.push(e._loadFile(r).then((function (A) { var t = e._createTexture(A); o[r] = t })).catch((function (A) { Bh.error(A) }))) }, r = 0, a = i.length; a > r; r += 1) n(r); return t.length > 0 ? new Promise((function (A, e) { Promise.all(t).then((function () { Object.keys(o).length > 0 ? A(o) : e("加载纹理失败") })) })) : Promise.resolve(o) } }, { key: "_getAllTextureFileKey", value: function (A) { var e = {}; return A.map && (e[A.map] = !0), A.aoMap && (e[A.aoMap] = !0), A.alphaMap && (e[A.alphaMap] = !0), A.envMap && (e[A.envMap] = !0), A.lightMap && (e[A.lightMap] = !0), A.emissiveMap && (e[A.emissiveMap] = !0), A.specularMap && (e[A.specularMap] = !0), A.specularMap && (e[A.specularMap] = !0), Object.keys(e) } }, { key: "_createTexture", value: function (A) { var e = new d, t = document.createElement("img"); e.wrapS = e.wrapT = 1e3, t.onerror = function (A) { Bh.error("加载纹理出错") }, t.onload = function (i) { "string" != typeof A && window.URL.revokeObjectURL(t.src), e.image = t, e.needsUpdate = !0 }; var i = new Blob([A]); return t.src = window.URL.createObjectURL(i), e } }, { key: "_createGeometry", value: function (A) { if (A.positions && 0 !== A.positions.length) { var e = null; e = new he; var t = new Float32Array(A.positions); e.setAttribute("position", new YA(t, 3)); var i = new Uint32Array(A.indices); if (e.setIndex(new YA(i, 1)), A.normals && A.normals.length > 0) { var o = new Float32Array(A.normals); e.setAttribute("normal", new YA(o, 3)) } else e.computeVertexNormals(); if (A.uv && A.uv.length > 0) { var n = new Float32Array(A.uv); e.setAttribute("uv", new YA(n, 2)) } if (void 0 !== A.materialIndices) { for (var r = null, a = [], s = void 0, l = 0; A.materialIndices.length > l; l += 1) { var c = A.materialIndices[l]; c !== s && (s = c, null != r && (r.count = 3 * l - r.start, a.push(r)), r = { start: 3 * l, materialIndex: s }) } null != r && (r.count = 3 * A.materialIndices.length - r.start, a.push(r)), e.groups = a } return e } } }, { key: "_createMaterial", value: function (A, e) { return Kd.createMaterialByMaterialBufferAndTexture(A, e) } }, { key: "_createMesh", value: function (A, e) { var t = null; if (e) { t = []; for (var i = 0, o = A.materials.length; o > i; i += 1) t.push(A.materials[i].clone()) } else t = A.materials; var n = new Kf(A.geometry, t); return n.visible = !0, n.key = A.componentKey, A.matrix && (n.applyMatrix4(A.matrix), n.updateMatrixWorld(!0)), n } }, { key: "_loadFile", value: function (A) { var e = this._cachedFile[A]; return e ? Promise.resolve(e) : this._http("GET", this.host + "/api/" + this.projectUrl + "/files?fileKey=" + A, "arraybuffer").then((function (A) { return A })) } }, { key: "_httpGet", value: function (A) { return this._http("GET", A) } }, { key: "_httpPost", value: function (A, e) { return this._http("POST", A, void 0, e) } }, { key: "_http", value: function (A, e, t, i) { var o = this; return new Promise((function (n, r) { var a = {}; "POST" === A && (a["Content-type"] = "application/json;charset=UTF-8"), o.accessToken && (a.Authorization = o.accessToken), _d({ type: A, url: e, headers: a, data: JSON.stringify(i), responseType: t || "json", requestQueue: o._requestQueue, success: function (A) { if (A) try { t && "json" !== t ? n(A) : A.data ? n(A.data) : "success" !== A.code.toLowerCase() && r(A.message ? A.message : "未知错误") } catch (A) { r(A.message) } else r("数据为空") }, error: function (A, e) { r(e) } }) })) } }]), A }(), xB = {}; xB.ToolBar = Xd; var SB = {}; SB.ModelCompares = $y, SB.DISPLAYMODEL = zy, SB.CompareGlobalData = Xy, SB.CompareComponentType = Zy, SB.COMPAREEVENTS = _y, SB.ViewerConnector = ev, SB.RoadNetManager = JE, SB.TextLoader = _E, SB.TrackSimulator = AB, SB.Heatmap = BE, SB.Fire = FE, SB.Water = eB, SB.WaterEffect = sv, SB.WaterEffectConfig = function () { this.boundary = [], this.color = new Xh("#80FDFF", .8), this.scale = 4, this.viewer = null, this.xDirection = 1, this.yDirection = 1, this.reflectivity = 1, this.reflectorTexturePosition = new y, this.refractorTexturePosition = new y, this.height = 0, this.geometry = null }, SB.ArrowManager = cv; var wB = {}; wB.Line2 = QE, wB.LineMaterial = YC, wB.LineGeometry = KE; for (var MB = {}, bB = Object.keys(sc), UB = 0; bB.length > UB; UB += 1) { var FB = bB[UB]; Object.defineProperty(MB, FB, { value: sc[FB], enumerable: !0, configurable: !0, writable: !1 }) } A.Animation = hp, A.ArrowDomMark = uB, A.ArrowDomMarkManager = fB, A.BOSCatmullRomCurve3 = CB, A.BOSCatmullRomCurve3ForFrameEdit = yB, A.BaseControl = Fg, A.CAMERATYPE = Ec, A.Camera = cp, A.CameraAnimator = dp, A.CameraControl = mp, A.CameraInfo = Qd, A.CameraUtil = Rd, A.ClipPlaneService = Ap, A.ClipPlanes = HC, A.ClipPlanesTool = vp, A.CollisionDetection = function (A) { this.cameraControl = A, this.intersector = A.intersector; var e = new Dd, t = new Dd, i = new Dd, o = new Dd, n = new Dd, r = new Dd; this.run = function (a, s) { var l = {}, c = this.cameraControl.getIntersectContext(null); e.set(a, new y(0, 0, 1)), t.set(a, new y(0, 0, -1)), n.set(a, s), r.set(a, new y(-s.x, -s.y, -s.z)), i.set(a, new y(-s.y, s.x, s.z)), o.set(a, new y(s.y, -s.x, s.z)), l.top = this.intersector.getIntersectByRay(c, e.ray), l.down = this.intersector.getIntersectByRay(c, t.ray), l.front = this.intersector.getIntersectByRay(c, n.ray), l.back = this.intersector.getIntersectByRay(c, r.ray), l.left = this.intersector.getIntersectByRay(c, i.ray), l.right = this.intersector.getIntersectByRay(c, o.ray); var h = new y(a.x, a.y, a.z - .8 * A.manHeight), d = new Dd; d.set(h, s); var p = new Dd; p.set(h, new y(-s.x, -s.y, -s.z)); var g = new Dd; g.set(h, new y(-s.y, s.x, s.z)); var u = new Dd; return u.set(h, new y(s.y, -s.x, s.z)), l.frontMiddle = this.intersector.getIntersectByRay(c, d.ray), l.backMiddle = this.intersector.getIntersectByRay(c, p.ray), l.leftMiddle = this.intersector.getIntersectByRay(c, g.ray), l.rightMiddle = this.intersector.getIntersectByRay(c, u.ray), l } }, A.Color = Xh, A.ColorPicker = Hh, A.ControlConfig = jh, A.ControlManager = Og, A.ControlMode = Gc, A.DOMMark = Od, A.DefaultInvisibleComponentType = bc, A.DefaultMaterial = _u, A.DeviceTest = mh, A.DomUtil = xh, A.DrawingStyle = jc, A.EIMMODELMaterial = ld, A.EVENTS = Rc, A.Edge = wp, A.EnumCesiumImageryLayerType = { AUTO: 0, BAIDU: 1, GAODE: 2, MAPBOX: 3, ARCGIS: 4, GOOGLE: 5 }, A.EnumConditionType = { HIDDEN_OTHERS: 0, TRANSLUCENT_OTHERS: 1, OVERRIDE: 2, BORDERLINE: 3 }, A.EnumDataProvider = Wc, A.EnumFilterState = zc, A.EnumIdBasedType = Dc, A.EnumInstanceState = Hc, A.EnumIsolateState = Nc, A.EnumObjectState = Lc, A.EnumRenderType = { RENDER: 0, RENDER_FINISHED: 1, RESIZE: 2 }, A.EnumRendererType = { AUTO: 0, FULL: 1, INCREMENT: 2 }, A.EnumSceneState = Vc, A.EnumShaderColorState = Yc, A.EnumTransparentState = Oc, A.EnumUserType = { HIDDEN_DATA: 0, OVERRIDE_DATA: 1, WITH_BOARDLINE: 2 }, A.EventDispatcher = Ld, A.ExternalObjectConverter = BB, A.ExternalObjectNodeInfo = EB, A.ExternalObjectNodeInfoType = IB, A.ExternalScene = ey, A.FillClipPlane = _C, A.FillClipPlaneTool = Sp, A.FilterResultMode = Jc, A.FullScreen = Wh, A.GLTFLoader = OC, A.GeomUtil = Tu, A.GlobalData = vc, A.Group = ep, A.IDENTITYMATRIX3 = xc, A.IDENTITYMATRIX4 = Bc, A.ImageResources = Pd, A.IntersectHelper = fp, A.KDNode = Zu, A.LOADERROREVENTS = Tc, A.LightType = Fc, A.LineSegmentsEx = cf, A.Lobibox = bh, A.LogLevels = Ch, A.MarkObject = Hd, A.MaterialEx = ay, A.MaterialUtil = Kd, A.MeasureTool = Eg, A.MeasurementManager = mB, A.MeshEx = Kf, A.ModelType = Zc, A.MoveDirection = qc, A.NodeItemType = { SYMBOL: 0, MESH: 1, TUBE: 2, PIPE: 3, BOX: 4, BOX_M: 5, PIPE_M: 6, MESH_REF: 7, LINE: 8 }, A.NoiseTextureType = xd, A.NormalControl = Qg, A.OPSELECTIONTYPE = Kc, A.OrbitControl = Rg, A.PICKABLETYPE = Qc, A.PhongLightingMaterial = jC, A.PickControl = kg, A.PickHelper = kp, A.PickUtil = wg, A.PlaneMark = Vd, A.Plugins = SB, A.PostilObject = Jd, A.PrimitiveCount = { vertexCount: 0, triangleCount: 0 }, A.Raycaster = Dd, A.RectOpTool = Mg, A.RectPickTool = bg, A.RectZoomTool = Ug, A.Roam = tB, A.RoamManager = oB, A.RoamPlayer = iB, A.RotatePivotMode = kc, A.RotationOrders = Ic, A.SVGRect = tp, A.Scene = oy, A.SceneStateHelper = ny, A.SectionPlane = hB, A.SelectPad = Dg, A.Snapshot = Zd, A.SpriteMark = Gd, A.StorageCache = AC, A.THREE = MB, A.THREEEX = wB, A.ThreeMark = dB, A.Tool = yp, A.ToolBar = Xd, A.ToolMode = Pc, A.UI = xB, A.Utils = uh, A.Version = "4.18.0", A.ViewController = lp, A.Viewer = Py, A.ViewerImpl = Gy, A.WalkControl = Lg, A.WordPlaneMark = pB, A.ajax = _d, A.buildEdge = Up, A.createNoiseTexture = Fd, A.getFaceIndex = Fp, A.getScript = function (A, e) { var t = {}; if (t[A]) e && e(); else { var i = document.createElement("script"); i.type = "text/javascript", i.src = A, document.head.appendChild(i), t[A] = !0, i.readyState ? i.onreadystatechange = function () { "loaded" !== i.readyState && "complete" !== i.readyState || (i.onreadystatechange = null, e && e()) } : i.onload = function () { e && e() } } }, A.i18nMessage = fh, A.logger = Bh, A.message = jd, A.removeDuplicateIndex = Mp, A.removeDuplicateVertex = bp, A.standardView = Uc, Object.defineProperty(A, "__esModule", { value: !0 }) })); //# sourceMappingURL=EIMMODEL.min.js.map