;(self.webpackChunk_N_E = self.webpackChunk_N_E || []).push([ [446], { 75569: function (t, n, r) { t.exports = (function () { var t return (function () { function e(t, n, r) { function i(a, s) { if (!n[a]) { if (!t[a]) { if (o) return o(a, !0) var l = new Error("Cannot find module '" + a + "'") throw ((l.code = 'MODULE_NOT_FOUND'), l) } var c = (n[a] = { exports: {} }) t[a][0].call( c.exports, function (e) { return i(t[a][1][e] || e) }, c, c.exports, e, t, n, r, ) } return n[a].exports } for (var o = void 0, a = 0; a < r.length; a++) i(r[a]) return i } return e })()( { 1: [ function (e, t, n) { var r = Object.prototype.toString function i(e) { return ( (e.BYTES_PER_ELEMENT && '[object ArrayBuffer]' === r.call(e.buffer)) || Array.isArray(e) ) } t.exports = i }, {}, ], 2: [ function (e, t, n) { t.exports = function (e, t) { return 'number' === typeof e ? e : 'number' === typeof t ? t : 0 } }, {}, ], 3: [ function (e, t, n) { 'use strict' ;(n.byteLength = u), (n.toByteArray = d), (n.fromByteArray = m) for ( var r = [], i = [], o = 'undefined' !== typeof Uint8Array ? Uint8Array : Array, a = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/', s = 0, l = a.length; s < l; ++s ) (r[s] = a[s]), (i[a.charCodeAt(s)] = s) function c(e) { var t = e.length if (t % 4 > 0) throw new Error('Invalid string. Length must be a multiple of 4') var n = e.indexOf('=') return -1 === n && (n = t), [n, n === t ? 0 : 4 - (n % 4)] } function u(e) { var t = c(e), n = t[0], r = t[1] return (3 * (n + r)) / 4 - r } function h(e, t, n) { return (3 * (t + n)) / 4 - n } function d(e) { for ( var t, n = c(e), r = n[0], a = n[1], s = new o(h(e, r, a)), l = 0, u = a > 0 ? r - 4 : r, d = 0; d < u; d += 4 ) (t = (i[e.charCodeAt(d)] << 18) | (i[e.charCodeAt(d + 1)] << 12) | (i[e.charCodeAt(d + 2)] << 6) | i[e.charCodeAt(d + 3)]), (s[l++] = (t >> 16) & 255), (s[l++] = (t >> 8) & 255), (s[l++] = 255 & t) return ( 2 === a && ((t = (i[e.charCodeAt(d)] << 2) | (i[e.charCodeAt(d + 1)] >> 4)), (s[l++] = 255 & t)), 1 === a && ((t = (i[e.charCodeAt(d)] << 10) | (i[e.charCodeAt(d + 1)] << 4) | (i[e.charCodeAt(d + 2)] >> 2)), (s[l++] = (t >> 8) & 255), (s[l++] = 255 & t)), s ) } function p(e) { return r[(e >> 18) & 63] + r[(e >> 12) & 63] + r[(e >> 6) & 63] + r[63 & e] } function f(e, t, n) { for (var r, i = [], o = t; o < n; o += 3) (r = ((e[o] << 16) & 16711680) + ((e[o + 1] << 8) & 65280) + (255 & e[o + 2])), i.push(p(r)) return i.join('') } function m(e) { for ( var t, n = e.length, i = n % 3, o = [], a = 16383, s = 0, l = n - i; s < l; s += a ) o.push(f(e, s, s + a > l ? l : s + a)) return ( 1 === i ? ((t = e[n - 1]), o.push(r[t >> 2] + r[(t << 4) & 63] + '==')) : 2 === i && ((t = (e[n - 2] << 8) + e[n - 1]), o.push(r[t >> 10] + r[(t >> 4) & 63] + r[(t << 2) & 63] + '=')), o.join('') ) } ;(i['-'.charCodeAt(0)] = 62), (i['_'.charCodeAt(0)] = 63) }, {}, ], 4: [ function (e, t, n) { 'use strict' t.exports = { createLink: function (e, t) { var n = document.head || document.getElementsByTagName('head')[0], r = document.createElement('link') for (var i in ((r.href = e), (r.rel = 'stylesheet'), t)) if (t.hasOwnProperty(i)) { var o = t[i] r.setAttribute('data-' + i, o) } n.appendChild(r) }, createStyle: function (e, t) { var n = document.head || document.getElementsByTagName('head')[0], r = document.createElement('style') for (var i in ((r.type = 'text/css'), t)) if (t.hasOwnProperty(i)) { var o = t[i] r.setAttribute('data-' + i, o) } r.sheet ? ((r.innerHTML = e), (r.sheet.cssText = e), n.appendChild(r)) : r.styleSheet ? (n.appendChild(r), (r.styleSheet.cssText = e)) : (r.appendChild(document.createTextNode(e)), n.appendChild(r)) }, } }, {}, ], 5: [ function (e, t, n) { var r = e('buffer').Buffer t.exports = function (e, t) { if (r.isBuffer(e) && r.isBuffer(t)) { if ('function' === typeof e.equals) return e.equals(t) if (e.length !== t.length) return !1 for (var n = 0; n < e.length; n++) if (e[n] !== t[n]) return !1 return !0 } } }, { buffer: 6 }, ], 6: [ function (t, n, i) { ;(function (n, r) { 'use strict' var o = t('base64-js'), a = t('ieee754'), s = t('isarray') function l() { try { var t = new Uint8Array(1) return ( (t.__proto__ = { __proto__: Uint8Array.prototype, foo: function () { return 42 }, }), 42 === t.foo() && 'function' === typeof t.subarray && 0 === t.subarray(1, 1).byteLength ) } catch (e) { return !1 } } function c() { return r.TYPED_ARRAY_SUPPORT ? 2147483647 : 1073741823 } function u(e, t) { if (c() < t) throw new RangeError('Invalid typed array length') return ( r.TYPED_ARRAY_SUPPORT ? ((e = new Uint8Array(t)).__proto__ = r.prototype) : (null === e && (e = new r(t)), (e.length = t)), e ) } function r(e, t, n) { if (!r.TYPED_ARRAY_SUPPORT && !(this instanceof r)) return new r(e, t, n) if ('number' === typeof e) { if ('string' === typeof t) throw new Error( 'If encoding is specified then the first argument must be a string', ) return f(this, e) } return h(this, e, t, n) } function h(e, t, n, r) { if ('number' === typeof t) throw new TypeError('"value" argument must not be a number') return 'undefined' !== typeof ArrayBuffer && t instanceof ArrayBuffer ? g(e, t, n, r) : 'string' === typeof t ? m(e, t, n) : y(e, t) } function d(e) { if ('number' !== typeof e) throw new TypeError('"size" argument must be a number') if (e < 0) throw new RangeError('"size" argument must not be negative') } function p(e, t, n, r) { return ( d(t), t <= 0 ? u(e, t) : void 0 !== n ? 'string' === typeof r ? u(e, t).fill(n, r) : u(e, t).fill(n) : u(e, t) ) } function f(e, t) { if ((d(t), (e = u(e, t < 0 ? 0 : 0 | b(t))), !r.TYPED_ARRAY_SUPPORT)) for (var n = 0; n < t; ++n) e[n] = 0 return e } function m(e, t, n) { if ((('string' === typeof n && '' !== n) || (n = 'utf8'), !r.isEncoding(n))) throw new TypeError('"encoding" must be a valid string encoding') var i = 0 | w(t, n), o = (e = u(e, i)).write(t, n) return o !== i && (e = e.slice(0, o)), e } function v(e, t) { var n = t.length < 0 ? 0 : 0 | b(t.length) e = u(e, n) for (var r = 0; r < n; r += 1) e[r] = 255 & t[r] return e } function g(e, t, n, i) { if ((t.byteLength, n < 0 || t.byteLength < n)) throw new RangeError("'offset' is out of bounds") if (t.byteLength < n + (i || 0)) throw new RangeError("'length' is out of bounds") return ( (t = void 0 === n && void 0 === i ? new Uint8Array(t) : void 0 === i ? new Uint8Array(t, n) : new Uint8Array(t, n, i)), r.TYPED_ARRAY_SUPPORT ? ((e = t).__proto__ = r.prototype) : (e = v(e, t)), e ) } function y(e, t) { if (r.isBuffer(t)) { var n = 0 | b(t.length) return 0 === (e = u(e, n)).length || t.copy(e, 0, 0, n), e } if (t) { if ( ('undefined' !== typeof ArrayBuffer && t.buffer instanceof ArrayBuffer) || 'length' in t ) return 'number' !== typeof t.length || ne(t.length) ? u(e, 0) : v(e, t) if ('Buffer' === t.type && s(t.data)) return v(e, t.data) } throw new TypeError( 'First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.', ) } function b(e) { if (e >= c()) throw new RangeError( 'Attempt to allocate Buffer larger than maximum size: 0x' + c().toString(16) + ' bytes', ) return 0 | e } function A(e) { return +e != e && (e = 0), r.alloc(+e) } function w(e, t) { if (r.isBuffer(e)) return e.length if ( 'undefined' !== typeof ArrayBuffer && 'function' === typeof ArrayBuffer.isView && (ArrayBuffer.isView(e) || e instanceof ArrayBuffer) ) return e.byteLength 'string' !== typeof e && (e = '' + e) var n = e.length if (0 === n) return 0 for (var i = !1; ; ) switch (t) { case 'ascii': case 'latin1': case 'binary': return n case 'utf8': case 'utf-8': case void 0: return K(e).length case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': return 2 * n case 'hex': return n >>> 1 case 'base64': return ee(e).length default: if (i) return K(e).length ;(t = ('' + t).toLowerCase()), (i = !0) } } function x(e, t, n) { var r = !1 if (((void 0 === t || t < 0) && (t = 0), t > this.length)) return '' if (((void 0 === n || n > this.length) && (n = this.length), n <= 0)) return '' if ((n >>>= 0) <= (t >>>= 0)) return '' for (e || (e = 'utf8'); ; ) switch (e) { case 'hex': return N(this, t, n) case 'utf8': case 'utf-8': return O(this, t, n) case 'ascii': return F(this, t, n) case 'latin1': case 'binary': return k(this, t, n) case 'base64': return D(this, t, n) case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': return U(this, t, n) default: if (r) throw new TypeError('Unknown encoding: ' + e) ;(e = (e + '').toLowerCase()), (r = !0) } } function E(e, t, n) { var r = e[t] ;(e[t] = e[n]), (e[n] = r) } function M(e, t, n, i, o) { if (0 === e.length) return -1 if ( ('string' === typeof n ? ((i = n), (n = 0)) : n > 2147483647 ? (n = 2147483647) : n < -2147483648 && (n = -2147483648), (n = +n), isNaN(n) && (n = o ? 0 : e.length - 1), n < 0 && (n = e.length + n), n >= e.length) ) { if (o) return -1 n = e.length - 1 } else if (n < 0) { if (!o) return -1 n = 0 } if (('string' === typeof t && (t = r.from(t, i)), r.isBuffer(t))) return 0 === t.length ? -1 : _(e, t, n, i, o) if ('number' === typeof t) return ( (t &= 255), r.TYPED_ARRAY_SUPPORT && 'function' === typeof Uint8Array.prototype.indexOf ? o ? Uint8Array.prototype.indexOf.call(e, t, n) : Uint8Array.prototype.lastIndexOf.call(e, t, n) : _(e, [t], n, i, o) ) throw new TypeError('val must be string, number or Buffer') } function _(e, t, n, r, i) { var o, a = 1, s = e.length, l = t.length if ( void 0 !== r && ('ucs2' === (r = String(r).toLowerCase()) || 'ucs-2' === r || 'utf16le' === r || 'utf-16le' === r) ) { if (e.length < 2 || t.length < 2) return -1 ;(a = 2), (s /= 2), (l /= 2), (n /= 2) } function c(e, t) { return 1 === a ? e[t] : e.readUInt16BE(t * a) } if (i) { var u = -1 for (o = n; o < s; o++) if (c(e, o) === c(t, -1 === u ? 0 : o - u)) { if ((-1 === u && (u = o), o - u + 1 === l)) return u * a } else -1 !== u && (o -= o - u), (u = -1) } else for (n + l > s && (n = s - l), o = n; o >= 0; o--) { for (var h = !0, d = 0; d < l; d++) if (c(e, o + d) !== c(t, d)) { h = !1 break } if (h) return o } return -1 } function T(e, t, n, r) { n = Number(n) || 0 var i = e.length - n r ? (r = Number(r)) > i && (r = i) : (r = i) var o = t.length if (o % 2 !== 0) throw new TypeError('Invalid hex string') r > o / 2 && (r = o / 2) for (var a = 0; a < r; ++a) { var s = parseInt(t.substr(2 * a, 2), 16) if (isNaN(s)) return a e[n + a] = s } return a } function S(e, t, n, r) { return te(K(t, e.length - n), e, n, r) } function C(e, t, n, r) { return te(J(t), e, n, r) } function L(e, t, n, r) { return C(e, t, n, r) } function R(e, t, n, r) { return te(ee(t), e, n, r) } function P(e, t, n, r) { return te($(t, e.length - n), e, n, r) } function D(e, t, n) { return 0 === t && n === e.length ? o.fromByteArray(e) : o.fromByteArray(e.slice(t, n)) } function O(e, t, n) { n = Math.min(e.length, n) for (var r = [], i = t; i < n; ) { var o, a, s, l, c = e[i], u = null, h = c > 239 ? 4 : c > 223 ? 3 : c > 191 ? 2 : 1 if (i + h <= n) switch (h) { case 1: c < 128 && (u = c) break case 2: 128 === (192 & (o = e[i + 1])) && (l = ((31 & c) << 6) | (63 & o)) > 127 && (u = l) break case 3: ;(o = e[i + 1]), (a = e[i + 2]), 128 === (192 & o) && 128 === (192 & a) && (l = ((15 & c) << 12) | ((63 & o) << 6) | (63 & a)) > 2047 && (l < 55296 || l > 57343) && (u = l) break case 4: ;(o = e[i + 1]), (a = e[i + 2]), (s = e[i + 3]), 128 === (192 & o) && 128 === (192 & a) && 128 === (192 & s) && (l = ((15 & c) << 18) | ((63 & o) << 12) | ((63 & a) << 6) | (63 & s)) > 65535 && l < 1114112 && (u = l) } null === u ? ((u = 65533), (h = 1)) : u > 65535 && ((u -= 65536), r.push(((u >>> 10) & 1023) | 55296), (u = 56320 | (1023 & u))), r.push(u), (i += h) } return B(r) } ;(i.Buffer = r), (i.SlowBuffer = A), (i.INSPECT_MAX_BYTES = 50), (r.TYPED_ARRAY_SUPPORT = void 0 !== n.TYPED_ARRAY_SUPPORT ? n.TYPED_ARRAY_SUPPORT : l()), (i.kMaxLength = c()), (r.poolSize = 8192), (r._augment = function (e) { return (e.__proto__ = r.prototype), e }), (r.from = function (e, t, n) { return h(null, e, t, n) }), r.TYPED_ARRAY_SUPPORT && ((r.prototype.__proto__ = Uint8Array.prototype), (r.__proto__ = Uint8Array), 'undefined' !== typeof Symbol && Symbol.species && r[Symbol.species] === r && Object.defineProperty(r, Symbol.species, { value: null, configurable: !0, })), (r.alloc = function (e, t, n) { return p(null, e, t, n) }), (r.allocUnsafe = function (e) { return f(null, e) }), (r.allocUnsafeSlow = function (e) { return f(null, e) }), (r.isBuffer = function (e) { return !(null == e || !e._isBuffer) }), (r.compare = function (e, t) { if (!r.isBuffer(e) || !r.isBuffer(t)) throw new TypeError('Arguments must be Buffers') if (e === t) return 0 for (var n = e.length, i = t.length, o = 0, a = Math.min(n, i); o < a; ++o) if (e[o] !== t[o]) { ;(n = e[o]), (i = t[o]) break } return n < i ? -1 : i < n ? 1 : 0 }), (r.isEncoding = function (e) { switch (String(e).toLowerCase()) { case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'latin1': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': return !0 default: return !1 } }), (r.concat = function (e, t) { if (!s(e)) throw new TypeError('"list" argument must be an Array of Buffers') if (0 === e.length) return r.alloc(0) var n if (void 0 === t) for (t = 0, n = 0; n < e.length; ++n) t += e[n].length var i = r.allocUnsafe(t), o = 0 for (n = 0; n < e.length; ++n) { var a = e[n] if (!r.isBuffer(a)) throw new TypeError('"list" argument must be an Array of Buffers') a.copy(i, o), (o += a.length) } return i }), (r.byteLength = w), (r.prototype._isBuffer = !0), (r.prototype.swap16 = function () { var e = this.length if (e % 2 !== 0) throw new RangeError('Buffer size must be a multiple of 16-bits') for (var t = 0; t < e; t += 2) E(this, t, t + 1) return this }), (r.prototype.swap32 = function () { var e = this.length if (e % 4 !== 0) throw new RangeError('Buffer size must be a multiple of 32-bits') for (var t = 0; t < e; t += 4) E(this, t, t + 3), E(this, t + 1, t + 2) return this }), (r.prototype.swap64 = function () { var e = this.length if (e % 8 !== 0) throw new RangeError('Buffer size must be a multiple of 64-bits') for (var t = 0; t < e; t += 8) E(this, t, t + 7), E(this, t + 1, t + 6), E(this, t + 2, t + 5), E(this, t + 3, t + 4) return this }), (r.prototype.toString = function () { var e = 0 | this.length return 0 === e ? '' : 0 === arguments.length ? O(this, 0, e) : x.apply(this, arguments) }), (r.prototype.equals = function (e) { if (!r.isBuffer(e)) throw new TypeError('Argument must be a Buffer') return this === e || 0 === r.compare(this, e) }), (r.prototype.inspect = function () { var e = '', t = i.INSPECT_MAX_BYTES return ( this.length > 0 && ((e = this.toString('hex', 0, t).match(/.{2}/g).join(' ')), this.length > t && (e += ' ... ')), '' ) }), (r.prototype.compare = function (e, t, n, i, o) { if (!r.isBuffer(e)) throw new TypeError('Argument must be a Buffer') if ( (void 0 === t && (t = 0), void 0 === n && (n = e ? e.length : 0), void 0 === i && (i = 0), void 0 === o && (o = this.length), t < 0 || n > e.length || i < 0 || o > this.length) ) throw new RangeError('out of range index') if (i >= o && t >= n) return 0 if (i >= o) return -1 if (t >= n) return 1 if (this === e) return 0 for ( var a = (o >>>= 0) - (i >>>= 0), s = (n >>>= 0) - (t >>>= 0), l = Math.min(a, s), c = this.slice(i, o), u = e.slice(t, n), h = 0; h < l; ++h ) if (c[h] !== u[h]) { ;(a = c[h]), (s = u[h]) break } return a < s ? -1 : s < a ? 1 : 0 }), (r.prototype.includes = function (e, t, n) { return -1 !== this.indexOf(e, t, n) }), (r.prototype.indexOf = function (e, t, n) { return M(this, e, t, n, !0) }), (r.prototype.lastIndexOf = function (e, t, n) { return M(this, e, t, n, !1) }), (r.prototype.write = function (e, t, n, r) { if (void 0 === t) (r = 'utf8'), (n = this.length), (t = 0) else if (void 0 === n && 'string' === typeof t) (r = t), (n = this.length), (t = 0) else { if (!isFinite(t)) throw new Error( 'Buffer.write(string, encoding, offset[, length]) is no longer supported', ) ;(t |= 0), isFinite(n) ? ((n |= 0), void 0 === r && (r = 'utf8')) : ((r = n), (n = void 0)) } var i = this.length - t if ( ((void 0 === n || n > i) && (n = i), (e.length > 0 && (n < 0 || t < 0)) || t > this.length) ) throw new RangeError('Attempt to write outside buffer bounds') r || (r = 'utf8') for (var o = !1; ; ) switch (r) { case 'hex': return T(this, e, t, n) case 'utf8': case 'utf-8': return S(this, e, t, n) case 'ascii': return C(this, e, t, n) case 'latin1': case 'binary': return L(this, e, t, n) case 'base64': return R(this, e, t, n) case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': return P(this, e, t, n) default: if (o) throw new TypeError('Unknown encoding: ' + r) ;(r = ('' + r).toLowerCase()), (o = !0) } }), (r.prototype.toJSON = function () { return { type: 'Buffer', data: Array.prototype.slice.call(this._arr || this, 0), } }) var I = 4096 function B(e) { var t = e.length if (t <= I) return String.fromCharCode.apply(String, e) for (var n = '', r = 0; r < t; ) n += String.fromCharCode.apply(String, e.slice(r, (r += I))) return n } function F(e, t, n) { var r = '' n = Math.min(e.length, n) for (var i = t; i < n; ++i) r += String.fromCharCode(127 & e[i]) return r } function k(e, t, n) { var r = '' n = Math.min(e.length, n) for (var i = t; i < n; ++i) r += String.fromCharCode(e[i]) return r } function N(e, t, n) { var r = e.length ;(!t || t < 0) && (t = 0), (!n || n < 0 || n > r) && (n = r) for (var i = '', o = t; o < n; ++o) i += Z(e[o]) return i } function U(e, t, n) { for (var r = e.slice(t, n), i = '', o = 0; o < r.length; o += 2) i += String.fromCharCode(r[o] + 256 * r[o + 1]) return i } function H(e, t, n) { if (e % 1 !== 0 || e < 0) throw new RangeError('offset is not uint') if (e + t > n) throw new RangeError('Trying to access beyond buffer length') } function G(e, t, n, i, o, a) { if (!r.isBuffer(e)) throw new TypeError('"buffer" argument must be a Buffer instance') if (t > o || t < a) throw new RangeError('"value" argument is out of bounds') if (n + i > e.length) throw new RangeError('Index out of range') } function z(e, t, n, r) { t < 0 && (t = 65535 + t + 1) for (var i = 0, o = Math.min(e.length - n, 2); i < o; ++i) e[n + i] = (t & (255 << (8 * (r ? i : 1 - i)))) >>> (8 * (r ? i : 1 - i)) } function j(e, t, n, r) { t < 0 && (t = 4294967295 + t + 1) for (var i = 0, o = Math.min(e.length - n, 4); i < o; ++i) e[n + i] = (t >>> (8 * (r ? i : 3 - i))) & 255 } function V(e, t, n, r, i, o) { if (n + r > e.length) throw new RangeError('Index out of range') if (n < 0) throw new RangeError('Index out of range') } function W(e, t, n, r, i) { return ( i || V(e, t, n, 4, 34028234663852886e22, -34028234663852886e22), a.write(e, t, n, r, 23, 4), n + 4 ) } function q(e, t, n, r, i) { return ( i || V(e, t, n, 8, 17976931348623157e292, -17976931348623157e292), a.write(e, t, n, r, 52, 8), n + 8 ) } ;(r.prototype.slice = function (e, t) { var n, i = this.length if ( ((e = ~~e) < 0 ? (e += i) < 0 && (e = 0) : e > i && (e = i), (t = void 0 === t ? i : ~~t) < 0 ? (t += i) < 0 && (t = 0) : t > i && (t = i), t < e && (t = e), r.TYPED_ARRAY_SUPPORT) ) (n = this.subarray(e, t)).__proto__ = r.prototype else { var o = t - e n = new r(o, void 0) for (var a = 0; a < o; ++a) n[a] = this[a + e] } return n }), (r.prototype.readUIntLE = function (e, t, n) { ;(e |= 0), (t |= 0), n || H(e, t, this.length) for (var r = this[e], i = 1, o = 0; ++o < t && (i *= 256); ) r += this[e + o] * i return r }), (r.prototype.readUIntBE = function (e, t, n) { ;(e |= 0), (t |= 0), n || H(e, t, this.length) for (var r = this[e + --t], i = 1; t > 0 && (i *= 256); ) r += this[e + --t] * i return r }), (r.prototype.readUInt8 = function (e, t) { return t || H(e, 1, this.length), this[e] }), (r.prototype.readUInt16LE = function (e, t) { return t || H(e, 2, this.length), this[e] | (this[e + 1] << 8) }), (r.prototype.readUInt16BE = function (e, t) { return t || H(e, 2, this.length), (this[e] << 8) | this[e + 1] }), (r.prototype.readUInt32LE = function (e, t) { return ( t || H(e, 4, this.length), (this[e] | (this[e + 1] << 8) | (this[e + 2] << 16)) + 16777216 * this[e + 3] ) }), (r.prototype.readUInt32BE = function (e, t) { return ( t || H(e, 4, this.length), 16777216 * this[e] + ((this[e + 1] << 16) | (this[e + 2] << 8) | this[e + 3]) ) }), (r.prototype.readIntLE = function (e, t, n) { ;(e |= 0), (t |= 0), n || H(e, t, this.length) for (var r = this[e], i = 1, o = 0; ++o < t && (i *= 256); ) r += this[e + o] * i return r >= (i *= 128) && (r -= Math.pow(2, 8 * t)), r }), (r.prototype.readIntBE = function (e, t, n) { ;(e |= 0), (t |= 0), n || H(e, t, this.length) for (var r = t, i = 1, o = this[e + --r]; r > 0 && (i *= 256); ) o += this[e + --r] * i return o >= (i *= 128) && (o -= Math.pow(2, 8 * t)), o }), (r.prototype.readInt8 = function (e, t) { return ( t || H(e, 1, this.length), 128 & this[e] ? -1 * (255 - this[e] + 1) : this[e] ) }), (r.prototype.readInt16LE = function (e, t) { t || H(e, 2, this.length) var n = this[e] | (this[e + 1] << 8) return 32768 & n ? 4294901760 | n : n }), (r.prototype.readInt16BE = function (e, t) { t || H(e, 2, this.length) var n = this[e + 1] | (this[e] << 8) return 32768 & n ? 4294901760 | n : n }), (r.prototype.readInt32LE = function (e, t) { return ( t || H(e, 4, this.length), this[e] | (this[e + 1] << 8) | (this[e + 2] << 16) | (this[e + 3] << 24) ) }), (r.prototype.readInt32BE = function (e, t) { return ( t || H(e, 4, this.length), (this[e] << 24) | (this[e + 1] << 16) | (this[e + 2] << 8) | this[e + 3] ) }), (r.prototype.readFloatLE = function (e, t) { return t || H(e, 4, this.length), a.read(this, e, !0, 23, 4) }), (r.prototype.readFloatBE = function (e, t) { return t || H(e, 4, this.length), a.read(this, e, !1, 23, 4) }), (r.prototype.readDoubleLE = function (e, t) { return t || H(e, 8, this.length), a.read(this, e, !0, 52, 8) }), (r.prototype.readDoubleBE = function (e, t) { return t || H(e, 8, this.length), a.read(this, e, !1, 52, 8) }), (r.prototype.writeUIntLE = function (e, t, n, r) { ;(e = +e), (t |= 0), (n |= 0), r || G(this, e, t, n, Math.pow(2, 8 * n) - 1, 0) var i = 1, o = 0 for (this[t] = 255 & e; ++o < n && (i *= 256); ) this[t + o] = (e / i) & 255 return t + n }), (r.prototype.writeUIntBE = function (e, t, n, r) { ;(e = +e), (t |= 0), (n |= 0), r || G(this, e, t, n, Math.pow(2, 8 * n) - 1, 0) var i = n - 1, o = 1 for (this[t + i] = 255 & e; --i >= 0 && (o *= 256); ) this[t + i] = (e / o) & 255 return t + n }), (r.prototype.writeUInt8 = function (e, t, n) { return ( (e = +e), (t |= 0), n || G(this, e, t, 1, 255, 0), r.TYPED_ARRAY_SUPPORT || (e = Math.floor(e)), (this[t] = 255 & e), t + 1 ) }), (r.prototype.writeUInt16LE = function (e, t, n) { return ( (e = +e), (t |= 0), n || G(this, e, t, 2, 65535, 0), r.TYPED_ARRAY_SUPPORT ? ((this[t] = 255 & e), (this[t + 1] = e >>> 8)) : z(this, e, t, !0), t + 2 ) }), (r.prototype.writeUInt16BE = function (e, t, n) { return ( (e = +e), (t |= 0), n || G(this, e, t, 2, 65535, 0), r.TYPED_ARRAY_SUPPORT ? ((this[t] = e >>> 8), (this[t + 1] = 255 & e)) : z(this, e, t, !1), t + 2 ) }), (r.prototype.writeUInt32LE = function (e, t, n) { return ( (e = +e), (t |= 0), n || G(this, e, t, 4, 4294967295, 0), r.TYPED_ARRAY_SUPPORT ? ((this[t + 3] = e >>> 24), (this[t + 2] = e >>> 16), (this[t + 1] = e >>> 8), (this[t] = 255 & e)) : j(this, e, t, !0), t + 4 ) }), (r.prototype.writeUInt32BE = function (e, t, n) { return ( (e = +e), (t |= 0), n || G(this, e, t, 4, 4294967295, 0), r.TYPED_ARRAY_SUPPORT ? ((this[t] = e >>> 24), (this[t + 1] = e >>> 16), (this[t + 2] = e >>> 8), (this[t + 3] = 255 & e)) : j(this, e, t, !1), t + 4 ) }), (r.prototype.writeIntLE = function (e, t, n, r) { if (((e = +e), (t |= 0), !r)) { var i = Math.pow(2, 8 * n - 1) G(this, e, t, n, i - 1, -i) } var o = 0, a = 1, s = 0 for (this[t] = 255 & e; ++o < n && (a *= 256); ) e < 0 && 0 === s && 0 !== this[t + o - 1] && (s = 1), (this[t + o] = (((e / a) >> 0) - s) & 255) return t + n }), (r.prototype.writeIntBE = function (e, t, n, r) { if (((e = +e), (t |= 0), !r)) { var i = Math.pow(2, 8 * n - 1) G(this, e, t, n, i - 1, -i) } var o = n - 1, a = 1, s = 0 for (this[t + o] = 255 & e; --o >= 0 && (a *= 256); ) e < 0 && 0 === s && 0 !== this[t + o + 1] && (s = 1), (this[t + o] = (((e / a) >> 0) - s) & 255) return t + n }), (r.prototype.writeInt8 = function (e, t, n) { return ( (e = +e), (t |= 0), n || G(this, e, t, 1, 127, -128), r.TYPED_ARRAY_SUPPORT || (e = Math.floor(e)), e < 0 && (e = 255 + e + 1), (this[t] = 255 & e), t + 1 ) }), (r.prototype.writeInt16LE = function (e, t, n) { return ( (e = +e), (t |= 0), n || G(this, e, t, 2, 32767, -32768), r.TYPED_ARRAY_SUPPORT ? ((this[t] = 255 & e), (this[t + 1] = e >>> 8)) : z(this, e, t, !0), t + 2 ) }), (r.prototype.writeInt16BE = function (e, t, n) { return ( (e = +e), (t |= 0), n || G(this, e, t, 2, 32767, -32768), r.TYPED_ARRAY_SUPPORT ? ((this[t] = e >>> 8), (this[t + 1] = 255 & e)) : z(this, e, t, !1), t + 2 ) }), (r.prototype.writeInt32LE = function (e, t, n) { return ( (e = +e), (t |= 0), n || G(this, e, t, 4, 2147483647, -2147483648), r.TYPED_ARRAY_SUPPORT ? ((this[t] = 255 & e), (this[t + 1] = e >>> 8), (this[t + 2] = e >>> 16), (this[t + 3] = e >>> 24)) : j(this, e, t, !0), t + 4 ) }), (r.prototype.writeInt32BE = function (e, t, n) { return ( (e = +e), (t |= 0), n || G(this, e, t, 4, 2147483647, -2147483648), e < 0 && (e = 4294967295 + e + 1), r.TYPED_ARRAY_SUPPORT ? ((this[t] = e >>> 24), (this[t + 1] = e >>> 16), (this[t + 2] = e >>> 8), (this[t + 3] = 255 & e)) : j(this, e, t, !1), t + 4 ) }), (r.prototype.writeFloatLE = function (e, t, n) { return W(this, e, t, !0, n) }), (r.prototype.writeFloatBE = function (e, t, n) { return W(this, e, t, !1, n) }), (r.prototype.writeDoubleLE = function (e, t, n) { return q(this, e, t, !0, n) }), (r.prototype.writeDoubleBE = function (e, t, n) { return q(this, e, t, !1, n) }), (r.prototype.copy = function (e, t, n, i) { if ( (n || (n = 0), i || 0 === i || (i = this.length), t >= e.length && (t = e.length), t || (t = 0), i > 0 && i < n && (i = n), i === n) ) return 0 if (0 === e.length || 0 === this.length) return 0 if (t < 0) throw new RangeError('targetStart out of bounds') if (n < 0 || n >= this.length) throw new RangeError('sourceStart out of bounds') if (i < 0) throw new RangeError('sourceEnd out of bounds') i > this.length && (i = this.length), e.length - t < i - n && (i = e.length - t + n) var o, a = i - n if (this === e && n < t && t < i) for (o = a - 1; o >= 0; --o) e[o + t] = this[o + n] else if (a < 1e3 || !r.TYPED_ARRAY_SUPPORT) for (o = 0; o < a; ++o) e[o + t] = this[o + n] else Uint8Array.prototype.set.call(e, this.subarray(n, n + a), t) return a }), (r.prototype.fill = function (e, t, n, i) { if ('string' === typeof e) { if ( ('string' === typeof t ? ((i = t), (t = 0), (n = this.length)) : 'string' === typeof n && ((i = n), (n = this.length)), 1 === e.length) ) { var o = e.charCodeAt(0) o < 256 && (e = o) } if (void 0 !== i && 'string' !== typeof i) throw new TypeError('encoding must be a string') if ('string' === typeof i && !r.isEncoding(i)) throw new TypeError('Unknown encoding: ' + i) } else 'number' === typeof e && (e &= 255) if (t < 0 || this.length < t || this.length < n) throw new RangeError('Out of range index') if (n <= t) return this var a if ( ((t >>>= 0), (n = void 0 === n ? this.length : n >>> 0), e || (e = 0), 'number' === typeof e) ) for (a = t; a < n; ++a) this[a] = e else { var s = r.isBuffer(e) ? e : K(new r(e, i).toString()), l = s.length for (a = 0; a < n - t; ++a) this[a + t] = s[a % l] } return this }) var X = /[^+\/0-9A-Za-z-_]/g function Y(e) { if ((e = Q(e).replace(X, '')).length < 2) return '' for (; e.length % 4 !== 0; ) e += '=' return e } function Q(e) { return e.trim ? e.trim() : e.replace(/^\s+|\s+$/g, '') } function Z(e) { return e < 16 ? '0' + e.toString(16) : e.toString(16) } function K(e, t) { var n t = t || 1 / 0 for (var r = e.length, i = null, o = [], a = 0; a < r; ++a) { if ((n = e.charCodeAt(a)) > 55295 && n < 57344) { if (!i) { if (n > 56319) { ;(t -= 3) > -1 && o.push(239, 191, 189) continue } if (a + 1 === r) { ;(t -= 3) > -1 && o.push(239, 191, 189) continue } i = n continue } if (n < 56320) { ;(t -= 3) > -1 && o.push(239, 191, 189), (i = n) continue } n = 65536 + (((i - 55296) << 10) | (n - 56320)) } else i && (t -= 3) > -1 && o.push(239, 191, 189) if (((i = null), n < 128)) { if ((t -= 1) < 0) break o.push(n) } else if (n < 2048) { if ((t -= 2) < 0) break o.push((n >> 6) | 192, (63 & n) | 128) } else if (n < 65536) { if ((t -= 3) < 0) break o.push((n >> 12) | 224, ((n >> 6) & 63) | 128, (63 & n) | 128) } else { if (!(n < 1114112)) throw new Error('Invalid code point') if ((t -= 4) < 0) break o.push( (n >> 18) | 240, ((n >> 12) & 63) | 128, ((n >> 6) & 63) | 128, (63 & n) | 128, ) } } return o } function J(e) { for (var t = [], n = 0; n < e.length; ++n) t.push(255 & e.charCodeAt(n)) return t } function $(e, t) { for (var n, r, i, o = [], a = 0; a < e.length && !((t -= 2) < 0); ++a) (r = (n = e.charCodeAt(a)) >> 8), (i = n % 256), o.push(i), o.push(r) return o } function ee(e) { return o.toByteArray(Y(e)) } function te(e, t, n, r) { for (var i = 0; i < r && !(i + n >= t.length || i >= e.length); ++i) t[i + n] = e[i] return i } function ne(e) { return e !== e } }.call( this, 'undefined' !== typeof r.g ? r.g : 'undefined' !== typeof self ? self : 'undefined' !== typeof window ? window : {}, t('buffer').Buffer, )) }, { 'base64-js': 3, buffer: 6, ieee754: 29, isarray: 35 }, ], 7: [ function (t, n, r) { !(function () { if ('undefined' !== typeof window) try { var t = new window.CustomEvent('test', { cancelable: !0 }) if ((t.preventDefault(), !0 !== t.defaultPrevented)) throw new Error('Could not prevent default') } catch (e) { var n = function (e, n) { var r, i return ( ((n = n || {}).bubbles = !!n.bubbles), (n.cancelable = !!n.cancelable), (r = document.createEvent('CustomEvent')).initCustomEvent( e, n.bubbles, n.cancelable, n.detail, ), (i = r.preventDefault), (r.preventDefault = function () { i.call(this) try { Object.defineProperty(this, 'defaultPrevented', { get: function () { return !0 }, }) } catch (t) { this.defaultPrevented = !0 } }), r ) } ;(n.prototype = window.Event.prototype), (window.CustomEvent = n) } })() }, {}, ], 8: [ function (t, n, r) { function i() { return ( 'WebkitAppearance' in document.documentElement.style || (window.console && (console.firebug || (console.exception && console.table))) || (navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31) ) } function o() { var e = arguments, t = this.useColors if ( ((e[0] = (t ? '%c' : '') + this.namespace + (t ? ' %c' : ' ') + e[0] + (t ? '%c ' : ' ')), !t) ) return e var n = 'color: ' + this.color e = [e[0], n, 'color: inherit'].concat(Array.prototype.slice.call(e, 1)) var r = 0, i = 0 return ( e[0].replace(/%[a-z%]/g, function (e) { '%%' !== e && (r++, '%c' === e && (i = r)) }), e.splice(i, 0, n), e ) } function a() { return ( 'object' === typeof console && console.log && Function.prototype.apply.call(console.log, console, arguments) ) } function s(t) { try { null == t ? r.storage.removeItem('debug') : (r.storage.debug = t) } catch (e) {} } function l() { var t try { t = r.storage.debug } catch (e) {} return t } function c() { try { return window.localStorage } catch (e) {} } ;((r = n.exports = t('./debug')).log = a), (r.formatArgs = o), (r.save = s), (r.load = l), (r.useColors = i), (r.storage = 'undefined' != typeof chrome && 'undefined' != typeof chrome.storage ? chrome.storage.local : c()), (r.colors = [ 'lightseagreen', 'forestgreen', 'goldenrod', 'dodgerblue', 'darkorchid', 'crimson', ]), (r.formatters.j = function (e) { return JSON.stringify(e) }), r.enable(l()) }, { './debug': 9 }, ], 9: [ function (e, t, n) { ;((n = t.exports = o).coerce = c), (n.disable = s), (n.enable = a), (n.enabled = l), (n.names = []), (n.skips = []), (n.formatters = {}) var r = 0 function i() { return n.colors[r++ % n.colors.length] } function o(e) { function t() {} function r() { var e = r null == e.useColors && (e.useColors = n.useColors()), null == e.color && e.useColors && (e.color = i()) var t = Array.prototype.slice.call(arguments) ;(t[0] = n.coerce(t[0])), 'string' !== typeof t[0] && (t = ['%o'].concat(t)) var o = 0 ;(t[0] = t[0].replace(/%([a-z%])/g, function (r, i) { if ('%%' === r) return r o++ var a = n.formatters[i] if ('function' === typeof a) { var s = t[o] ;(r = a.call(e, s)), t.splice(o, 1), o-- } return r })), 'function' === typeof n.formatArgs && (t = n.formatArgs.apply(e, t)), (r.log || n.log || console.log.bind(console)).apply(e, t) } ;(t.enabled = !1), (r.enabled = !0) var o = n.enabled(e) ? r : t return (o.namespace = e), o } function a(e) { n.save(e) for (var t = (e || '').split(/[\s,]+/), r = t.length, i = 0; i < r; i++) t[i] && ('-' === (e = t[i].replace(/\*/g, '.*?'))[0] ? n.skips.push(new RegExp('^' + e.substr(1) + '$')) : n.names.push(new RegExp('^' + e + '$'))) } function s() { n.enable('') } function l(e) { var t, r for (t = 0, r = n.skips.length; t < r; t++) if (n.skips[t].test(e)) return !1 for (t = 0, r = n.names.length; t < r; t++) if (n.names[t].test(e)) return !0 return !1 } function c(e) { return e instanceof Error ? e.stack || e.message : e } }, {}, ], 10: [ function (e, t, n) { 'use strict' var r = e('is-obj'), i = Object.prototype.hasOwnProperty, o = Object.prototype.propertyIsEnumerable function a(e) { if (null === e || void 0 === e) throw new TypeError('Sources cannot be null or undefined') return Object(e) } function s(e, t, n) { var o = t[n] if (void 0 !== o && null !== o) { if (i.call(e, n) && (void 0 === e[n] || null === e[n])) throw new TypeError('Cannot convert undefined or null to object (' + n + ')') i.call(e, n) && r(o) ? (e[n] = l(Object(e[n]), t[n])) : (e[n] = o) } } function l(e, t) { if (e === t) return e for (var n in (t = Object(t))) i.call(t, n) && s(e, t, n) if (Object.getOwnPropertySymbols) for (var r = Object.getOwnPropertySymbols(t), a = 0; a < r.length; a++) o.call(t, r[a]) && s(e, t, r[a]) return e } t.exports = function (e) { e = a(e) for (var t = 1; t < arguments.length; t++) l(e, arguments[t]) return e } }, { 'is-obj': 34 }, ], 11: [ function (t, n, r) { 'use strict' var i = t('object-keys'), o = 'function' === typeof Symbol && 'symbol' === typeof Symbol('foo'), a = Object.prototype.toString, s = Array.prototype.concat, l = Object.defineProperty, c = function (e) { return 'function' === typeof e && '[object Function]' === a.call(e) }, u = function () { var t = {} try { for (var n in (l(t, 'x', { enumerable: !1, value: t }), t)) return !1 return t.x === t } catch (e) { return !1 } }, h = l && u(), d = function (e, t, n, r) { ;(!(t in e) || (c(r) && r())) && (h ? l(e, t, { configurable: !0, enumerable: !1, value: n, writable: !0 }) : (e[t] = n)) }, p = function (e, t) { var n = arguments.length > 2 ? arguments[2] : {}, r = i(t) o && (r = s.call(r, Object.getOwnPropertySymbols(t))) for (var a = 0; a < r.length; a += 1) d(e, r[a], t[r[a]], n[r[a]]) } ;(p.supportsDescriptors = !!h), (n.exports = p) }, { 'object-keys': 41 }, ], 12: [ function (t, n, r) { !(function (t, n, r, i) { 'use strict' function o(e, t) { for (var n = 0, r = e.length; n < r; n++) g(e[n], t) } function a(e) { for (var t, n = 0, r = e.length; n < r; n++) (t = e[n]), M(t, H[l(t)]) } function s(e) { return function (t) { ie(t) && (g(t, e), o(t.querySelectorAll(G), e)) } } function l(e) { var t = se.call(e, 'is'), n = e.nodeName.toUpperCase(), r = j.call(U, t ? F + t.toUpperCase() : B + n) return t && -1 < r && !c(n, t) ? -1 : r } function c(e, t) { return -1 < G.indexOf(e + '[is="' + t + '"]') } function u(e) { var t = e.currentTarget, n = e.attrChange, r = e.attrName, i = e.target ge && (!i || i === t) && t.attributeChangedCallback && 'style' !== r && e.prevValue !== e.newValue && t.attributeChangedCallback( r, n === e[L] ? null : e.prevValue, n === e[P] ? null : e.newValue, ) } function h(e) { var t = s(e) return function (e) { y.push(t, e.target) } } function d(e) { ve && ((ve = !1), e.currentTarget.removeEventListener(O, d)), o((e.target || n).querySelectorAll(G), e.detail === S ? S : T), re && m() } function p(e, t) { var n = this le.call(n, e, t), b.call(n, { target: n }) } function f(e, t) { ee(e, t), x ? x.observe(e, he) : (me && ((e.setAttribute = p), (e[_] = w(e)), e.addEventListener(I, b)), e.addEventListener(D, u)), e.createdCallback && ge && ((e.created = !0), e.createdCallback(), (e.created = !1)) } function m() { for (var e, t = 0, n = oe.length; t < n; t++) (e = oe[t]), z.contains(e) || (n--, oe.splice(t--, 1), g(e, S)) } function v(e) { throw new Error('A ' + e + ' type is already registered') } function g(e, t) { var n, r = l(e) ;-1 < r && (E(e, H[r]), (r = 0), t !== T || e[T] ? t === S && !e[S] && ((e[T] = !1), (e[S] = !0), (r = 1)) : ((e[S] = !1), (e[T] = !0), (r = 1), re && j.call(oe, e) < 0 && oe.push(e)), r && (n = e[t + 'Callback']) && n.call(e)) } if (!(i in n)) { var y, b, A, w, x, E, M, _ = '__' + i + ((1e5 * Math.random()) >> 0), T = 'attached', S = 'detached', C = 'extends', L = 'ADDITION', R = 'MODIFICATION', P = 'REMOVAL', D = 'DOMAttrModified', O = 'DOMContentLoaded', I = 'DOMSubtreeModified', B = '<', F = '=', k = /^[A-Z][A-Z0-9]*(?:-[A-Z0-9]+)+$/, N = [ 'ANNOTATION-XML', 'COLOR-PROFILE', 'FONT-FACE', 'FONT-FACE-SRC', 'FONT-FACE-URI', 'FONT-FACE-FORMAT', 'FONT-FACE-NAME', 'MISSING-GLYPH', ], U = [], H = [], G = '', z = n.documentElement, j = U.indexOf || function (e) { for (var t = this.length; t-- && this[t] !== e; ); return t }, V = r.prototype, W = V.hasOwnProperty, q = V.isPrototypeOf, X = r.defineProperty, Y = r.getOwnPropertyDescriptor, Q = r.getOwnPropertyNames, Z = r.getPrototypeOf, K = r.setPrototypeOf, J = !!r.__proto__, $ = r.create || function e(t) { return t ? ((e.prototype = t), new e()) : this }, ee = K || (J ? function (e, t) { return (e.__proto__ = t), e } : Q && Y ? (function () { function e(e, t) { for (var n, r = Q(t), i = 0, o = r.length; i < o; i++) (n = r[i]), W.call(e, n) || X(e, n, Y(t, n)) } return function (t, n) { do { e(t, n) } while ((n = Z(n)) && !q.call(n, t)) return t } })() : function (e, t) { for (var n in t) e[n] = t[n] return e }), te = t.MutationObserver || t.WebKitMutationObserver, ne = (t.HTMLElement || t.Element || t.Node).prototype, re = !q.call(ne, z), ie = re ? function (e) { return 1 === e.nodeType } : function (e) { return q.call(ne, e) }, oe = re && [], ae = ne.cloneNode, se = ne.getAttribute, le = ne.setAttribute, ce = ne.removeAttribute, ue = n.createElement, he = te && { attributes: !0, characterData: !0, attributeOldValue: !0 }, de = te || function (e) { ;(me = !1), z.removeEventListener(D, de) }, pe = t.requestAnimationFrame || t.webkitRequestAnimationFrame || t.mozRequestAnimationFrame || t.msRequestAnimationFrame || function (e) { setTimeout(e, 10) }, fe = !1, me = !0, ve = !0, ge = !0 K || J ? ((E = function (e, t) { q.call(t, e) || f(e, t) }), (M = f)) : (M = E = function (e, t) { e[_] || ((e[_] = r(!0)), f(e, t)) }), re ? ((me = !1), (function () { var t = Y(ne, 'addEventListener'), n = t.value, r = function (e) { var t = new CustomEvent(D, { bubbles: !0 }) ;(t.attrName = e), (t.prevValue = se.call(this, e)), (t.newValue = null), (t[P] = t.attrChange = 2), ce.call(this, e), this.dispatchEvent(t) }, i = function (t, n) { var r = this.hasAttribute(t), i = r && se.call(this, t) ;(e = new CustomEvent(D, { bubbles: !0 })), le.call(this, t, n), (e.attrName = t), (e.prevValue = r ? i : null), (e.newValue = n), r ? (e[R] = e.attrChange = 1) : (e[L] = e.attrChange = 0), this.dispatchEvent(e) }, o = function (e) { var t, n = e.currentTarget, r = n[_], i = e.propertyName r.hasOwnProperty(i) && ((r = r[i]), ((t = new CustomEvent(D, { bubbles: !0 })).attrName = r.name), (t.prevValue = r.value || null), (t.newValue = r.value = n[i] || null), null == t.prevValue ? (t[L] = t.attrChange = 0) : (t[R] = t.attrChange = 1), n.dispatchEvent(t)) } ;(t.value = function (e, t, a) { e === D && this.attributeChangedCallback && this.setAttribute !== i && ((this[_] = { className: { name: 'class', value: this.className }, }), (this.setAttribute = i), (this.removeAttribute = r), n.call(this, 'propertychange', o)), n.call(this, e, t, a) }), X(ne, 'addEventListener', t) })()) : te || (z.addEventListener(D, de), z.setAttribute(_, 1), z.removeAttribute(_), me && ((b = function (e) { var t, n, r, i = this if (i === e.target) { for (r in ((t = i[_]), (i[_] = n = w(i)), n)) { if (!(r in t)) return A(0, i, r, t[r], n[r], L) if (n[r] !== t[r]) return A(1, i, r, t[r], n[r], R) } for (r in t) if (!(r in n)) return A(2, i, r, t[r], n[r], P) } }), (A = function (e, t, n, r, i, o) { var a = { attrChange: e, currentTarget: t, attrName: n, prevValue: r, newValue: i, } ;(a[o] = e), u(a) }), (w = function (e) { for ( var t, n, r = {}, i = e.attributes, o = 0, a = i.length; o < a; o++ ) 'setAttribute' !== (n = (t = i[o]).name) && (r[n] = t.value) return r }))), (n[i] = function (e, t) { if ( ((r = e.toUpperCase()), fe || ((fe = !0), te ? (x = (function (e, t) { function n(e, t) { for (var n = 0, r = e.length; n < r; t(e[n++])); } return new te(function (r) { for (var i, o, a, s = 0, l = r.length; s < l; s++) 'childList' === (i = r[s]).type ? (n(i.addedNodes, e), n(i.removedNodes, t)) : ((o = i.target), ge && o.attributeChangedCallback && 'style' !== i.attributeName && (a = se.call(o, i.attributeName)) !== i.oldValue && o.attributeChangedCallback( i.attributeName, i.oldValue, a, )) }) })(s(T), s(S))).observe(n, { childList: !0, subtree: !0 }) : ((y = []), pe(function e() { for (; y.length; ) y.shift().call(null, y.shift()) pe(e) }), n.addEventListener('DOMNodeInserted', h(T)), n.addEventListener('DOMNodeRemoved', h(S))), n.addEventListener(O, d), n.addEventListener('readystatechange', d), (n.createElement = function (e, t) { var r = ue.apply(n, arguments), i = '' + e, o = j.call(U, (t ? F : B) + (t || i).toUpperCase()), a = -1 < o return ( t && (r.setAttribute('is', (t = t.toLowerCase())), a && (a = c(i.toUpperCase(), t))), (ge = !n.createElement.innerHTMLHelper), a && M(r, H[o]), r ) }), (ne.cloneNode = function (e) { var t = ae.call(this, !!e), n = l(t) return -1 < n && M(t, H[n]), e && a(t.querySelectorAll(G)), t })), -2 < j.call(U, F + r) + j.call(U, B + r) && v(e), !k.test(r) || -1 < j.call(N, r)) ) throw new Error('The type ' + e + ' is invalid') var r, i, u = function () { return f ? n.createElement(m, r) : n.createElement(m) }, p = t || V, f = W.call(p, C), m = f ? t[C].toUpperCase() : r return ( f && -1 < j.call(U, B + m) && v(m), (i = U.push((f ? F : B) + r) - 1), (G = G.concat( G.length ? ',' : '', f ? m + '[is="' + e.toLowerCase() + '"]' : m, )), (u.prototype = H[i] = W.call(p, 'prototype') ? p.prototype : $(ne)), o(n.querySelectorAll(G), T), u ) }) } })(window, document, Object, 'registerElement') }, {}, ], 13: [ function (e, t, n) { t.exports = function (e) { switch (e) { case 'int8': return Int8Array case 'int16': return Int16Array case 'int32': return Int32Array case 'uint8': return Uint8Array case 'uint16': return Uint16Array case 'uint32': return Uint32Array case 'float32': return Float32Array case 'float64': return Float64Array case 'array': return Array case 'uint8_clamped': return Uint8ClampedArray } } }, {}, ], 14: [ function (e, t, n) { 'use strict' var r, i, o, a, s = Object.getOwnPropertyDescriptor ? (function () { return Object.getOwnPropertyDescriptor(arguments, 'callee').get })() : function () { throw new TypeError() }, l = 'function' === typeof Symbol && 'symbol' === typeof Symbol.iterator, c = Object.getPrototypeOf || function (e) { return e.__proto__ }, u = i ? c(i) : r, h = o ? o.constructor : r, d = a ? c(a) : r, p = a ? a() : r, f = 'undefined' === typeof Uint8Array ? r : c(Uint8Array), m = { '$ %Array%': Array, '$ %ArrayBuffer%': 'undefined' === typeof ArrayBuffer ? r : ArrayBuffer, '$ %ArrayBufferPrototype%': 'undefined' === typeof ArrayBuffer ? r : ArrayBuffer.prototype, '$ %ArrayIteratorPrototype%': l ? c([][Symbol.iterator]()) : r, '$ %ArrayPrototype%': Array.prototype, '$ %ArrayProto_entries%': Array.prototype.entries, '$ %ArrayProto_forEach%': Array.prototype.forEach, '$ %ArrayProto_keys%': Array.prototype.keys, '$ %ArrayProto_values%': Array.prototype.values, '$ %AsyncFromSyncIteratorPrototype%': r, '$ %AsyncFunction%': h, '$ %AsyncFunctionPrototype%': h ? h.prototype : r, '$ %AsyncGenerator%': a ? c(p) : r, '$ %AsyncGeneratorFunction%': d, '$ %AsyncGeneratorPrototype%': d ? d.prototype : r, '$ %AsyncIteratorPrototype%': p && l && Symbol.asyncIterator ? p[Symbol.asyncIterator]() : r, '$ %Atomics%': 'undefined' === typeof Atomics ? r : Atomics, '$ %Boolean%': Boolean, '$ %BooleanPrototype%': Boolean.prototype, '$ %DataView%': 'undefined' === typeof DataView ? r : DataView, '$ %DataViewPrototype%': 'undefined' === typeof DataView ? r : DataView.prototype, '$ %Date%': Date, '$ %DatePrototype%': Date.prototype, '$ %decodeURI%': decodeURI, '$ %decodeURIComponent%': decodeURIComponent, '$ %encodeURI%': encodeURI, '$ %encodeURIComponent%': encodeURIComponent, '$ %Error%': Error, '$ %ErrorPrototype%': Error.prototype, '$ %eval%': eval, '$ %EvalError%': EvalError, '$ %EvalErrorPrototype%': EvalError.prototype, '$ %Float32Array%': 'undefined' === typeof Float32Array ? r : Float32Array, '$ %Float32ArrayPrototype%': 'undefined' === typeof Float32Array ? r : Float32Array.prototype, '$ %Float64Array%': 'undefined' === typeof Float64Array ? r : Float64Array, '$ %Float64ArrayPrototype%': 'undefined' === typeof Float64Array ? r : Float64Array.prototype, '$ %Function%': Function, '$ %FunctionPrototype%': Function.prototype, '$ %Generator%': i ? c(i()) : r, '$ %GeneratorFunction%': u, '$ %GeneratorPrototype%': u ? u.prototype : r, '$ %Int8Array%': 'undefined' === typeof Int8Array ? r : Int8Array, '$ %Int8ArrayPrototype%': 'undefined' === typeof Int8Array ? r : Int8Array.prototype, '$ %Int16Array%': 'undefined' === typeof Int16Array ? r : Int16Array, '$ %Int16ArrayPrototype%': 'undefined' === typeof Int16Array ? r : Int8Array.prototype, '$ %Int32Array%': 'undefined' === typeof Int32Array ? r : Int32Array, '$ %Int32ArrayPrototype%': 'undefined' === typeof Int32Array ? r : Int32Array.prototype, '$ %isFinite%': isFinite, '$ %isNaN%': isNaN, '$ %IteratorPrototype%': l ? c(c([][Symbol.iterator]())) : r, '$ %JSON%': JSON, '$ %JSONParse%': JSON.parse, '$ %Map%': 'undefined' === typeof Map ? r : Map, '$ %MapIteratorPrototype%': 'undefined' !== typeof Map && l ? c(new Map()[Symbol.iterator]()) : r, '$ %MapPrototype%': 'undefined' === typeof Map ? r : Map.prototype, '$ %Math%': Math, '$ %Number%': Number, '$ %NumberPrototype%': Number.prototype, '$ %Object%': Object, '$ %ObjectPrototype%': Object.prototype, '$ %ObjProto_toString%': Object.prototype.toString, '$ %ObjProto_valueOf%': Object.prototype.valueOf, '$ %parseFloat%': parseFloat, '$ %parseInt%': parseInt, '$ %Promise%': 'undefined' === typeof Promise ? r : Promise, '$ %PromisePrototype%': 'undefined' === typeof Promise ? r : Promise.prototype, '$ %PromiseProto_then%': 'undefined' === typeof Promise ? r : Promise.prototype.then, '$ %Promise_all%': 'undefined' === typeof Promise ? r : Promise.all, '$ %Promise_reject%': 'undefined' === typeof Promise ? r : Promise.reject, '$ %Promise_resolve%': 'undefined' === typeof Promise ? r : Promise.resolve, '$ %Proxy%': 'undefined' === typeof Proxy ? r : Proxy, '$ %RangeError%': RangeError, '$ %RangeErrorPrototype%': RangeError.prototype, '$ %ReferenceError%': ReferenceError, '$ %ReferenceErrorPrototype%': ReferenceError.prototype, '$ %Reflect%': 'undefined' === typeof Reflect ? r : Reflect, '$ %RegExp%': RegExp, '$ %RegExpPrototype%': RegExp.prototype, '$ %Set%': 'undefined' === typeof Set ? r : Set, '$ %SetIteratorPrototype%': 'undefined' !== typeof Set && l ? c(new Set()[Symbol.iterator]()) : r, '$ %SetPrototype%': 'undefined' === typeof Set ? r : Set.prototype, '$ %SharedArrayBuffer%': 'undefined' === typeof SharedArrayBuffer ? r : SharedArrayBuffer, '$ %SharedArrayBufferPrototype%': 'undefined' === typeof SharedArrayBuffer ? r : SharedArrayBuffer.prototype, '$ %String%': String, '$ %StringIteratorPrototype%': l ? c(''[Symbol.iterator]()) : r, '$ %StringPrototype%': String.prototype, '$ %Symbol%': l ? Symbol : r, '$ %SymbolPrototype%': l ? Symbol.prototype : r, '$ %SyntaxError%': SyntaxError, '$ %SyntaxErrorPrototype%': SyntaxError.prototype, '$ %ThrowTypeError%': s, '$ %TypedArray%': f, '$ %TypedArrayPrototype%': f ? f.prototype : r, '$ %TypeError%': TypeError, '$ %TypeErrorPrototype%': TypeError.prototype, '$ %Uint8Array%': 'undefined' === typeof Uint8Array ? r : Uint8Array, '$ %Uint8ArrayPrototype%': 'undefined' === typeof Uint8Array ? r : Uint8Array.prototype, '$ %Uint8ClampedArray%': 'undefined' === typeof Uint8ClampedArray ? r : Uint8ClampedArray, '$ %Uint8ClampedArrayPrototype%': 'undefined' === typeof Uint8ClampedArray ? r : Uint8ClampedArray.prototype, '$ %Uint16Array%': 'undefined' === typeof Uint16Array ? r : Uint16Array, '$ %Uint16ArrayPrototype%': 'undefined' === typeof Uint16Array ? r : Uint16Array.prototype, '$ %Uint32Array%': 'undefined' === typeof Uint32Array ? r : Uint32Array, '$ %Uint32ArrayPrototype%': 'undefined' === typeof Uint32Array ? r : Uint32Array.prototype, '$ %URIError%': URIError, '$ %URIErrorPrototype%': URIError.prototype, '$ %WeakMap%': 'undefined' === typeof WeakMap ? r : WeakMap, '$ %WeakMapPrototype%': 'undefined' === typeof WeakMap ? r : WeakMap.prototype, '$ %WeakSet%': 'undefined' === typeof WeakSet ? r : WeakSet, '$ %WeakSetPrototype%': 'undefined' === typeof WeakSet ? r : WeakSet.prototype, } t.exports = function (e, t) { if (arguments.length > 1 && 'boolean' !== typeof t) throw new TypeError('"allowMissing" argument must be a boolean') var n = '$ ' + e if (!(n in m)) throw new SyntaxError('intrinsic ' + e + ' does not exist!') if ('undefined' === typeof m[n] && !t) throw new TypeError( 'intrinsic ' + e + ' exists, but is not available. Please file an issue!', ) return m[n] } }, {}, ], 15: [ function (e, t, n) { 'use strict' var r = e('./GetIntrinsic'), i = r('%Object%'), o = r('%TypeError%'), a = r('%String%'), s = e('./helpers/assertRecord'), l = e('./helpers/isNaN'), c = e('./helpers/isFinite'), u = e('./helpers/sign'), h = e('./helpers/mod'), d = e('is-callable'), p = e('es-to-primitive/es5'), f = e('has'), m = { ToPrimitive: p, ToBoolean: function (e) { return !!e }, ToNumber: function (e) { return +e }, ToInteger: function (e) { var t = this.ToNumber(e) return l(t) ? 0 : 0 !== t && c(t) ? u(t) * Math.floor(Math.abs(t)) : t }, ToInt32: function (e) { return this.ToNumber(e) >> 0 }, ToUint32: function (e) { return this.ToNumber(e) >>> 0 }, ToUint16: function (e) { var t = this.ToNumber(e) if (l(t) || 0 === t || !c(t)) return 0 var n = u(t) * Math.floor(Math.abs(t)) return h(n, 65536) }, ToString: function (e) { return a(e) }, ToObject: function (e) { return this.CheckObjectCoercible(e), i(e) }, CheckObjectCoercible: function (e, t) { if (null == e) throw new o(t || 'Cannot call method on ' + e) return e }, IsCallable: d, SameValue: function (e, t) { return e === t ? 0 !== e || 1 / e === 1 / t : l(e) && l(t) }, Type: function (e) { return null === e ? 'Null' : 'undefined' === typeof e ? 'Undefined' : 'function' === typeof e || 'object' === typeof e ? 'Object' : 'number' === typeof e ? 'Number' : 'boolean' === typeof e ? 'Boolean' : 'string' === typeof e ? 'String' : void 0 }, IsPropertyDescriptor: function (e) { if ('Object' !== this.Type(e)) return !1 var t = { '[[Configurable]]': !0, '[[Enumerable]]': !0, '[[Get]]': !0, '[[Set]]': !0, '[[Value]]': !0, '[[Writable]]': !0, } for (var n in e) if (f(e, n) && !t[n]) return !1 var r = f(e, '[[Value]]'), i = f(e, '[[Get]]') || f(e, '[[Set]]') if (r && i) throw new o( 'Property Descriptors may not be both accessor and data descriptors', ) return !0 }, IsAccessorDescriptor: function (e) { return ( 'undefined' !== typeof e && (s(this, 'Property Descriptor', 'Desc', e), !(!f(e, '[[Get]]') && !f(e, '[[Set]]'))) ) }, IsDataDescriptor: function (e) { return ( 'undefined' !== typeof e && (s(this, 'Property Descriptor', 'Desc', e), !(!f(e, '[[Value]]') && !f(e, '[[Writable]]'))) ) }, IsGenericDescriptor: function (e) { return ( 'undefined' !== typeof e && (s(this, 'Property Descriptor', 'Desc', e), !this.IsAccessorDescriptor(e) && !this.IsDataDescriptor(e)) ) }, FromPropertyDescriptor: function (e) { if ('undefined' === typeof e) return e if ((s(this, 'Property Descriptor', 'Desc', e), this.IsDataDescriptor(e))) return { value: e['[[Value]]'], writable: !!e['[[Writable]]'], enumerable: !!e['[[Enumerable]]'], configurable: !!e['[[Configurable]]'], } if (this.IsAccessorDescriptor(e)) return { get: e['[[Get]]'], set: e['[[Set]]'], enumerable: !!e['[[Enumerable]]'], configurable: !!e['[[Configurable]]'], } throw new o( 'FromPropertyDescriptor must be called with a fully populated Property Descriptor', ) }, ToPropertyDescriptor: function (e) { if ('Object' !== this.Type(e)) throw new o('ToPropertyDescriptor requires an object') var t = {} if ( (f(e, 'enumerable') && (t['[[Enumerable]]'] = this.ToBoolean(e.enumerable)), f(e, 'configurable') && (t['[[Configurable]]'] = this.ToBoolean(e.configurable)), f(e, 'value') && (t['[[Value]]'] = e.value), f(e, 'writable') && (t['[[Writable]]'] = this.ToBoolean(e.writable)), f(e, 'get')) ) { var n = e.get if ('undefined' !== typeof n && !this.IsCallable(n)) throw new TypeError('getter must be a function') t['[[Get]]'] = n } if (f(e, 'set')) { var r = e.set if ('undefined' !== typeof r && !this.IsCallable(r)) throw new o('setter must be a function') t['[[Set]]'] = r } if ( (f(t, '[[Get]]') || f(t, '[[Set]]')) && (f(t, '[[Value]]') || f(t, '[[Writable]]')) ) throw new o( 'Invalid property descriptor. Cannot both specify accessors and a value or writable attribute', ) return t }, } t.exports = m }, { './GetIntrinsic': 14, './helpers/assertRecord': 16, './helpers/isFinite': 17, './helpers/isNaN': 18, './helpers/mod': 19, './helpers/sign': 20, 'es-to-primitive/es5': 21, has: 28, 'is-callable': 32, }, ], 16: [ function (e, t, n) { 'use strict' var r = e('../GetIntrinsic'), i = r('%TypeError%'), o = r('%SyntaxError%'), a = e('has'), s = { 'Property Descriptor': function (e, t) { if ('Object' !== e.Type(t)) return !1 var n = { '[[Configurable]]': !0, '[[Enumerable]]': !0, '[[Get]]': !0, '[[Set]]': !0, '[[Value]]': !0, '[[Writable]]': !0, } for (var r in t) if (a(t, r) && !n[r]) return !1 var o = a(t, '[[Value]]'), s = a(t, '[[Get]]') || a(t, '[[Set]]') if (o && s) throw new i( 'Property Descriptors may not be both accessor and data descriptors', ) return !0 }, } t.exports = function (e, t, n, r) { var a = s[t] if ('function' !== typeof a) throw new o('unknown record type: ' + t) if (!a(e, r)) throw new i(n + ' must be a ' + t) console.log(a(e, r), r) } }, { '../GetIntrinsic': 14, has: 28 }, ], 17: [ function (e, t, n) { var r = Number.isNaN || function (e) { return e !== e } t.exports = Number.isFinite || function (e) { return 'number' === typeof e && !r(e) && e !== 1 / 0 && e !== -1 / 0 } }, {}, ], 18: [ function (e, t, n) { t.exports = Number.isNaN || function (e) { return e !== e } }, {}, ], 19: [ function (e, t, n) { t.exports = function (e, t) { var n = e % t return Math.floor(n >= 0 ? n : n + t) } }, {}, ], 20: [ function (e, t, n) { t.exports = function (e) { return e >= 0 ? 1 : -1 } }, {}, ], 21: [ function (e, t, n) { 'use strict' var r = Object.prototype.toString, i = e('./helpers/isPrimitive'), o = e('is-callable'), a = { '[[DefaultValue]]': function (e) { var t if ( (t = arguments.length > 1 ? arguments[1] : '[object Date]' === r.call(e) ? String : Number) === String || t === Number ) { var n, a, s = t === String ? ['toString', 'valueOf'] : ['valueOf', 'toString'] for (a = 0; a < s.length; ++a) if (o(e[s[a]]) && ((n = e[s[a]]()), i(n))) return n throw new TypeError('No default value') } throw new TypeError('invalid [[DefaultValue]] hint supplied') }, } t.exports = function (e) { return i(e) ? e : arguments.length > 1 ? a['[[DefaultValue]]'](e, arguments[1]) : a['[[DefaultValue]]'](e) } }, { './helpers/isPrimitive': 22, 'is-callable': 32 }, ], 22: [ function (e, t, n) { t.exports = function (e) { return null === e || ('function' !== typeof e && 'object' !== typeof e) } }, {}, ], 23: [ function (e, t, n) { var r = e('dtype') function i(e, t, n) { if (!e) throw new TypeError('must specify data as first parameter') if ( ((n = 0 | +(n || 0)), Array.isArray(e) && e[0] && 'number' === typeof e[0][0]) ) { var i, o, a, s, l = e[0].length, c = e.length * l ;(t && 'string' !== typeof t) || (t = new (r(t || 'float32'))(c + n)) var u = t.length - n if (c !== u) throw new Error( 'source length ' + c + ' (' + l + 'x' + e.length + ') does not match destination length ' + u, ) for (i = 0, a = n; i < e.length; i++) for (o = 0; o < l; o++) t[a++] = null === e[i][o] ? NaN : e[i][o] } else if (t && 'string' !== typeof t) t.set(e, n) else { var h = r(t || 'float32') if (Array.isArray(e) || 'array' === t) for (i = 0, a = n, s = (t = new h(e.length + n)).length; a < s; a++, i++) t[a] = null === e[i] ? NaN : e[i] else 0 === n ? (t = new h(e)) : (t = new h(e.length + n)).set(e, n) } return t } t.exports = i }, { dtype: 13 }, ], 24: [ function (e, t, n) { 'use strict' var r = e('is-callable'), i = Object.prototype.toString, o = Object.prototype.hasOwnProperty, a = function (e, t, n) { for (var r = 0, i = e.length; r < i; r++) o.call(e, r) && (null == n ? t(e[r], r, e) : t.call(n, e[r], r, e)) }, s = function (e, t, n) { for (var r = 0, i = e.length; r < i; r++) null == n ? t(e.charAt(r), r, e) : t.call(n, e.charAt(r), r, e) }, l = function (e, t, n) { for (var r in e) o.call(e, r) && (null == n ? t(e[r], r, e) : t.call(n, e[r], r, e)) }, c = function (e, t, n) { if (!r(t)) throw new TypeError('iterator must be a function') var o arguments.length >= 3 && (o = n), '[object Array]' === i.call(e) ? a(e, t, o) : 'string' === typeof e ? s(e, t, o) : l(e, t, o) } t.exports = c }, { 'is-callable': 32 }, ], 25: [ function (e, t, n) { 'use strict' var r = 'Function.prototype.bind called on incompatible ', i = Array.prototype.slice, o = Object.prototype.toString, a = '[object Function]' t.exports = function (e) { var t = this if ('function' !== typeof t || o.call(t) !== a) throw new TypeError(r + t) for ( var n, s = i.call(arguments, 1), l = function () { if (this instanceof n) { var r = t.apply(this, s.concat(i.call(arguments))) return Object(r) === r ? r : this } return t.apply(e, s.concat(i.call(arguments))) }, c = Math.max(0, t.length - s.length), u = [], h = 0; h < c; h++ ) u.push('$' + h) if ( ((n = Function( 'binder', 'return function (' + u.join(',') + '){ return binder.apply(this,arguments); }', )(l)), t.prototype) ) { var d = function () {} ;(d.prototype = t.prototype), (n.prototype = new d()), (d.prototype = null) } return n } }, {}, ], 26: [ function (e, t, n) { 'use strict' var r = e('./implementation') t.exports = Function.prototype.bind || r }, { './implementation': 25 }, ], 27: [ function (e, t, n) { ;(function (e) { var n ;(n = 'undefined' !== typeof window ? window : 'undefined' !== typeof e ? e : 'undefined' !== typeof self ? self : {}), (t.exports = n) }.call( this, 'undefined' !== typeof r.g ? r.g : 'undefined' !== typeof self ? self : 'undefined' !== typeof window ? window : {}, )) }, {}, ], 28: [ function (e, t, n) { 'use strict' var r = e('function-bind') t.exports = r.call(Function.call, Object.prototype.hasOwnProperty) }, { 'function-bind': 26 }, ], 29: [ function (e, t, n) { ;(n.read = function (e, t, n, r, i) { var o, a, s = 8 * i - r - 1, l = (1 << s) - 1, c = l >> 1, u = -7, h = n ? i - 1 : 0, d = n ? -1 : 1, p = e[t + h] for ( h += d, o = p & ((1 << -u) - 1), p >>= -u, u += s; u > 0; o = 256 * o + e[t + h], h += d, u -= 8 ); for ( a = o & ((1 << -u) - 1), o >>= -u, u += r; u > 0; a = 256 * a + e[t + h], h += d, u -= 8 ); if (0 === o) o = 1 - c else { if (o === l) return a ? NaN : (1 / 0) * (p ? -1 : 1) ;(a += Math.pow(2, r)), (o -= c) } return (p ? -1 : 1) * a * Math.pow(2, o - r) }), (n.write = function (e, t, n, r, i, o) { var a, s, l, c = 8 * o - i - 1, u = (1 << c) - 1, h = u >> 1, d = 23 === i ? Math.pow(2, -24) - Math.pow(2, -77) : 0, p = r ? 0 : o - 1, f = r ? 1 : -1, m = t < 0 || (0 === t && 1 / t < 0) ? 1 : 0 for ( t = Math.abs(t), isNaN(t) || t === 1 / 0 ? ((s = isNaN(t) ? 1 : 0), (a = u)) : ((a = Math.floor(Math.log(t) / Math.LN2)), t * (l = Math.pow(2, -a)) < 1 && (a--, (l *= 2)), (t += a + h >= 1 ? d / l : d * Math.pow(2, 1 - h)) * l >= 2 && (a++, (l /= 2)), a + h >= u ? ((s = 0), (a = u)) : a + h >= 1 ? ((s = (t * l - 1) * Math.pow(2, i)), (a += h)) : ((s = t * Math.pow(2, h - 1) * Math.pow(2, i)), (a = 0))); i >= 8; e[n + p] = 255 & s, p += f, s /= 256, i -= 8 ); for ( a = (a << i) | s, c += i; c > 0; e[n + p] = 255 & a, p += f, a /= 256, c -= 8 ); e[n + p - f] |= 128 * m }) }, {}, ], 30: [ function (e, t, n) { 'function' === typeof Object.create ? (t.exports = function (e, t) { t && ((e.super_ = t), (e.prototype = Object.create(t.prototype, { constructor: { value: e, enumerable: !1, writable: !0, configurable: !0 }, }))) }) : (t.exports = function (e, t) { if (t) { e.super_ = t var n = function () {} ;(n.prototype = t.prototype), (e.prototype = new n()), (e.prototype.constructor = e) } }) }, {}, ], 31: [ function (e, t, n) { function r(e) { return ( !!e.constructor && 'function' === typeof e.constructor.isBuffer && e.constructor.isBuffer(e) ) } function i(e) { return ( 'function' === typeof e.readFloatLE && 'function' === typeof e.slice && r(e.slice(0, 0)) ) } t.exports = function (e) { return null != e && (r(e) || i(e) || !!e._isBuffer) } }, {}, ], 32: [ function (t, n, r) { 'use strict' var i = Function.prototype.toString, o = /^\s*class\b/, a = function (t) { try { var n = i.call(t) return o.test(n) } catch (e) { return !1 } }, s = function (t) { try { return !a(t) && (i.call(t), !0) } catch (e) { return !1 } }, l = Object.prototype.toString, c = '[object Function]', u = '[object GeneratorFunction]', h = 'function' === typeof Symbol && 'symbol' === typeof Symbol.toStringTag n.exports = function (e) { if (!e) return !1 if ('function' !== typeof e && 'object' !== typeof e) return !1 if ('function' === typeof e && !e.prototype) return !0 if (h) return s(e) if (a(e)) return !1 var t = l.call(e) return t === c || t === u } }, {}, ], 33: [ function (e, t, n) { t.exports = i var r = Object.prototype.toString function i(e) { var t = r.call(e) return ( '[object Function]' === t || ('function' === typeof e && '[object RegExp]' !== t) || ('undefined' !== typeof window && (e === window.setTimeout || e === window.alert || e === window.confirm || e === window.prompt)) ) } }, {}, ], 34: [ function (e, t, n) { 'use strict' t.exports = function (e) { var t = typeof e return null !== e && ('object' === t || 'function' === t) } }, {}, ], 35: [ function (e, t, n) { var r = {}.toString t.exports = Array.isArray || function (e) { return '[object Array]' == r.call(e) } }, {}, ], 36: [ function (e, t, n) { var r = e('word-wrapper'), i = e('xtend'), o = e('as-number'), a = ['x', 'e', 'a', 'o', 'n', 's', 'r', 'c', 'u', 'm', 'v', 'w', 'z'], s = ['m', 'w'], l = ['H', 'I', 'N', 'E', 'F', 'K', 'L', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'], c = '\t'.charCodeAt(0), u = ' '.charCodeAt(0), h = 0, d = 1, p = 2 function f(e) { ;(this.glyphs = []), (this._measure = this.computeMetrics.bind(this)), this.update(e) } function m(e) { Object.defineProperty(f.prototype, e, { get: v(e), configurable: !0 }) } function v(e) { return new Function( ['return function ' + e + '() {', ' return this._' + e, '}'].join('\n'), )() } function g(e, t) { if (!e.chars || 0 === e.chars.length) return null var n = E(e.chars, t) return n >= 0 ? e.chars[n] : null } function y(e) { for (var t = 0; t < a.length; t++) { var n = a[t].charCodeAt(0), r = E(e.chars, n) if (r >= 0) return e.chars[r].height } return 0 } function b(e) { for (var t = 0; t < s.length; t++) { var n = s[t].charCodeAt(0), r = E(e.chars, n) if (r >= 0) return e.chars[r] } return 0 } function A(e) { for (var t = 0; t < l.length; t++) { var n = l[t].charCodeAt(0), r = E(e.chars, n) if (r >= 0) return e.chars[r].height } return 0 } function w(e, t, n) { if (!e.kernings || 0 === e.kernings.length) return 0 for (var r = e.kernings, i = 0; i < r.length; i++) { var o = r[i] if (o.first === t && o.second === n) return o.amount } return 0 } function x(e) { return 'center' === e ? d : 'right' === e ? p : h } function E(e, t, n) { for (var r = (n = n || 0); r < e.length; r++) if (e[r].id === t) return r return -1 } ;(t.exports = function (e) { return new f(e) }), (f.prototype.update = function (e) { if ( ((e = i({ measure: this._measure }, e)), (this._opt = e), (this._opt.tabSize = o(this._opt.tabSize, 4)), !e.font) ) throw new Error('must provide a valid bitmap font') var t = this.glyphs, n = e.text || '', a = e.font this._setupSpaceGlyphs(a) var s = r.lines(n, e), l = e.width || 0 t.length = 0 var c = s.reduce(function (e, t) { return Math.max(e, t.width, l) }, 0), u = 0, h = 0, f = o(e.lineHeight, a.common.lineHeight), m = a.common.base, v = f - m, g = e.letterSpacing || 0, b = f * s.length - v, E = x(this._opt.align) ;(h -= b), (this._width = c), (this._height = b), (this._descender = f - m), (this._baseline = m), (this._xHeight = y(a)), (this._capHeight = A(a)), (this._lineHeight = f), (this._ascender = f - v - this._xHeight) var M = this s.forEach(function (e, r) { for (var i, o = e.start, s = e.end, l = e.width, m = o; m < s; m++) { var v = n.charCodeAt(m), y = M.getGlyph(a, v) if (y) { i && (u += w(a, i.id, y.id)) var b = u E === d ? (b += (c - l) / 2) : E === p && (b += c - l), t.push({ position: [b, h], data: y, index: m, line: r }), (u += y.xadvance + g), (i = y) } } ;(h += f), (u = 0) }), (this._linesTotal = s.length) }), (f.prototype._setupSpaceGlyphs = function (e) { if ( ((this._fallbackSpaceGlyph = null), (this._fallbackTabGlyph = null), e.chars && 0 !== e.chars.length) ) { var t = g(e, u) || b(e) || e.chars[0], n = this._opt.tabSize * t.xadvance ;(this._fallbackSpaceGlyph = t), (this._fallbackTabGlyph = i(t, { x: 0, y: 0, xadvance: n, id: c, xoffset: 0, yoffset: 0, width: 0, height: 0, })) } }), (f.prototype.getGlyph = function (e, t) { var n = g(e, t) return ( n || (t === c ? this._fallbackTabGlyph : t === u ? this._fallbackSpaceGlyph : null) ) }), (f.prototype.computeMetrics = function (e, t, n, r) { var i, o = this._opt.letterSpacing || 0, a = this._opt.font, s = 0, l = 0, c = 0 if (!a.chars || 0 === a.chars.length) return { start: t, end: t, width: 0 } n = Math.min(e.length, n) for (var u = t; u < n; u++) { var h, d = e.charCodeAt(u) if ((h = this.getGlyph(a, d))) { h.xoffset var p = (s += i ? w(a, i.id, h.id) : 0) + h.xadvance + o, f = s + h.width if (f >= r || p >= r) break ;(s = p), (l = f), (i = h) } c++ } return i && (l += i.xoffset), { start: t, end: t + c, width: l } }), [ 'width', 'height', 'descender', 'ascender', 'xHeight', 'baseline', 'capHeight', 'lineHeight', ].forEach(m) }, { 'as-number': 2, 'word-wrapper': 69, xtend: 72 }, ], 37: [ function (t, n, r) { ;(function (r) { var i = t('xhr'), o = function () {}, a = t('parse-bmfont-ascii'), s = t('parse-bmfont-xml'), l = t('parse-bmfont-binary'), c = t('./lib/is-binary'), u = t('xtend'), h = self.XMLHttpRequest && 'withCredentials' in new XMLHttpRequest() function d(e) { return '[object ArrayBuffer]' === Object.prototype.toString.call(e) } function p(e) { if (h) return u(e, { responseType: 'arraybuffer' }) if ('undefined' === typeof self.XMLHttpRequest) throw new Error('your browser does not support XHR loading') var t = new self.XMLHttpRequest() return ( t.overrideMimeType('text/plain; charset=x-user-defined'), u({ xhr: t }, e) ) } n.exports = function (t, n) { ;(n = 'function' === typeof n ? n : o), 'string' === typeof t ? (t = { uri: t }) : t || (t = {}), t.binary && (t = p(t)), i(t, function (i, u, h) { if (i) return n(i) if (!/^2/.test(u.statusCode)) return n(new Error('http status code: ' + u.statusCode)) if (!h) return n(new Error('no body result')) var p, f = !1 if (d(h)) { var m = new Uint8Array(h) h = new r(m, 'binary') } c(h) && ((f = !0), 'string' === typeof h && (h = new r(h, 'binary'))), f || (r.isBuffer(h) && (h = h.toString(t.encoding)), (h = h.trim())) try { var v = u.headers['content-type'] p = f ? l(h) : /json/.test(v) || '{' === h.charAt(0) ? JSON.parse(h) : /xml/.test(v) || '<' === h.charAt(0) ? s(h) : a(h) } catch (e) { n(new Error('error parsing font ' + e.message)), (n = o) } n(null, p) }) } }.call(this, t('buffer').Buffer)) }, { './lib/is-binary': 38, buffer: 6, 'parse-bmfont-ascii': 43, 'parse-bmfont-binary': 44, 'parse-bmfont-xml': 45, xhr: 70, xtend: 72, }, ], 38: [ function (e, t, n) { ;(function (n) { var r = e('buffer-equal'), i = new n([66, 77, 70, 3]) t.exports = function (e) { return 'string' === typeof e ? 'BMF' === e.substring(0, 3) : e.length > 4 && r(e.slice(0, 4), i) } }.call(this, e('buffer').Buffer)) }, { buffer: 6, 'buffer-equal': 5 }, ], 39: [ function (e, t, n) { 'use strict' var r = Object.getOwnPropertySymbols, i = Object.prototype.hasOwnProperty, o = Object.prototype.propertyIsEnumerable function a(e) { if (null === e || void 0 === e) throw new TypeError('Object.assign cannot be called with null or undefined') return Object(e) } function s() { try { if (!Object.assign) return !1 var e = new String('abc') if (((e[5] = 'de'), '5' === Object.getOwnPropertyNames(e)[0])) return !1 for (var t = {}, n = 0; n < 10; n++) t['_' + String.fromCharCode(n)] = n if ( '0123456789' !== Object.getOwnPropertyNames(t) .map(function (e) { return t[e] }) .join('') ) return !1 var r = {} return ( 'abcdefghijklmnopqrst'.split('').forEach(function (e) { r[e] = e }), 'abcdefghijklmnopqrst' === Object.keys(Object.assign({}, r)).join('') ) } catch (i) { return !1 } } t.exports = s() ? Object.assign : function (e, t) { for (var n, s, l = a(e), c = 1; c < arguments.length; c++) { for (var u in (n = Object(arguments[c]))) i.call(n, u) && (l[u] = n[u]) if (r) { s = r(n) for (var h = 0; h < s.length; h++) o.call(n, s[h]) && (l[s[h]] = n[s[h]]) } } return l } }, {}, ], 40: [ function (t, n, r) { 'use strict' var i if (!Object.keys) { var o = Object.prototype.hasOwnProperty, a = Object.prototype.toString, s = t('./isArguments'), l = Object.prototype.propertyIsEnumerable, c = !l.call({ toString: null }, 'toString'), u = l.call(function () {}, 'prototype'), h = [ 'toString', 'toLocaleString', 'valueOf', 'hasOwnProperty', 'isPrototypeOf', 'propertyIsEnumerable', 'constructor', ], d = function (e) { var t = e.constructor return t && t.prototype === e }, p = { $applicationCache: !0, $console: !0, $external: !0, $frame: !0, $frameElement: !0, $frames: !0, $innerHeight: !0, $innerWidth: !0, $onmozfullscreenchange: !0, $onmozfullscreenerror: !0, $outerHeight: !0, $outerWidth: !0, $pageXOffset: !0, $pageYOffset: !0, $parent: !0, $scrollLeft: !0, $scrollTop: !0, $scrollX: !0, $scrollY: !0, $self: !0, $webkitIndexedDB: !0, $webkitStorageInfo: !0, $window: !0, }, f = (function () { if ('undefined' === typeof window) return !1 for (var t in window) try { if ( !p['$' + t] && o.call(window, t) && null !== window[t] && 'object' === typeof window[t] ) try { d(window[t]) } catch (e) { return !0 } } catch (e) { return !0 } return !1 })(), m = function (t) { if ('undefined' === typeof window || !f) return d(t) try { return d(t) } catch (e) { return !1 } } i = function (e) { var t = null !== e && 'object' === typeof e, n = '[object Function]' === a.call(e), r = s(e), i = t && '[object String]' === a.call(e), l = [] if (!t && !n && !r) throw new TypeError('Object.keys called on a non-object') var d = u && n if (i && e.length > 0 && !o.call(e, 0)) for (var p = 0; p < e.length; ++p) l.push(String(p)) if (r && e.length > 0) for (var f = 0; f < e.length; ++f) l.push(String(f)) else for (var v in e) (d && 'prototype' === v) || !o.call(e, v) || l.push(String(v)) if (c) for (var g = m(e), y = 0; y < h.length; ++y) (g && 'constructor' === h[y]) || !o.call(e, h[y]) || l.push(h[y]) return l } } n.exports = i }, { './isArguments': 42 }, ], 41: [ function (e, t, n) { 'use strict' var r = Array.prototype.slice, i = e('./isArguments'), o = Object.keys, a = o ? function (e) { return o(e) } : e('./implementation'), s = Object.keys ;(a.shim = function () { return ( Object.keys ? (function () { var e = Object.keys(arguments) return e && e.length === arguments.length })(1, 2) || (Object.keys = function (e) { return i(e) ? s(r.call(e)) : s(e) }) : (Object.keys = a), Object.keys || a ) }), (t.exports = a) }, { './implementation': 40, './isArguments': 42 }, ], 42: [ function (e, t, n) { 'use strict' var r = Object.prototype.toString t.exports = function (e) { var t = r.call(e), n = '[object Arguments]' === t return ( n || (n = '[object Array]' !== t && null !== e && 'object' === typeof e && 'number' === typeof e.length && e.length >= 0 && '[object Function]' === r.call(e.callee)), n ) } }, {}, ], 43: [ function (e, t, n) { function r(e, t) { if (!(e = e.replace(/\t+/g, ' ').trim())) return null var n = e.indexOf(' ') if (-1 === n) throw new Error('no named row at line ' + t) var r = e.substring(0, n) e = (e = (e = (e = e.substring(n + 1)).replace( /letter=[\'\"]\S+[\'\"]/gi, '', )).split('=')).map(function (e) { return e.trim().match(/(".*?"|[^"\s]+)+(?=\s*|\s*$)/g) }) for (var o = [], a = 0; a < e.length; a++) { var s = e[a] 0 === a ? o.push({ key: s[0], data: '' }) : a === e.length - 1 ? (o[o.length - 1].data = i(s[0])) : ((o[o.length - 1].data = i(s[0])), o.push({ key: s[1], data: '' })) } var l = { key: r, data: {} } return ( o.forEach(function (e) { l.data[e.key] = e.data }), l ) } function i(e) { return e && 0 !== e.length ? 0 === e.indexOf('"') || 0 === e.indexOf("'") ? e.substring(1, e.length - 1) : -1 !== e.indexOf(',') ? o(e) : parseInt(e, 10) : '' } function o(e) { return e.split(',').map(function (e) { return parseInt(e, 10) }) } t.exports = function (e) { if (!e) throw new Error('no data provided') var t = { pages: [], chars: [], kernings: [] }, n = (e = e.toString().trim()).split(/\r\n?|\n/g) if (0 === n.length) throw new Error('no data in BMFont file') for (var i = 0; i < n.length; i++) { var o = r(n[i], i) if (o) if ('page' === o.key) { if ('number' !== typeof o.data.id) throw new Error('malformed file at line ' + i + ' -- needs page id=N') if ('string' !== typeof o.data.file) throw new Error( 'malformed file at line ' + i + ' -- needs page file="path"', ) t.pages[o.data.id] = o.data.file } else 'chars' === o.key || 'kernings' === o.key || ('char' === o.key ? t.chars.push(o.data) : 'kerning' === o.key ? t.kernings.push(o.data) : (t[o.key] = o.data)) } return t } }, {}, ], 44: [ function (e, t, n) { var r = [66, 77, 70] function i(e, t, n) { if (n > t.length - 1) return 0 var r = t.readUInt8(n++), i = t.readInt32LE(n) switch (((n += 4), r)) { case 1: e.info = o(t, n) break case 2: e.common = a(t, n) break case 3: e.pages = s(t, n, i) break case 4: e.chars = l(t, n, i) break case 5: e.kernings = c(t, n, i) } return 5 + i } function o(e, t) { var n = {} n.size = e.readInt16LE(t) var r = e.readUInt8(t + 2) return ( (n.smooth = (r >> 7) & 1), (n.unicode = (r >> 6) & 1), (n.italic = (r >> 5) & 1), (n.bold = (r >> 4) & 1), (r >> 3) & 1 && (n.fixedHeight = 1), (n.charset = e.readUInt8(t + 3) || ''), (n.stretchH = e.readUInt16LE(t + 4)), (n.aa = e.readUInt8(t + 6)), (n.padding = [ e.readInt8(t + 7), e.readInt8(t + 8), e.readInt8(t + 9), e.readInt8(t + 10), ]), (n.spacing = [e.readInt8(t + 11), e.readInt8(t + 12)]), (n.outline = e.readUInt8(t + 13)), (n.face = h(e, t + 14)), n ) } function a(e, t) { var n = {} return ( (n.lineHeight = e.readUInt16LE(t)), (n.base = e.readUInt16LE(t + 2)), (n.scaleW = e.readUInt16LE(t + 4)), (n.scaleH = e.readUInt16LE(t + 6)), (n.pages = e.readUInt16LE(t + 8)), e.readUInt8(t + 10), (n.packed = 0), (n.alphaChnl = e.readUInt8(t + 11)), (n.redChnl = e.readUInt8(t + 12)), (n.greenChnl = e.readUInt8(t + 13)), (n.blueChnl = e.readUInt8(t + 14)), n ) } function s(e, t, n) { for (var r = [], i = u(e, t), o = i.length + 1, a = n / o, s = 0; s < a; s++) (r[s] = e.slice(t, t + i.length).toString('utf8')), (t += o) return r } function l(e, t, n) { for (var r = [], i = n / 20, o = 0; o < i; o++) { var a = {}, s = 20 * o ;(a.id = e.readUInt32LE(t + 0 + s)), (a.x = e.readUInt16LE(t + 4 + s)), (a.y = e.readUInt16LE(t + 6 + s)), (a.width = e.readUInt16LE(t + 8 + s)), (a.height = e.readUInt16LE(t + 10 + s)), (a.xoffset = e.readInt16LE(t + 12 + s)), (a.yoffset = e.readInt16LE(t + 14 + s)), (a.xadvance = e.readInt16LE(t + 16 + s)), (a.page = e.readUInt8(t + 18 + s)), (a.chnl = e.readUInt8(t + 19 + s)), (r[o] = a) } return r } function c(e, t, n) { for (var r = [], i = n / 10, o = 0; o < i; o++) { var a = {}, s = 10 * o ;(a.first = e.readUInt32LE(t + 0 + s)), (a.second = e.readUInt32LE(t + 4 + s)), (a.amount = e.readInt16LE(t + 8 + s)), (r[o] = a) } return r } function u(e, t) { for (var n = t; n < e.length && 0 !== e[n]; n++); return e.slice(t, n) } function h(e, t) { return u(e, t).toString('utf8') } t.exports = function (e) { if (e.length < 6) throw new Error('invalid buffer length for BMFont') if ( !r.every(function (t, n) { return e.readUInt8(n) === t }) ) throw new Error('BMFont missing BMF byte header') var t = 3 if (e.readUInt8(t++) > 3) throw new Error('Only supports BMFont Binary v3 (BMFont App v1.10)') for (var n = { kernings: [], chars: [] }, o = 0; o < 5; o++) t += i(n, e, t) return n } }, {}, ], 45: [ function (e, t, n) { var r = e('./parse-attribs'), i = e('xml-parse-from-string'), o = { scaleh: 'scaleH', scalew: 'scaleW', stretchh: 'stretchH', lineheight: 'lineHeight', alphachnl: 'alphaChnl', redchnl: 'redChnl', greenchnl: 'greenChnl', bluechnl: 'blueChnl', } function a(e) { return s(e).reduce(function (e, t) { return (e[l(t.nodeName)] = t.nodeValue), e }, {}) } function s(e) { for (var t = [], n = 0; n < e.attributes.length; n++) t.push(e.attributes[n]) return t } function l(e) { return o[e.toLowerCase()] || e } t.exports = function (e) { e = e.toString() var t = i(e), n = { pages: [], chars: [], kernings: [] } ;['info', 'common'].forEach(function (e) { var i = t.getElementsByTagName(e)[0] i && (n[e] = r(a(i))) }) var o = t.getElementsByTagName('pages')[0] if (!o) throw new Error('malformed file -- no element') for (var s = o.getElementsByTagName('page'), l = 0; l < s.length; l++) { var c = s[l], u = parseInt(c.getAttribute('id'), 10), h = c.getAttribute('file') if (isNaN(u)) throw new Error('malformed file -- page "id" attribute is NaN') if (!h) throw new Error('malformed file -- needs page "file" attribute') n.pages[parseInt(u, 10)] = h } return ( ['chars', 'kernings'].forEach(function (e) { var i = t.getElementsByTagName(e)[0] if (i) for ( var o = e.substring(0, e.length - 1), s = i.getElementsByTagName(o), l = 0; l < s.length; l++ ) { var c = s[l] n[e].push(r(a(c))) } }), n ) } }, { './parse-attribs': 46, 'xml-parse-from-string': 71 }, ], 46: [ function (e, t, n) { var r = 'chasrset' function i(e) { return e.split(',').map(function (e) { return parseInt(e, 10) }) } t.exports = function (e) { for (var t in (r in e && ((e.charset = e[r]), delete e[r]), e)) 'face' !== t && 'charset' !== t && (e[t] = 'padding' === t || 'spacing' === t ? i(e[t]) : parseInt(e[t], 10)) return e } }, {}, ], 47: [ function (e, t, n) { var r = e('string.prototype.trim'), i = e('for-each'), o = function (e) { return '[object Array]' === Object.prototype.toString.call(e) } t.exports = function (e) { if (!e) return {} var t = {} return ( i(r(e).split('\n'), function (e) { var n = e.indexOf(':'), i = r(e.slice(0, n)).toLowerCase(), a = r(e.slice(n + 1)) 'undefined' === typeof t[i] ? (t[i] = a) : o(t[i]) ? t[i].push(a) : (t[i] = [t[i], a]) }), t ) } }, { 'for-each': 24, 'string.prototype.trim': 53 }, ], 48: [ function (e, t, n) { ;(function (e) { var n = e.performance || {}, r = (function () { for (var e = ['now', 'webkitNow', 'msNow', 'mozNow', 'oNow']; e.length; ) { var t = e.shift() if (t in n) return n[t].bind(n) } var r = Date.now || function () { return new Date().getTime() }, i = (n.timing || {}).navigationStart || r() return function () { return r() - i } })() ;(r.performanceNow = n.now), (r.noConflict = function () { n.now = r.performanceNow }), (r.conflict = function () { n.now = r }), r.conflict(), (t.exports = r) }.call( this, 'undefined' !== typeof r.g ? r.g : 'undefined' !== typeof self ? self : 'undefined' !== typeof window ? window : {}, )) }, {}, ], 49: [ function (t, n, r) { var i, o, a = (n.exports = {}) function s() { throw new Error('setTimeout has not been defined') } function l() { throw new Error('clearTimeout has not been defined') } function c(t) { if (i === setTimeout) return setTimeout(t, 0) if ((i === s || !i) && setTimeout) return (i = setTimeout), setTimeout(t, 0) try { return i(t, 0) } catch (e) { try { return i.call(null, t, 0) } catch (e) { return i.call(this, t, 0) } } } function u(t) { if (o === clearTimeout) return clearTimeout(t) if ((o === l || !o) && clearTimeout) return (o = clearTimeout), clearTimeout(t) try { return o(t) } catch (e) { try { return o.call(null, t) } catch (e) { return o.call(this, t) } } } !(function () { try { i = 'function' === typeof setTimeout ? setTimeout : s } catch (e) { i = s } try { o = 'function' === typeof clearTimeout ? clearTimeout : l } catch (e) { o = l } })() var h, d = [], p = !1, f = -1 function m() { p && h && ((p = !1), h.length ? (d = h.concat(d)) : (f = -1), d.length && v()) } function v() { if (!p) { var e = c(m) p = !0 for (var t = d.length; t; ) { for (h = d, d = []; ++f < t; ) h && h[f].run() ;(f = -1), (t = d.length) } ;(h = null), (p = !1), u(e) } } function g(e, t) { ;(this.fun = e), (this.array = t) } function y() {} ;(a.nextTick = function (e) { var t = new Array(arguments.length - 1) if (arguments.length > 1) for (var n = 1; n < arguments.length; n++) t[n - 1] = arguments[n] d.push(new g(e, t)), 1 !== d.length || p || c(v) }), (g.prototype.run = function () { this.fun.apply(null, this.array) }), (a.title = 'browser'), (a.browser = !0), (a.env = {}), (a.argv = []), (a.version = ''), (a.versions = {}), (a.on = y), (a.addListener = y), (a.once = y), (a.off = y), (a.removeListener = y), (a.removeAllListeners = y), (a.emit = y), (a.prependListener = y), (a.prependOnceListener = y), (a.listeners = function (e) { return [] }), (a.binding = function (e) { throw new Error('process.binding is not supported') }), (a.cwd = function () { return '/' }), (a.chdir = function (e) { throw new Error('process.chdir is not supported') }), (a.umask = function () { return 0 }) }, {}, ], 50: [ function (t, n, r) { ;(function (t) { !(function (r) { var i = setTimeout, o = ('function' === typeof t && t) || function (e) { i(e, 1) } function a(e, t) { return function () { e.apply(t, arguments) } } var s = Array.isArray || function (e) { return '[object Array]' === Object.prototype.toString.call(e) } function l(e) { if ('object' !== typeof this) throw new TypeError('Promises must be constructed via new') if ('function' !== typeof e) throw new TypeError('not a function') ;(this._state = null), (this._value = null), (this._deferreds = []), f(e, a(u, this), a(h, this)) } function c(t) { var n = this null !== this._state ? o(function () { var r = n._state ? t.onFulfilled : t.onRejected if (null !== r) { var i try { i = r(n._value) } catch (e) { return void t.reject(e) } t.resolve(i) } else (n._state ? t.resolve : t.reject)(n._value) }) : this._deferreds.push(t) } function u(t) { try { if (t === this) throw new TypeError('A promise cannot be resolved with itself.') if (t && ('object' === typeof t || 'function' === typeof t)) { var n = t.then if ('function' === typeof n) return void f(a(n, t), a(u, this), a(h, this)) } ;(this._state = !0), (this._value = t), d.call(this) } catch (e) { h.call(this, e) } } function h(e) { ;(this._state = !1), (this._value = e), d.call(this) } function d() { for (var e = 0, t = this._deferreds.length; e < t; e++) c.call(this, this._deferreds[e]) this._deferreds = null } function p(e, t, n, r) { ;(this.onFulfilled = 'function' === typeof e ? e : null), (this.onRejected = 'function' === typeof t ? t : null), (this.resolve = n), (this.reject = r) } function f(e, t, n) { var r = !1 try { e( function (e) { r || ((r = !0), t(e)) }, function (e) { r || ((r = !0), n(e)) }, ) } catch (i) { if (r) return ;(r = !0), n(i) } } ;(l.prototype.catch = function (e) { return this.then(null, e) }), (l.prototype.then = function (e, t) { var n = this return new l(function (r, i) { c.call(n, new p(e, t, r, i)) }) }), (l.all = function () { var e = Array.prototype.slice.call( 1 === arguments.length && s(arguments[0]) ? arguments[0] : arguments, ) return new l(function (t, n) { if (0 === e.length) return t([]) var r = e.length function i(o, a) { try { if (a && ('object' === typeof a || 'function' === typeof a)) { var s = a.then if ('function' === typeof s) return void s.call( a, function (e) { i(o, e) }, n, ) } ;(e[o] = a), 0 === --r && t(e) } catch (l) { n(l) } } for (var o = 0; o < e.length; o++) i(o, e[o]) }) }), (l.resolve = function (e) { return e && 'object' === typeof e && e.constructor === l ? e : new l(function (t) { t(e) }) }), (l.reject = function (e) { return new l(function (t, n) { n(e) }) }), (l.race = function (e) { return new l(function (t, n) { for (var r = 0, i = e.length; r < i; r++) e[r].then(t, n) }) }), (l._setImmediateFn = function (e) { o = e }), 'undefined' !== typeof n && n.exports ? (n.exports = l) : r.Promise || (r.Promise = l) })(this) }.call(this, t('timers').setImmediate)) }, { timers: 67 }, ], 51: [ function (e, t, n) { var r = e('dtype'), i = e('an-array'), o = e('is-buffer'), a = [0, 2, 3], s = [2, 1, 3] t.exports = function (e, t) { ;(e && (i(e) || o(e))) || ((t = e || {}), (e = null)) for ( var n = 'string' === typeof (t = 'number' === typeof t ? { count: t } : t || {}).type ? t.type : 'uint16', l = 'number' === typeof t.count ? t.count : 1, c = t.start || 0, u = !1 !== t.clockwise ? a : s, h = u[0], d = u[1], p = u[2], f = 6 * l, m = e || new (r(n))(f), v = 0, g = 0; v < f; v += 6, g += 4 ) { var y = v + c ;(m[y + 0] = g + 0), (m[y + 1] = g + 1), (m[y + 2] = g + 2), (m[y + 3] = g + h), (m[y + 4] = g + d), (m[y + 5] = g + p) } return m } }, { 'an-array': 1, dtype: 13, 'is-buffer': 31 }, ], 52: [ function (e, t, n) { 'use strict' var r = e('function-bind'), i = e('es-abstract/es5'), o = r.call(Function.call, String.prototype.replace), a = /^[\x09\x0A\x0B\x0C\x0D\x20\xA0\u1680\u180E\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200A\u202F\u205F\u3000\u2028\u2029\uFEFF]+/, s = /[\x09\x0A\x0B\x0C\x0D\x20\xA0\u1680\u180E\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200A\u202F\u205F\u3000\u2028\u2029\uFEFF]+$/ t.exports = function () { var e = i.ToString(i.CheckObjectCoercible(this)) return o(o(e, a, ''), s, '') } }, { 'es-abstract/es5': 15, 'function-bind': 26 }, ], 53: [ function (e, t, n) { 'use strict' var r = e('function-bind'), i = e('define-properties'), o = e('./implementation'), a = e('./polyfill'), s = e('./shim'), l = r.call(Function.call, a()) i(l, { getPolyfill: a, implementation: o, shim: s }), (t.exports = l) }, { './implementation': 52, './polyfill': 54, './shim': 55, 'define-properties': 11, 'function-bind': 26, }, ], 54: [ function (e, t, n) { 'use strict' var r = e('./implementation'), i = '\u200b' t.exports = function () { return String.prototype.trim && i.trim() === i ? String.prototype.trim : r } }, { './implementation': 52 }, ], 55: [ function (e, t, n) { 'use strict' var r = e('define-properties'), i = e('./polyfill') t.exports = function () { var e = i() return ( r( String.prototype, { trim: e }, { trim: function () { return String.prototype.trim !== e }, }, ), e ) } }, { './polyfill': 54, 'define-properties': 11 }, ], 56: [ function (t, n, r) { 'use strict' var i = { update: null, begin: null, loopBegin: null, changeBegin: null, change: null, changeComplete: null, loopComplete: null, complete: null, loop: 1, direction: 'normal', autoplay: !0, timelineOffset: 0, }, o = { duration: 1e3, delay: 0, endDelay: 0, easing: 'easeOutElastic(1, .5)', round: 0, }, a = [ 'translateX', 'translateY', 'translateZ', 'rotate', 'rotateX', 'rotateY', 'rotateZ', 'scale', 'scaleX', 'scaleY', 'scaleZ', 'skew', 'skewX', 'skewY', 'perspective', ], s = { CSS: {}, springs: {} } function l(e, t, n) { return Math.min(Math.max(e, t), n) } function c(e, t) { return e.indexOf(t) > -1 } function u(e, t) { return e.apply(null, t) } var h = /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i, d = /^rgb/, p = /^hsl/, f = { arr: function (e) { return Array.isArray(e) }, obj: function (e) { return c(Object.prototype.toString.call(e), 'Object') }, pth: function (e) { return f.obj(e) && e.hasOwnProperty('totalLength') }, svg: function (e) { return e instanceof SVGElement }, inp: function (e) { return e instanceof HTMLInputElement }, dom: function (e) { return e.nodeType || f.svg(e) }, str: function (e) { return 'string' === typeof e }, fnc: function (e) { return 'function' === typeof e }, und: function (e) { return 'undefined' === typeof e }, hex: function (e) { return h.test(e) }, rgb: function (e) { return d.test(e) }, hsl: function (e) { return p.test(e) }, col: function (e) { return f.hex(e) || f.rgb(e) || f.hsl(e) }, key: function (e) { return ( !i.hasOwnProperty(e) && !o.hasOwnProperty(e) && 'targets' !== e && 'keyframes' !== e ) }, }, m = /\(([^)]+)\)/ function v(e) { var t = m.exec(e) return t ? t[1].split(',').map(function (e) { return parseFloat(e) }) : [] } function g(e, t) { var n = v(e), r = l(f.und(n[0]) ? 1 : n[0], 0.1, 100), i = l(f.und(n[1]) ? 100 : n[1], 0.1, 100), o = l(f.und(n[2]) ? 10 : n[2], 0.1, 100), a = l(f.und(n[3]) ? 0 : n[3], 0.1, 100), c = Math.sqrt(i / r), u = o / (2 * Math.sqrt(i * r)), h = u < 1 ? c * Math.sqrt(1 - u * u) : 0, d = 1, p = u < 1 ? (u * c - a) / h : -a + c function m(e) { var n = t ? (t * e) / 1e3 : e return ( (n = u < 1 ? Math.exp(-n * u * c) * (d * Math.cos(h * n) + p * Math.sin(h * n)) : (d + p * n) * Math.exp(-n * c)), 0 === e || 1 === e ? e : 1 - n ) } function g() { var t = s.springs[e] if (t) return t for (var n = 1 / 6, r = 0, i = 0; ; ) if (1 === m((r += n))) { if (++i >= 16) break } else i = 0 var o = r * n * 1e3 return (s.springs[e] = o), o } return t ? m : g } function y(e, t) { void 0 === e && (e = 1), void 0 === t && (t = 0.5) var n = l(e, 1, 10), r = l(t, 0.1, 2) return function (e) { return 0 === e || 1 === e ? e : -n * Math.pow(2, 10 * (e - 1)) * Math.sin( ((e - 1 - (r / (2 * Math.PI)) * Math.asin(1 / n)) * (2 * Math.PI)) / r, ) } } function b(e) { return ( void 0 === e && (e = 10), function (t) { return Math.round(t * e) * (1 / e) } ) } var A = (function () { var e = 11, t = 1 / (e - 1) function n(e, t) { return 1 - 3 * t + 3 * e } function r(e, t) { return 3 * t - 6 * e } function i(e) { return 3 * e } function o(e, t, o) { return ((n(t, o) * e + r(t, o)) * e + i(t)) * e } function a(e, t, o) { return 3 * n(t, o) * e * e + 2 * r(t, o) * e + i(t) } function s(e, t, n, r, i) { var a, s, l = 0 do { ;(a = o((s = t + (n - t) / 2), r, i) - e) > 0 ? (n = s) : (t = s) } while (Math.abs(a) > 1e-7 && ++l < 10) return s } function l(e, t, n, r) { for (var i = 0; i < 4; ++i) { var s = a(t, n, r) if (0 === s) return t t -= (o(t, n, r) - e) / s } return t } function c(n, r, i, c) { if (0 <= n && n <= 1 && 0 <= i && i <= 1) { var u = new Float32Array(e) if (n !== r || i !== c) for (var h = 0; h < e; ++h) u[h] = o(h * t, n, i) return function (e) { return (n === r && i === c) || 0 === e || 1 === e ? e : o(d(e), r, c) } } function d(r) { for (var o = 0, c = 1, h = e - 1; c !== h && u[c] <= r; ++c) o += t --c var d = o + ((r - u[c]) / (u[c + 1] - u[c])) * t, p = a(d, n, i) return p >= 0.001 ? l(r, d, n, i) : 0 === p ? d : s(r, o, o + t, n, i) } } return c })(), w = (function () { var e = [ 'Quad', 'Cubic', 'Quart', 'Quint', 'Sine', 'Expo', 'Circ', 'Back', 'Elastic', ], t = { In: [ [0.55, 0.085, 0.68, 0.53], [0.55, 0.055, 0.675, 0.19], [0.895, 0.03, 0.685, 0.22], [0.755, 0.05, 0.855, 0.06], [0.47, 0, 0.745, 0.715], [0.95, 0.05, 0.795, 0.035], [0.6, 0.04, 0.98, 0.335], [0.6, -0.28, 0.735, 0.045], y, ], Out: [ [0.25, 0.46, 0.45, 0.94], [0.215, 0.61, 0.355, 1], [0.165, 0.84, 0.44, 1], [0.23, 1, 0.32, 1], [0.39, 0.575, 0.565, 1], [0.19, 1, 0.22, 1], [0.075, 0.82, 0.165, 1], [0.175, 0.885, 0.32, 1.275], function (e, t) { return function (n) { return 1 - y(e, t)(1 - n) } }, ], InOut: [ [0.455, 0.03, 0.515, 0.955], [0.645, 0.045, 0.355, 1], [0.77, 0, 0.175, 1], [0.86, 0, 0.07, 1], [0.445, 0.05, 0.55, 0.95], [1, 0, 0, 1], [0.785, 0.135, 0.15, 0.86], [0.68, -0.55, 0.265, 1.55], function (e, t) { return function (n) { return n < 0.5 ? y(e, t)(2 * n) / 2 : 1 - y(e, t)(-2 * n + 2) / 2 } }, ], }, n = { linear: [0.25, 0.25, 0.75, 0.75] } for (var r in t) for (var i = 0, o = t[r].length; i < o; i++) n['ease' + r + e[i]] = t[r][i] return n })() function x(e, t) { if (f.fnc(e)) return e var n = e.split('(')[0], r = w[n], i = v(e) switch (n) { case 'spring': return g(e, t) case 'cubicBezier': return u(A, i) case 'steps': return u(b, i) default: return f.fnc(r) ? u(r, i) : u(A, r) } } function E(t) { try { return document.querySelectorAll(t) } catch (e) { return } } var M = [] function _(e, t) { for ( var n = M, r = e.length, i = arguments.length >= 2 ? arguments[1] : void 0, o = 0; o < r; o++ ) if (o in e) { var a = e[o] t.call(i, a, o, e) && n.push(a) } return ((M = e).length = 0), n } function T(e, t) { t || (t = []) for (var n = 0, r = e.length; n < r; n++) { var i = e[n] Array.isArray(i) ? T(i, t) : t.push(i) } return t } function S(e) { return f.arr(e) ? e : (f.str(e) && (e = E(e) || e), e instanceof NodeList || e instanceof HTMLCollection ? [].slice.call(e) : [e]) } function C(e, t) { return e.some(function (e) { return e === t }) } function L(e) { var t = {} for (var n in e) t[n] = e[n] return t } function R(e, t) { var n = L(e) for (var r in e) n[r] = t.hasOwnProperty(r) ? t[r] : e[r] return n } function P(e, t) { var n = L(e) for (var r in t) n[r] = f.und(e[r]) ? t[r] : e[r] return n } var D = /rgb\((\d+,\s*[\d]+,\s*[\d]+)\)/g function O(e) { var t = D.exec(e) return t ? 'rgba(' + t[1] + ',1)' : e } var I = /^#?([a-f\d])([a-f\d])([a-f\d])$/i, B = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i function F(e) { var t = e.replace(I, function (e, t, n, r) { return t + t + n + n + r + r }), n = B.exec(t) return ( 'rgba(' + parseInt(n[1], 16) + ',' + parseInt(n[2], 16) + ',' + parseInt(n[3], 16) + ',1)' ) } var k = /hsl\((\d+),\s*([\d.]+)%,\s*([\d.]+)%\)/g, N = /hsla\((\d+),\s*([\d.]+)%,\s*([\d.]+)%,\s*([\d.]+)\)/g function U(e) { var t, n, r, i = k.exec(e) || N.exec(e), o = parseInt(i[1], 10) / 360, a = parseInt(i[2], 10) / 100, s = parseInt(i[3], 10) / 100, l = i[4] || 1 function c(e, t, n) { return ( n < 0 && (n += 1), n > 1 && (n -= 1), n < 1 / 6 ? e + 6 * (t - e) * n : n < 0.5 ? t : n < 2 / 3 ? e + (t - e) * (2 / 3 - n) * 6 : e ) } if (0 == a) t = n = r = s else { var u = s < 0.5 ? s * (1 + a) : s + a - s * a, h = 2 * s - u ;(t = c(h, u, o + 1 / 3)), (n = c(h, u, o)), (r = c(h, u, o - 1 / 3)) } return 'rgba(' + 255 * t + ',' + 255 * n + ',' + 255 * r + ',' + l + ')' } function H(e) { return f.rgb(e) ? O(e) : f.hex(e) ? F(e) : f.hsl(e) ? U(e) : void 0 } var G = /([\+\-]?[0-9#\.]+)(%|px|pt|em|rem|in|cm|mm|ex|ch|pc|vw|vh|vmin|vmax|deg|rad|turn)?$/ function z(e) { var t = G.exec(e) if (t) return t[2] } function j(e) { return c(e, 'translate') || 'perspective' === e ? 'px' : c(e, 'rotate') || c(e, 'skew') ? 'deg' : void 0 } function V(e, t) { return f.fnc(e) ? e(t.target, t.id, t.total) : e } function W(e, t) { return e.getAttribute(t) } function q(e, t, n) { if (C([n, 'deg', 'rad', 'turn'], z(t))) return t var r = s.CSS[t + n] if (!f.und(r)) return r var i = 100, o = document.createElement(e.tagName), a = e.parentNode && e.parentNode !== document ? e.parentNode : document.body a.appendChild(o), (o.style.position = 'absolute'), (o.style.width = i + n) var l = i / o.offsetWidth a.removeChild(o) var c = l * parseFloat(t) return (s.CSS[t + n] = c), c } function X(e, t, n) { if (t in e.style) { var r = t.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase(), i = e.style[t] || getComputedStyle(e).getPropertyValue(r) || '0' return n ? q(e, i, n) : i } } function Y(e, t) { return f.dom(e) && !f.inp(e) && (W(e, t) || (f.svg(e) && e[t])) ? 'attribute' : f.dom(e) && C(a, t) ? 'transform' : f.dom(e) && 'transform' !== t && X(e, t) ? 'css' : null != e[t] ? 'object' : void 0 } var Q = /(\w+)\(([^)]*)\)/g function Z(e) { if (f.dom(e)) { for (var t, n = e.style.transform || '', r = new Map(); (t = Q.exec(n)); ) r.set(t[1], t[2]) return r } } function K(e, t, n, r) { var i = c(t, 'scale') ? 1 : 0 + j(t), o = Z(e).get(t) || i return ( n && (n.transforms.list.set(t, o), (n.transforms.last = t)), r ? q(e, o, r) : o ) } function J(e, t, n, r) { switch (Y(e, t)) { case 'transform': return K(e, t, r, n) case 'css': return X(e, t, n) case 'attribute': return W(e, t) default: return e[t] || 0 } } var $ = /^(\*=|\+=|-=)/ function ee(e, t) { var n = $.exec(e) if (!n) return e var r = z(e) || 0, i = parseFloat(t), o = parseFloat(e.replace(n[0], '')) switch (n[0][0]) { case '+': return i + o + r case '-': return i - o + r case '*': return i * o + r } } var te = /\s/g function ne(e, t) { if (f.col(e)) return H(e) var n = z(e), r = n ? e.substr(0, e.length - n.length) : e return t && !te.test(e) ? r + t : r } function re(e, t) { return Math.sqrt(Math.pow(t.x - e.x, 2) + Math.pow(t.y - e.y, 2)) } function ie(e) { return 2 * Math.PI * W(e, 'r') } function oe(e) { return 2 * W(e, 'width') + 2 * W(e, 'height') } function ae(e) { return re({ x: W(e, 'x1'), y: W(e, 'y1') }, { x: W(e, 'x2'), y: W(e, 'y2') }) } function se(e) { for (var t, n = e.points, r = 0, i = 0; i < n.numberOfItems; i++) { var o = n.getItem(i) i > 0 && (r += re(t, o)), (t = o) } return r } function le(e) { var t = e.points return se(e) + re(t.getItem(t.numberOfItems - 1), t.getItem(0)) } function ce(e) { if (e.getTotalLength) return e.getTotalLength() switch (e.tagName.toLowerCase()) { case 'circle': return ie(e) case 'rect': return oe(e) case 'line': return ae(e) case 'polyline': return se(e) case 'polygon': return le(e) } } function ue(e) { var t = ce(e) return e.setAttribute('stroke-dasharray', t), t } function he(e) { for ( var t = e.parentNode; f.svg(t) && ((t = t.parentNode), f.svg(t.parentNode)); ); return t } function de(e, t) { var n = t || {}, r = n.el || he(e), i = r.getBoundingClientRect(), o = W(r, 'viewBox'), a = i.width, s = i.height, l = n.viewBox || (o ? o.split(' ') : [0, 0, a, s]) return { el: r, viewBox: l, x: l[0] / 1, y: l[1] / 1, w: a / l[2], h: s / l[3] } } function pe(e, t) { var n = f.str(e) ? E(e)[0] : e, r = t || 100 return function (e) { return { property: e, el: n, svg: de(n), totalLength: ce(n) * (r / 100) } } } function fe(e, t) { function n(n) { void 0 === n && (n = 0) var r = t + n >= 1 ? t + n : 0 return e.el.getPointAtLength(r) } var r = de(e.el, e.svg), i = n(), o = n(-1), a = n(1) switch (e.property) { case 'x': return (i.x - r.x) * r.w case 'y': return (i.y - r.y) * r.h case 'angle': return (180 * Math.atan2(a.y - o.y, a.x - o.x)) / Math.PI } } var me = /-?\d*\.?\d+/g function ve(e, t) { var n = ne(f.pth(e) ? e.totalLength : e, t) + '' return { original: n, numbers: n.match(me) ? n.match(me).map(Number) : [0], strings: f.str(e) || t ? n.split(me) : [], } } function ge(e) { return _(e ? T(f.arr(e) ? e.map(S) : S(e)) : [], function (e, t, n) { return n.indexOf(e) === t }) } function ye(e) { var t = ge(e) return t.map(function (e, n) { return { target: e, id: n, total: t.length, transforms: { list: Z(e) } } }) } var be = /^spring/ function Ae(e, t) { var n = L(t) if ((be.test(n.easing) && (n.duration = g(n.easing)), f.arr(e))) { var r = e.length 2 !== r || f.obj(e[0]) ? f.fnc(t.duration) || (n.duration = t.duration / r) : (e = { value: e }) } var i = f.arr(e) ? e : [e] return i .map(function (e, n) { var r = f.obj(e) && !f.pth(e) ? e : { value: e } return ( f.und(r.delay) && (r.delay = n ? 0 : t.delay), f.und(r.endDelay) && (r.endDelay = n === i.length - 1 ? t.endDelay : 0), r ) }) .map(function (e) { return P(e, n) }) } function we(e) { for ( var t = _( T( e.map(function (e) { return Object.keys(e) }), ), function (e) { return f.key(e) }, ).reduce(function (e, t) { return e.indexOf(t) < 0 && e.push(t), e }, []), n = {}, r = function (r) { var i = t[r] n[i] = e.map(function (e) { var t = {} for (var n in e) f.key(n) ? n == i && (t.value = e[n]) : (t[n] = e[n]) return t }) }, i = 0; i < t.length; i++ ) r(i) return n } function xe(e, t) { var n = [], r = t.keyframes for (var i in (r && (t = P(we(r), t)), t)) f.key(i) && n.push({ name: i, tweens: Ae(t[i], e) }) return n } function Ee(e, t) { var n = {} for (var r in e) { var i = V(e[r], t) f.arr(i) && 1 === (i = i.map(function (e) { return V(e, t) })).length && (i = i[0]), (n[r] = i) } return (n.duration = parseFloat(n.duration)), (n.delay = parseFloat(n.delay)), n } function Me(e, t) { var n return e.tweens.map(function (r) { var i = Ee(r, t), o = i.value, a = f.arr(o) ? o[1] : o, s = z(a), l = J(t.target, e.name, s, t), c = n ? n.to.original : l, u = f.arr(o) ? o[0] : c, h = z(u) || z(l), d = s || h return ( f.und(a) && (a = c), (i.from = ve(u, d)), (i.to = ve(ee(a, u), d)), (i.start = n ? n.end : 0), (i.end = i.start + i.delay + i.duration + i.endDelay), (i.easing = x(i.easing, i.duration)), (i.isPath = f.pth(o)), (i.isColor = f.col(i.from.original)), i.isColor && (i.round = 1), (n = i), i ) }) } var _e = { css: function (e, t, n) { return (e.style[t] = n) }, attribute: function (e, t, n) { return e.setAttribute(t, n) }, object: function (e, t, n) { return (e[t] = n) }, transform: function (e, t, n, r, i) { if ((r.list.set(t, n), t === r.last || i)) { var o = '' r.list.forEach(function (e, t) { o += t + '(' + e + ') ' }), (e.style.transform = o) } }, } function Te(e, t) { for (var n = ye(e), r = 0, i = n.length; r < i; r++) { var o = n[r] for (var a in t) { var s = V(t[a], o), l = o.target, c = z(s), u = J(l, a, c, o), h = ee(ne(s, c || z(u)), u), d = Y(l, a) _e[d](l, a, h, o.transforms, !0) } } } function Se(e, t) { var n = Y(e.target, t.name) if (n) { var r = Me(t, e), i = r[r.length - 1] return { type: n, property: t.name, animatable: e, tweens: r, duration: i.end, delay: r[0].delay, endDelay: i.endDelay, } } } function Ce(e, t) { return _( T( e.map(function (e) { return t.map(function (t) { return Se(e, t) }) }), ), function (e) { return !f.und(e) }, ) } function Le(e, t) { var n = e.length, r = function (e) { return e.timelineOffset ? e.timelineOffset : 0 }, i = {} return ( (i.duration = n ? Math.max.apply( Math, e.map(function (e) { return r(e) + e.duration }), ) : t.duration), (i.delay = n ? Math.min.apply( Math, e.map(function (e) { return r(e) + e.delay }), ) : t.delay), (i.endDelay = n ? i.duration - Math.max.apply( Math, e.map(function (e) { return r(e) + e.duration - e.endDelay }), ) : t.endDelay), i ) } var Re = 0 function Pe(e) { var t = R(i, e), n = R(o, e), r = xe(n, e), a = ye(e.targets), s = Ce(a, r), l = Le(s, n), c = Re return ( Re++, P(t, { id: c, children: [], animatables: a, animations: s, duration: l.duration, delay: l.delay, endDelay: l.endDelay, }) ) } var De, Oe = [], Ie = [], Be = (function () { function e() { De = requestAnimationFrame(t) } function t(t) { var n = Oe.length if (n) { for (var r = 0; r < n; ) { var i = Oe[r] if (i.paused) { var o = Oe.indexOf(i) o > -1 && (Oe.splice(o, 1), (n = Oe.length)) } else i.tick(t) r++ } e() } else De = cancelAnimationFrame(De) } return e })() function Fe() { if (document.hidden) { for (var e = 0, t = Oe.length; e < t; e++) activeInstance[e].pause() ;(Ie = Oe.slice(0)), (Oe = []) } else for (var n = 0, r = Ie.length; n < r; n++) Ie[n].play() } function ke(e) { void 0 === e && (e = {}) var t, n = 0, r = 0, i = 0, o = 0, a = null function s() { return ( window.Promise && new Promise(function (e) { return (a = e) }) ) } var c = s(), u = Pe(e) function h() { u.reversed = !u.reversed for (var e = 0, n = t.length; e < n; e++) t[e].reversed = u.reversed } function d(e) { return u.reversed ? u.duration - e : e } function p() { ;(n = 0), (r = d(u.currentTime) * (1 / ke.speed)) } function f(e, t) { t && t.seek(e - t.timelineOffset) } function m(e) { if (u.reversePlayback) for (var n = o; n--; ) f(e, t[n]) else for (var r = 0; r < o; r++) f(e, t[r]) } function v(e) { for (var t = 0, n = u.animations, r = n.length; t < r; ) { var i = n[t], o = i.animatable, a = i.tweens, s = a.length - 1, c = a[s] s && (c = _(a, function (t) { return e < t.end })[0] || c) for ( var h = l(e - c.start - c.delay, 0, c.duration) / c.duration, d = isNaN(h) ? 1 : c.easing(h), p = c.to.strings, f = c.round, m = [], v = c.to.numbers.length, g = void 0, y = 0; y < v; y++ ) { var b = void 0, A = c.to.numbers[y], w = c.from.numbers[y] || 0 ;(b = c.isPath ? fe(c.value, d * A) : w + d * (A - w)), f && ((c.isColor && y > 2) || (b = Math.round(b * f) / f)), m.push(b) } var x = p.length if (x) { g = p[0] for (var E = 0; E < x; E++) { p[E] var M = p[E + 1], T = m[E] isNaN(T) || (g += M ? T + M : T + ' ') } } else g = m[0] _e[i.type](o.target, i.property, g, o.transforms), (i.currentValue = g), t++ } } function g(e) { u[e] && !u.passThrough && u[e](u) } function y() { u.remaining && !0 !== u.remaining && u.remaining-- } function b(e) { var o = u.duration, p = u.delay, f = o - u.endDelay, b = d(e) ;(u.progress = l((b / o) * 100, 0, 100)), (u.reversePlayback = b < u.currentTime), t && m(b), !u.began && u.currentTime > 0 && ((u.began = !0), g('begin'), g('loopBegin')), b <= p && 0 !== u.currentTime && v(0), ((b >= f && u.currentTime !== o) || !o) && v(o), b > p && b < f ? (u.changeBegan || ((u.changeBegan = !0), (u.changeCompleted = !1), g('changeBegin')), g('change'), v(b)) : u.changeBegan && ((u.changeCompleted = !0), (u.changeBegan = !1), g('changeComplete')), (u.currentTime = l(b, 0, o)), u.began && g('update'), e >= o && ((r = 0), y(), u.remaining ? ((n = i), g('loopComplete'), g('loopBegin'), 'alternate' === u.direction && h()) : ((u.paused = !0), u.completed || ((u.completed = !0), g('loopComplete'), g('complete'), 'Promise' in window && (a(), (c = s()))))) } return ( (u.reset = function () { var e = u.direction ;(u.passThrough = !1), (u.currentTime = 0), (u.progress = 0), (u.paused = !0), (u.began = !1), (u.changeBegan = !1), (u.completed = !1), (u.changeCompleted = !1), (u.reversePlayback = !1), (u.reversed = 'reverse' === e), (u.remaining = u.loop), (t = u.children) for (var n = (o = t.length); n--; ) u.children[n].reset() ;((u.reversed && !0 !== u.loop) || ('alternate' === e && 1 === u.loop)) && u.remaining++, v(0) }), (u.set = function (e, t) { return Te(e, t), u }), (u.tick = function (e) { ;(i = e), n || (n = i), b((i + (r - n)) * ke.speed) }), (u.seek = function (e) { b(d(e)) }), (u.pause = function () { ;(u.paused = !0), p() }), (u.play = function () { u.paused && ((u.paused = !1), Oe.push(u), p(), De || Be()) }), (u.reverse = function () { h(), p() }), (u.restart = function () { u.reset(), u.play() }), (u.finished = c), u.reset(), u.autoplay && u.play(), u ) } function Ne(e, t) { for (var n = t.length; n--; ) C(e, t[n].animatable.target) && t.splice(n, 1) } function Ue(e) { for (var t = ge(e), n = Oe.length; n--; ) { var r = Oe[n], i = r.animations, o = r.children Ne(t, i) for (var a = o.length; a--; ) { var s = o[a], l = s.animations Ne(t, l), l.length || s.children.length || o.splice(a, 1) } i.length || o.length || r.pause() } } function He(e, t) { void 0 === t && (t = {}) var n = t.direction || 'normal', r = t.easing ? x(t.easing) : null, i = t.grid, o = t.axis, a = t.from || 0, s = 'first' === a, l = 'center' === a, c = 'last' === a, u = f.arr(e), h = u ? parseFloat(e[0]) : parseFloat(e), d = u ? parseFloat(e[1]) : 0, p = z(u ? e[1] : e) || 0, m = t.start || 0 + (u ? h : 0), v = [], g = 0 return function (e, t, f) { if ((s && (a = 0), l && (a = (f - 1) / 2), c && (a = f - 1), !v.length)) { for (var y = 0; y < f; y++) { if (i) { var b = l ? (i[0] - 1) / 2 : a % i[0], A = l ? (i[1] - 1) / 2 : Math.floor(a / i[0]), w = b - (y % i[0]), x = A - Math.floor(y / i[0]), E = Math.sqrt(w * w + x * x) 'x' === o && (E = -w), 'y' === o && (E = -x), v.push(E) } else v.push(Math.abs(a - y)) g = Math.max.apply(Math, v) } r && (v = v.map(function (e) { return r(e / g) * g })), 'reverse' === n && (v = v.map(function (e) { return o ? (e < 0 ? -1 * e : -e) : Math.abs(g - e) })) } return m + (u ? (d - h) / g : h) * (Math.round(100 * v[t]) / 100) + p } } function Ge(e) { void 0 === e && (e = {}) var t = ke(e) return ( (t.duration = 0), (t.add = function (n, r) { var i = Oe.indexOf(t), a = t.children function s(e) { e.passThrough = !0 } i > -1 && Oe.splice(i, 1) for (var l = 0; l < a.length; l++) s(a[l]) var c = P(n, R(o, e)) c.targets = c.targets || e.targets var u = t.duration ;(c.autoplay = !1), (c.direction = t.direction), (c.timelineOffset = f.und(r) ? u : ee(r, u)), s(t), t.seek(c.timelineOffset) var h = ke(c) s(h), a.push(h) var d = Le(a, e) return ( (t.delay = d.delay), (t.endDelay = d.endDelay), (t.duration = d.duration), t.seek(0), t.reset(), t.autoplay && t.play(), t ) }), t ) } document.addEventListener('visibilitychange', Fe), (ke.version = '3.0.0'), (ke.speed = 1), (ke.running = Oe), (ke.remove = Ue), (ke.get = J), (ke.set = Te), (ke.convertPx = q), (ke.path = pe), (ke.setDashoffset = ue), (ke.stagger = He), (ke.timeline = Ge), (ke.easing = x), (ke.penner = w), (ke.random = function (e, t) { return Math.floor(Math.random() * (t - e + 1)) + e }), (n.exports = ke) }, {}, ], 57: [ function (n, r, i) { var o, a ;(o = this), (a = function (t) { 'use strict' void 0 === Number.EPSILON && (Number.EPSILON = Math.pow(2, -52)), void 0 === Number.isInteger && (Number.isInteger = function (e) { return 'number' === typeof e && isFinite(e) && Math.floor(e) === e }), void 0 === Math.sign && (Math.sign = function (e) { return e < 0 ? -1 : e > 0 ? 1 : +e }), '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 (e) { if (void 0 === e || null === e) throw new TypeError('Cannot convert undefined or null to object') for (var t = Object(e), n = 1; n < arguments.length; n++) { var r = arguments[n] if (void 0 !== r && null !== r) for (var i in r) Object.prototype.hasOwnProperty.call(r, i) && (t[i] = r[i]) } return t }) var n = (function (e) { var t, n = Object.prototype, r = n.hasOwnProperty, i = 'function' === typeof Symbol ? Symbol : {}, o = i.iterator || '@@iterator', a = i.asyncIterator || '@@asyncIterator', s = i.toStringTag || '@@toStringTag' function l(e, t, n) { return ( Object.defineProperty(e, t, { value: n, enumerable: !0, configurable: !0, writable: !0, }), e[t] ) } try { l({}, '') } catch (D) { l = function (e, t, n) { return (e[t] = n) } } function c(e, t, n, r) { var i = t && t.prototype instanceof v ? t : v, o = Object.create(i.prototype), a = new L(r || []) return (o._invoke = _(e, n, a)), o } function u(e, t, n) { try { return { type: 'normal', arg: e.call(t, n) } } catch (D) { return { type: 'throw', arg: D } } } e.wrap = c var h = 'suspendedStart', d = 'suspendedYield', p = 'executing', f = 'completed', m = {} function v() {} function g() {} function y() {} var b = {} b[o] = function () { return this } var A = Object.getPrototypeOf, w = A && A(A(R([]))) w && w !== n && r.call(w, o) && (b = w) var x = (y.prototype = v.prototype = Object.create(b)) function E(e) { ;['next', 'throw', 'return'].forEach(function (t) { l(e, t, function (e) { return this._invoke(t, e) }) }) } function M(e, t) { function n(i, o, a, s) { var l = u(e[i], e, o) if ('throw' !== l.type) { var c = l.arg, h = c.value return h && 'object' === typeof h && r.call(h, '__await') ? t.resolve(h.__await).then( function (e) { n('next', e, a, s) }, function (e) { n('throw', e, a, s) }, ) : t.resolve(h).then( function (e) { ;(c.value = e), a(c) }, function (e) { return n('throw', e, a, s) }, ) } s(l.arg) } var i function o(e, r) { function o() { return new t(function (t, i) { n(e, r, t, i) }) } return (i = i ? i.then(o, o) : o()) } this._invoke = o } function _(e, t, n) { var r = h return function (i, o) { if (r === p) throw new Error('Generator is already running') if (r === f) { if ('throw' === i) throw o return P() } for (n.method = i, n.arg = o; ; ) { var a = n.delegate if (a) { var s = T(a, n) if (s) { if (s === m) continue return s } } if ('next' === n.method) n.sent = n._sent = n.arg else if ('throw' === n.method) { if (r === h) throw ((r = f), n.arg) n.dispatchException(n.arg) } else 'return' === n.method && n.abrupt('return', n.arg) r = p var l = u(e, t, n) if ('normal' === l.type) { if (((r = n.done ? f : d), l.arg === m)) continue return { value: l.arg, done: n.done } } 'throw' === l.type && ((r = f), (n.method = 'throw'), (n.arg = l.arg)) } } } function T(e, n) { var r = e.iterator[n.method] if (r === t) { if (((n.delegate = null), 'throw' === n.method)) { if ( e.iterator.return && ((n.method = 'return'), (n.arg = t), T(e, n), 'throw' === n.method) ) return m ;(n.method = 'throw'), (n.arg = new TypeError( "The iterator does not provide a 'throw' method", )) } return m } var i = u(r, e.iterator, n.arg) if ('throw' === i.type) return (n.method = 'throw'), (n.arg = i.arg), (n.delegate = null), m var o = i.arg return o ? o.done ? ((n[e.resultName] = o.value), (n.next = e.nextLoc), 'return' !== n.method && ((n.method = 'next'), (n.arg = t)), (n.delegate = null), m) : o : ((n.method = 'throw'), (n.arg = new TypeError('iterator result is not an object')), (n.delegate = null), m) } function S(e) { var t = { tryLoc: e[0] } 1 in e && (t.catchLoc = e[1]), 2 in e && ((t.finallyLoc = e[2]), (t.afterLoc = e[3])), this.tryEntries.push(t) } function C(e) { var t = e.completion || {} ;(t.type = 'normal'), delete t.arg, (e.completion = t) } function L(e) { ;(this.tryEntries = [{ tryLoc: 'root' }]), e.forEach(S, this), this.reset(!0) } function R(e) { if (e) { var n = e[o] if (n) return n.call(e) if ('function' === typeof e.next) return e if (!isNaN(e.length)) { var i = -1, a = function n() { for (; ++i < e.length; ) if (r.call(e, i)) return (n.value = e[i]), (n.done = !1), n return (n.value = t), (n.done = !0), n } return (a.next = a) } } return { next: P } } function P() { return { value: t, done: !0 } } return ( (g.prototype = x.constructor = y), (y.constructor = g), (g.displayName = l(y, s, 'GeneratorFunction')), (e.isGeneratorFunction = function (e) { var t = 'function' === typeof e && e.constructor return ( !!t && (t === g || 'GeneratorFunction' === (t.displayName || t.name)) ) }), (e.mark = function (e) { return ( Object.setPrototypeOf ? Object.setPrototypeOf(e, y) : ((e.__proto__ = y), l(e, s, 'GeneratorFunction')), (e.prototype = Object.create(x)), e ) }), (e.awrap = function (e) { return { __await: e } }), E(M.prototype), (M.prototype[a] = function () { return this }), (e.AsyncIterator = M), (e.async = function (t, n, r, i, o) { void 0 === o && (o = Promise) var a = new M(c(t, n, r, i), o) return e.isGeneratorFunction(n) ? a : a.next().then(function (e) { return e.done ? e.value : a.next() }) }), E(x), l(x, s, 'Generator'), (x[o] = function () { return this }), (x.toString = function () { return '[object Generator]' }), (e.keys = function (e) { var t = [] for (var n in e) t.push(n) return ( t.reverse(), function n() { for (; t.length; ) { var r = t.pop() if (r in e) return (n.value = r), (n.done = !1), n } return (n.done = !0), n } ) }), (e.values = R), (L.prototype = { constructor: L, reset: function (e) { if ( ((this.prev = 0), (this.next = 0), (this.sent = this._sent = t), (this.done = !1), (this.delegate = null), (this.method = 'next'), (this.arg = t), this.tryEntries.forEach(C), !e) ) for (var n in this) 't' === n.charAt(0) && r.call(this, n) && !isNaN(+n.slice(1)) && (this[n] = t) }, stop: function () { this.done = !0 var e = this.tryEntries[0].completion if ('throw' === e.type) throw e.arg return this.rval }, dispatchException: function (e) { if (this.done) throw e var n = this function i(r, i) { return ( (s.type = 'throw'), (s.arg = e), (n.next = r), i && ((n.method = 'next'), (n.arg = t)), !!i ) } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var a = this.tryEntries[o], s = a.completion if ('root' === a.tryLoc) return i('end') if (a.tryLoc <= this.prev) { var l = r.call(a, 'catchLoc'), c = r.call(a, 'finallyLoc') if (l && c) { if (this.prev < a.catchLoc) return i(a.catchLoc, !0) if (this.prev < a.finallyLoc) return i(a.finallyLoc) } else if (l) { if (this.prev < a.catchLoc) return i(a.catchLoc, !0) } else { if (!c) throw new Error('try statement without catch or finally') if (this.prev < a.finallyLoc) return i(a.finallyLoc) } } } }, abrupt: function (e, t) { for (var n = this.tryEntries.length - 1; n >= 0; --n) { var i = this.tryEntries[n] if ( i.tryLoc <= this.prev && r.call(i, 'finallyLoc') && this.prev < i.finallyLoc ) { var o = i break } } o && ('break' === e || 'continue' === e) && o.tryLoc <= t && t <= o.finallyLoc && (o = null) var a = o ? o.completion : {} return ( (a.type = e), (a.arg = t), o ? ((this.method = 'next'), (this.next = o.finallyLoc), m) : this.complete(a) ) }, complete: function (e, t) { if ('throw' === e.type) throw e.arg return ( 'break' === e.type || 'continue' === e.type ? (this.next = e.arg) : 'return' === e.type ? ((this.rval = this.arg = e.arg), (this.method = 'return'), (this.next = 'end')) : 'normal' === e.type && t && (this.next = t), m ) }, finish: function (e) { for (var t = this.tryEntries.length - 1; t >= 0; --t) { var n = this.tryEntries[t] if (n.finallyLoc === e) return this.complete(n.completion, n.afterLoc), C(n), m } }, catch: function (e) { for (var t = this.tryEntries.length - 1; t >= 0; --t) { var n = this.tryEntries[t] if (n.tryLoc === e) { var r = n.completion if ('throw' === r.type) { var i = r.arg C(n) } return i } } throw new Error('illegal catch attempt') }, delegateYield: function (e, n, r) { return ( (this.delegate = { iterator: R(e), resultName: n, nextLoc: r }), 'next' === this.method && (this.arg = t), m ) }, }), e ) })('object' === typeof r ? r.exports : {}) try { regeneratorRuntime = n } catch (ym) { Function('r', 'regeneratorRuntime = r')(n) } var i = '125', o = { LEFT: 0, MIDDLE: 1, RIGHT: 2, ROTATE: 0, DOLLY: 1, PAN: 2 }, a = { ROTATE: 0, PAN: 1, DOLLY_PAN: 2, DOLLY_ROTATE: 3 }, s = 0, l = 1, c = 2, u = 3, h = 0, d = 1, p = 2, f = 3, m = 0, v = 1, g = 2, y = 1, b = 2, A = 0, w = 1, x = 2, E = 3, M = 4, _ = 5, T = 100, S = 101, C = 102, L = 103, R = 104, P = 200, D = 201, O = 202, I = 203, B = 204, F = 205, k = 206, N = 207, U = 208, H = 209, G = 210, z = 0, j = 1, V = 2, W = 3, q = 4, X = 5, Y = 6, Q = 7, Z = 0, K = 1, J = 2, $ = 0, ee = 1, te = 2, ne = 3, re = 4, ie = 5, oe = 300, ae = 301, se = 302, le = 303, ce = 304, ue = 306, he = 307, de = 1e3, pe = 1001, fe = 1002, me = 1003, ve = 1004, ge = 1004, ye = 1005, be = 1005, Ae = 1006, we = 1007, xe = 1007, Ee = 1008, Me = 1008, _e = 1009, Te = 1010, Se = 1011, Ce = 1012, Le = 1013, Re = 1014, Pe = 1015, De = 1016, Oe = 1017, Ie = 1018, Be = 1019, Fe = 1020, ke = 1021, Ne = 1022, Ue = 1023, He = 1024, Ge = 1025, ze = Ue, je = 1026, Ve = 1027, We = 1028, qe = 1029, Xe = 1030, Ye = 1031, Qe = 1032, Ze = 1033, Ke = 33776, Je = 33777, $e = 33778, et = 33779, tt = 35840, nt = 35841, rt = 35842, it = 35843, ot = 36196, at = 37492, st = 37496, lt = 37808, ct = 37809, ut = 37810, ht = 37811, dt = 37812, pt = 37813, ft = 37814, mt = 37815, vt = 37816, gt = 37817, yt = 37818, bt = 37819, At = 37820, wt = 37821, xt = 36492, Et = 37840, Mt = 37841, _t = 37842, Tt = 37843, St = 37844, Ct = 37845, Lt = 37846, Rt = 37847, Pt = 37848, Dt = 37849, Ot = 37850, It = 37851, Bt = 37852, Ft = 37853, kt = 2200, Nt = 2201, Ut = 2202, Ht = 2300, Gt = 2301, zt = 2302, jt = 2400, Vt = 2401, Wt = 2402, qt = 2500, Xt = 2501, Yt = 0, Qt = 1, Zt = 2, Kt = 3e3, Jt = 3001, $t = 3007, en = 3002, tn = 3003, nn = 3004, rn = 3005, on = 3006, an = 3200, sn = 3201, ln = 0, cn = 1, un = 0, hn = 7680, dn = 7681, pn = 7682, fn = 7683, mn = 34055, vn = 34056, gn = 5386, yn = 512, bn = 513, An = 514, wn = 515, xn = 516, En = 517, Mn = 518, _n = 519, Tn = 35044, Sn = 35048, Cn = 35040, Ln = 35045, Rn = 35049, Pn = 35041, Dn = 35046, On = 35050, In = 35042, Bn = '100', Fn = '300 es' function kn(e, t, n, r, i, o, a) { try { var s = e[o](a), l = s.value } catch (c) { return void n(c) } s.done ? t(l) : Promise.resolve(l).then(r, i) } function Nn(e) { return function () { var t = this, n = arguments return new Promise(function (r, i) { var o = e.apply(t, n) function a(e) { kn(o, r, i, a, s, 'next', e) } function s(e) { kn(o, r, i, a, s, 'throw', e) } a(void 0) }) } } function Un(e, t) { for (var n = 0; n < t.length; n++) { var r = t[n] ;(r.enumerable = r.enumerable || !1), (r.configurable = !0), 'value' in r && (r.writable = !0), Object.defineProperty(e, r.key, r) } } function Hn(e, t, n) { return t && Un(e.prototype, t), n && Un(e, n), e } function Gn(e, t) { ;(e.prototype = Object.create(t.prototype)), (e.prototype.constructor = e), (e.__proto__ = t) } function zn(e) { if (void 0 === e) throw new ReferenceError( "this hasn't been initialised - super() hasn't been called", ) return e } function jn(e, t) { if (e) { if ('string' === typeof e) return Vn(e, t) var n = Object.prototype.toString.call(e).slice(8, -1) return ( 'Object' === n && e.constructor && (n = e.constructor.name), 'Map' === n || 'Set' === n ? Array.from(e) : 'Arguments' === n || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n) ? Vn(e, t) : void 0 ) } } function Vn(e, t) { ;(null == t || t > e.length) && (t = e.length) for (var n = 0, r = new Array(t); n < t; n++) r[n] = e[n] return r } function Wn(e, t) { var n if ('undefined' === typeof Symbol || null == e[Symbol.iterator]) { if ( Array.isArray(e) || (n = jn(e)) || (t && e && 'number' === typeof e.length) ) { n && (e = n) var r = 0 return function () { return r >= e.length ? { done: !0 } : { done: !1, value: e[r++] } } } throw new TypeError( 'Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.', ) } return (n = e[Symbol.iterator]()).next.bind(n) } function qn() {} Object.assign(qn.prototype, { addEventListener: function (e, t) { void 0 === this._listeners && (this._listeners = {}) var n = this._listeners void 0 === n[e] && (n[e] = []), -1 === n[e].indexOf(t) && n[e].push(t) }, hasEventListener: function (e, t) { if (void 0 === this._listeners) return !1 var n = this._listeners return void 0 !== n[e] && -1 !== n[e].indexOf(t) }, removeEventListener: function (e, t) { if (void 0 !== this._listeners) { var n = this._listeners[e] if (void 0 !== n) { var r = n.indexOf(t) ;-1 !== r && n.splice(r, 1) } } }, dispatchEvent: function (e) { if (void 0 !== this._listeners) { var t = this._listeners[e.type] if (void 0 !== t) { e.target = this for (var n = t.slice(0), r = 0, i = n.length; r < i; r++) n[r].call(this, e) } } }, }) for (var Xn = [], Yn = 0; Yn < 256; Yn++) Xn[Yn] = (Yn < 16 ? '0' : '') + Yn.toString(16) var Qn, Zn = 1234567, Kn = { DEG2RAD: Math.PI / 180, RAD2DEG: 180 / Math.PI, generateUUID: function () { var e = (4294967295 * Math.random()) | 0, t = (4294967295 * Math.random()) | 0, n = (4294967295 * Math.random()) | 0, r = (4294967295 * Math.random()) | 0 return ( Xn[255 & e] + Xn[(e >> 8) & 255] + Xn[(e >> 16) & 255] + Xn[(e >> 24) & 255] + '-' + Xn[255 & t] + Xn[(t >> 8) & 255] + '-' + Xn[((t >> 16) & 15) | 64] + Xn[(t >> 24) & 255] + '-' + Xn[(63 & n) | 128] + Xn[(n >> 8) & 255] + '-' + Xn[(n >> 16) & 255] + Xn[(n >> 24) & 255] + Xn[255 & r] + Xn[(r >> 8) & 255] + Xn[(r >> 16) & 255] + Xn[(r >> 24) & 255] ).toUpperCase() }, clamp: function (e, t, n) { return Math.max(t, Math.min(n, e)) }, euclideanModulo: function (e, t) { return ((e % t) + t) % t }, mapLinear: function (e, t, n, r, i) { return r + ((e - t) * (i - r)) / (n - t) }, lerp: function (e, t, n) { return (1 - n) * e + n * t }, damp: function (e, t, n, r) { return Kn.lerp(e, t, 1 - Math.exp(-n * r)) }, pingpong: function (e, t) { return ( void 0 === t && (t = 1), t - Math.abs(Kn.euclideanModulo(e, 2 * t) - t) ) }, smoothstep: function (e, t, n) { return e <= t ? 0 : e >= n ? 1 : (e = (e - t) / (n - t)) * e * (3 - 2 * e) }, smootherstep: function (e, t, n) { return e <= t ? 0 : e >= n ? 1 : (e = (e - t) / (n - t)) * e * e * (e * (6 * e - 15) + 10) }, randInt: function (e, t) { return e + Math.floor(Math.random() * (t - e + 1)) }, randFloat: function (e, t) { return e + Math.random() * (t - e) }, randFloatSpread: function (e) { return e * (0.5 - Math.random()) }, seededRandom: function (e) { return ( void 0 !== e && (Zn = e % 2147483647), ((Zn = (16807 * Zn) % 2147483647) - 1) / 2147483646 ) }, degToRad: function (e) { return e * Kn.DEG2RAD }, radToDeg: function (e) { return e * Kn.RAD2DEG }, isPowerOfTwo: function (e) { return 0 === (e & (e - 1)) && 0 !== e }, ceilPowerOfTwo: function (e) { return Math.pow(2, Math.ceil(Math.log(e) / Math.LN2)) }, floorPowerOfTwo: function (e) { return Math.pow(2, Math.floor(Math.log(e) / Math.LN2)) }, setQuaternionFromProperEuler: function (e, t, n, r, i) { var o = Math.cos, a = Math.sin, s = o(n / 2), l = a(n / 2), c = o((t + r) / 2), u = a((t + r) / 2), h = o((t - r) / 2), d = a((t - r) / 2), p = o((r - t) / 2), f = a((r - t) / 2) switch (i) { case 'XYX': e.set(s * u, l * h, l * d, s * c) break case 'YZY': e.set(l * d, s * u, l * h, s * c) break case 'ZXZ': e.set(l * h, l * d, s * u, s * c) break case 'XZX': e.set(s * u, l * f, l * p, s * c) break case 'YXY': e.set(l * p, s * u, l * f, s * c) break case 'ZYZ': e.set(l * f, l * p, s * u, s * c) break default: console.warn( 'THREE.MathUtils: .setQuaternionFromProperEuler() encountered an unknown order: ' + i, ) } }, }, Jn = (function () { function e(e, t) { void 0 === e && (e = 0), void 0 === t && (t = 0), Object.defineProperty(this, 'isVector2', { value: !0 }), (this.x = e), (this.y = t) } var t = e.prototype return ( (t.set = function (e, t) { return (this.x = e), (this.y = t), this }), (t.setScalar = function (e) { return (this.x = e), (this.y = e), this }), (t.setX = function (e) { return (this.x = e), this }), (t.setY = function (e) { return (this.y = e), this }), (t.setComponent = function (e, t) { switch (e) { case 0: this.x = t break case 1: this.y = t break default: throw new Error('index is out of range: ' + e) } return this }), (t.getComponent = function (e) { switch (e) { case 0: return this.x case 1: return this.y default: throw new Error('index is out of range: ' + e) } }), (t.clone = function () { return new this.constructor(this.x, this.y) }), (t.copy = function (e) { return (this.x = e.x), (this.y = e.y), this }), (t.add = function (e, t) { return void 0 !== t ? (console.warn( 'THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead.', ), this.addVectors(e, t)) : ((this.x += e.x), (this.y += e.y), this) }), (t.addScalar = function (e) { return (this.x += e), (this.y += e), this }), (t.addVectors = function (e, t) { return (this.x = e.x + t.x), (this.y = e.y + t.y), this }), (t.addScaledVector = function (e, t) { return (this.x += e.x * t), (this.y += e.y * t), this }), (t.sub = function (e, t) { return void 0 !== t ? (console.warn( 'THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.', ), this.subVectors(e, t)) : ((this.x -= e.x), (this.y -= e.y), this) }), (t.subScalar = function (e) { return (this.x -= e), (this.y -= e), this }), (t.subVectors = function (e, t) { return (this.x = e.x - t.x), (this.y = e.y - t.y), this }), (t.multiply = function (e) { return (this.x *= e.x), (this.y *= e.y), this }), (t.multiplyScalar = function (e) { return (this.x *= e), (this.y *= e), this }), (t.divide = function (e) { return (this.x /= e.x), (this.y /= e.y), this }), (t.divideScalar = function (e) { return this.multiplyScalar(1 / e) }), (t.applyMatrix3 = function (e) { var t = this.x, n = this.y, r = e.elements return ( (this.x = r[0] * t + r[3] * n + r[6]), (this.y = r[1] * t + r[4] * n + r[7]), this ) }), (t.min = function (e) { return ( (this.x = Math.min(this.x, e.x)), (this.y = Math.min(this.y, e.y)), this ) }), (t.max = function (e) { return ( (this.x = Math.max(this.x, e.x)), (this.y = Math.max(this.y, e.y)), this ) }), (t.clamp = function (e, t) { return ( (this.x = Math.max(e.x, Math.min(t.x, this.x))), (this.y = Math.max(e.y, Math.min(t.y, this.y))), this ) }), (t.clampScalar = function (e, t) { return ( (this.x = Math.max(e, Math.min(t, this.x))), (this.y = Math.max(e, Math.min(t, this.y))), this ) }), (t.clampLength = function (e, t) { var n = this.length() return this.divideScalar(n || 1).multiplyScalar( Math.max(e, Math.min(t, n)), ) }), (t.floor = function () { return ( (this.x = Math.floor(this.x)), (this.y = Math.floor(this.y)), this ) }), (t.ceil = function () { return (this.x = Math.ceil(this.x)), (this.y = Math.ceil(this.y)), this }), (t.round = function () { return ( (this.x = Math.round(this.x)), (this.y = Math.round(this.y)), this ) }), (t.roundToZero = function () { return ( (this.x = this.x < 0 ? Math.ceil(this.x) : Math.floor(this.x)), (this.y = this.y < 0 ? Math.ceil(this.y) : Math.floor(this.y)), this ) }), (t.negate = function () { return (this.x = -this.x), (this.y = -this.y), this }), (t.dot = function (e) { return this.x * e.x + this.y * e.y }), (t.cross = function (e) { return this.x * e.y - this.y * e.x }), (t.lengthSq = function () { return this.x * this.x + this.y * this.y }), (t.length = function () { return Math.sqrt(this.x * this.x + this.y * this.y) }), (t.manhattanLength = function () { return Math.abs(this.x) + Math.abs(this.y) }), (t.normalize = function () { return this.divideScalar(this.length() || 1) }), (t.angle = function () { var e = Math.atan2(-this.y, -this.x) + Math.PI return e }), (t.distanceTo = function (e) { return Math.sqrt(this.distanceToSquared(e)) }), (t.distanceToSquared = function (e) { var t = this.x - e.x, n = this.y - e.y return t * t + n * n }), (t.manhattanDistanceTo = function (e) { return Math.abs(this.x - e.x) + Math.abs(this.y - e.y) }), (t.setLength = function (e) { return this.normalize().multiplyScalar(e) }), (t.lerp = function (e, t) { return ( (this.x += (e.x - this.x) * t), (this.y += (e.y - this.y) * t), this ) }), (t.lerpVectors = function (e, t, n) { return ( (this.x = e.x + (t.x - e.x) * n), (this.y = e.y + (t.y - e.y) * n), this ) }), (t.equals = function (e) { return e.x === this.x && e.y === this.y }), (t.fromArray = function (e, t) { return ( void 0 === t && (t = 0), (this.x = e[t]), (this.y = e[t + 1]), this ) }), (t.toArray = function (e, t) { return ( void 0 === e && (e = []), void 0 === t && (t = 0), (e[t] = this.x), (e[t + 1] = this.y), e ) }), (t.fromBufferAttribute = function (e, t, n) { return ( void 0 !== n && console.warn( 'THREE.Vector2: offset has been removed from .fromBufferAttribute().', ), (this.x = e.getX(t)), (this.y = e.getY(t)), this ) }), (t.rotateAround = function (e, t) { var n = Math.cos(t), r = Math.sin(t), i = this.x - e.x, o = this.y - e.y return ( (this.x = i * n - o * r + e.x), (this.y = i * r + o * n + e.y), this ) }), (t.random = function () { return (this.x = Math.random()), (this.y = Math.random()), this }), Hn(e, [ { key: 'width', get: function () { return this.x }, set: function (e) { this.x = e }, }, { key: 'height', get: function () { return this.y }, set: function (e) { this.y = e }, }, ]), e ) })(), $n = (function () { function e() { Object.defineProperty(this, 'isMatrix3', { value: !0 }), (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.', ) } var t = e.prototype return ( (t.set = function (e, t, n, r, i, o, a, s, l) { var c = this.elements return ( (c[0] = e), (c[1] = r), (c[2] = a), (c[3] = t), (c[4] = i), (c[5] = s), (c[6] = n), (c[7] = o), (c[8] = l), this ) }), (t.identity = function () { return this.set(1, 0, 0, 0, 1, 0, 0, 0, 1), this }), (t.clone = function () { return new this.constructor().fromArray(this.elements) }), (t.copy = function (e) { var t = this.elements, n = e.elements return ( (t[0] = n[0]), (t[1] = n[1]), (t[2] = n[2]), (t[3] = n[3]), (t[4] = n[4]), (t[5] = n[5]), (t[6] = n[6]), (t[7] = n[7]), (t[8] = n[8]), this ) }), (t.extractBasis = function (e, t, n) { return ( e.setFromMatrix3Column(this, 0), t.setFromMatrix3Column(this, 1), n.setFromMatrix3Column(this, 2), this ) }), (t.setFromMatrix4 = function (e) { var t = e.elements return ( this.set(t[0], t[4], t[8], t[1], t[5], t[9], t[2], t[6], t[10]), this ) }), (t.multiply = function (e) { return this.multiplyMatrices(this, e) }), (t.premultiply = function (e) { return this.multiplyMatrices(e, this) }), (t.multiplyMatrices = function (e, t) { var n = e.elements, r = t.elements, i = this.elements, o = n[0], a = n[3], s = n[6], l = n[1], c = n[4], u = n[7], h = n[2], d = n[5], p = n[8], f = r[0], m = r[3], v = r[6], g = r[1], y = r[4], b = r[7], A = r[2], w = r[5], x = r[8] return ( (i[0] = o * f + a * g + s * A), (i[3] = o * m + a * y + s * w), (i[6] = o * v + a * b + s * x), (i[1] = l * f + c * g + u * A), (i[4] = l * m + c * y + u * w), (i[7] = l * v + c * b + u * x), (i[2] = h * f + d * g + p * A), (i[5] = h * m + d * y + p * w), (i[8] = h * v + d * b + p * x), this ) }), (t.multiplyScalar = function (e) { var t = this.elements return ( (t[0] *= e), (t[3] *= e), (t[6] *= e), (t[1] *= e), (t[4] *= e), (t[7] *= e), (t[2] *= e), (t[5] *= e), (t[8] *= e), this ) }), (t.determinant = function () { var e = this.elements, t = e[0], n = e[1], r = e[2], i = e[3], o = e[4], a = e[5], s = e[6], l = e[7], c = e[8] return ( t * o * c - t * a * l - n * i * c + n * a * s + r * i * l - r * o * s ) }), (t.invert = function () { var e = this.elements, t = e[0], n = e[1], r = e[2], i = e[3], o = e[4], a = e[5], s = e[6], l = e[7], c = e[8], u = c * o - a * l, h = a * s - c * i, d = l * i - o * s, p = t * u + n * h + r * d if (0 === p) return this.set(0, 0, 0, 0, 0, 0, 0, 0, 0) var f = 1 / p return ( (e[0] = u * f), (e[1] = (r * l - c * n) * f), (e[2] = (a * n - r * o) * f), (e[3] = h * f), (e[4] = (c * t - r * s) * f), (e[5] = (r * i - a * t) * f), (e[6] = d * f), (e[7] = (n * s - l * t) * f), (e[8] = (o * t - n * i) * f), this ) }), (t.transpose = function () { var e, t = this.elements return ( (e = t[1]), (t[1] = t[3]), (t[3] = e), (e = t[2]), (t[2] = t[6]), (t[6] = e), (e = t[5]), (t[5] = t[7]), (t[7] = e), this ) }), (t.getNormalMatrix = function (e) { return this.setFromMatrix4(e).copy(this).invert().transpose() }), (t.transposeIntoArray = function (e) { var t = this.elements return ( (e[0] = t[0]), (e[1] = t[3]), (e[2] = t[6]), (e[3] = t[1]), (e[4] = t[4]), (e[5] = t[7]), (e[6] = t[2]), (e[7] = t[5]), (e[8] = t[8]), this ) }), (t.setUvTransform = function (e, t, n, r, i, o, a) { var s = Math.cos(i), l = Math.sin(i) return ( this.set( n * s, n * l, -n * (s * o + l * a) + o + e, -r * l, r * s, -r * (-l * o + s * a) + a + t, 0, 0, 1, ), this ) }), (t.scale = function (e, t) { var n = this.elements return ( (n[0] *= e), (n[3] *= e), (n[6] *= e), (n[1] *= t), (n[4] *= t), (n[7] *= t), this ) }), (t.rotate = function (e) { var t = Math.cos(e), n = Math.sin(e), r = this.elements, i = r[0], o = r[3], a = r[6], s = r[1], l = r[4], c = r[7] return ( (r[0] = t * i + n * s), (r[3] = t * o + n * l), (r[6] = t * a + n * c), (r[1] = -n * i + t * s), (r[4] = -n * o + t * l), (r[7] = -n * a + t * c), this ) }), (t.translate = function (e, t) { var n = this.elements return ( (n[0] += e * n[2]), (n[3] += e * n[5]), (n[6] += e * n[8]), (n[1] += t * n[2]), (n[4] += t * n[5]), (n[7] += t * n[8]), this ) }), (t.equals = function (e) { for (var t = this.elements, n = e.elements, r = 0; r < 9; r++) if (t[r] !== n[r]) return !1 return !0 }), (t.fromArray = function (e, t) { void 0 === t && (t = 0) for (var n = 0; n < 9; n++) this.elements[n] = e[n + t] return this }), (t.toArray = function (e, t) { void 0 === e && (e = []), void 0 === t && (t = 0) var n = this.elements return ( (e[t] = n[0]), (e[t + 1] = n[1]), (e[t + 2] = n[2]), (e[t + 3] = n[3]), (e[t + 4] = n[4]), (e[t + 5] = n[5]), (e[t + 6] = n[6]), (e[t + 7] = n[7]), (e[t + 8] = n[8]), e ) }), e ) })(), er = { getDataURL: function (e) { if (/^data:/i.test(e.src)) return e.src if ('undefined' == typeof HTMLCanvasElement) return e.src var t if (e instanceof HTMLCanvasElement) t = e else { void 0 === Qn && (Qn = document.createElementNS( 'http://www.w3.org/1999/xhtml', 'canvas', )), (Qn.width = e.width), (Qn.height = e.height) var n = Qn.getContext('2d') e instanceof ImageData ? n.putImageData(e, 0, 0) : n.drawImage(e, 0, 0, e.width, e.height), (t = Qn) } return t.width > 2048 || t.height > 2048 ? t.toDataURL('image/jpeg', 0.6) : t.toDataURL('image/png') }, }, tr = 0 function nr(e, t, n, r, i, o, a, s, l, c) { void 0 === e && (e = nr.DEFAULT_IMAGE), void 0 === t && (t = nr.DEFAULT_MAPPING), void 0 === n && (n = pe), void 0 === r && (r = pe), void 0 === i && (i = Ae), void 0 === o && (o = Ee), void 0 === a && (a = Ue), void 0 === s && (s = _e), void 0 === l && (l = 1), void 0 === c && (c = Kt), Object.defineProperty(this, 'id', { value: tr++ }), (this.uuid = Kn.generateUUID()), (this.name = ''), (this.image = e), (this.mipmaps = []), (this.mapping = t), (this.wrapS = n), (this.wrapT = r), (this.magFilter = i), (this.minFilter = o), (this.anisotropy = l), (this.format = a), (this.internalFormat = null), (this.type = s), (this.offset = new Jn(0, 0)), (this.repeat = new Jn(1, 1)), (this.center = new Jn(0, 0)), (this.rotation = 0), (this.matrixAutoUpdate = !0), (this.matrix = new $n()), (this.generateMipmaps = !0), (this.premultiplyAlpha = !1), (this.flipY = !0), (this.unpackAlignment = 4), (this.encoding = c), (this.version = 0), (this.onUpdate = null) } function rr(e) { return ('undefined' !== typeof HTMLImageElement && e instanceof HTMLImageElement) || ('undefined' !== typeof HTMLCanvasElement && e instanceof HTMLCanvasElement) || ('undefined' !== typeof ImageBitmap && e instanceof ImageBitmap) ? er.getDataURL(e) : e.data ? { data: Array.prototype.slice.call(e.data), width: e.width, height: e.height, type: e.data.constructor.name, } : (console.warn('THREE.Texture: Unable to serialize Texture.'), {}) } ;(nr.DEFAULT_IMAGE = void 0), (nr.DEFAULT_MAPPING = oe), (nr.prototype = Object.assign(Object.create(qn.prototype), { constructor: nr, 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 (e) { return ( (this.name = e.name), (this.image = e.image), (this.mipmaps = e.mipmaps.slice(0)), (this.mapping = e.mapping), (this.wrapS = e.wrapS), (this.wrapT = e.wrapT), (this.magFilter = e.magFilter), (this.minFilter = e.minFilter), (this.anisotropy = e.anisotropy), (this.format = e.format), (this.internalFormat = e.internalFormat), (this.type = e.type), this.offset.copy(e.offset), this.repeat.copy(e.repeat), this.center.copy(e.center), (this.rotation = e.rotation), (this.matrixAutoUpdate = e.matrixAutoUpdate), this.matrix.copy(e.matrix), (this.generateMipmaps = e.generateMipmaps), (this.premultiplyAlpha = e.premultiplyAlpha), (this.flipY = e.flipY), (this.unpackAlignment = e.unpackAlignment), (this.encoding = e.encoding), this ) }, toJSON: function (e) { var t = void 0 === e || 'string' === typeof e if (!t && void 0 !== e.textures[this.uuid]) return e.textures[this.uuid] var n = { 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 r = this.image if ( (void 0 === r.uuid && (r.uuid = Kn.generateUUID()), !t && void 0 === e.images[r.uuid]) ) { var i if (Array.isArray(r)) { i = [] for (var o = 0, a = r.length; o < a; o++) r[o].isDataTexture ? i.push(rr(r[o].image)) : i.push(rr(r[o])) } else i = rr(r) e.images[r.uuid] = { uuid: r.uuid, url: i } } n.image = r.uuid } return t || (e.textures[this.uuid] = n), n }, dispose: function () { this.dispatchEvent({ type: 'dispose' }) }, transformUv: function (e) { if (this.mapping !== oe) return e if ((e.applyMatrix3(this.matrix), e.x < 0 || e.x > 1)) switch (this.wrapS) { case de: e.x = e.x - Math.floor(e.x) break case pe: e.x = e.x < 0 ? 0 : 1 break case fe: 1 === Math.abs(Math.floor(e.x) % 2) ? (e.x = Math.ceil(e.x) - e.x) : (e.x = e.x - Math.floor(e.x)) } if (e.y < 0 || e.y > 1) switch (this.wrapT) { case de: e.y = e.y - Math.floor(e.y) break case pe: e.y = e.y < 0 ? 0 : 1 break case fe: 1 === Math.abs(Math.floor(e.y) % 2) ? (e.y = Math.ceil(e.y) - e.y) : (e.y = e.y - Math.floor(e.y)) } return this.flipY && (e.y = 1 - e.y), e }, })), Object.defineProperty(nr.prototype, 'needsUpdate', { set: function (e) { !0 === e && this.version++ }, }) var ir = (function () { function e(e, t, n, r) { void 0 === e && (e = 0), void 0 === t && (t = 0), void 0 === n && (n = 0), void 0 === r && (r = 1), Object.defineProperty(this, 'isVector4', { value: !0 }), (this.x = e), (this.y = t), (this.z = n), (this.w = r) } var t = e.prototype return ( (t.set = function (e, t, n, r) { return (this.x = e), (this.y = t), (this.z = n), (this.w = r), this }), (t.setScalar = function (e) { return (this.x = e), (this.y = e), (this.z = e), (this.w = e), this }), (t.setX = function (e) { return (this.x = e), this }), (t.setY = function (e) { return (this.y = e), this }), (t.setZ = function (e) { return (this.z = e), this }), (t.setW = function (e) { return (this.w = e), this }), (t.setComponent = function (e, t) { switch (e) { case 0: this.x = t break case 1: this.y = t break case 2: this.z = t break case 3: this.w = t break default: throw new Error('index is out of range: ' + e) } return this }), (t.getComponent = function (e) { switch (e) { 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: ' + e) } }), (t.clone = function () { return new this.constructor(this.x, this.y, this.z, this.w) }), (t.copy = function (e) { return ( (this.x = e.x), (this.y = e.y), (this.z = e.z), (this.w = void 0 !== e.w ? e.w : 1), this ) }), (t.add = function (e, t) { return void 0 !== t ? (console.warn( 'THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead.', ), this.addVectors(e, t)) : ((this.x += e.x), (this.y += e.y), (this.z += e.z), (this.w += e.w), this) }), (t.addScalar = function (e) { return (this.x += e), (this.y += e), (this.z += e), (this.w += e), this }), (t.addVectors = function (e, t) { return ( (this.x = e.x + t.x), (this.y = e.y + t.y), (this.z = e.z + t.z), (this.w = e.w + t.w), this ) }), (t.addScaledVector = function (e, t) { return ( (this.x += e.x * t), (this.y += e.y * t), (this.z += e.z * t), (this.w += e.w * t), this ) }), (t.sub = function (e, t) { return void 0 !== t ? (console.warn( 'THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.', ), this.subVectors(e, t)) : ((this.x -= e.x), (this.y -= e.y), (this.z -= e.z), (this.w -= e.w), this) }), (t.subScalar = function (e) { return (this.x -= e), (this.y -= e), (this.z -= e), (this.w -= e), this }), (t.subVectors = function (e, t) { return ( (this.x = e.x - t.x), (this.y = e.y - t.y), (this.z = e.z - t.z), (this.w = e.w - t.w), this ) }), (t.multiply = function (e) { return ( (this.x *= e.x), (this.y *= e.y), (this.z *= e.z), (this.w *= e.w), this ) }), (t.multiplyScalar = function (e) { return (this.x *= e), (this.y *= e), (this.z *= e), (this.w *= e), this }), (t.applyMatrix4 = function (e) { var t = this.x, n = this.y, r = this.z, i = this.w, o = e.elements return ( (this.x = o[0] * t + o[4] * n + o[8] * r + o[12] * i), (this.y = o[1] * t + o[5] * n + o[9] * r + o[13] * i), (this.z = o[2] * t + o[6] * n + o[10] * r + o[14] * i), (this.w = o[3] * t + o[7] * n + o[11] * r + o[15] * i), this ) }), (t.divideScalar = function (e) { return this.multiplyScalar(1 / e) }), (t.setAxisAngleFromQuaternion = function (e) { this.w = 2 * Math.acos(e.w) var t = Math.sqrt(1 - e.w * e.w) return ( t < 1e-4 ? ((this.x = 1), (this.y = 0), (this.z = 0)) : ((this.x = e.x / t), (this.y = e.y / t), (this.z = e.z / t)), this ) }), (t.setAxisAngleFromRotationMatrix = function (e) { var t, n, r, i, o = 0.01, a = 0.1, s = e.elements, l = s[0], c = s[4], u = s[8], h = s[1], d = s[5], p = s[9], f = s[2], m = s[6], v = s[10] if (Math.abs(c - h) < o && Math.abs(u - f) < o && Math.abs(p - m) < o) { if ( Math.abs(c + h) < a && Math.abs(u + f) < a && Math.abs(p + m) < a && Math.abs(l + d + v - 3) < a ) return this.set(1, 0, 0, 0), this t = Math.PI var g = (l + 1) / 2, y = (d + 1) / 2, b = (v + 1) / 2, A = (c + h) / 4, w = (u + f) / 4, x = (p + m) / 4 return ( g > y && g > b ? g < o ? ((n = 0), (r = 0.707106781), (i = 0.707106781)) : ((r = A / (n = Math.sqrt(g))), (i = w / n)) : y > b ? y < o ? ((n = 0.707106781), (r = 0), (i = 0.707106781)) : ((n = A / (r = Math.sqrt(y))), (i = x / r)) : b < o ? ((n = 0.707106781), (r = 0.707106781), (i = 0)) : ((n = w / (i = Math.sqrt(b))), (r = x / i)), this.set(n, r, i, t), this ) } var E = Math.sqrt( (m - p) * (m - p) + (u - f) * (u - f) + (h - c) * (h - c), ) return ( Math.abs(E) < 0.001 && (E = 1), (this.x = (m - p) / E), (this.y = (u - f) / E), (this.z = (h - c) / E), (this.w = Math.acos((l + d + v - 1) / 2)), this ) }), (t.min = function (e) { return ( (this.x = Math.min(this.x, e.x)), (this.y = Math.min(this.y, e.y)), (this.z = Math.min(this.z, e.z)), (this.w = Math.min(this.w, e.w)), this ) }), (t.max = function (e) { return ( (this.x = Math.max(this.x, e.x)), (this.y = Math.max(this.y, e.y)), (this.z = Math.max(this.z, e.z)), (this.w = Math.max(this.w, e.w)), this ) }), (t.clamp = function (e, t) { return ( (this.x = Math.max(e.x, Math.min(t.x, this.x))), (this.y = Math.max(e.y, Math.min(t.y, this.y))), (this.z = Math.max(e.z, Math.min(t.z, this.z))), (this.w = Math.max(e.w, Math.min(t.w, this.w))), this ) }), (t.clampScalar = function (e, t) { return ( (this.x = Math.max(e, Math.min(t, this.x))), (this.y = Math.max(e, Math.min(t, this.y))), (this.z = Math.max(e, Math.min(t, this.z))), (this.w = Math.max(e, Math.min(t, this.w))), this ) }), (t.clampLength = function (e, t) { var n = this.length() return this.divideScalar(n || 1).multiplyScalar( Math.max(e, Math.min(t, n)), ) }), (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 ) }), (t.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 ) }), (t.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 ) }), (t.roundToZero = function () { return ( (this.x = this.x < 0 ? Math.ceil(this.x) : Math.floor(this.x)), (this.y = this.y < 0 ? Math.ceil(this.y) : Math.floor(this.y)), (this.z = this.z < 0 ? Math.ceil(this.z) : Math.floor(this.z)), (this.w = this.w < 0 ? Math.ceil(this.w) : Math.floor(this.w)), this ) }), (t.negate = function () { return ( (this.x = -this.x), (this.y = -this.y), (this.z = -this.z), (this.w = -this.w), this ) }), (t.dot = function (e) { return this.x * e.x + this.y * e.y + this.z * e.z + this.w * e.w }), (t.lengthSq = function () { return ( this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w ) }), (t.length = function () { return Math.sqrt( this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w, ) }), (t.manhattanLength = function () { return ( Math.abs(this.x) + Math.abs(this.y) + Math.abs(this.z) + Math.abs(this.w) ) }), (t.normalize = function () { return this.divideScalar(this.length() || 1) }), (t.setLength = function (e) { return this.normalize().multiplyScalar(e) }), (t.lerp = function (e, t) { return ( (this.x += (e.x - this.x) * t), (this.y += (e.y - this.y) * t), (this.z += (e.z - this.z) * t), (this.w += (e.w - this.w) * t), this ) }), (t.lerpVectors = function (e, t, n) { return ( (this.x = e.x + (t.x - e.x) * n), (this.y = e.y + (t.y - e.y) * n), (this.z = e.z + (t.z - e.z) * n), (this.w = e.w + (t.w - e.w) * n), this ) }), (t.equals = function (e) { return ( e.x === this.x && e.y === this.y && e.z === this.z && e.w === this.w ) }), (t.fromArray = function (e, t) { return ( void 0 === t && (t = 0), (this.x = e[t]), (this.y = e[t + 1]), (this.z = e[t + 2]), (this.w = e[t + 3]), this ) }), (t.toArray = function (e, t) { return ( void 0 === e && (e = []), void 0 === t && (t = 0), (e[t] = this.x), (e[t + 1] = this.y), (e[t + 2] = this.z), (e[t + 3] = this.w), e ) }), (t.fromBufferAttribute = function (e, t, n) { return ( void 0 !== n && console.warn( 'THREE.Vector4: offset has been removed from .fromBufferAttribute().', ), (this.x = e.getX(t)), (this.y = e.getY(t)), (this.z = e.getZ(t)), (this.w = e.getW(t)), this ) }), (t.random = function () { return ( (this.x = Math.random()), (this.y = Math.random()), (this.z = Math.random()), (this.w = Math.random()), this ) }), Hn(e, [ { key: 'width', get: function () { return this.z }, set: function (e) { this.z = e }, }, { key: 'height', get: function () { return this.w }, set: function (e) { this.w = e }, }, ]), e ) })(), or = (function (e) { function t(t, n, r) { var i return ( (i = e.call(this) || this), Object.defineProperty(zn(i), 'isWebGLRenderTarget', { value: !0 }), (i.width = t), (i.height = n), (i.scissor = new ir(0, 0, t, n)), (i.scissorTest = !1), (i.viewport = new ir(0, 0, t, n)), (r = r || {}), (i.texture = new nr( void 0, r.mapping, r.wrapS, r.wrapT, r.magFilter, r.minFilter, r.format, r.type, r.anisotropy, r.encoding, )), (i.texture.image = {}), (i.texture.image.width = t), (i.texture.image.height = n), (i.texture.generateMipmaps = void 0 !== r.generateMipmaps && r.generateMipmaps), (i.texture.minFilter = void 0 !== r.minFilter ? r.minFilter : Ae), (i.depthBuffer = void 0 === r.depthBuffer || r.depthBuffer), (i.stencilBuffer = void 0 !== r.stencilBuffer && r.stencilBuffer), (i.depthTexture = void 0 !== r.depthTexture ? r.depthTexture : null), i ) } Gn(t, e) var n = t.prototype return ( (n.setSize = function (e, t) { ;(this.width === e && this.height === t) || ((this.width = e), (this.height = t), (this.texture.image.width = e), (this.texture.image.height = t), this.dispose()), this.viewport.set(0, 0, e, t), this.scissor.set(0, 0, e, t) }), (n.clone = function () { return new this.constructor().copy(this) }), (n.copy = function (e) { return ( (this.width = e.width), (this.height = e.height), this.viewport.copy(e.viewport), (this.texture = e.texture.clone()), (this.depthBuffer = e.depthBuffer), (this.stencilBuffer = e.stencilBuffer), (this.depthTexture = e.depthTexture), this ) }), (n.dispose = function () { this.dispatchEvent({ type: 'dispose' }) }), t ) })(qn), ar = (function (e) { function t(t, n, r) { var i return ( (i = e.call(this, t, n, r) || this), Object.defineProperty(zn(i), 'isWebGLMultisampleRenderTarget', { value: !0, }), (i.samples = 4), i ) } return ( Gn(t, e), (t.prototype.copy = function (t) { return e.prototype.copy.call(this, t), (this.samples = t.samples), this }), t ) })(or), sr = (function () { function e(e, t, n, r) { void 0 === e && (e = 0), void 0 === t && (t = 0), void 0 === n && (n = 0), void 0 === r && (r = 1), Object.defineProperty(this, 'isQuaternion', { value: !0 }), (this._x = e), (this._y = t), (this._z = n), (this._w = r) } ;(e.slerp = function (e, t, n, r) { return n.copy(e).slerp(t, r) }), (e.slerpFlat = function (e, t, n, r, i, o, a) { var s = n[r + 0], l = n[r + 1], c = n[r + 2], u = n[r + 3], h = i[o + 0], d = i[o + 1], p = i[o + 2], f = i[o + 3] if (u !== f || s !== h || l !== d || c !== p) { var m = 1 - a, v = s * h + l * d + c * p + u * f, g = v >= 0 ? 1 : -1, y = 1 - v * v if (y > Number.EPSILON) { var b = Math.sqrt(y), A = Math.atan2(b, v * g) ;(m = Math.sin(m * A) / b), (a = Math.sin(a * A) / b) } var w = a * g if ( ((s = s * m + h * w), (l = l * m + d * w), (c = c * m + p * w), (u = u * m + f * w), m === 1 - a) ) { var x = 1 / Math.sqrt(s * s + l * l + c * c + u * u) ;(s *= x), (l *= x), (c *= x), (u *= x) } } ;(e[t] = s), (e[t + 1] = l), (e[t + 2] = c), (e[t + 3] = u) }), (e.multiplyQuaternionsFlat = function (e, t, n, r, i, o) { var a = n[r], s = n[r + 1], l = n[r + 2], c = n[r + 3], u = i[o], h = i[o + 1], d = i[o + 2], p = i[o + 3] return ( (e[t] = a * p + c * u + s * d - l * h), (e[t + 1] = s * p + c * h + l * u - a * d), (e[t + 2] = l * p + c * d + a * h - s * u), (e[t + 3] = c * p - a * u - s * h - l * d), e ) }) var t = e.prototype return ( (t.set = function (e, t, n, r) { return ( (this._x = e), (this._y = t), (this._z = n), (this._w = r), this._onChangeCallback(), this ) }), (t.clone = function () { return new this.constructor(this._x, this._y, this._z, this._w) }), (t.copy = function (e) { return ( (this._x = e.x), (this._y = e.y), (this._z = e.z), (this._w = e.w), this._onChangeCallback(), this ) }), (t.setFromEuler = function (e, t) { if (!e || !e.isEuler) throw new Error( 'THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order.', ) var n = e._x, r = e._y, i = e._z, o = e._order, a = Math.cos, s = Math.sin, l = a(n / 2), c = a(r / 2), u = a(i / 2), h = s(n / 2), d = s(r / 2), p = s(i / 2) switch (o) { case 'XYZ': ;(this._x = h * c * u + l * d * p), (this._y = l * d * u - h * c * p), (this._z = l * c * p + h * d * u), (this._w = l * c * u - h * d * p) break case 'YXZ': ;(this._x = h * c * u + l * d * p), (this._y = l * d * u - h * c * p), (this._z = l * c * p - h * d * u), (this._w = l * c * u + h * d * p) break case 'ZXY': ;(this._x = h * c * u - l * d * p), (this._y = l * d * u + h * c * p), (this._z = l * c * p + h * d * u), (this._w = l * c * u - h * d * p) break case 'ZYX': ;(this._x = h * c * u - l * d * p), (this._y = l * d * u + h * c * p), (this._z = l * c * p - h * d * u), (this._w = l * c * u + h * d * p) break case 'YZX': ;(this._x = h * c * u + l * d * p), (this._y = l * d * u + h * c * p), (this._z = l * c * p - h * d * u), (this._w = l * c * u - h * d * p) break case 'XZY': ;(this._x = h * c * u - l * d * p), (this._y = l * d * u - h * c * p), (this._z = l * c * p + h * d * u), (this._w = l * c * u + h * d * p) break default: console.warn( 'THREE.Quaternion: .setFromEuler() encountered an unknown order: ' + o, ) } return !1 !== t && this._onChangeCallback(), this }), (t.setFromAxisAngle = function (e, t) { var n = t / 2, r = Math.sin(n) return ( (this._x = e.x * r), (this._y = e.y * r), (this._z = e.z * r), (this._w = Math.cos(n)), this._onChangeCallback(), this ) }), (t.setFromRotationMatrix = function (e) { var t = e.elements, n = t[0], r = t[4], i = t[8], o = t[1], a = t[5], s = t[9], l = t[2], c = t[6], u = t[10], h = n + a + u if (h > 0) { var d = 0.5 / Math.sqrt(h + 1) ;(this._w = 0.25 / d), (this._x = (c - s) * d), (this._y = (i - l) * d), (this._z = (o - r) * d) } else if (n > a && n > u) { var p = 2 * Math.sqrt(1 + n - a - u) ;(this._w = (c - s) / p), (this._x = 0.25 * p), (this._y = (r + o) / p), (this._z = (i + l) / p) } else if (a > u) { var f = 2 * Math.sqrt(1 + a - n - u) ;(this._w = (i - l) / f), (this._x = (r + o) / f), (this._y = 0.25 * f), (this._z = (s + c) / f) } else { var m = 2 * Math.sqrt(1 + u - n - a) ;(this._w = (o - r) / m), (this._x = (i + l) / m), (this._y = (s + c) / m), (this._z = 0.25 * m) } return this._onChangeCallback(), this }), (t.setFromUnitVectors = function (e, t) { var n = 1e-6, r = e.dot(t) + 1 return ( r < n ? ((r = 0), Math.abs(e.x) > Math.abs(e.z) ? ((this._x = -e.y), (this._y = e.x), (this._z = 0), (this._w = r)) : ((this._x = 0), (this._y = -e.z), (this._z = e.y), (this._w = r))) : ((this._x = e.y * t.z - e.z * t.y), (this._y = e.z * t.x - e.x * t.z), (this._z = e.x * t.y - e.y * t.x), (this._w = r)), this.normalize() ) }), (t.angleTo = function (e) { return 2 * Math.acos(Math.abs(Kn.clamp(this.dot(e), -1, 1))) }), (t.rotateTowards = function (e, t) { var n = this.angleTo(e) if (0 === n) return this var r = Math.min(1, t / n) return this.slerp(e, r), this }), (t.identity = function () { return this.set(0, 0, 0, 1) }), (t.invert = function () { return this.conjugate() }), (t.conjugate = function () { return ( (this._x *= -1), (this._y *= -1), (this._z *= -1), this._onChangeCallback(), this ) }), (t.dot = function (e) { return this._x * e._x + this._y * e._y + this._z * e._z + this._w * e._w }), (t.lengthSq = function () { return ( this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w ) }), (t.length = function () { return Math.sqrt( this._x * this._x + this._y * this._y + this._z * this._z + this._w * this._w, ) }), (t.normalize = function () { var e = this.length() return ( 0 === e ? ((this._x = 0), (this._y = 0), (this._z = 0), (this._w = 1)) : ((e = 1 / e), (this._x = this._x * e), (this._y = this._y * e), (this._z = this._z * e), (this._w = this._w * e)), this._onChangeCallback(), this ) }), (t.multiply = function (e, t) { return void 0 !== t ? (console.warn( 'THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead.', ), this.multiplyQuaternions(e, t)) : this.multiplyQuaternions(this, e) }), (t.premultiply = function (e) { return this.multiplyQuaternions(e, this) }), (t.multiplyQuaternions = function (e, t) { var n = e._x, r = e._y, i = e._z, o = e._w, a = t._x, s = t._y, l = t._z, c = t._w return ( (this._x = n * c + o * a + r * l - i * s), (this._y = r * c + o * s + i * a - n * l), (this._z = i * c + o * l + n * s - r * a), (this._w = o * c - n * a - r * s - i * l), this._onChangeCallback(), this ) }), (t.slerp = function (e, t) { if (0 === t) return this if (1 === t) return this.copy(e) var n = this._x, r = this._y, i = this._z, o = this._w, a = o * e._w + n * e._x + r * e._y + i * e._z if ( (a < 0 ? ((this._w = -e._w), (this._x = -e._x), (this._y = -e._y), (this._z = -e._z), (a = -a)) : this.copy(e), a >= 1) ) return ( (this._w = o), (this._x = n), (this._y = r), (this._z = i), this ) var s = 1 - a * a if (s <= Number.EPSILON) { var l = 1 - t return ( (this._w = l * o + t * this._w), (this._x = l * n + t * this._x), (this._y = l * r + t * this._y), (this._z = l * i + t * this._z), this.normalize(), this._onChangeCallback(), this ) } var c = Math.sqrt(s), u = Math.atan2(c, a), h = Math.sin((1 - t) * u) / c, d = Math.sin(t * u) / c return ( (this._w = o * h + this._w * d), (this._x = n * h + this._x * d), (this._y = r * h + this._y * d), (this._z = i * h + this._z * d), this._onChangeCallback(), this ) }), (t.equals = function (e) { return ( e._x === this._x && e._y === this._y && e._z === this._z && e._w === this._w ) }), (t.fromArray = function (e, t) { return ( void 0 === t && (t = 0), (this._x = e[t]), (this._y = e[t + 1]), (this._z = e[t + 2]), (this._w = e[t + 3]), this._onChangeCallback(), this ) }), (t.toArray = function (e, t) { return ( void 0 === e && (e = []), void 0 === t && (t = 0), (e[t] = this._x), (e[t + 1] = this._y), (e[t + 2] = this._z), (e[t + 3] = this._w), e ) }), (t.fromBufferAttribute = function (e, t) { return ( (this._x = e.getX(t)), (this._y = e.getY(t)), (this._z = e.getZ(t)), (this._w = e.getW(t)), this ) }), (t._onChange = function (e) { return (this._onChangeCallback = e), this }), (t._onChangeCallback = function () {}), Hn(e, [ { key: 'x', get: function () { return this._x }, set: function (e) { ;(this._x = e), this._onChangeCallback() }, }, { key: 'y', get: function () { return this._y }, set: function (e) { ;(this._y = e), this._onChangeCallback() }, }, { key: 'z', get: function () { return this._z }, set: function (e) { ;(this._z = e), this._onChangeCallback() }, }, { key: 'w', get: function () { return this._w }, set: function (e) { ;(this._w = e), this._onChangeCallback() }, }, ]), e ) })(), lr = (function () { function e(e, t, n) { void 0 === e && (e = 0), void 0 === t && (t = 0), void 0 === n && (n = 0), Object.defineProperty(this, 'isVector3', { value: !0 }), (this.x = e), (this.y = t), (this.z = n) } var t = e.prototype return ( (t.set = function (e, t, n) { return ( void 0 === n && (n = this.z), (this.x = e), (this.y = t), (this.z = n), this ) }), (t.setScalar = function (e) { return (this.x = e), (this.y = e), (this.z = e), this }), (t.setX = function (e) { return (this.x = e), this }), (t.setY = function (e) { return (this.y = e), this }), (t.setZ = function (e) { return (this.z = e), this }), (t.setComponent = function (e, t) { switch (e) { case 0: this.x = t break case 1: this.y = t break case 2: this.z = t break default: throw new Error('index is out of range: ' + e) } return this }), (t.getComponent = function (e) { switch (e) { case 0: return this.x case 1: return this.y case 2: return this.z default: throw new Error('index is out of range: ' + e) } }), (t.clone = function () { return new this.constructor(this.x, this.y, this.z) }), (t.copy = function (e) { return (this.x = e.x), (this.y = e.y), (this.z = e.z), this }), (t.add = function (e, t) { return void 0 !== t ? (console.warn( 'THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead.', ), this.addVectors(e, t)) : ((this.x += e.x), (this.y += e.y), (this.z += e.z), this) }), (t.addScalar = function (e) { return (this.x += e), (this.y += e), (this.z += e), this }), (t.addVectors = function (e, t) { return ( (this.x = e.x + t.x), (this.y = e.y + t.y), (this.z = e.z + t.z), this ) }), (t.addScaledVector = function (e, t) { return ( (this.x += e.x * t), (this.y += e.y * t), (this.z += e.z * t), this ) }), (t.sub = function (e, t) { return void 0 !== t ? (console.warn( 'THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead.', ), this.subVectors(e, t)) : ((this.x -= e.x), (this.y -= e.y), (this.z -= e.z), this) }), (t.subScalar = function (e) { return (this.x -= e), (this.y -= e), (this.z -= e), this }), (t.subVectors = function (e, t) { return ( (this.x = e.x - t.x), (this.y = e.y - t.y), (this.z = e.z - t.z), this ) }), (t.multiply = function (e, t) { return void 0 !== t ? (console.warn( 'THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead.', ), this.multiplyVectors(e, t)) : ((this.x *= e.x), (this.y *= e.y), (this.z *= e.z), this) }), (t.multiplyScalar = function (e) { return (this.x *= e), (this.y *= e), (this.z *= e), this }), (t.multiplyVectors = function (e, t) { return ( (this.x = e.x * t.x), (this.y = e.y * t.y), (this.z = e.z * t.z), this ) }), (t.applyEuler = function (e) { return ( (e && e.isEuler) || console.error( 'THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order.', ), this.applyQuaternion(ur.setFromEuler(e)) ) }), (t.applyAxisAngle = function (e, t) { return this.applyQuaternion(ur.setFromAxisAngle(e, t)) }), (t.applyMatrix3 = function (e) { var t = this.x, n = this.y, r = this.z, i = e.elements return ( (this.x = i[0] * t + i[3] * n + i[6] * r), (this.y = i[1] * t + i[4] * n + i[7] * r), (this.z = i[2] * t + i[5] * n + i[8] * r), this ) }), (t.applyNormalMatrix = function (e) { return this.applyMatrix3(e).normalize() }), (t.applyMatrix4 = function (e) { var t = this.x, n = this.y, r = this.z, i = e.elements, o = 1 / (i[3] * t + i[7] * n + i[11] * r + i[15]) return ( (this.x = (i[0] * t + i[4] * n + i[8] * r + i[12]) * o), (this.y = (i[1] * t + i[5] * n + i[9] * r + i[13]) * o), (this.z = (i[2] * t + i[6] * n + i[10] * r + i[14]) * o), this ) }), (t.applyQuaternion = function (e) { var t = this.x, n = this.y, r = this.z, i = e.x, o = e.y, a = e.z, s = e.w, l = s * t + o * r - a * n, c = s * n + a * t - i * r, u = s * r + i * n - o * t, h = -i * t - o * n - a * r return ( (this.x = l * s + h * -i + c * -a - u * -o), (this.y = c * s + h * -o + u * -i - l * -a), (this.z = u * s + h * -a + l * -o - c * -i), this ) }), (t.project = function (e) { return this.applyMatrix4(e.matrixWorldInverse).applyMatrix4( e.projectionMatrix, ) }), (t.unproject = function (e) { return this.applyMatrix4(e.projectionMatrixInverse).applyMatrix4( e.matrixWorld, ) }), (t.transformDirection = function (e) { var t = this.x, n = this.y, r = this.z, i = e.elements return ( (this.x = i[0] * t + i[4] * n + i[8] * r), (this.y = i[1] * t + i[5] * n + i[9] * r), (this.z = i[2] * t + i[6] * n + i[10] * r), this.normalize() ) }), (t.divide = function (e) { return (this.x /= e.x), (this.y /= e.y), (this.z /= e.z), this }), (t.divideScalar = function (e) { return this.multiplyScalar(1 / e) }), (t.min = function (e) { return ( (this.x = Math.min(this.x, e.x)), (this.y = Math.min(this.y, e.y)), (this.z = Math.min(this.z, e.z)), this ) }), (t.max = function (e) { return ( (this.x = Math.max(this.x, e.x)), (this.y = Math.max(this.y, e.y)), (this.z = Math.max(this.z, e.z)), this ) }), (t.clamp = function (e, t) { return ( (this.x = Math.max(e.x, Math.min(t.x, this.x))), (this.y = Math.max(e.y, Math.min(t.y, this.y))), (this.z = Math.max(e.z, Math.min(t.z, this.z))), this ) }), (t.clampScalar = function (e, t) { return ( (this.x = Math.max(e, Math.min(t, this.x))), (this.y = Math.max(e, Math.min(t, this.y))), (this.z = Math.max(e, Math.min(t, this.z))), this ) }), (t.clampLength = function (e, t) { var n = this.length() return this.divideScalar(n || 1).multiplyScalar( Math.max(e, Math.min(t, n)), ) }), (t.floor = function () { return ( (this.x = Math.floor(this.x)), (this.y = Math.floor(this.y)), (this.z = Math.floor(this.z)), this ) }), (t.ceil = function () { return ( (this.x = Math.ceil(this.x)), (this.y = Math.ceil(this.y)), (this.z = Math.ceil(this.z)), this ) }), (t.round = function () { return ( (this.x = Math.round(this.x)), (this.y = Math.round(this.y)), (this.z = Math.round(this.z)), this ) }), (t.roundToZero = function () { return ( (this.x = this.x < 0 ? Math.ceil(this.x) : Math.floor(this.x)), (this.y = this.y < 0 ? Math.ceil(this.y) : Math.floor(this.y)), (this.z = this.z < 0 ? Math.ceil(this.z) : Math.floor(this.z)), this ) }), (t.negate = function () { return (this.x = -this.x), (this.y = -this.y), (this.z = -this.z), this }), (t.dot = function (e) { return this.x * e.x + this.y * e.y + this.z * e.z }), (t.lengthSq = function () { return this.x * this.x + this.y * this.y + this.z * this.z }), (t.length = function () { return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z) }), (t.manhattanLength = function () { return Math.abs(this.x) + Math.abs(this.y) + Math.abs(this.z) }), (t.normalize = function () { return this.divideScalar(this.length() || 1) }), (t.setLength = function (e) { return this.normalize().multiplyScalar(e) }), (t.lerp = function (e, t) { return ( (this.x += (e.x - this.x) * t), (this.y += (e.y - this.y) * t), (this.z += (e.z - this.z) * t), this ) }), (t.lerpVectors = function (e, t, n) { return ( (this.x = e.x + (t.x - e.x) * n), (this.y = e.y + (t.y - e.y) * n), (this.z = e.z + (t.z - e.z) * n), this ) }), (t.cross = function (e, t) { return void 0 !== t ? (console.warn( 'THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead.', ), this.crossVectors(e, t)) : this.crossVectors(this, e) }), (t.crossVectors = function (e, t) { var n = e.x, r = e.y, i = e.z, o = t.x, a = t.y, s = t.z return ( (this.x = r * s - i * a), (this.y = i * o - n * s), (this.z = n * a - r * o), this ) }), (t.projectOnVector = function (e) { var t = e.lengthSq() if (0 === t) return this.set(0, 0, 0) var n = e.dot(this) / t return this.copy(e).multiplyScalar(n) }), (t.projectOnPlane = function (e) { return cr.copy(this).projectOnVector(e), this.sub(cr) }), (t.reflect = function (e) { return this.sub(cr.copy(e).multiplyScalar(2 * this.dot(e))) }), (t.angleTo = function (e) { var t = Math.sqrt(this.lengthSq() * e.lengthSq()) if (0 === t) return Math.PI / 2 var n = this.dot(e) / t return Math.acos(Kn.clamp(n, -1, 1)) }), (t.distanceTo = function (e) { return Math.sqrt(this.distanceToSquared(e)) }), (t.distanceToSquared = function (e) { var t = this.x - e.x, n = this.y - e.y, r = this.z - e.z return t * t + n * n + r * r }), (t.manhattanDistanceTo = function (e) { return ( Math.abs(this.x - e.x) + Math.abs(this.y - e.y) + Math.abs(this.z - e.z) ) }), (t.setFromSpherical = function (e) { return this.setFromSphericalCoords(e.radius, e.phi, e.theta) }), (t.setFromSphericalCoords = function (e, t, n) { var r = Math.sin(t) * e return ( (this.x = r * Math.sin(n)), (this.y = Math.cos(t) * e), (this.z = r * Math.cos(n)), this ) }), (t.setFromCylindrical = function (e) { return this.setFromCylindricalCoords(e.radius, e.theta, e.y) }), (t.setFromCylindricalCoords = function (e, t, n) { return ( (this.x = e * Math.sin(t)), (this.y = n), (this.z = e * Math.cos(t)), this ) }), (t.setFromMatrixPosition = function (e) { var t = e.elements return (this.x = t[12]), (this.y = t[13]), (this.z = t[14]), this }), (t.setFromMatrixScale = function (e) { var t = this.setFromMatrixColumn(e, 0).length(), n = this.setFromMatrixColumn(e, 1).length(), r = this.setFromMatrixColumn(e, 2).length() return (this.x = t), (this.y = n), (this.z = r), this }), (t.setFromMatrixColumn = function (e, t) { return this.fromArray(e.elements, 4 * t) }), (t.setFromMatrix3Column = function (e, t) { return this.fromArray(e.elements, 3 * t) }), (t.equals = function (e) { return e.x === this.x && e.y === this.y && e.z === this.z }), (t.fromArray = function (e, t) { return ( void 0 === t && (t = 0), (this.x = e[t]), (this.y = e[t + 1]), (this.z = e[t + 2]), this ) }), (t.toArray = function (e, t) { return ( void 0 === e && (e = []), void 0 === t && (t = 0), (e[t] = this.x), (e[t + 1] = this.y), (e[t + 2] = this.z), e ) }), (t.fromBufferAttribute = function (e, t, n) { return ( void 0 !== n && console.warn( 'THREE.Vector3: offset has been removed from .fromBufferAttribute().', ), (this.x = e.getX(t)), (this.y = e.getY(t)), (this.z = e.getZ(t)), this ) }), (t.random = function () { return ( (this.x = Math.random()), (this.y = Math.random()), (this.z = Math.random()), this ) }), e ) })(), cr = new lr(), ur = new sr(), hr = (function () { function e(e, t) { Object.defineProperty(this, 'isBox3', { value: !0 }), (this.min = void 0 !== e ? e : new lr(1 / 0, 1 / 0, 1 / 0)), (this.max = void 0 !== t ? t : new lr(-1 / 0, -1 / 0, -1 / 0)) } var t = e.prototype return ( (t.set = function (e, t) { return this.min.copy(e), this.max.copy(t), this }), (t.setFromArray = function (e) { for ( var t = 1 / 0, n = 1 / 0, r = 1 / 0, i = -1 / 0, o = -1 / 0, a = -1 / 0, s = 0, l = e.length; s < l; s += 3 ) { var c = e[s], u = e[s + 1], h = e[s + 2] c < t && (t = c), u < n && (n = u), h < r && (r = h), c > i && (i = c), u > o && (o = u), h > a && (a = h) } return this.min.set(t, n, r), this.max.set(i, o, a), this }), (t.setFromBufferAttribute = function (e) { for ( var t = 1 / 0, n = 1 / 0, r = 1 / 0, i = -1 / 0, o = -1 / 0, a = -1 / 0, s = 0, l = e.count; s < l; s++ ) { var c = e.getX(s), u = e.getY(s), h = e.getZ(s) c < t && (t = c), u < n && (n = u), h < r && (r = h), c > i && (i = c), u > o && (o = u), h > a && (a = h) } return this.min.set(t, n, r), this.max.set(i, o, a), this }), (t.setFromPoints = function (e) { this.makeEmpty() for (var t = 0, n = e.length; t < n; t++) this.expandByPoint(e[t]) return this }), (t.setFromCenterAndSize = function (e, t) { var n = fr.copy(t).multiplyScalar(0.5) return this.min.copy(e).sub(n), this.max.copy(e).add(n), this }), (t.setFromObject = function (e) { return this.makeEmpty(), this.expandByObject(e) }), (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { return this.min.copy(e.min), this.max.copy(e.max), this }), (t.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 ) }), (t.isEmpty = function () { return ( this.max.x < this.min.x || this.max.y < this.min.y || this.max.z < this.min.z ) }), (t.getCenter = function (e) { return ( void 0 === e && (console.warn('THREE.Box3: .getCenter() target is now required'), (e = new lr())), this.isEmpty() ? e.set(0, 0, 0) : e.addVectors(this.min, this.max).multiplyScalar(0.5) ) }), (t.getSize = function (e) { return ( void 0 === e && (console.warn('THREE.Box3: .getSize() target is now required'), (e = new lr())), this.isEmpty() ? e.set(0, 0, 0) : e.subVectors(this.max, this.min) ) }), (t.expandByPoint = function (e) { return this.min.min(e), this.max.max(e), this }), (t.expandByVector = function (e) { return this.min.sub(e), this.max.add(e), this }), (t.expandByScalar = function (e) { return this.min.addScalar(-e), this.max.addScalar(e), this }), (t.expandByObject = function (e) { e.updateWorldMatrix(!1, !1) var t = e.geometry void 0 !== t && (null === t.boundingBox && t.computeBoundingBox(), mr.copy(t.boundingBox), mr.applyMatrix4(e.matrixWorld), this.union(mr)) for (var n = e.children, r = 0, i = n.length; r < i; r++) this.expandByObject(n[r]) return this }), (t.containsPoint = function (e) { return !( e.x < this.min.x || e.x > this.max.x || e.y < this.min.y || e.y > this.max.y || e.z < this.min.z || e.z > this.max.z ) }), (t.containsBox = function (e) { return ( this.min.x <= e.min.x && e.max.x <= this.max.x && this.min.y <= e.min.y && e.max.y <= this.max.y && this.min.z <= e.min.z && e.max.z <= this.max.z ) }), (t.getParameter = function (e, t) { return ( void 0 === t && (console.warn('THREE.Box3: .getParameter() target is now required'), (t = new lr())), t.set( (e.x - this.min.x) / (this.max.x - this.min.x), (e.y - this.min.y) / (this.max.y - this.min.y), (e.z - this.min.z) / (this.max.z - this.min.z), ) ) }), (t.intersectsBox = function (e) { return !( e.max.x < this.min.x || e.min.x > this.max.x || e.max.y < this.min.y || e.min.y > this.max.y || e.max.z < this.min.z || e.min.z > this.max.z ) }), (t.intersectsSphere = function (e) { return ( this.clampPoint(e.center, fr), fr.distanceToSquared(e.center) <= e.radius * e.radius ) }), (t.intersectsPlane = function (e) { var t, n return ( e.normal.x > 0 ? ((t = e.normal.x * this.min.x), (n = e.normal.x * this.max.x)) : ((t = e.normal.x * this.max.x), (n = e.normal.x * this.min.x)), e.normal.y > 0 ? ((t += e.normal.y * this.min.y), (n += e.normal.y * this.max.y)) : ((t += e.normal.y * this.max.y), (n += e.normal.y * this.min.y)), e.normal.z > 0 ? ((t += e.normal.z * this.min.z), (n += e.normal.z * this.max.z)) : ((t += e.normal.z * this.max.z), (n += e.normal.z * this.min.z)), t <= -e.constant && n >= -e.constant ) }), (t.intersectsTriangle = function (e) { if (this.isEmpty()) return !1 this.getCenter(xr), Er.subVectors(this.max, xr), vr.subVectors(e.a, xr), gr.subVectors(e.b, xr), yr.subVectors(e.c, xr), br.subVectors(gr, vr), Ar.subVectors(yr, gr), wr.subVectors(vr, yr) var t = [ 0, -br.z, br.y, 0, -Ar.z, Ar.y, 0, -wr.z, wr.y, br.z, 0, -br.x, Ar.z, 0, -Ar.x, wr.z, 0, -wr.x, -br.y, br.x, 0, -Ar.y, Ar.x, 0, -wr.y, wr.x, 0, ] return ( !!dr(t, vr, gr, yr, Er) && !!dr((t = [1, 0, 0, 0, 1, 0, 0, 0, 1]), vr, gr, yr, Er) && (Mr.crossVectors(br, Ar), dr((t = [Mr.x, Mr.y, Mr.z]), vr, gr, yr, Er)) ) }), (t.clampPoint = function (e, t) { return ( void 0 === t && (console.warn('THREE.Box3: .clampPoint() target is now required'), (t = new lr())), t.copy(e).clamp(this.min, this.max) ) }), (t.distanceToPoint = function (e) { return fr.copy(e).clamp(this.min, this.max).sub(e).length() }), (t.getBoundingSphere = function (e) { return ( void 0 === e && console.error( 'THREE.Box3: .getBoundingSphere() target is now required', ), this.getCenter(e.center), (e.radius = 0.5 * this.getSize(fr).length()), e ) }), (t.intersect = function (e) { return ( this.min.max(e.min), this.max.min(e.max), this.isEmpty() && this.makeEmpty(), this ) }), (t.union = function (e) { return this.min.min(e.min), this.max.max(e.max), this }), (t.applyMatrix4 = function (e) { return ( this.isEmpty() || (pr[0].set(this.min.x, this.min.y, this.min.z).applyMatrix4(e), pr[1].set(this.min.x, this.min.y, this.max.z).applyMatrix4(e), pr[2].set(this.min.x, this.max.y, this.min.z).applyMatrix4(e), pr[3].set(this.min.x, this.max.y, this.max.z).applyMatrix4(e), pr[4].set(this.max.x, this.min.y, this.min.z).applyMatrix4(e), pr[5].set(this.max.x, this.min.y, this.max.z).applyMatrix4(e), pr[6].set(this.max.x, this.max.y, this.min.z).applyMatrix4(e), pr[7].set(this.max.x, this.max.y, this.max.z).applyMatrix4(e), this.setFromPoints(pr)), this ) }), (t.translate = function (e) { return this.min.add(e), this.max.add(e), this }), (t.equals = function (e) { return e.min.equals(this.min) && e.max.equals(this.max) }), e ) })() function dr(e, t, n, r, i) { for (var o = 0, a = e.length - 3; o <= a; o += 3) { _r.fromArray(e, o) var s = i.x * Math.abs(_r.x) + i.y * Math.abs(_r.y) + i.z * Math.abs(_r.z), l = t.dot(_r), c = n.dot(_r), u = r.dot(_r) if (Math.max(-Math.max(l, c, u), Math.min(l, c, u)) > s) return !1 } return !0 } var pr = [ new lr(), new lr(), new lr(), new lr(), new lr(), new lr(), new lr(), new lr(), ], fr = new lr(), mr = new hr(), vr = new lr(), gr = new lr(), yr = new lr(), br = new lr(), Ar = new lr(), wr = new lr(), xr = new lr(), Er = new lr(), Mr = new lr(), _r = new lr(), Tr = new hr(), Sr = (function () { function e(e, t) { ;(this.center = void 0 !== e ? e : new lr()), (this.radius = void 0 !== t ? t : -1) } var t = e.prototype return ( (t.set = function (e, t) { return this.center.copy(e), (this.radius = t), this }), (t.setFromPoints = function (e, t) { var n = this.center void 0 !== t ? n.copy(t) : Tr.setFromPoints(e).getCenter(n) for (var r = 0, i = 0, o = e.length; i < o; i++) r = Math.max(r, n.distanceToSquared(e[i])) return (this.radius = Math.sqrt(r)), this }), (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { return this.center.copy(e.center), (this.radius = e.radius), this }), (t.isEmpty = function () { return this.radius < 0 }), (t.makeEmpty = function () { return this.center.set(0, 0, 0), (this.radius = -1), this }), (t.containsPoint = function (e) { return e.distanceToSquared(this.center) <= this.radius * this.radius }), (t.distanceToPoint = function (e) { return e.distanceTo(this.center) - this.radius }), (t.intersectsSphere = function (e) { var t = this.radius + e.radius return e.center.distanceToSquared(this.center) <= t * t }), (t.intersectsBox = function (e) { return e.intersectsSphere(this) }), (t.intersectsPlane = function (e) { return Math.abs(e.distanceToPoint(this.center)) <= this.radius }), (t.clampPoint = function (e, t) { var n = this.center.distanceToSquared(e) return ( void 0 === t && (console.warn('THREE.Sphere: .clampPoint() target is now required'), (t = new lr())), t.copy(e), n > this.radius * this.radius && (t.sub(this.center).normalize(), t.multiplyScalar(this.radius).add(this.center)), t ) }), (t.getBoundingBox = function (e) { return ( void 0 === e && (console.warn( 'THREE.Sphere: .getBoundingBox() target is now required', ), (e = new hr())), this.isEmpty() ? (e.makeEmpty(), e) : (e.set(this.center, this.center), e.expandByScalar(this.radius), e) ) }), (t.applyMatrix4 = function (e) { return ( this.center.applyMatrix4(e), (this.radius = this.radius * e.getMaxScaleOnAxis()), this ) }), (t.translate = function (e) { return this.center.add(e), this }), (t.equals = function (e) { return e.center.equals(this.center) && e.radius === this.radius }), e ) })(), Cr = new lr(), Lr = new lr(), Rr = new lr(), Pr = new lr(), Dr = new lr(), Or = new lr(), Ir = new lr(), Br = (function () { function e(e, t) { ;(this.origin = void 0 !== e ? e : new lr()), (this.direction = void 0 !== t ? t : new lr(0, 0, -1)) } var t = e.prototype return ( (t.set = function (e, t) { return this.origin.copy(e), this.direction.copy(t), this }), (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { return ( this.origin.copy(e.origin), this.direction.copy(e.direction), this ) }), (t.at = function (e, t) { return ( void 0 === t && (console.warn('THREE.Ray: .at() target is now required'), (t = new lr())), t.copy(this.direction).multiplyScalar(e).add(this.origin) ) }), (t.lookAt = function (e) { return this.direction.copy(e).sub(this.origin).normalize(), this }), (t.recast = function (e) { return this.origin.copy(this.at(e, Cr)), this }), (t.closestPointToPoint = function (e, t) { void 0 === t && (console.warn( 'THREE.Ray: .closestPointToPoint() target is now required', ), (t = new lr())), t.subVectors(e, this.origin) var n = t.dot(this.direction) return n < 0 ? t.copy(this.origin) : t.copy(this.direction).multiplyScalar(n).add(this.origin) }), (t.distanceToPoint = function (e) { return Math.sqrt(this.distanceSqToPoint(e)) }), (t.distanceSqToPoint = function (e) { var t = Cr.subVectors(e, this.origin).dot(this.direction) return t < 0 ? this.origin.distanceToSquared(e) : (Cr.copy(this.direction).multiplyScalar(t).add(this.origin), Cr.distanceToSquared(e)) }), (t.distanceSqToSegment = function (e, t, n, r) { Lr.copy(e).add(t).multiplyScalar(0.5), Rr.copy(t).sub(e).normalize(), Pr.copy(this.origin).sub(Lr) var i, o, a, s, l = 0.5 * e.distanceTo(t), c = -this.direction.dot(Rr), u = Pr.dot(this.direction), h = -Pr.dot(Rr), d = Pr.lengthSq(), p = Math.abs(1 - c * c) if (p > 0) if (((o = c * u - h), (s = l * p), (i = c * h - u) >= 0)) if (o >= -s) if (o <= s) { var f = 1 / p a = (i *= f) * (i + c * (o *= f) + 2 * u) + o * (c * i + o + 2 * h) + d } else (o = l), (a = -(i = Math.max(0, -(c * o + u))) * i + o * (o + 2 * h) + d) else (o = -l), (a = -(i = Math.max(0, -(c * o + u))) * i + o * (o + 2 * h) + d) else o <= -s ? (a = -(i = Math.max(0, -(-c * l + u))) * i + (o = i > 0 ? -l : Math.min(Math.max(-l, -h), l)) * (o + 2 * h) + d) : o <= s ? ((i = 0), (a = (o = Math.min(Math.max(-l, -h), l)) * (o + 2 * h) + d)) : (a = -(i = Math.max(0, -(c * l + u))) * i + (o = i > 0 ? l : Math.min(Math.max(-l, -h), l)) * (o + 2 * h) + d) else (o = c > 0 ? -l : l), (a = -(i = Math.max(0, -(c * o + u))) * i + o * (o + 2 * h) + d) return ( n && n.copy(this.direction).multiplyScalar(i).add(this.origin), r && r.copy(Rr).multiplyScalar(o).add(Lr), a ) }), (t.intersectSphere = function (e, t) { Cr.subVectors(e.center, this.origin) var n = Cr.dot(this.direction), r = Cr.dot(Cr) - n * n, i = e.radius * e.radius if (r > i) return null var o = Math.sqrt(i - r), a = n - o, s = n + o return a < 0 && s < 0 ? null : a < 0 ? this.at(s, t) : this.at(a, t) }), (t.intersectsSphere = function (e) { return this.distanceSqToPoint(e.center) <= e.radius * e.radius }), (t.distanceToPlane = function (e) { var t = e.normal.dot(this.direction) if (0 === t) return 0 === e.distanceToPoint(this.origin) ? 0 : null var n = -(this.origin.dot(e.normal) + e.constant) / t return n >= 0 ? n : null }), (t.intersectPlane = function (e, t) { var n = this.distanceToPlane(e) return null === n ? null : this.at(n, t) }), (t.intersectsPlane = function (e) { var t = e.distanceToPoint(this.origin) return 0 === t || e.normal.dot(this.direction) * t < 0 }), (t.intersectBox = function (e, t) { var n, r, i, o, a, s, l = 1 / this.direction.x, c = 1 / this.direction.y, u = 1 / this.direction.z, h = this.origin return ( l >= 0 ? ((n = (e.min.x - h.x) * l), (r = (e.max.x - h.x) * l)) : ((n = (e.max.x - h.x) * l), (r = (e.min.x - h.x) * l)), c >= 0 ? ((i = (e.min.y - h.y) * c), (o = (e.max.y - h.y) * c)) : ((i = (e.max.y - h.y) * c), (o = (e.min.y - h.y) * c)), n > o || i > r ? null : ((i > n || n !== n) && (n = i), (o < r || r !== r) && (r = o), u >= 0 ? ((a = (e.min.z - h.z) * u), (s = (e.max.z - h.z) * u)) : ((a = (e.max.z - h.z) * u), (s = (e.min.z - h.z) * u)), n > s || a > r ? null : ((a > n || n !== n) && (n = a), (s < r || r !== r) && (r = s), r < 0 ? null : this.at(n >= 0 ? n : r, t))) ) }), (t.intersectsBox = function (e) { return null !== this.intersectBox(e, Cr) }), (t.intersectTriangle = function (e, t, n, r, i) { Dr.subVectors(t, e), Or.subVectors(n, e), Ir.crossVectors(Dr, Or) var o, a = this.direction.dot(Ir) if (a > 0) { if (r) return null o = 1 } else { if (!(a < 0)) return null ;(o = -1), (a = -a) } Pr.subVectors(this.origin, e) var s = o * this.direction.dot(Or.crossVectors(Pr, Or)) if (s < 0) return null var l = o * this.direction.dot(Dr.cross(Pr)) if (l < 0) return null if (s + l > a) return null var c = -o * Pr.dot(Ir) return c < 0 ? null : this.at(c / a, i) }), (t.applyMatrix4 = function (e) { return ( this.origin.applyMatrix4(e), this.direction.transformDirection(e), this ) }), (t.equals = function (e) { return ( e.origin.equals(this.origin) && e.direction.equals(this.direction) ) }), e ) })(), Fr = (function () { function e() { Object.defineProperty(this, 'isMatrix4', { value: !0 }), (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.', ) } var t = e.prototype return ( (t.set = function (e, t, n, r, i, o, a, s, l, c, u, h, d, p, f, m) { var v = this.elements return ( (v[0] = e), (v[4] = t), (v[8] = n), (v[12] = r), (v[1] = i), (v[5] = o), (v[9] = a), (v[13] = s), (v[2] = l), (v[6] = c), (v[10] = u), (v[14] = h), (v[3] = d), (v[7] = p), (v[11] = f), (v[15] = m), this ) }), (t.identity = function () { return this.set(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1), this }), (t.clone = function () { return new e().fromArray(this.elements) }), (t.copy = function (e) { var t = this.elements, n = e.elements return ( (t[0] = n[0]), (t[1] = n[1]), (t[2] = n[2]), (t[3] = n[3]), (t[4] = n[4]), (t[5] = n[5]), (t[6] = n[6]), (t[7] = n[7]), (t[8] = n[8]), (t[9] = n[9]), (t[10] = n[10]), (t[11] = n[11]), (t[12] = n[12]), (t[13] = n[13]), (t[14] = n[14]), (t[15] = n[15]), this ) }), (t.copyPosition = function (e) { var t = this.elements, n = e.elements return (t[12] = n[12]), (t[13] = n[13]), (t[14] = n[14]), this }), (t.setFromMatrix3 = function (e) { var t = e.elements return ( this.set( t[0], t[3], t[6], 0, t[1], t[4], t[7], 0, t[2], t[5], t[8], 0, 0, 0, 0, 1, ), this ) }), (t.extractBasis = function (e, t, n) { return ( e.setFromMatrixColumn(this, 0), t.setFromMatrixColumn(this, 1), n.setFromMatrixColumn(this, 2), this ) }), (t.makeBasis = function (e, t, n) { return ( this.set( e.x, t.x, n.x, 0, e.y, t.y, n.y, 0, e.z, t.z, n.z, 0, 0, 0, 0, 1, ), this ) }), (t.extractRotation = function (e) { var t = this.elements, n = e.elements, r = 1 / kr.setFromMatrixColumn(e, 0).length(), i = 1 / kr.setFromMatrixColumn(e, 1).length(), o = 1 / kr.setFromMatrixColumn(e, 2).length() return ( (t[0] = n[0] * r), (t[1] = n[1] * r), (t[2] = n[2] * r), (t[3] = 0), (t[4] = n[4] * i), (t[5] = n[5] * i), (t[6] = n[6] * i), (t[7] = 0), (t[8] = n[8] * o), (t[9] = n[9] * o), (t[10] = n[10] * o), (t[11] = 0), (t[12] = 0), (t[13] = 0), (t[14] = 0), (t[15] = 1), this ) }), (t.makeRotationFromEuler = function (e) { ;(e && e.isEuler) || console.error( 'THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order.', ) var t = this.elements, n = e.x, r = e.y, i = e.z, o = Math.cos(n), a = Math.sin(n), s = Math.cos(r), l = Math.sin(r), c = Math.cos(i), u = Math.sin(i) if ('XYZ' === e.order) { var h = o * c, d = o * u, p = a * c, f = a * u ;(t[0] = s * c), (t[4] = -s * u), (t[8] = l), (t[1] = d + p * l), (t[5] = h - f * l), (t[9] = -a * s), (t[2] = f - h * l), (t[6] = p + d * l), (t[10] = o * s) } else if ('YXZ' === e.order) { var m = s * c, v = s * u, g = l * c, y = l * u ;(t[0] = m + y * a), (t[4] = g * a - v), (t[8] = o * l), (t[1] = o * u), (t[5] = o * c), (t[9] = -a), (t[2] = v * a - g), (t[6] = y + m * a), (t[10] = o * s) } else if ('ZXY' === e.order) { var b = s * c, A = s * u, w = l * c, x = l * u ;(t[0] = b - x * a), (t[4] = -o * u), (t[8] = w + A * a), (t[1] = A + w * a), (t[5] = o * c), (t[9] = x - b * a), (t[2] = -o * l), (t[6] = a), (t[10] = o * s) } else if ('ZYX' === e.order) { var E = o * c, M = o * u, _ = a * c, T = a * u ;(t[0] = s * c), (t[4] = _ * l - M), (t[8] = E * l + T), (t[1] = s * u), (t[5] = T * l + E), (t[9] = M * l - _), (t[2] = -l), (t[6] = a * s), (t[10] = o * s) } else if ('YZX' === e.order) { var S = o * s, C = o * l, L = a * s, R = a * l ;(t[0] = s * c), (t[4] = R - S * u), (t[8] = L * u + C), (t[1] = u), (t[5] = o * c), (t[9] = -a * c), (t[2] = -l * c), (t[6] = C * u + L), (t[10] = S - R * u) } else if ('XZY' === e.order) { var P = o * s, D = o * l, O = a * s, I = a * l ;(t[0] = s * c), (t[4] = -u), (t[8] = l * c), (t[1] = P * u + I), (t[5] = o * c), (t[9] = D * u - O), (t[2] = O * u - D), (t[6] = a * c), (t[10] = I * u + P) } return ( (t[3] = 0), (t[7] = 0), (t[11] = 0), (t[12] = 0), (t[13] = 0), (t[14] = 0), (t[15] = 1), this ) }), (t.makeRotationFromQuaternion = function (e) { return this.compose(Ur, e, Hr) }), (t.lookAt = function (e, t, n) { var r = this.elements return ( jr.subVectors(e, t), 0 === jr.lengthSq() && (jr.z = 1), jr.normalize(), Gr.crossVectors(n, jr), 0 === Gr.lengthSq() && (1 === Math.abs(n.z) ? (jr.x += 1e-4) : (jr.z += 1e-4), jr.normalize(), Gr.crossVectors(n, jr)), Gr.normalize(), zr.crossVectors(jr, Gr), (r[0] = Gr.x), (r[4] = zr.x), (r[8] = jr.x), (r[1] = Gr.y), (r[5] = zr.y), (r[9] = jr.y), (r[2] = Gr.z), (r[6] = zr.z), (r[10] = jr.z), this ) }), (t.multiply = function (e, t) { return void 0 !== t ? (console.warn( 'THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead.', ), this.multiplyMatrices(e, t)) : this.multiplyMatrices(this, e) }), (t.premultiply = function (e) { return this.multiplyMatrices(e, this) }), (t.multiplyMatrices = function (e, t) { var n = e.elements, r = t.elements, i = this.elements, o = n[0], a = n[4], s = n[8], l = n[12], c = n[1], u = n[5], h = n[9], d = n[13], p = n[2], f = n[6], m = n[10], v = n[14], g = n[3], y = n[7], b = n[11], A = n[15], w = r[0], x = r[4], E = r[8], M = r[12], _ = r[1], T = r[5], S = r[9], C = r[13], L = r[2], R = r[6], P = r[10], D = r[14], O = r[3], I = r[7], B = r[11], F = r[15] return ( (i[0] = o * w + a * _ + s * L + l * O), (i[4] = o * x + a * T + s * R + l * I), (i[8] = o * E + a * S + s * P + l * B), (i[12] = o * M + a * C + s * D + l * F), (i[1] = c * w + u * _ + h * L + d * O), (i[5] = c * x + u * T + h * R + d * I), (i[9] = c * E + u * S + h * P + d * B), (i[13] = c * M + u * C + h * D + d * F), (i[2] = p * w + f * _ + m * L + v * O), (i[6] = p * x + f * T + m * R + v * I), (i[10] = p * E + f * S + m * P + v * B), (i[14] = p * M + f * C + m * D + v * F), (i[3] = g * w + y * _ + b * L + A * O), (i[7] = g * x + y * T + b * R + A * I), (i[11] = g * E + y * S + b * P + A * B), (i[15] = g * M + y * C + b * D + A * F), this ) }), (t.multiplyScalar = function (e) { var t = this.elements return ( (t[0] *= e), (t[4] *= e), (t[8] *= e), (t[12] *= e), (t[1] *= e), (t[5] *= e), (t[9] *= e), (t[13] *= e), (t[2] *= e), (t[6] *= e), (t[10] *= e), (t[14] *= e), (t[3] *= e), (t[7] *= e), (t[11] *= e), (t[15] *= e), this ) }), (t.determinant = function () { var e = this.elements, t = e[0], n = e[4], r = e[8], i = e[12], o = e[1], a = e[5], s = e[9], l = e[13], c = e[2], u = e[6], h = e[10], d = e[14] return ( e[3] * (+i * s * u - r * l * u - i * a * h + n * l * h + r * a * d - n * s * d) + e[7] * (+t * s * d - t * l * h + i * o * h - r * o * d + r * l * c - i * s * c) + e[11] * (+t * l * u - t * a * d - i * o * u + n * o * d + i * a * c - n * l * c) + e[15] * (-r * a * c - t * s * u + t * a * h + r * o * u - n * o * h + n * s * c) ) }), (t.transpose = function () { var e, t = this.elements return ( (e = t[1]), (t[1] = t[4]), (t[4] = e), (e = t[2]), (t[2] = t[8]), (t[8] = e), (e = t[6]), (t[6] = t[9]), (t[9] = e), (e = t[3]), (t[3] = t[12]), (t[12] = e), (e = t[7]), (t[7] = t[13]), (t[13] = e), (e = t[11]), (t[11] = t[14]), (t[14] = e), this ) }), (t.setPosition = function (e, t, n) { var r = this.elements return ( e.isVector3 ? ((r[12] = e.x), (r[13] = e.y), (r[14] = e.z)) : ((r[12] = e), (r[13] = t), (r[14] = n)), this ) }), (t.invert = function () { var e = this.elements, t = e[0], n = e[1], r = e[2], i = e[3], o = e[4], a = e[5], s = e[6], l = e[7], c = e[8], u = e[9], h = e[10], d = e[11], p = e[12], f = e[13], m = e[14], v = e[15], g = u * m * l - f * h * l + f * s * d - a * m * d - u * s * v + a * h * v, y = p * h * l - c * m * l - p * s * d + o * m * d + c * s * v - o * h * v, b = c * f * l - p * u * l + p * a * d - o * f * d - c * a * v + o * u * v, A = p * u * s - c * f * s - p * a * h + o * f * h + c * a * m - o * u * m, w = t * g + n * y + r * b + i * A if (0 === w) return this.set(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0) var x = 1 / w return ( (e[0] = g * x), (e[1] = (f * h * i - u * m * i - f * r * d + n * m * d + u * r * v - n * h * v) * x), (e[2] = (a * m * i - f * s * i + f * r * l - n * m * l - a * r * v + n * s * v) * x), (e[3] = (u * s * i - a * h * i - u * r * l + n * h * l + a * r * d - n * s * d) * x), (e[4] = y * x), (e[5] = (c * m * i - p * h * i + p * r * d - t * m * d - c * r * v + t * h * v) * x), (e[6] = (p * s * i - o * m * i - p * r * l + t * m * l + o * r * v - t * s * v) * x), (e[7] = (o * h * i - c * s * i + c * r * l - t * h * l - o * r * d + t * s * d) * x), (e[8] = b * x), (e[9] = (p * u * i - c * f * i - p * n * d + t * f * d + c * n * v - t * u * v) * x), (e[10] = (o * f * i - p * a * i + p * n * l - t * f * l - o * n * v + t * a * v) * x), (e[11] = (c * a * i - o * u * i - c * n * l + t * u * l + o * n * d - t * a * d) * x), (e[12] = A * x), (e[13] = (c * f * r - p * u * r + p * n * h - t * f * h - c * n * m + t * u * m) * x), (e[14] = (p * a * r - o * f * r - p * n * s + t * f * s + o * n * m - t * a * m) * x), (e[15] = (o * u * r - c * a * r + c * n * s - t * u * s - o * n * h + t * a * h) * x), this ) }), (t.scale = function (e) { var t = this.elements, n = e.x, r = e.y, i = e.z return ( (t[0] *= n), (t[4] *= r), (t[8] *= i), (t[1] *= n), (t[5] *= r), (t[9] *= i), (t[2] *= n), (t[6] *= r), (t[10] *= i), (t[3] *= n), (t[7] *= r), (t[11] *= i), this ) }), (t.getMaxScaleOnAxis = function () { var e = this.elements, t = e[0] * e[0] + e[1] * e[1] + e[2] * e[2], n = e[4] * e[4] + e[5] * e[5] + e[6] * e[6], r = e[8] * e[8] + e[9] * e[9] + e[10] * e[10] return Math.sqrt(Math.max(t, n, r)) }), (t.makeTranslation = function (e, t, n) { return this.set(1, 0, 0, e, 0, 1, 0, t, 0, 0, 1, n, 0, 0, 0, 1), this }), (t.makeRotationX = function (e) { var t = Math.cos(e), n = Math.sin(e) return this.set(1, 0, 0, 0, 0, t, -n, 0, 0, n, t, 0, 0, 0, 0, 1), this }), (t.makeRotationY = function (e) { var t = Math.cos(e), n = Math.sin(e) return this.set(t, 0, n, 0, 0, 1, 0, 0, -n, 0, t, 0, 0, 0, 0, 1), this }), (t.makeRotationZ = function (e) { var t = Math.cos(e), n = Math.sin(e) return this.set(t, -n, 0, 0, n, t, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1), this }), (t.makeRotationAxis = function (e, t) { var n = Math.cos(t), r = Math.sin(t), i = 1 - n, o = e.x, a = e.y, s = e.z, l = i * o, c = i * a return ( this.set( l * o + n, l * a - r * s, l * s + r * a, 0, l * a + r * s, c * a + n, c * s - r * o, 0, l * s - r * a, c * s + r * o, i * s * s + n, 0, 0, 0, 0, 1, ), this ) }), (t.makeScale = function (e, t, n) { return this.set(e, 0, 0, 0, 0, t, 0, 0, 0, 0, n, 0, 0, 0, 0, 1), this }), (t.makeShear = function (e, t, n) { return this.set(1, t, n, 0, e, 1, n, 0, e, t, 1, 0, 0, 0, 0, 1), this }), (t.compose = function (e, t, n) { var r = this.elements, i = t._x, o = t._y, a = t._z, s = t._w, l = i + i, c = o + o, u = a + a, h = i * l, d = i * c, p = i * u, f = o * c, m = o * u, v = a * u, g = s * l, y = s * c, b = s * u, A = n.x, w = n.y, x = n.z return ( (r[0] = (1 - (f + v)) * A), (r[1] = (d + b) * A), (r[2] = (p - y) * A), (r[3] = 0), (r[4] = (d - b) * w), (r[5] = (1 - (h + v)) * w), (r[6] = (m + g) * w), (r[7] = 0), (r[8] = (p + y) * x), (r[9] = (m - g) * x), (r[10] = (1 - (h + f)) * x), (r[11] = 0), (r[12] = e.x), (r[13] = e.y), (r[14] = e.z), (r[15] = 1), this ) }), (t.decompose = function (e, t, n) { var r = this.elements, i = kr.set(r[0], r[1], r[2]).length(), o = kr.set(r[4], r[5], r[6]).length(), a = kr.set(r[8], r[9], r[10]).length() this.determinant() < 0 && (i = -i), (e.x = r[12]), (e.y = r[13]), (e.z = r[14]), Nr.copy(this) var s = 1 / i, l = 1 / o, c = 1 / a return ( (Nr.elements[0] *= s), (Nr.elements[1] *= s), (Nr.elements[2] *= s), (Nr.elements[4] *= l), (Nr.elements[5] *= l), (Nr.elements[6] *= l), (Nr.elements[8] *= c), (Nr.elements[9] *= c), (Nr.elements[10] *= c), t.setFromRotationMatrix(Nr), (n.x = i), (n.y = o), (n.z = a), this ) }), (t.makePerspective = function (e, t, n, r, i, o) { void 0 === o && console.warn( 'THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs.', ) var a = this.elements, s = (2 * i) / (t - e), l = (2 * i) / (n - r), c = (t + e) / (t - e), u = (n + r) / (n - r), h = -(o + i) / (o - i), d = (-2 * o * i) / (o - i) return ( (a[0] = s), (a[4] = 0), (a[8] = c), (a[12] = 0), (a[1] = 0), (a[5] = l), (a[9] = u), (a[13] = 0), (a[2] = 0), (a[6] = 0), (a[10] = h), (a[14] = d), (a[3] = 0), (a[7] = 0), (a[11] = -1), (a[15] = 0), this ) }), (t.makeOrthographic = function (e, t, n, r, i, o) { var a = this.elements, s = 1 / (t - e), l = 1 / (n - r), c = 1 / (o - i), u = (t + e) * s, h = (n + r) * l, d = (o + i) * c return ( (a[0] = 2 * s), (a[4] = 0), (a[8] = 0), (a[12] = -u), (a[1] = 0), (a[5] = 2 * l), (a[9] = 0), (a[13] = -h), (a[2] = 0), (a[6] = 0), (a[10] = -2 * c), (a[14] = -d), (a[3] = 0), (a[7] = 0), (a[11] = 0), (a[15] = 1), this ) }), (t.equals = function (e) { for (var t = this.elements, n = e.elements, r = 0; r < 16; r++) if (t[r] !== n[r]) return !1 return !0 }), (t.fromArray = function (e, t) { void 0 === t && (t = 0) for (var n = 0; n < 16; n++) this.elements[n] = e[n + t] return this }), (t.toArray = function (e, t) { void 0 === e && (e = []), void 0 === t && (t = 0) var n = this.elements return ( (e[t] = n[0]), (e[t + 1] = n[1]), (e[t + 2] = n[2]), (e[t + 3] = n[3]), (e[t + 4] = n[4]), (e[t + 5] = n[5]), (e[t + 6] = n[6]), (e[t + 7] = n[7]), (e[t + 8] = n[8]), (e[t + 9] = n[9]), (e[t + 10] = n[10]), (e[t + 11] = n[11]), (e[t + 12] = n[12]), (e[t + 13] = n[13]), (e[t + 14] = n[14]), (e[t + 15] = n[15]), e ) }), e ) })(), kr = new lr(), Nr = new Fr(), Ur = new lr(0, 0, 0), Hr = new lr(1, 1, 1), Gr = new lr(), zr = new lr(), jr = new lr(), Vr = (function () { function e(t, n, r, i) { void 0 === t && (t = 0), void 0 === n && (n = 0), void 0 === r && (r = 0), void 0 === i && (i = e.DefaultOrder), Object.defineProperty(this, 'isEuler', { value: !0 }), (this._x = t), (this._y = n), (this._z = r), (this._order = i) } var t = e.prototype return ( (t.set = function (e, t, n, r) { return ( (this._x = e), (this._y = t), (this._z = n), (this._order = r || this._order), this._onChangeCallback(), this ) }), (t.clone = function () { return new this.constructor(this._x, this._y, this._z, this._order) }), (t.copy = function (e) { return ( (this._x = e._x), (this._y = e._y), (this._z = e._z), (this._order = e._order), this._onChangeCallback(), this ) }), (t.setFromRotationMatrix = function (e, t, n) { var r = Kn.clamp, i = e.elements, o = i[0], a = i[4], s = i[8], l = i[1], c = i[5], u = i[9], h = i[2], d = i[6], p = i[10] switch ((t = t || this._order)) { case 'XYZ': ;(this._y = Math.asin(r(s, -1, 1))), Math.abs(s) < 0.9999999 ? ((this._x = Math.atan2(-u, p)), (this._z = Math.atan2(-a, o))) : ((this._x = Math.atan2(d, c)), (this._z = 0)) break case 'YXZ': ;(this._x = Math.asin(-r(u, -1, 1))), Math.abs(u) < 0.9999999 ? ((this._y = Math.atan2(s, p)), (this._z = Math.atan2(l, c))) : ((this._y = Math.atan2(-h, o)), (this._z = 0)) break case 'ZXY': ;(this._x = Math.asin(r(d, -1, 1))), Math.abs(d) < 0.9999999 ? ((this._y = Math.atan2(-h, p)), (this._z = Math.atan2(-a, c))) : ((this._y = 0), (this._z = Math.atan2(l, o))) break case 'ZYX': ;(this._y = Math.asin(-r(h, -1, 1))), Math.abs(h) < 0.9999999 ? ((this._x = Math.atan2(d, p)), (this._z = Math.atan2(l, o))) : ((this._x = 0), (this._z = Math.atan2(-a, c))) break case 'YZX': ;(this._z = Math.asin(r(l, -1, 1))), Math.abs(l) < 0.9999999 ? ((this._x = Math.atan2(-u, c)), (this._y = Math.atan2(-h, o))) : ((this._x = 0), (this._y = Math.atan2(s, p))) break case 'XZY': ;(this._z = Math.asin(-r(a, -1, 1))), Math.abs(a) < 0.9999999 ? ((this._x = Math.atan2(d, c)), (this._y = Math.atan2(s, o))) : ((this._x = Math.atan2(-u, p)), (this._y = 0)) break default: console.warn( 'THREE.Euler: .setFromRotationMatrix() encountered an unknown order: ' + t, ) } return (this._order = t), !1 !== n && this._onChangeCallback(), this }), (t.setFromQuaternion = function (e, t, n) { return ( Wr.makeRotationFromQuaternion(e), this.setFromRotationMatrix(Wr, t, n) ) }), (t.setFromVector3 = function (e, t) { return this.set(e.x, e.y, e.z, t || this._order) }), (t.reorder = function (e) { return qr.setFromEuler(this), this.setFromQuaternion(qr, e) }), (t.equals = function (e) { return ( e._x === this._x && e._y === this._y && e._z === this._z && e._order === this._order ) }), (t.fromArray = function (e) { return ( (this._x = e[0]), (this._y = e[1]), (this._z = e[2]), void 0 !== e[3] && (this._order = e[3]), this._onChangeCallback(), this ) }), (t.toArray = function (e, t) { return ( void 0 === e && (e = []), void 0 === t && (t = 0), (e[t] = this._x), (e[t + 1] = this._y), (e[t + 2] = this._z), (e[t + 3] = this._order), e ) }), (t.toVector3 = function (e) { return e ? e.set(this._x, this._y, this._z) : new lr(this._x, this._y, this._z) }), (t._onChange = function (e) { return (this._onChangeCallback = e), this }), (t._onChangeCallback = function () {}), Hn(e, [ { key: 'x', get: function () { return this._x }, set: function (e) { ;(this._x = e), this._onChangeCallback() }, }, { key: 'y', get: function () { return this._y }, set: function (e) { ;(this._y = e), this._onChangeCallback() }, }, { key: 'z', get: function () { return this._z }, set: function (e) { ;(this._z = e), this._onChangeCallback() }, }, { key: 'order', get: function () { return this._order }, set: function (e) { ;(this._order = e), this._onChangeCallback() }, }, ]), e ) })() ;(Vr.DefaultOrder = 'XYZ'), (Vr.RotationOrders = ['XYZ', 'YZX', 'ZXY', 'XZY', 'YXZ', 'ZYX']) var Wr = new Fr(), qr = new sr(), Xr = (function () { function e() { this.mask = 1 } var t = e.prototype return ( (t.set = function (e) { this.mask = (1 << e) | 0 }), (t.enable = function (e) { this.mask |= (1 << e) | 0 }), (t.enableAll = function () { this.mask = -1 }), (t.toggle = function (e) { this.mask ^= (1 << e) | 0 }), (t.disable = function (e) { this.mask &= ~((1 << e) | 0) }), (t.disableAll = function () { this.mask = 0 }), (t.test = function (e) { return 0 !== (this.mask & e.mask) }), e ) })(), Yr = 0, Qr = new lr(), Zr = new sr(), Kr = new Fr(), Jr = new lr(), $r = new lr(), ei = new lr(), ti = new sr(), ni = new lr(1, 0, 0), ri = new lr(0, 1, 0), ii = new lr(0, 0, 1), oi = { type: 'added' }, ai = { type: 'removed' } function si() { Object.defineProperty(this, 'id', { value: Yr++ }), (this.uuid = Kn.generateUUID()), (this.name = ''), (this.type = 'Object3D'), (this.parent = null), (this.children = []), (this.up = si.DefaultUp.clone()) var e = new lr(), t = new Vr(), n = new sr(), r = new lr(1, 1, 1) function i() { n.setFromEuler(t, !1) } function o() { t.setFromQuaternion(n, void 0, !1) } t._onChange(i), n._onChange(o), Object.defineProperties(this, { position: { configurable: !0, enumerable: !0, value: e }, rotation: { configurable: !0, enumerable: !0, value: t }, quaternion: { configurable: !0, enumerable: !0, value: n }, scale: { configurable: !0, enumerable: !0, value: r }, modelViewMatrix: { value: new Fr() }, normalMatrix: { value: new $n() }, }), (this.matrix = new Fr()), (this.matrixWorld = new Fr()), (this.matrixAutoUpdate = si.DefaultMatrixAutoUpdate), (this.matrixWorldNeedsUpdate = !1), (this.layers = new Xr()), (this.visible = !0), (this.castShadow = !1), (this.receiveShadow = !1), (this.frustumCulled = !0), (this.renderOrder = 0), (this.animations = []), (this.userData = {}) } ;(si.DefaultUp = new lr(0, 1, 0)), (si.DefaultMatrixAutoUpdate = !0), (si.prototype = Object.assign(Object.create(qn.prototype), { constructor: si, isObject3D: !0, onBeforeRender: function () {}, onAfterRender: function () {}, applyMatrix4: function (e) { this.matrixAutoUpdate && this.updateMatrix(), this.matrix.premultiply(e), this.matrix.decompose(this.position, this.quaternion, this.scale) }, applyQuaternion: function (e) { return this.quaternion.premultiply(e), this }, setRotationFromAxisAngle: function (e, t) { this.quaternion.setFromAxisAngle(e, t) }, setRotationFromEuler: function (e) { this.quaternion.setFromEuler(e, !0) }, setRotationFromMatrix: function (e) { this.quaternion.setFromRotationMatrix(e) }, setRotationFromQuaternion: function (e) { this.quaternion.copy(e) }, rotateOnAxis: function (e, t) { return Zr.setFromAxisAngle(e, t), this.quaternion.multiply(Zr), this }, rotateOnWorldAxis: function (e, t) { return Zr.setFromAxisAngle(e, t), this.quaternion.premultiply(Zr), this }, rotateX: function (e) { return this.rotateOnAxis(ni, e) }, rotateY: function (e) { return this.rotateOnAxis(ri, e) }, rotateZ: function (e) { return this.rotateOnAxis(ii, e) }, translateOnAxis: function (e, t) { return ( Qr.copy(e).applyQuaternion(this.quaternion), this.position.add(Qr.multiplyScalar(t)), this ) }, translateX: function (e) { return this.translateOnAxis(ni, e) }, translateY: function (e) { return this.translateOnAxis(ri, e) }, translateZ: function (e) { return this.translateOnAxis(ii, e) }, localToWorld: function (e) { return e.applyMatrix4(this.matrixWorld) }, worldToLocal: function (e) { return e.applyMatrix4(Kr.copy(this.matrixWorld).invert()) }, lookAt: function (e, t, n) { e.isVector3 ? Jr.copy(e) : Jr.set(e, t, n) var r = this.parent this.updateWorldMatrix(!0, !1), $r.setFromMatrixPosition(this.matrixWorld), this.isCamera || this.isLight ? Kr.lookAt($r, Jr, this.up) : Kr.lookAt(Jr, $r, this.up), this.quaternion.setFromRotationMatrix(Kr), r && (Kr.extractRotation(r.matrixWorld), Zr.setFromRotationMatrix(Kr), this.quaternion.premultiply(Zr.invert())) }, add: function (e) { if (arguments.length > 1) { for (var t = 0; t < arguments.length; t++) this.add(arguments[t]) return this } return e === this ? (console.error( "THREE.Object3D.add: object can't be added as a child of itself.", e, ), this) : (e && e.isObject3D ? (null !== e.parent && e.parent.remove(e), (e.parent = this), this.children.push(e), e.dispatchEvent(oi)) : console.error( 'THREE.Object3D.add: object not an instance of THREE.Object3D.', e, ), this) }, remove: function (e) { if (arguments.length > 1) { for (var t = 0; t < arguments.length; t++) this.remove(arguments[t]) return this } var n = this.children.indexOf(e) return ( -1 !== n && ((e.parent = null), this.children.splice(n, 1), e.dispatchEvent(ai)), this ) }, clear: function () { for (var e = 0; e < this.children.length; e++) { var t = this.children[e] ;(t.parent = null), t.dispatchEvent(ai) } return (this.children.length = 0), this }, attach: function (e) { return ( this.updateWorldMatrix(!0, !1), Kr.copy(this.matrixWorld).invert(), null !== e.parent && (e.parent.updateWorldMatrix(!0, !1), Kr.multiply(e.parent.matrixWorld)), e.applyMatrix4(Kr), e.updateWorldMatrix(!1, !1), this.add(e), this ) }, getObjectById: function (e) { return this.getObjectByProperty('id', e) }, getObjectByName: function (e) { return this.getObjectByProperty('name', e) }, getObjectByProperty: function (e, t) { if (this[e] === t) return this for (var n = 0, r = this.children.length; n < r; n++) { var i = this.children[n].getObjectByProperty(e, t) if (void 0 !== i) return i } }, getWorldPosition: function (e) { return ( void 0 === e && (console.warn( 'THREE.Object3D: .getWorldPosition() target is now required', ), (e = new lr())), this.updateWorldMatrix(!0, !1), e.setFromMatrixPosition(this.matrixWorld) ) }, getWorldQuaternion: function (e) { return ( void 0 === e && (console.warn( 'THREE.Object3D: .getWorldQuaternion() target is now required', ), (e = new sr())), this.updateWorldMatrix(!0, !1), this.matrixWorld.decompose($r, e, ei), e ) }, getWorldScale: function (e) { return ( void 0 === e && (console.warn( 'THREE.Object3D: .getWorldScale() target is now required', ), (e = new lr())), this.updateWorldMatrix(!0, !1), this.matrixWorld.decompose($r, ti, e), e ) }, getWorldDirection: function (e) { void 0 === e && (console.warn( 'THREE.Object3D: .getWorldDirection() target is now required', ), (e = new lr())), this.updateWorldMatrix(!0, !1) var t = this.matrixWorld.elements return e.set(t[8], t[9], t[10]).normalize() }, raycast: function () {}, traverse: function (e) { e(this) for (var t = this.children, n = 0, r = t.length; n < r; n++) t[n].traverse(e) }, traverseVisible: function (e) { if (!1 !== this.visible) { e(this) for (var t = this.children, n = 0, r = t.length; n < r; n++) t[n].traverseVisible(e) } }, traverseAncestors: function (e) { var t = this.parent null !== t && (e(t), t.traverseAncestors(e)) }, updateMatrix: function () { this.matrix.compose(this.position, this.quaternion, this.scale), (this.matrixWorldNeedsUpdate = !0) }, updateMatrixWorld: function (e) { this.matrixAutoUpdate && this.updateMatrix(), (this.matrixWorldNeedsUpdate || e) && (null === this.parent ? this.matrixWorld.copy(this.matrix) : this.matrixWorld.multiplyMatrices( this.parent.matrixWorld, this.matrix, ), (this.matrixWorldNeedsUpdate = !1), (e = !0)) for (var t = this.children, n = 0, r = t.length; n < r; n++) t[n].updateMatrixWorld(e) }, updateWorldMatrix: function (e, t) { var n = this.parent if ( (!0 === e && null !== n && n.updateWorldMatrix(!0, !1), this.matrixAutoUpdate && this.updateMatrix(), null === this.parent ? this.matrixWorld.copy(this.matrix) : this.matrixWorld.multiplyMatrices( this.parent.matrixWorld, this.matrix, ), !0 === t) ) for (var r = this.children, i = 0, o = r.length; i < o; i++) r[i].updateWorldMatrix(!1, !0) }, toJSON: function (e) { var t = void 0 === e || 'string' === typeof e, n = {} t && ((e = { geometries: {}, materials: {}, textures: {}, images: {}, shapes: {}, skeletons: {}, animations: {}, }), (n.metadata = { version: 4.5, type: 'Object', generator: 'Object3D.toJSON', })) var r = {} function i(t, n) { return void 0 === t[n.uuid] && (t[n.uuid] = n.toJSON(e)), n.uuid } if ( ((r.uuid = this.uuid), (r.type = this.type), '' !== this.name && (r.name = this.name), !0 === this.castShadow && (r.castShadow = !0), !0 === this.receiveShadow && (r.receiveShadow = !0), !1 === this.visible && (r.visible = !1), !1 === this.frustumCulled && (r.frustumCulled = !1), 0 !== this.renderOrder && (r.renderOrder = this.renderOrder), '{}' !== JSON.stringify(this.userData) && (r.userData = this.userData), (r.layers = this.layers.mask), (r.matrix = this.matrix.toArray()), !1 === this.matrixAutoUpdate && (r.matrixAutoUpdate = !1), this.isInstancedMesh && ((r.type = 'InstancedMesh'), (r.count = this.count), (r.instanceMatrix = this.instanceMatrix.toJSON())), this.isMesh || this.isLine || this.isPoints) ) { r.geometry = i(e.geometries, this.geometry) var o = this.geometry.parameters if (void 0 !== o && void 0 !== o.shapes) { var a = o.shapes if (Array.isArray(a)) for (var s = 0, l = a.length; s < l; s++) { var c = a[s] i(e.shapes, c) } else i(e.shapes, a) } } if ( (this.isSkinnedMesh && ((r.bindMode = this.bindMode), (r.bindMatrix = this.bindMatrix.toArray()), void 0 !== this.skeleton && (i(e.skeletons, this.skeleton), (r.skeleton = this.skeleton.uuid))), void 0 !== this.material) ) if (Array.isArray(this.material)) { for (var u = [], h = 0, d = this.material.length; h < d; h++) u.push(i(e.materials, this.material[h])) r.material = u } else r.material = i(e.materials, this.material) if (this.children.length > 0) { r.children = [] for (var p = 0; p < this.children.length; p++) r.children.push(this.children[p].toJSON(e).object) } if (this.animations.length > 0) { r.animations = [] for (var f = 0; f < this.animations.length; f++) { var m = this.animations[f] r.animations.push(i(e.animations, m)) } } if (t) { var v = E(e.geometries), g = E(e.materials), y = E(e.textures), b = E(e.images), A = E(e.shapes), w = E(e.skeletons), x = E(e.animations) v.length > 0 && (n.geometries = v), g.length > 0 && (n.materials = g), y.length > 0 && (n.textures = y), b.length > 0 && (n.images = b), A.length > 0 && (n.shapes = A), w.length > 0 && (n.skeletons = w), x.length > 0 && (n.animations = x) } return (n.object = r), n function E(e) { var t = [] for (var n in e) { var r = e[n] delete r.metadata, t.push(r) } return t } }, clone: function (e) { return new this.constructor().copy(this, e) }, copy: function (e, t) { if ( (void 0 === t && (t = !0), (this.name = e.name), this.up.copy(e.up), this.position.copy(e.position), (this.rotation.order = e.rotation.order), this.quaternion.copy(e.quaternion), this.scale.copy(e.scale), this.matrix.copy(e.matrix), this.matrixWorld.copy(e.matrixWorld), (this.matrixAutoUpdate = e.matrixAutoUpdate), (this.matrixWorldNeedsUpdate = e.matrixWorldNeedsUpdate), (this.layers.mask = e.layers.mask), (this.visible = e.visible), (this.castShadow = e.castShadow), (this.receiveShadow = e.receiveShadow), (this.frustumCulled = e.frustumCulled), (this.renderOrder = e.renderOrder), (this.userData = JSON.parse(JSON.stringify(e.userData))), !0 === t) ) for (var n = 0; n < e.children.length; n++) { var r = e.children[n] this.add(r.clone()) } return this }, })) var li = new lr(), ci = new lr(), ui = new $n(), hi = (function () { function e(e, t) { Object.defineProperty(this, 'isPlane', { value: !0 }), (this.normal = void 0 !== e ? e : new lr(1, 0, 0)), (this.constant = void 0 !== t ? t : 0) } var t = e.prototype return ( (t.set = function (e, t) { return this.normal.copy(e), (this.constant = t), this }), (t.setComponents = function (e, t, n, r) { return this.normal.set(e, t, n), (this.constant = r), this }), (t.setFromNormalAndCoplanarPoint = function (e, t) { return this.normal.copy(e), (this.constant = -t.dot(this.normal)), this }), (t.setFromCoplanarPoints = function (e, t, n) { var r = li.subVectors(n, t).cross(ci.subVectors(e, t)).normalize() return this.setFromNormalAndCoplanarPoint(r, e), this }), (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { return this.normal.copy(e.normal), (this.constant = e.constant), this }), (t.normalize = function () { var e = 1 / this.normal.length() return this.normal.multiplyScalar(e), (this.constant *= e), this }), (t.negate = function () { return (this.constant *= -1), this.normal.negate(), this }), (t.distanceToPoint = function (e) { return this.normal.dot(e) + this.constant }), (t.distanceToSphere = function (e) { return this.distanceToPoint(e.center) - e.radius }), (t.projectPoint = function (e, t) { return ( void 0 === t && (console.warn( 'THREE.Plane: .projectPoint() target is now required', ), (t = new lr())), t.copy(this.normal).multiplyScalar(-this.distanceToPoint(e)).add(e) ) }), (t.intersectLine = function (e, t) { void 0 === t && (console.warn('THREE.Plane: .intersectLine() target is now required'), (t = new lr())) var n = e.delta(li), r = this.normal.dot(n) if (0 === r) return 0 === this.distanceToPoint(e.start) ? t.copy(e.start) : void 0 var i = -(e.start.dot(this.normal) + this.constant) / r return i < 0 || i > 1 ? void 0 : t.copy(n).multiplyScalar(i).add(e.start) }), (t.intersectsLine = function (e) { var t = this.distanceToPoint(e.start), n = this.distanceToPoint(e.end) return (t < 0 && n > 0) || (n < 0 && t > 0) }), (t.intersectsBox = function (e) { return e.intersectsPlane(this) }), (t.intersectsSphere = function (e) { return e.intersectsPlane(this) }), (t.coplanarPoint = function (e) { return ( void 0 === e && (console.warn( 'THREE.Plane: .coplanarPoint() target is now required', ), (e = new lr())), e.copy(this.normal).multiplyScalar(-this.constant) ) }), (t.applyMatrix4 = function (e, t) { var n = t || ui.getNormalMatrix(e), r = this.coplanarPoint(li).applyMatrix4(e), i = this.normal.applyMatrix3(n).normalize() return (this.constant = -r.dot(i)), this }), (t.translate = function (e) { return (this.constant -= e.dot(this.normal)), this }), (t.equals = function (e) { return e.normal.equals(this.normal) && e.constant === this.constant }), e ) })(), di = new lr(), pi = new lr(), fi = new lr(), mi = new lr(), vi = new lr(), gi = new lr(), yi = new lr(), bi = new lr(), Ai = new lr(), wi = new lr(), xi = (function () { function e(e, t, n) { ;(this.a = void 0 !== e ? e : new lr()), (this.b = void 0 !== t ? t : new lr()), (this.c = void 0 !== n ? n : new lr()) } ;(e.getNormal = function (e, t, n, r) { void 0 === r && (console.warn('THREE.Triangle: .getNormal() target is now required'), (r = new lr())), r.subVectors(n, t), di.subVectors(e, t), r.cross(di) var i = r.lengthSq() return i > 0 ? r.multiplyScalar(1 / Math.sqrt(i)) : r.set(0, 0, 0) }), (e.getBarycoord = function (e, t, n, r, i) { di.subVectors(r, t), pi.subVectors(n, t), fi.subVectors(e, t) var o = di.dot(di), a = di.dot(pi), s = di.dot(fi), l = pi.dot(pi), c = pi.dot(fi), u = o * l - a * a if ( (void 0 === i && (console.warn( 'THREE.Triangle: .getBarycoord() target is now required', ), (i = new lr())), 0 === u) ) return i.set(-2, -1, -1) var h = 1 / u, d = (l * s - a * c) * h, p = (o * c - a * s) * h return i.set(1 - d - p, p, d) }), (e.containsPoint = function (e, t, n, r) { return ( this.getBarycoord(e, t, n, r, mi), mi.x >= 0 && mi.y >= 0 && mi.x + mi.y <= 1 ) }), (e.getUV = function (e, t, n, r, i, o, a, s) { return ( this.getBarycoord(e, t, n, r, mi), s.set(0, 0), s.addScaledVector(i, mi.x), s.addScaledVector(o, mi.y), s.addScaledVector(a, mi.z), s ) }), (e.isFrontFacing = function (e, t, n, r) { return di.subVectors(n, t), pi.subVectors(e, t), di.cross(pi).dot(r) < 0 }) var t = e.prototype return ( (t.set = function (e, t, n) { return this.a.copy(e), this.b.copy(t), this.c.copy(n), this }), (t.setFromPointsAndIndices = function (e, t, n, r) { return this.a.copy(e[t]), this.b.copy(e[n]), this.c.copy(e[r]), this }), (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { return this.a.copy(e.a), this.b.copy(e.b), this.c.copy(e.c), this }), (t.getArea = function () { return ( di.subVectors(this.c, this.b), pi.subVectors(this.a, this.b), 0.5 * di.cross(pi).length() ) }), (t.getMidpoint = function (e) { return ( void 0 === e && (console.warn( 'THREE.Triangle: .getMidpoint() target is now required', ), (e = new lr())), e .addVectors(this.a, this.b) .add(this.c) .multiplyScalar(1 / 3) ) }), (t.getNormal = function (t) { return e.getNormal(this.a, this.b, this.c, t) }), (t.getPlane = function (e) { return ( void 0 === e && (console.warn('THREE.Triangle: .getPlane() target is now required'), (e = new hi())), e.setFromCoplanarPoints(this.a, this.b, this.c) ) }), (t.getBarycoord = function (t, n) { return e.getBarycoord(t, this.a, this.b, this.c, n) }), (t.getUV = function (t, n, r, i, o) { return e.getUV(t, this.a, this.b, this.c, n, r, i, o) }), (t.containsPoint = function (t) { return e.containsPoint(t, this.a, this.b, this.c) }), (t.isFrontFacing = function (t) { return e.isFrontFacing(this.a, this.b, this.c, t) }), (t.intersectsBox = function (e) { return e.intersectsTriangle(this) }), (t.closestPointToPoint = function (e, t) { void 0 === t && (console.warn( 'THREE.Triangle: .closestPointToPoint() target is now required', ), (t = new lr())) var n, r, i = this.a, o = this.b, a = this.c vi.subVectors(o, i), gi.subVectors(a, i), bi.subVectors(e, i) var s = vi.dot(bi), l = gi.dot(bi) if (s <= 0 && l <= 0) return t.copy(i) Ai.subVectors(e, o) var c = vi.dot(Ai), u = gi.dot(Ai) if (c >= 0 && u <= c) return t.copy(o) var h = s * u - c * l if (h <= 0 && s >= 0 && c <= 0) return (n = s / (s - c)), t.copy(i).addScaledVector(vi, n) wi.subVectors(e, a) var d = vi.dot(wi), p = gi.dot(wi) if (p >= 0 && d <= p) return t.copy(a) var f = d * l - s * p if (f <= 0 && l >= 0 && p <= 0) return (r = l / (l - p)), t.copy(i).addScaledVector(gi, r) var m = c * p - d * u if (m <= 0 && u - c >= 0 && d - p >= 0) return ( yi.subVectors(a, o), (r = (u - c) / (u - c + (d - p))), t.copy(o).addScaledVector(yi, r) ) var v = 1 / (m + f + h) return ( (n = f * v), (r = h * v), t.copy(i).addScaledVector(vi, n).addScaledVector(gi, r) ) }), (t.equals = function (e) { return e.a.equals(this.a) && e.b.equals(this.b) && e.c.equals(this.c) }), e ) })(), Ei = { 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, }, Mi = { h: 0, s: 0, l: 0 }, _i = { h: 0, s: 0, l: 0 } function Ti(e, t, n) { return ( n < 0 && (n += 1), n > 1 && (n -= 1), n < 1 / 6 ? e + 6 * (t - e) * n : n < 0.5 ? t : n < 2 / 3 ? e + 6 * (t - e) * (2 / 3 - n) : e ) } function Si(e) { return e < 0.04045 ? 0.0773993808 * e : Math.pow(0.9478672986 * e + 0.0521327014, 2.4) } function Ci(e) { return e < 0.0031308 ? 12.92 * e : 1.055 * Math.pow(e, 0.41666) - 0.055 } var Li = (function () { function e(e, t, n) { return ( Object.defineProperty(this, 'isColor', { value: !0 }), void 0 === t && void 0 === n ? this.set(e) : this.setRGB(e, t, n) ) } var t = e.prototype return ( (t.set = function (e) { return ( e && e.isColor ? this.copy(e) : 'number' === typeof e ? this.setHex(e) : 'string' === typeof e && this.setStyle(e), this ) }), (t.setScalar = function (e) { return (this.r = e), (this.g = e), (this.b = e), this }), (t.setHex = function (e) { return ( (e = Math.floor(e)), (this.r = ((e >> 16) & 255) / 255), (this.g = ((e >> 8) & 255) / 255), (this.b = (255 & e) / 255), this ) }), (t.setRGB = function (e, t, n) { return (this.r = e), (this.g = t), (this.b = n), this }), (t.setHSL = function (e, t, n) { if ( ((e = Kn.euclideanModulo(e, 1)), (t = Kn.clamp(t, 0, 1)), (n = Kn.clamp(n, 0, 1)), 0 === t) ) this.r = this.g = this.b = n else { var r = n <= 0.5 ? n * (1 + t) : n + t - n * t, i = 2 * n - r ;(this.r = Ti(i, r, e + 1 / 3)), (this.g = Ti(i, r, e)), (this.b = Ti(i, r, e - 1 / 3)) } return this }), (t.setStyle = function (e) { function t(t) { void 0 !== t && parseFloat(t) < 1 && console.warn( 'THREE.Color: Alpha component of ' + e + ' will be ignored.', ) } var n if ((n = /^((?:rgb|hsl)a?)\(([^\)]*)\)/.exec(e))) { var r, i = n[1], o = n[2] switch (i) { case 'rgb': case 'rgba': if ( (r = /^\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec( o, )) ) return ( (this.r = Math.min(255, parseInt(r[1], 10)) / 255), (this.g = Math.min(255, parseInt(r[2], 10)) / 255), (this.b = Math.min(255, parseInt(r[3], 10)) / 255), t(r[4]), this ) if ( (r = /^\s*(\d+)\%\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec( o, )) ) return ( (this.r = Math.min(100, parseInt(r[1], 10)) / 100), (this.g = Math.min(100, parseInt(r[2], 10)) / 100), (this.b = Math.min(100, parseInt(r[3], 10)) / 100), t(r[4]), this ) break case 'hsl': case 'hsla': if ( (r = /^\s*(\d*\.?\d+)\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec( o, )) ) { var a = parseFloat(r[1]) / 360, s = parseInt(r[2], 10) / 100, l = parseInt(r[3], 10) / 100 return t(r[4]), this.setHSL(a, s, l) } } } else if ((n = /^\#([A-Fa-f\d]+)$/.exec(e))) { var c = n[1], u = c.length if (3 === u) return ( (this.r = parseInt(c.charAt(0) + c.charAt(0), 16) / 255), (this.g = parseInt(c.charAt(1) + c.charAt(1), 16) / 255), (this.b = parseInt(c.charAt(2) + c.charAt(2), 16) / 255), this ) if (6 === u) return ( (this.r = parseInt(c.charAt(0) + c.charAt(1), 16) / 255), (this.g = parseInt(c.charAt(2) + c.charAt(3), 16) / 255), (this.b = parseInt(c.charAt(4) + c.charAt(5), 16) / 255), this ) } return e && e.length > 0 ? this.setColorName(e) : this }), (t.setColorName = function (e) { var t = Ei[e] return ( void 0 !== t ? this.setHex(t) : console.warn('THREE.Color: Unknown color ' + e), this ) }), (t.clone = function () { return new this.constructor(this.r, this.g, this.b) }), (t.copy = function (e) { return (this.r = e.r), (this.g = e.g), (this.b = e.b), this }), (t.copyGammaToLinear = function (e, t) { return ( void 0 === t && (t = 2), (this.r = Math.pow(e.r, t)), (this.g = Math.pow(e.g, t)), (this.b = Math.pow(e.b, t)), this ) }), (t.copyLinearToGamma = function (e, t) { void 0 === t && (t = 2) var n = t > 0 ? 1 / t : 1 return ( (this.r = Math.pow(e.r, n)), (this.g = Math.pow(e.g, n)), (this.b = Math.pow(e.b, n)), this ) }), (t.convertGammaToLinear = function (e) { return this.copyGammaToLinear(this, e), this }), (t.convertLinearToGamma = function (e) { return this.copyLinearToGamma(this, e), this }), (t.copySRGBToLinear = function (e) { return (this.r = Si(e.r)), (this.g = Si(e.g)), (this.b = Si(e.b)), this }), (t.copyLinearToSRGB = function (e) { return (this.r = Ci(e.r)), (this.g = Ci(e.g)), (this.b = Ci(e.b)), this }), (t.convertSRGBToLinear = function () { return this.copySRGBToLinear(this), this }), (t.convertLinearToSRGB = function () { return this.copyLinearToSRGB(this), this }), (t.getHex = function () { return ( ((255 * this.r) << 16) ^ ((255 * this.g) << 8) ^ ((255 * this.b) << 0) ) }), (t.getHexString = function () { return ('000000' + this.getHex().toString(16)).slice(-6) }), (t.getHSL = function (e) { void 0 === e && (console.warn('THREE.Color: .getHSL() target is now required'), (e = { h: 0, s: 0, l: 0 })) var t, n, r = this.r, i = this.g, o = this.b, a = Math.max(r, i, o), s = Math.min(r, i, o), l = (s + a) / 2 if (s === a) (t = 0), (n = 0) else { var c = a - s switch (((n = l <= 0.5 ? c / (a + s) : c / (2 - a - s)), a)) { case r: t = (i - o) / c + (i < o ? 6 : 0) break case i: t = (o - r) / c + 2 break case o: t = (r - i) / c + 4 } t /= 6 } return (e.h = t), (e.s = n), (e.l = l), e }), (t.getStyle = function () { return ( 'rgb(' + ((255 * this.r) | 0) + ',' + ((255 * this.g) | 0) + ',' + ((255 * this.b) | 0) + ')' ) }), (t.offsetHSL = function (e, t, n) { return ( this.getHSL(Mi), (Mi.h += e), (Mi.s += t), (Mi.l += n), this.setHSL(Mi.h, Mi.s, Mi.l), this ) }), (t.add = function (e) { return (this.r += e.r), (this.g += e.g), (this.b += e.b), this }), (t.addColors = function (e, t) { return ( (this.r = e.r + t.r), (this.g = e.g + t.g), (this.b = e.b + t.b), this ) }), (t.addScalar = function (e) { return (this.r += e), (this.g += e), (this.b += e), this }), (t.sub = function (e) { return ( (this.r = Math.max(0, this.r - e.r)), (this.g = Math.max(0, this.g - e.g)), (this.b = Math.max(0, this.b - e.b)), this ) }), (t.multiply = function (e) { return (this.r *= e.r), (this.g *= e.g), (this.b *= e.b), this }), (t.multiplyScalar = function (e) { return (this.r *= e), (this.g *= e), (this.b *= e), this }), (t.lerp = function (e, t) { return ( (this.r += (e.r - this.r) * t), (this.g += (e.g - this.g) * t), (this.b += (e.b - this.b) * t), this ) }), (t.lerpColors = function (e, t, n) { return ( (this.r = e.r + (t.r - e.r) * n), (this.g = e.g + (t.g - e.g) * n), (this.b = e.b + (t.b - e.b) * n), this ) }), (t.lerpHSL = function (e, t) { this.getHSL(Mi), e.getHSL(_i) var n = Kn.lerp(Mi.h, _i.h, t), r = Kn.lerp(Mi.s, _i.s, t), i = Kn.lerp(Mi.l, _i.l, t) return this.setHSL(n, r, i), this }), (t.equals = function (e) { return e.r === this.r && e.g === this.g && e.b === this.b }), (t.fromArray = function (e, t) { return ( void 0 === t && (t = 0), (this.r = e[t]), (this.g = e[t + 1]), (this.b = e[t + 2]), this ) }), (t.toArray = function (e, t) { return ( void 0 === e && (e = []), void 0 === t && (t = 0), (e[t] = this.r), (e[t + 1] = this.g), (e[t + 2] = this.b), e ) }), (t.fromBufferAttribute = function (e, t) { return ( (this.r = e.getX(t)), (this.g = e.getY(t)), (this.b = e.getZ(t)), !0 === e.normalized && ((this.r /= 255), (this.g /= 255), (this.b /= 255)), this ) }), (t.toJSON = function () { return this.getHex() }), e ) })() ;(Li.NAMES = Ei), (Li.prototype.r = 1), (Li.prototype.g = 1), (Li.prototype.b = 1) var Ri = (function () { function e(e, t, n, r, i, o) { void 0 === o && (o = 0), (this.a = e), (this.b = t), (this.c = n), (this.normal = r && r.isVector3 ? r : new lr()), (this.vertexNormals = Array.isArray(r) ? r : []), (this.color = i && i.isColor ? i : new Li()), (this.vertexColors = Array.isArray(i) ? i : []), (this.materialIndex = o) } var t = e.prototype return ( (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { ;(this.a = e.a), (this.b = e.b), (this.c = e.c), this.normal.copy(e.normal), this.color.copy(e.color), (this.materialIndex = e.materialIndex) for (var t = 0, n = e.vertexNormals.length; t < n; t++) this.vertexNormals[t] = e.vertexNormals[t].clone() for (var r = 0, i = e.vertexColors.length; r < i; r++) this.vertexColors[r] = e.vertexColors[r].clone() return this }), e ) })(), Pi = 0 function Di() { Object.defineProperty(this, 'id', { value: Pi++ }), (this.uuid = Kn.generateUUID()), (this.name = ''), (this.type = 'Material'), (this.fog = !0), (this.blending = w), (this.side = m), (this.flatShading = !1), (this.vertexColors = !1), (this.opacity = 1), (this.transparent = !1), (this.blendSrc = B), (this.blendDst = F), (this.blendEquation = T), (this.blendSrcAlpha = null), (this.blendDstAlpha = null), (this.blendEquationAlpha = null), (this.depthFunc = W), (this.depthTest = !0), (this.depthWrite = !0), (this.stencilWriteMask = 255), (this.stencilFunc = _n), (this.stencilRef = 0), (this.stencilFuncMask = 255), (this.stencilFail = hn), (this.stencilZFail = hn), (this.stencilZPass = hn), (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 Oi(e) { Di.call(this), (this.type = 'MeshBasicMaterial'), (this.color = new Li(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 = Z), (this.reflectivity = 1), (this.refractionRatio = 0.98), (this.wireframe = !1), (this.wireframeLinewidth = 1), (this.wireframeLinecap = 'round'), (this.wireframeLinejoin = 'round'), (this.skinning = !1), (this.morphTargets = !1), this.setValues(e) } ;(Di.prototype = Object.assign(Object.create(qn.prototype), { constructor: Di, isMaterial: !0, onBeforeCompile: function () {}, customProgramCacheKey: function () { return this.onBeforeCompile.toString() }, setValues: function (e) { if (void 0 !== e) for (var t in e) { var n = e[t] if (void 0 !== n) if ('shading' !== t) { var r = this[t] void 0 !== r ? r && r.isColor ? r.set(n) : r && r.isVector3 && n && n.isVector3 ? r.copy(n) : (this[t] = n) : console.warn( 'THREE.' + this.type + ": '" + t + "' is not a property of this material.", ) } else console.warn( 'THREE.' + this.type + ': .shading has been removed. Use the boolean .flatShading instead.', ), (this.flatShading = n === y) else console.warn("THREE.Material: '" + t + "' parameter is undefined.") } }, toJSON: function (e) { var t = void 0 === e || 'string' === typeof e t && (e = { textures: {}, images: {} }) var n = { metadata: { version: 4.5, type: 'Material', generator: 'Material.toJSON', }, } function r(e) { var t = [] for (var n in e) { var r = e[n] delete r.metadata, t.push(r) } return t } if ( ((n.uuid = this.uuid), (n.type = this.type), '' !== this.name && (n.name = this.name), this.color && this.color.isColor && (n.color = this.color.getHex()), void 0 !== this.roughness && (n.roughness = this.roughness), void 0 !== this.metalness && (n.metalness = this.metalness), this.sheen && this.sheen.isColor && (n.sheen = this.sheen.getHex()), this.emissive && this.emissive.isColor && (n.emissive = this.emissive.getHex()), this.emissiveIntensity && 1 !== this.emissiveIntensity && (n.emissiveIntensity = this.emissiveIntensity), this.specular && this.specular.isColor && (n.specular = this.specular.getHex()), void 0 !== this.shininess && (n.shininess = this.shininess), void 0 !== this.clearcoat && (n.clearcoat = this.clearcoat), void 0 !== this.clearcoatRoughness && (n.clearcoatRoughness = this.clearcoatRoughness), this.clearcoatMap && this.clearcoatMap.isTexture && (n.clearcoatMap = this.clearcoatMap.toJSON(e).uuid), this.clearcoatRoughnessMap && this.clearcoatRoughnessMap.isTexture && (n.clearcoatRoughnessMap = this.clearcoatRoughnessMap.toJSON(e).uuid), this.clearcoatNormalMap && this.clearcoatNormalMap.isTexture && ((n.clearcoatNormalMap = this.clearcoatNormalMap.toJSON(e).uuid), (n.clearcoatNormalScale = this.clearcoatNormalScale.toArray())), this.map && this.map.isTexture && (n.map = this.map.toJSON(e).uuid), this.matcap && this.matcap.isTexture && (n.matcap = this.matcap.toJSON(e).uuid), this.alphaMap && this.alphaMap.isTexture && (n.alphaMap = this.alphaMap.toJSON(e).uuid), this.lightMap && this.lightMap.isTexture && (n.lightMap = this.lightMap.toJSON(e).uuid), this.aoMap && this.aoMap.isTexture && ((n.aoMap = this.aoMap.toJSON(e).uuid), (n.aoMapIntensity = this.aoMapIntensity)), this.bumpMap && this.bumpMap.isTexture && ((n.bumpMap = this.bumpMap.toJSON(e).uuid), (n.bumpScale = this.bumpScale)), this.normalMap && this.normalMap.isTexture && ((n.normalMap = this.normalMap.toJSON(e).uuid), (n.normalMapType = this.normalMapType), (n.normalScale = this.normalScale.toArray())), this.displacementMap && this.displacementMap.isTexture && ((n.displacementMap = this.displacementMap.toJSON(e).uuid), (n.displacementScale = this.displacementScale), (n.displacementBias = this.displacementBias)), this.roughnessMap && this.roughnessMap.isTexture && (n.roughnessMap = this.roughnessMap.toJSON(e).uuid), this.metalnessMap && this.metalnessMap.isTexture && (n.metalnessMap = this.metalnessMap.toJSON(e).uuid), this.emissiveMap && this.emissiveMap.isTexture && (n.emissiveMap = this.emissiveMap.toJSON(e).uuid), this.specularMap && this.specularMap.isTexture && (n.specularMap = this.specularMap.toJSON(e).uuid), this.envMap && this.envMap.isTexture && ((n.envMap = this.envMap.toJSON(e).uuid), (n.reflectivity = this.reflectivity), (n.refractionRatio = this.refractionRatio), void 0 !== this.combine && (n.combine = this.combine), void 0 !== this.envMapIntensity && (n.envMapIntensity = this.envMapIntensity)), this.gradientMap && this.gradientMap.isTexture && (n.gradientMap = this.gradientMap.toJSON(e).uuid), void 0 !== this.size && (n.size = this.size), void 0 !== this.sizeAttenuation && (n.sizeAttenuation = this.sizeAttenuation), this.blending !== w && (n.blending = this.blending), !0 === this.flatShading && (n.flatShading = this.flatShading), this.side !== m && (n.side = this.side), this.vertexColors && (n.vertexColors = !0), this.opacity < 1 && (n.opacity = this.opacity), !0 === this.transparent && (n.transparent = this.transparent), (n.depthFunc = this.depthFunc), (n.depthTest = this.depthTest), (n.depthWrite = this.depthWrite), (n.stencilWrite = this.stencilWrite), (n.stencilWriteMask = this.stencilWriteMask), (n.stencilFunc = this.stencilFunc), (n.stencilRef = this.stencilRef), (n.stencilFuncMask = this.stencilFuncMask), (n.stencilFail = this.stencilFail), (n.stencilZFail = this.stencilZFail), (n.stencilZPass = this.stencilZPass), this.rotation && 0 !== this.rotation && (n.rotation = this.rotation), !0 === this.polygonOffset && (n.polygonOffset = !0), 0 !== this.polygonOffsetFactor && (n.polygonOffsetFactor = this.polygonOffsetFactor), 0 !== this.polygonOffsetUnits && (n.polygonOffsetUnits = this.polygonOffsetUnits), this.linewidth && 1 !== this.linewidth && (n.linewidth = this.linewidth), void 0 !== this.dashSize && (n.dashSize = this.dashSize), void 0 !== this.gapSize && (n.gapSize = this.gapSize), void 0 !== this.scale && (n.scale = this.scale), !0 === this.dithering && (n.dithering = !0), this.alphaTest > 0 && (n.alphaTest = this.alphaTest), !0 === this.premultipliedAlpha && (n.premultipliedAlpha = this.premultipliedAlpha), !0 === this.wireframe && (n.wireframe = this.wireframe), this.wireframeLinewidth > 1 && (n.wireframeLinewidth = this.wireframeLinewidth), 'round' !== this.wireframeLinecap && (n.wireframeLinecap = this.wireframeLinecap), 'round' !== this.wireframeLinejoin && (n.wireframeLinejoin = this.wireframeLinejoin), !0 === this.morphTargets && (n.morphTargets = !0), !0 === this.morphNormals && (n.morphNormals = !0), !0 === this.skinning && (n.skinning = !0), !1 === this.visible && (n.visible = !1), !1 === this.toneMapped && (n.toneMapped = !1), '{}' !== JSON.stringify(this.userData) && (n.userData = this.userData), t) ) { var i = r(e.textures), o = r(e.images) i.length > 0 && (n.textures = i), o.length > 0 && (n.images = o) } return n }, clone: function () { return new this.constructor().copy(this) }, copy: function (e) { ;(this.name = e.name), (this.fog = e.fog), (this.blending = e.blending), (this.side = e.side), (this.flatShading = e.flatShading), (this.vertexColors = e.vertexColors), (this.opacity = e.opacity), (this.transparent = e.transparent), (this.blendSrc = e.blendSrc), (this.blendDst = e.blendDst), (this.blendEquation = e.blendEquation), (this.blendSrcAlpha = e.blendSrcAlpha), (this.blendDstAlpha = e.blendDstAlpha), (this.blendEquationAlpha = e.blendEquationAlpha), (this.depthFunc = e.depthFunc), (this.depthTest = e.depthTest), (this.depthWrite = e.depthWrite), (this.stencilWriteMask = e.stencilWriteMask), (this.stencilFunc = e.stencilFunc), (this.stencilRef = e.stencilRef), (this.stencilFuncMask = e.stencilFuncMask), (this.stencilFail = e.stencilFail), (this.stencilZFail = e.stencilZFail), (this.stencilZPass = e.stencilZPass), (this.stencilWrite = e.stencilWrite) var t = e.clippingPlanes, n = null if (null !== t) { var r = t.length n = new Array(r) for (var i = 0; i !== r; ++i) n[i] = t[i].clone() } return ( (this.clippingPlanes = n), (this.clipIntersection = e.clipIntersection), (this.clipShadows = e.clipShadows), (this.shadowSide = e.shadowSide), (this.colorWrite = e.colorWrite), (this.precision = e.precision), (this.polygonOffset = e.polygonOffset), (this.polygonOffsetFactor = e.polygonOffsetFactor), (this.polygonOffsetUnits = e.polygonOffsetUnits), (this.dithering = e.dithering), (this.alphaTest = e.alphaTest), (this.premultipliedAlpha = e.premultipliedAlpha), (this.visible = e.visible), (this.toneMapped = e.toneMapped), (this.userData = JSON.parse(JSON.stringify(e.userData))), this ) }, dispose: function () { this.dispatchEvent({ type: 'dispose' }) }, })), Object.defineProperty(Di.prototype, 'needsUpdate', { set: function (e) { !0 === e && this.version++ }, }), (Oi.prototype = Object.create(Di.prototype)), (Oi.prototype.constructor = Oi), (Oi.prototype.isMeshBasicMaterial = !0), (Oi.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), this.color.copy(e.color), (this.map = e.map), (this.lightMap = e.lightMap), (this.lightMapIntensity = e.lightMapIntensity), (this.aoMap = e.aoMap), (this.aoMapIntensity = e.aoMapIntensity), (this.specularMap = e.specularMap), (this.alphaMap = e.alphaMap), (this.envMap = e.envMap), (this.combine = e.combine), (this.reflectivity = e.reflectivity), (this.refractionRatio = e.refractionRatio), (this.wireframe = e.wireframe), (this.wireframeLinewidth = e.wireframeLinewidth), (this.wireframeLinecap = e.wireframeLinecap), (this.wireframeLinejoin = e.wireframeLinejoin), (this.skinning = e.skinning), (this.morphTargets = e.morphTargets), this ) }) var Ii = new lr(), Bi = new Jn() function Fi(e, t, n) { if (Array.isArray(e)) throw new TypeError('THREE.BufferAttribute: array should be a Typed Array.') ;(this.name = ''), (this.array = e), (this.itemSize = t), (this.count = void 0 !== e ? e.length / t : 0), (this.normalized = !0 === n), (this.usage = Tn), (this.updateRange = { offset: 0, count: -1 }), (this.version = 0) } function ki(e, t, n) { Fi.call(this, new Int8Array(e), t, n) } function Ni(e, t, n) { Fi.call(this, new Uint8Array(e), t, n) } function Ui(e, t, n) { Fi.call(this, new Uint8ClampedArray(e), t, n) } function Hi(e, t, n) { Fi.call(this, new Int16Array(e), t, n) } function Gi(e, t, n) { Fi.call(this, new Uint16Array(e), t, n) } function zi(e, t, n) { Fi.call(this, new Int32Array(e), t, n) } function ji(e, t, n) { Fi.call(this, new Uint32Array(e), t, n) } function Vi(e, t, n) { Fi.call(this, new Uint16Array(e), t, n) } function Wi(e, t, n) { Fi.call(this, new Float32Array(e), t, n) } function qi(e, t, n) { Fi.call(this, new Float64Array(e), t, n) } function Xi(e) { if (0 === e.length) return -1 / 0 for (var t = e[0], n = 1, r = e.length; n < r; ++n) e[n] > t && (t = e[n]) return t } Object.defineProperty(Fi.prototype, 'needsUpdate', { set: function (e) { !0 === e && this.version++ }, }), Object.assign(Fi.prototype, { isBufferAttribute: !0, onUploadCallback: function () {}, setUsage: function (e) { return (this.usage = e), this }, copy: function (e) { return ( (this.name = e.name), (this.array = new e.array.constructor(e.array)), (this.itemSize = e.itemSize), (this.count = e.count), (this.normalized = e.normalized), (this.usage = e.usage), this ) }, copyAt: function (e, t, n) { ;(e *= this.itemSize), (n *= t.itemSize) for (var r = 0, i = this.itemSize; r < i; r++) this.array[e + r] = t.array[n + r] return this }, copyArray: function (e) { return this.array.set(e), this }, copyColorsArray: function (e) { for (var t = this.array, n = 0, r = 0, i = e.length; r < i; r++) { var o = e[r] void 0 === o && (console.warn( 'THREE.BufferAttribute.copyColorsArray(): color is undefined', r, ), (o = new Li())), (t[n++] = o.r), (t[n++] = o.g), (t[n++] = o.b) } return this }, copyVector2sArray: function (e) { for (var t = this.array, n = 0, r = 0, i = e.length; r < i; r++) { var o = e[r] void 0 === o && (console.warn( 'THREE.BufferAttribute.copyVector2sArray(): vector is undefined', r, ), (o = new Jn())), (t[n++] = o.x), (t[n++] = o.y) } return this }, copyVector3sArray: function (e) { for (var t = this.array, n = 0, r = 0, i = e.length; r < i; r++) { var o = e[r] void 0 === o && (console.warn( 'THREE.BufferAttribute.copyVector3sArray(): vector is undefined', r, ), (o = new lr())), (t[n++] = o.x), (t[n++] = o.y), (t[n++] = o.z) } return this }, copyVector4sArray: function (e) { for (var t = this.array, n = 0, r = 0, i = e.length; r < i; r++) { var o = e[r] void 0 === o && (console.warn( 'THREE.BufferAttribute.copyVector4sArray(): vector is undefined', r, ), (o = new ir())), (t[n++] = o.x), (t[n++] = o.y), (t[n++] = o.z), (t[n++] = o.w) } return this }, applyMatrix3: function (e) { if (2 === this.itemSize) for (var t = 0, n = this.count; t < n; t++) Bi.fromBufferAttribute(this, t), Bi.applyMatrix3(e), this.setXY(t, Bi.x, Bi.y) else if (3 === this.itemSize) for (var r = 0, i = this.count; r < i; r++) Ii.fromBufferAttribute(this, r), Ii.applyMatrix3(e), this.setXYZ(r, Ii.x, Ii.y, Ii.z) return this }, applyMatrix4: function (e) { for (var t = 0, n = this.count; t < n; t++) (Ii.x = this.getX(t)), (Ii.y = this.getY(t)), (Ii.z = this.getZ(t)), Ii.applyMatrix4(e), this.setXYZ(t, Ii.x, Ii.y, Ii.z) return this }, applyNormalMatrix: function (e) { for (var t = 0, n = this.count; t < n; t++) (Ii.x = this.getX(t)), (Ii.y = this.getY(t)), (Ii.z = this.getZ(t)), Ii.applyNormalMatrix(e), this.setXYZ(t, Ii.x, Ii.y, Ii.z) return this }, transformDirection: function (e) { for (var t = 0, n = this.count; t < n; t++) (Ii.x = this.getX(t)), (Ii.y = this.getY(t)), (Ii.z = this.getZ(t)), Ii.transformDirection(e), this.setXYZ(t, Ii.x, Ii.y, Ii.z) return this }, set: function (e, t) { return void 0 === t && (t = 0), this.array.set(e, t), this }, getX: function (e) { return this.array[e * this.itemSize] }, setX: function (e, t) { return (this.array[e * this.itemSize] = t), this }, getY: function (e) { return this.array[e * this.itemSize + 1] }, setY: function (e, t) { return (this.array[e * this.itemSize + 1] = t), this }, getZ: function (e) { return this.array[e * this.itemSize + 2] }, setZ: function (e, t) { return (this.array[e * this.itemSize + 2] = t), this }, getW: function (e) { return this.array[e * this.itemSize + 3] }, setW: function (e, t) { return (this.array[e * this.itemSize + 3] = t), this }, setXY: function (e, t, n) { return ( (e *= this.itemSize), (this.array[e + 0] = t), (this.array[e + 1] = n), this ) }, setXYZ: function (e, t, n, r) { return ( (e *= this.itemSize), (this.array[e + 0] = t), (this.array[e + 1] = n), (this.array[e + 2] = r), this ) }, setXYZW: function (e, t, n, r, i) { return ( (e *= this.itemSize), (this.array[e + 0] = t), (this.array[e + 1] = n), (this.array[e + 2] = r), (this.array[e + 3] = i), this ) }, onUpload: function (e) { return (this.onUploadCallback = e), 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, } }, }), (ki.prototype = Object.create(Fi.prototype)), (ki.prototype.constructor = ki), (Ni.prototype = Object.create(Fi.prototype)), (Ni.prototype.constructor = Ni), (Ui.prototype = Object.create(Fi.prototype)), (Ui.prototype.constructor = Ui), (Hi.prototype = Object.create(Fi.prototype)), (Hi.prototype.constructor = Hi), (Gi.prototype = Object.create(Fi.prototype)), (Gi.prototype.constructor = Gi), (zi.prototype = Object.create(Fi.prototype)), (zi.prototype.constructor = zi), (ji.prototype = Object.create(Fi.prototype)), (ji.prototype.constructor = ji), (Vi.prototype = Object.create(Fi.prototype)), (Vi.prototype.constructor = Vi), (Vi.prototype.isFloat16BufferAttribute = !0), (Wi.prototype = Object.create(Fi.prototype)), (Wi.prototype.constructor = Wi), (qi.prototype = Object.create(Fi.prototype)), (qi.prototype.constructor = qi) var Yi = { Int8Array: Int8Array, Uint8Array: Uint8Array, Uint8ClampedArray: 'undefined' !== typeof Uint8ClampedArray ? Uint8ClampedArray : Uint8Array, Int16Array: Int16Array, Uint16Array: Uint16Array, Int32Array: Int32Array, Uint32Array: Uint32Array, Float32Array: Float32Array, Float64Array: Float64Array, } function Qi(e, t) { return new Yi[e](t) } var Zi = 0, Ki = new Fr(), Ji = new si(), $i = new lr(), eo = new hr(), to = new hr(), no = new lr() function ro() { Object.defineProperty(this, 'id', { value: Zi++ }), (this.uuid = Kn.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 = {}) } ro.prototype = Object.assign(Object.create(qn.prototype), { constructor: ro, isBufferGeometry: !0, getIndex: function () { return this.index }, setIndex: function (e) { return ( Array.isArray(e) ? (this.index = new (Xi(e) > 65535 ? ji : Gi)(e, 1)) : (this.index = e), this ) }, getAttribute: function (e) { return this.attributes[e] }, setAttribute: function (e, t) { return (this.attributes[e] = t), this }, deleteAttribute: function (e) { return delete this.attributes[e], this }, hasAttribute: function (e) { return void 0 !== this.attributes[e] }, addGroup: function (e, t, n) { void 0 === n && (n = 0), this.groups.push({ start: e, count: t, materialIndex: n }) }, clearGroups: function () { this.groups = [] }, setDrawRange: function (e, t) { ;(this.drawRange.start = e), (this.drawRange.count = t) }, applyMatrix4: function (e) { var t = this.attributes.position void 0 !== t && (t.applyMatrix4(e), (t.needsUpdate = !0)) var n = this.attributes.normal if (void 0 !== n) { var r = new $n().getNormalMatrix(e) n.applyNormalMatrix(r), (n.needsUpdate = !0) } var i = this.attributes.tangent return ( void 0 !== i && (i.transformDirection(e), (i.needsUpdate = !0)), null !== this.boundingBox && this.computeBoundingBox(), null !== this.boundingSphere && this.computeBoundingSphere(), this ) }, rotateX: function (e) { return Ki.makeRotationX(e), this.applyMatrix4(Ki), this }, rotateY: function (e) { return Ki.makeRotationY(e), this.applyMatrix4(Ki), this }, rotateZ: function (e) { return Ki.makeRotationZ(e), this.applyMatrix4(Ki), this }, translate: function (e, t, n) { return Ki.makeTranslation(e, t, n), this.applyMatrix4(Ki), this }, scale: function (e, t, n) { return Ki.makeScale(e, t, n), this.applyMatrix4(Ki), this }, lookAt: function (e) { return Ji.lookAt(e), Ji.updateMatrix(), this.applyMatrix4(Ji.matrix), this }, center: function () { return ( this.computeBoundingBox(), this.boundingBox.getCenter($i).negate(), this.translate($i.x, $i.y, $i.z), this ) }, setFromPoints: function (e) { for (var t = [], n = 0, r = e.length; n < r; n++) { var i = e[n] t.push(i.x, i.y, i.z || 0) } return this.setAttribute('position', new Wi(t, 3)), this }, computeBoundingBox: function () { null === this.boundingBox && (this.boundingBox = new hr()) var e = this.attributes.position, t = this.morphAttributes.position if (e && e.isGLBufferAttribute) return ( console.error( 'THREE.BufferGeometry.computeBoundingBox(): GLBufferAttribute requires a manual bounding box. Alternatively set "mesh.frustumCulled" to "false".', this, ), void this.boundingBox.set( new lr(-1 / 0, -1 / 0, -1 / 0), new lr(1 / 0, 1 / 0, 1 / 0), ) ) if (void 0 !== e) { if ((this.boundingBox.setFromBufferAttribute(e), t)) for (var n = 0, r = t.length; n < r; n++) { var i = t[n] eo.setFromBufferAttribute(i), this.morphTargetsRelative ? (no.addVectors(this.boundingBox.min, eo.min), this.boundingBox.expandByPoint(no), no.addVectors(this.boundingBox.max, eo.max), this.boundingBox.expandByPoint(no)) : (this.boundingBox.expandByPoint(eo.min), this.boundingBox.expandByPoint(eo.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 Sr()) var e = this.attributes.position, t = this.morphAttributes.position if (e && e.isGLBufferAttribute) return ( console.error( 'THREE.BufferGeometry.computeBoundingSphere(): GLBufferAttribute requires a manual bounding sphere. Alternatively set "mesh.frustumCulled" to "false".', this, ), void this.boundingSphere.set(new lr(), 1 / 0) ) if (e) { var n = this.boundingSphere.center if ((eo.setFromBufferAttribute(e), t)) for (var r = 0, i = t.length; r < i; r++) { var o = t[r] to.setFromBufferAttribute(o), this.morphTargetsRelative ? (no.addVectors(eo.min, to.min), eo.expandByPoint(no), no.addVectors(eo.max, to.max), eo.expandByPoint(no)) : (eo.expandByPoint(to.min), eo.expandByPoint(to.max)) } eo.getCenter(n) for (var a = 0, s = 0, l = e.count; s < l; s++) no.fromBufferAttribute(e, s), (a = Math.max(a, n.distanceToSquared(no))) if (t) for (var c = 0, u = t.length; c < u; c++) for ( var h = t[c], d = this.morphTargetsRelative, p = 0, f = h.count; p < f; p++ ) no.fromBufferAttribute(h, p), d && ($i.fromBufferAttribute(e, p), no.add($i)), (a = Math.max(a, n.distanceToSquared(no))) ;(this.boundingSphere.radius = Math.sqrt(a)), 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 () {}, computeTangents: function () { var e = this.index, t = this.attributes if ( null !== e && void 0 !== t.position && void 0 !== t.normal && void 0 !== t.uv ) { var n = e.array, r = t.position.array, i = t.normal.array, o = t.uv.array, a = r.length / 3 void 0 === t.tangent && this.setAttribute('tangent', new Fi(new Float32Array(4 * a), 4)) for (var s = t.tangent.array, l = [], c = [], u = 0; u < a; u++) (l[u] = new lr()), (c[u] = new lr()) var h = new lr(), d = new lr(), p = new lr(), f = new Jn(), m = new Jn(), v = new Jn(), g = new lr(), y = new lr(), b = this.groups 0 === b.length && (b = [{ start: 0, count: n.length }]) for (var A = 0, w = b.length; A < w; ++A) for (var x = b[A], E = x.start, M = E, _ = E + x.count; M < _; M += 3) F(n[M + 0], n[M + 1], n[M + 2]) for ( var T = new lr(), S = new lr(), C = new lr(), L = new lr(), R = 0, P = b.length; R < P; ++R ) for (var D = b[R], O = D.start, I = O, B = O + D.count; I < B; I += 3) k(n[I + 0]), k(n[I + 1]), k(n[I + 2]) } else console.error( 'THREE.BufferGeometry: .computeTangents() failed. Missing required attributes (index, position, normal or uv)', ) function F(e, t, n) { h.fromArray(r, 3 * e), d.fromArray(r, 3 * t), p.fromArray(r, 3 * n), f.fromArray(o, 2 * e), m.fromArray(o, 2 * t), v.fromArray(o, 2 * n), d.sub(h), p.sub(h), m.sub(f), v.sub(f) var i = 1 / (m.x * v.y - v.x * m.y) isFinite(i) && (g .copy(d) .multiplyScalar(v.y) .addScaledVector(p, -m.y) .multiplyScalar(i), y .copy(p) .multiplyScalar(m.x) .addScaledVector(d, -v.x) .multiplyScalar(i), l[e].add(g), l[t].add(g), l[n].add(g), c[e].add(y), c[t].add(y), c[n].add(y)) } function k(e) { C.fromArray(i, 3 * e), L.copy(C) var t = l[e] T.copy(t), T.sub(C.multiplyScalar(C.dot(t))).normalize(), S.crossVectors(L, t) var n = S.dot(c[e]) < 0 ? -1 : 1 ;(s[4 * e] = T.x), (s[4 * e + 1] = T.y), (s[4 * e + 2] = T.z), (s[4 * e + 3] = n) } }, computeVertexNormals: function () { var e = this.index, t = this.getAttribute('position') if (void 0 !== t) { var n = this.getAttribute('normal') if (void 0 === n) (n = new Fi(new Float32Array(3 * t.count), 3)), this.setAttribute('normal', n) else for (var r = 0, i = n.count; r < i; r++) n.setXYZ(r, 0, 0, 0) var o = new lr(), a = new lr(), s = new lr(), l = new lr(), c = new lr(), u = new lr(), h = new lr(), d = new lr() if (e) for (var p = 0, f = e.count; p < f; p += 3) { var m = e.getX(p + 0), v = e.getX(p + 1), g = e.getX(p + 2) o.fromBufferAttribute(t, m), a.fromBufferAttribute(t, v), s.fromBufferAttribute(t, g), h.subVectors(s, a), d.subVectors(o, a), h.cross(d), l.fromBufferAttribute(n, m), c.fromBufferAttribute(n, v), u.fromBufferAttribute(n, g), l.add(h), c.add(h), u.add(h), n.setXYZ(m, l.x, l.y, l.z), n.setXYZ(v, c.x, c.y, c.z), n.setXYZ(g, u.x, u.y, u.z) } else for (var y = 0, b = t.count; y < b; y += 3) o.fromBufferAttribute(t, y + 0), a.fromBufferAttribute(t, y + 1), s.fromBufferAttribute(t, y + 2), h.subVectors(s, a), d.subVectors(o, a), h.cross(d), n.setXYZ(y + 0, h.x, h.y, h.z), n.setXYZ(y + 1, h.x, h.y, h.z), n.setXYZ(y + 2, h.x, h.y, h.z) this.normalizeNormals(), (n.needsUpdate = !0) } }, merge: function (e, t) { if (e && e.isBufferGeometry) { void 0 === t && ((t = 0), console.warn( 'THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset=0. Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge.', )) var n = this.attributes for (var r in n) if (void 0 !== e.attributes[r]) for ( var i = n[r].array, o = e.attributes[r], a = o.array, s = o.itemSize * t, l = Math.min(a.length, i.length - s), c = 0, u = s; c < l; c++, u++ ) i[u] = a[c] return this } console.error( 'THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.', e, ) }, normalizeNormals: function () { for (var e = this.attributes.normal, t = 0, n = e.count; t < n; t++) no.fromBufferAttribute(e, t), no.normalize(), e.setXYZ(t, no.x, no.y, no.z) }, toNonIndexed: function () { function e(e, t) { for ( var n = e.array, r = e.itemSize, i = e.normalized, o = new n.constructor(t.length * r), a = 0, s = 0, l = 0, c = t.length; l < c; l++ ) { a = t[l] * r for (var u = 0; u < r; u++) o[s++] = n[a++] } return new Fi(o, r, i) } if (null === this.index) return ( console.warn( 'THREE.BufferGeometry.toNonIndexed(): BufferGeometry is already non-indexed.', ), this ) var t = new ro(), n = this.index.array, r = this.attributes for (var i in r) { var o = e(r[i], n) t.setAttribute(i, o) } var a = this.morphAttributes for (var s in a) { for (var l = [], c = a[s], u = 0, h = c.length; u < h; u++) { var d = e(c[u], n) l.push(d) } t.morphAttributes[s] = l } t.morphTargetsRelative = this.morphTargetsRelative for (var p = this.groups, f = 0, m = p.length; f < m; f++) { var v = p[f] t.addGroup(v.start, v.count, v.materialIndex) } return t }, toJSON: function () { var e = { metadata: { version: 4.5, type: 'BufferGeometry', generator: 'BufferGeometry.toJSON', }, } if ( ((e.uuid = this.uuid), (e.type = this.type), '' !== this.name && (e.name = this.name), Object.keys(this.userData).length > 0 && (e.userData = this.userData), void 0 !== this.parameters) ) { var t = this.parameters for (var n in t) void 0 !== t[n] && (e[n] = t[n]) return e } e.data = { attributes: {} } var r = this.index null !== r && (e.data.index = { type: r.array.constructor.name, array: Array.prototype.slice.call(r.array), }) var i = this.attributes for (var o in i) { var a = i[o], s = a.toJSON(e.data) '' !== a.name && (s.name = a.name), (e.data.attributes[o] = s) } var l = {}, c = !1 for (var u in this.morphAttributes) { for ( var h = this.morphAttributes[u], d = [], p = 0, f = h.length; p < f; p++ ) { var m = h[p], v = m.toJSON(e.data) '' !== m.name && (v.name = m.name), d.push(v) } d.length > 0 && ((l[u] = d), (c = !0)) } c && ((e.data.morphAttributes = l), (e.data.morphTargetsRelative = this.morphTargetsRelative)) var g = this.groups g.length > 0 && (e.data.groups = JSON.parse(JSON.stringify(g))) var y = this.boundingSphere return ( null !== y && (e.data.boundingSphere = { center: y.center.toArray(), radius: y.radius, }), e ) }, clone: function () { return new ro().copy(this) }, copy: function (e) { ;(this.index = null), (this.attributes = {}), (this.morphAttributes = {}), (this.groups = []), (this.boundingBox = null), (this.boundingSphere = null) var t = {} this.name = e.name var n = e.index null !== n && this.setIndex(n.clone(t)) var r = e.attributes for (var i in r) { var o = r[i] this.setAttribute(i, o.clone(t)) } var a = e.morphAttributes for (var s in a) { for (var l = [], c = a[s], u = 0, h = c.length; u < h; u++) l.push(c[u].clone(t)) this.morphAttributes[s] = l } this.morphTargetsRelative = e.morphTargetsRelative for (var d = e.groups, p = 0, f = d.length; p < f; p++) { var m = d[p] this.addGroup(m.start, m.count, m.materialIndex) } var v = e.boundingBox null !== v && (this.boundingBox = v.clone()) var g = e.boundingSphere return ( null !== g && (this.boundingSphere = g.clone()), (this.drawRange.start = e.drawRange.start), (this.drawRange.count = e.drawRange.count), (this.userData = e.userData), this ) }, dispose: function () { this.dispatchEvent({ type: 'dispose' }) }, }) var io = new Fr(), oo = new Br(), ao = new Sr(), so = new lr(), lo = new lr(), co = new lr(), uo = new lr(), ho = new lr(), po = new lr(), fo = new lr(), mo = new lr(), vo = new lr(), go = new Jn(), yo = new Jn(), bo = new Jn(), Ao = new lr(), wo = new lr() function xo(e, t) { void 0 === e && (e = new ro()), void 0 === t && (t = new Oi()), si.call(this), (this.type = 'Mesh'), (this.geometry = e), (this.material = t), this.updateMorphTargets() } function Eo(e, t, n, r, i, o, a, s) { if ( null === (t.side === v ? r.intersectTriangle(a, o, i, !0, s) : r.intersectTriangle(i, o, a, t.side !== g, s)) ) return null wo.copy(s), wo.applyMatrix4(e.matrixWorld) var l = n.ray.origin.distanceTo(wo) return l < n.near || l > n.far ? null : { distance: l, point: wo.clone(), object: e } } function Mo(e, t, n, r, i, o, a, s, l, c, u, h) { so.fromBufferAttribute(i, c), lo.fromBufferAttribute(i, u), co.fromBufferAttribute(i, h) var d = e.morphTargetInfluences if (t.morphTargets && o && d) { fo.set(0, 0, 0), mo.set(0, 0, 0), vo.set(0, 0, 0) for (var p = 0, f = o.length; p < f; p++) { var m = d[p], v = o[p] 0 !== m && (uo.fromBufferAttribute(v, c), ho.fromBufferAttribute(v, u), po.fromBufferAttribute(v, h), a ? (fo.addScaledVector(uo, m), mo.addScaledVector(ho, m), vo.addScaledVector(po, m)) : (fo.addScaledVector(uo.sub(so), m), mo.addScaledVector(ho.sub(lo), m), vo.addScaledVector(po.sub(co), m))) } so.add(fo), lo.add(mo), co.add(vo) } e.isSkinnedMesh && (e.boneTransform(c, so), e.boneTransform(u, lo), e.boneTransform(h, co)) var g = Eo(e, t, n, r, so, lo, co, Ao) if (g) { s && (go.fromBufferAttribute(s, c), yo.fromBufferAttribute(s, u), bo.fromBufferAttribute(s, h), (g.uv = xi.getUV(Ao, so, lo, co, go, yo, bo, new Jn()))), l && (go.fromBufferAttribute(l, c), yo.fromBufferAttribute(l, u), bo.fromBufferAttribute(l, h), (g.uv2 = xi.getUV(Ao, so, lo, co, go, yo, bo, new Jn()))) var y = new Ri(c, u, h) xi.getNormal(so, lo, co, y.normal), (g.face = y) } return g } xo.prototype = Object.assign(Object.create(si.prototype), { constructor: xo, isMesh: !0, copy: function (e) { return ( si.prototype.copy.call(this, e), void 0 !== e.morphTargetInfluences && (this.morphTargetInfluences = e.morphTargetInfluences.slice()), void 0 !== e.morphTargetDictionary && (this.morphTargetDictionary = Object.assign( {}, e.morphTargetDictionary, )), (this.material = e.material), (this.geometry = e.geometry), this ) }, updateMorphTargets: function () { var e = this.geometry if (e.isBufferGeometry) { var t = e.morphAttributes, n = Object.keys(t) if (n.length > 0) { var r = t[n[0]] if (void 0 !== r) { ;(this.morphTargetInfluences = []), (this.morphTargetDictionary = {}) for (var i = 0, o = r.length; i < o; i++) { var a = r[i].name || String(i) this.morphTargetInfluences.push(0), (this.morphTargetDictionary[a] = i) } } } } else { var s = e.morphTargets void 0 !== s && s.length > 0 && console.error( 'THREE.Mesh.updateMorphTargets() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.', ) } }, raycast: function (e, t) { var n, r = this.geometry, i = this.material, o = this.matrixWorld if ( void 0 !== i && (null === r.boundingSphere && r.computeBoundingSphere(), ao.copy(r.boundingSphere), ao.applyMatrix4(o), !1 !== e.ray.intersectsSphere(ao) && (io.copy(o).invert(), oo.copy(e.ray).applyMatrix4(io), null === r.boundingBox || !1 !== oo.intersectsBox(r.boundingBox))) ) if (r.isBufferGeometry) { var a = r.index, s = r.attributes.position, l = r.morphAttributes.position, c = r.morphTargetsRelative, u = r.attributes.uv, h = r.attributes.uv2, d = r.groups, p = r.drawRange if (null !== a) if (Array.isArray(i)) for (var f = 0, m = d.length; f < m; f++) for ( var v = d[f], g = i[v.materialIndex], y = Math.max(v.start, p.start), b = Math.min(v.start + v.count, p.start + p.count); y < b; y += 3 ) { var A = a.getX(y), w = a.getX(y + 1), x = a.getX(y + 2) ;(n = Mo(this, g, e, oo, s, l, c, u, h, A, w, x)) && ((n.faceIndex = Math.floor(y / 3)), (n.face.materialIndex = v.materialIndex), t.push(n)) } else for ( var E = Math.max(0, p.start), M = Math.min(a.count, p.start + p.count); E < M; E += 3 ) { var _ = a.getX(E), T = a.getX(E + 1), S = a.getX(E + 2) ;(n = Mo(this, i, e, oo, s, l, c, u, h, _, T, S)) && ((n.faceIndex = Math.floor(E / 3)), t.push(n)) } else if (void 0 !== s) if (Array.isArray(i)) for (var C = 0, L = d.length; C < L; C++) for ( var R = d[C], P = i[R.materialIndex], D = Math.max(R.start, p.start), O = Math.min(R.start + R.count, p.start + p.count); D < O; D += 3 ) (n = Mo(this, P, e, oo, s, l, c, u, h, D, D + 1, D + 2)) && ((n.faceIndex = Math.floor(D / 3)), (n.face.materialIndex = R.materialIndex), t.push(n)) else for ( var I = Math.max(0, p.start), B = Math.min(s.count, p.start + p.count); I < B; I += 3 ) (n = Mo(this, i, e, oo, s, l, c, u, h, I, I + 1, I + 2)) && ((n.faceIndex = Math.floor(I / 3)), t.push(n)) } else r.isGeometry && console.error( 'THREE.Mesh.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.', ) }, }) var _o = (function (e) { function t(t, n, r, i, o, a) { var s void 0 === t && (t = 1), void 0 === n && (n = 1), void 0 === r && (r = 1), void 0 === i && (i = 1), void 0 === o && (o = 1), void 0 === a && (a = 1), ((s = e.call(this) || this).type = 'BoxGeometry'), (s.parameters = { width: t, height: n, depth: r, widthSegments: i, heightSegments: o, depthSegments: a, }) var l = zn(s) ;(i = Math.floor(i)), (o = Math.floor(o)), (a = Math.floor(a)) var c = [], u = [], h = [], d = [], p = 0, f = 0 function m(e, t, n, r, i, o, a, s, m, v, g) { for ( var y = o / m, b = a / v, A = o / 2, w = a / 2, x = s / 2, E = m + 1, M = v + 1, _ = 0, T = 0, S = new lr(), C = 0; C < M; C++ ) for (var L = C * b - w, R = 0; R < E; R++) { var P = R * y - A ;(S[e] = P * r), (S[t] = L * i), (S[n] = x), u.push(S.x, S.y, S.z), (S[e] = 0), (S[t] = 0), (S[n] = s > 0 ? 1 : -1), h.push(S.x, S.y, S.z), d.push(R / m), d.push(1 - C / v), (_ += 1) } for (var D = 0; D < v; D++) for (var O = 0; O < m; O++) { var I = p + O + E * D, B = p + O + E * (D + 1), F = p + (O + 1) + E * (D + 1), k = p + (O + 1) + E * D c.push(I, B, k), c.push(B, F, k), (T += 6) } l.addGroup(f, T, g), (f += T), (p += _) } return ( m('z', 'y', 'x', -1, -1, r, n, t, a, o, 0), m('z', 'y', 'x', 1, -1, r, n, -t, a, o, 1), m('x', 'z', 'y', 1, 1, t, r, n, i, a, 2), m('x', 'z', 'y', 1, -1, t, r, -n, i, a, 3), m('x', 'y', 'z', 1, -1, t, n, r, i, o, 4), m('x', 'y', 'z', -1, -1, t, n, -r, i, o, 5), s.setIndex(c), s.setAttribute('position', new Wi(u, 3)), s.setAttribute('normal', new Wi(h, 3)), s.setAttribute('uv', new Wi(d, 2)), s ) } return Gn(t, e), t })(ro) function To(e) { var t = {} for (var n in e) for (var r in ((t[n] = {}), e[n])) { var i = e[n][r] i && (i.isColor || i.isMatrix3 || i.isMatrix4 || i.isVector2 || i.isVector3 || i.isVector4 || i.isTexture) ? (t[n][r] = i.clone()) : Array.isArray(i) ? (t[n][r] = i.slice()) : (t[n][r] = i) } return t } function So(e) { for (var t = {}, n = 0; n < e.length; n++) { var r = To(e[n]) for (var i in r) t[i] = r[i] } return t } var Co = { clone: To, merge: So }, Lo = 'void main() {\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n}', Ro = 'void main() {\n\tgl_FragColor = vec4( 1.0, 0.0, 0.0, 1.0 );\n}' function Po(e) { Di.call(this), (this.type = 'ShaderMaterial'), (this.defines = {}), (this.uniforms = {}), (this.vertexShader = Lo), (this.fragmentShader = Ro), (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), (this.glslVersion = null), void 0 !== e && (void 0 !== e.attributes && console.error( 'THREE.ShaderMaterial: attributes should now be defined in THREE.BufferGeometry instead.', ), this.setValues(e)) } function Do() { si.call(this), (this.type = 'Camera'), (this.matrixWorldInverse = new Fr()), (this.projectionMatrix = new Fr()), (this.projectionMatrixInverse = new Fr()) } function Oo(e, t, n, r) { void 0 === e && (e = 50), void 0 === t && (t = 1), void 0 === n && (n = 0.1), void 0 === r && (r = 2e3), Do.call(this), (this.type = 'PerspectiveCamera'), (this.fov = e), (this.zoom = 1), (this.near = n), (this.far = r), (this.focus = 10), (this.aspect = t), (this.view = null), (this.filmGauge = 35), (this.filmOffset = 0), this.updateProjectionMatrix() } ;(Po.prototype = Object.create(Di.prototype)), (Po.prototype.constructor = Po), (Po.prototype.isShaderMaterial = !0), (Po.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), (this.fragmentShader = e.fragmentShader), (this.vertexShader = e.vertexShader), (this.uniforms = To(e.uniforms)), (this.defines = Object.assign({}, e.defines)), (this.wireframe = e.wireframe), (this.wireframeLinewidth = e.wireframeLinewidth), (this.lights = e.lights), (this.clipping = e.clipping), (this.skinning = e.skinning), (this.morphTargets = e.morphTargets), (this.morphNormals = e.morphNormals), (this.extensions = Object.assign({}, e.extensions)), (this.glslVersion = e.glslVersion), this ) }), (Po.prototype.toJSON = function (e) { var t = Di.prototype.toJSON.call(this, e) for (var n in ((t.glslVersion = this.glslVersion), (t.uniforms = {}), this.uniforms)) { var r = this.uniforms[n].value r && r.isTexture ? (t.uniforms[n] = { type: 't', value: r.toJSON(e).uuid }) : r && r.isColor ? (t.uniforms[n] = { type: 'c', value: r.getHex() }) : r && r.isVector2 ? (t.uniforms[n] = { type: 'v2', value: r.toArray() }) : r && r.isVector3 ? (t.uniforms[n] = { type: 'v3', value: r.toArray() }) : r && r.isVector4 ? (t.uniforms[n] = { type: 'v4', value: r.toArray() }) : r && r.isMatrix3 ? (t.uniforms[n] = { type: 'm3', value: r.toArray() }) : r && r.isMatrix4 ? (t.uniforms[n] = { type: 'm4', value: r.toArray() }) : (t.uniforms[n] = { value: r }) } Object.keys(this.defines).length > 0 && (t.defines = this.defines), (t.vertexShader = this.vertexShader), (t.fragmentShader = this.fragmentShader) var i = {} for (var o in this.extensions) !0 === this.extensions[o] && (i[o] = !0) return Object.keys(i).length > 0 && (t.extensions = i), t }), (Do.prototype = Object.assign(Object.create(si.prototype), { constructor: Do, isCamera: !0, copy: function (e, t) { return ( si.prototype.copy.call(this, e, t), this.matrixWorldInverse.copy(e.matrixWorldInverse), this.projectionMatrix.copy(e.projectionMatrix), this.projectionMatrixInverse.copy(e.projectionMatrixInverse), this ) }, getWorldDirection: function (e) { void 0 === e && (console.warn( 'THREE.Camera: .getWorldDirection() target is now required', ), (e = new lr())), this.updateWorldMatrix(!0, !1) var t = this.matrixWorld.elements return e.set(-t[8], -t[9], -t[10]).normalize() }, updateMatrixWorld: function (e) { si.prototype.updateMatrixWorld.call(this, e), this.matrixWorldInverse.copy(this.matrixWorld).invert() }, updateWorldMatrix: function (e, t) { si.prototype.updateWorldMatrix.call(this, e, t), this.matrixWorldInverse.copy(this.matrixWorld).invert() }, clone: function () { return new this.constructor().copy(this) }, })), (Oo.prototype = Object.assign(Object.create(Do.prototype), { constructor: Oo, isPerspectiveCamera: !0, copy: function (e, t) { return ( Do.prototype.copy.call(this, e, t), (this.fov = e.fov), (this.zoom = e.zoom), (this.near = e.near), (this.far = e.far), (this.focus = e.focus), (this.aspect = e.aspect), (this.view = null === e.view ? null : Object.assign({}, e.view)), (this.filmGauge = e.filmGauge), (this.filmOffset = e.filmOffset), this ) }, setFocalLength: function (e) { var t = (0.5 * this.getFilmHeight()) / e ;(this.fov = 2 * Kn.RAD2DEG * Math.atan(t)), this.updateProjectionMatrix() }, getFocalLength: function () { var e = Math.tan(0.5 * Kn.DEG2RAD * this.fov) return (0.5 * this.getFilmHeight()) / e }, getEffectiveFOV: function () { return ( 2 * Kn.RAD2DEG * Math.atan(Math.tan(0.5 * Kn.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 (e, t, n, r, i, o) { ;(this.aspect = e / t), 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 = e), (this.view.fullHeight = t), (this.view.offsetX = n), (this.view.offsetY = r), (this.view.width = i), (this.view.height = o), this.updateProjectionMatrix() }, clearViewOffset: function () { null !== this.view && (this.view.enabled = !1), this.updateProjectionMatrix() }, updateProjectionMatrix: function () { var e = this.near, t = (e * Math.tan(0.5 * Kn.DEG2RAD * this.fov)) / this.zoom, n = 2 * t, r = this.aspect * n, i = -0.5 * r, o = this.view if (null !== this.view && this.view.enabled) { var a = o.fullWidth, s = o.fullHeight ;(i += (o.offsetX * r) / a), (t -= (o.offsetY * n) / s), (r *= o.width / a), (n *= o.height / s) } var l = this.filmOffset 0 !== l && (i += (e * l) / this.getFilmWidth()), this.projectionMatrix.makePerspective(i, i + r, t, t - n, e, this.far), this.projectionMatrixInverse.copy(this.projectionMatrix).invert() }, toJSON: function (e) { var t = si.prototype.toJSON.call(this, e) return ( (t.object.fov = this.fov), (t.object.zoom = this.zoom), (t.object.near = this.near), (t.object.far = this.far), (t.object.focus = this.focus), (t.object.aspect = this.aspect), null !== this.view && (t.object.view = Object.assign({}, this.view)), (t.object.filmGauge = this.filmGauge), (t.object.filmOffset = this.filmOffset), t ) }, })) var Io = 90, Bo = 1 function Fo(e, t, n) { if ( (si.call(this), (this.type = 'CubeCamera'), !0 === n.isWebGLCubeRenderTarget) ) { this.renderTarget = n var r = new Oo(Io, Bo, e, t) ;(r.layers = this.layers), r.up.set(0, -1, 0), r.lookAt(new lr(1, 0, 0)), this.add(r) var i = new Oo(Io, Bo, e, t) ;(i.layers = this.layers), i.up.set(0, -1, 0), i.lookAt(new lr(-1, 0, 0)), this.add(i) var o = new Oo(Io, Bo, e, t) ;(o.layers = this.layers), o.up.set(0, 0, 1), o.lookAt(new lr(0, 1, 0)), this.add(o) var a = new Oo(Io, Bo, e, t) ;(a.layers = this.layers), a.up.set(0, 0, -1), a.lookAt(new lr(0, -1, 0)), this.add(a) var s = new Oo(Io, Bo, e, t) ;(s.layers = this.layers), s.up.set(0, -1, 0), s.lookAt(new lr(0, 0, 1)), this.add(s) var l = new Oo(Io, Bo, e, t) ;(l.layers = this.layers), l.up.set(0, -1, 0), l.lookAt(new lr(0, 0, -1)), this.add(l), (this.update = function (e, t) { null === this.parent && this.updateMatrixWorld() var c = e.xr.enabled, u = e.getRenderTarget() e.xr.enabled = !1 var h = n.texture.generateMipmaps ;(n.texture.generateMipmaps = !1), e.setRenderTarget(n, 0), e.render(t, r), e.setRenderTarget(n, 1), e.render(t, i), e.setRenderTarget(n, 2), e.render(t, o), e.setRenderTarget(n, 3), e.render(t, a), e.setRenderTarget(n, 4), e.render(t, s), (n.texture.generateMipmaps = h), e.setRenderTarget(n, 5), e.render(t, l), e.setRenderTarget(u), (e.xr.enabled = c) }) } else console.error( 'THREE.CubeCamera: The constructor now expects an instance of WebGLCubeRenderTarget as third parameter.', ) } function ko(e, t, n, r, i, o, a, s, l, c) { ;(e = void 0 !== e ? e : []), (t = void 0 !== t ? t : ae), (a = void 0 !== a ? a : Ne), nr.call(this, e, t, n, r, i, o, a, s, l, c), (this.flipY = !1), (this._needsFlipEnvMap = !0) } ;(Fo.prototype = Object.create(si.prototype)), (Fo.prototype.constructor = Fo), (ko.prototype = Object.create(nr.prototype)), (ko.prototype.constructor = ko), (ko.prototype.isCubeTexture = !0), Object.defineProperty(ko.prototype, 'images', { get: function () { return this.image }, set: function (e) { this.image = e }, }) var No = (function (e) { function t(t, n, r) { var i return ( Number.isInteger(n) && (console.warn( 'THREE.WebGLCubeRenderTarget: constructor signature is now WebGLCubeRenderTarget( size, options )', ), (n = r)), (i = e.call(this, t, t, n) || this), Object.defineProperty(zn(i), 'isWebGLCubeRenderTarget', { value: !0 }), (n = n || {}), (i.texture = new ko( void 0, n.mapping, n.wrapS, n.wrapT, n.magFilter, n.minFilter, n.format, n.type, n.anisotropy, n.encoding, )), (i.texture._needsFlipEnvMap = !1), i ) } Gn(t, e) var n = t.prototype return ( (n.fromEquirectangularTexture = function (e, t) { ;(this.texture.type = t.type), (this.texture.format = Ue), (this.texture.encoding = t.encoding), (this.texture.generateMipmaps = t.generateMipmaps), (this.texture.minFilter = t.minFilter), (this.texture.magFilter = t.magFilter) var n = { uniforms: { tEquirect: { value: null } }, vertexShader: '\n\n\t\t\t\tvarying vec3 vWorldDirection;\n\n\t\t\t\tvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\n\n\t\t\t\t\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\n\n\t\t\t\t}\n\n\t\t\t\tvoid main() {\n\n\t\t\t\t\tvWorldDirection = transformDirection( position, modelMatrix );\n\n\t\t\t\t\t#include \n\t\t\t\t\t#include \n\n\t\t\t\t}\n\t\t\t', fragmentShader: '\n\n\t\t\t\tuniform sampler2D tEquirect;\n\n\t\t\t\tvarying vec3 vWorldDirection;\n\n\t\t\t\t#include \n\n\t\t\t\tvoid main() {\n\n\t\t\t\t\tvec3 direction = normalize( vWorldDirection );\n\n\t\t\t\t\tvec2 sampleUV = equirectUv( direction );\n\n\t\t\t\t\tgl_FragColor = texture2D( tEquirect, sampleUV );\n\n\t\t\t\t}\n\t\t\t', }, r = new _o(5, 5, 5), i = new Po({ name: 'CubemapFromEquirect', uniforms: To(n.uniforms), vertexShader: n.vertexShader, fragmentShader: n.fragmentShader, side: v, blending: A, }) i.uniforms.tEquirect.value = t var o = new xo(r, i), a = t.minFilter return ( t.minFilter === Ee && (t.minFilter = Ae), new Fo(1, 10, this).update(e, o), (t.minFilter = a), o.geometry.dispose(), o.material.dispose(), this ) }), (n.clear = function (e, t, n, r) { for (var i = e.getRenderTarget(), o = 0; o < 6; o++) e.setRenderTarget(this, o), e.clear(t, n, r) e.setRenderTarget(i) }), t ) })(or) function Uo(e, t, n, r, i, o, a, s, l, c, u, h) { nr.call(this, null, o, a, s, l, c, r, i, u, h), (this.image = { data: e || null, width: t || 1, height: n || 1 }), (this.magFilter = void 0 !== l ? l : me), (this.minFilter = void 0 !== c ? c : me), (this.generateMipmaps = !1), (this.flipY = !1), (this.unpackAlignment = 1), (this.needsUpdate = !0) } ;(Uo.prototype = Object.create(nr.prototype)), (Uo.prototype.constructor = Uo), (Uo.prototype.isDataTexture = !0) var Ho = new Sr(), Go = new lr(), zo = (function () { function e(e, t, n, r, i, o) { this.planes = [ void 0 !== e ? e : new hi(), void 0 !== t ? t : new hi(), void 0 !== n ? n : new hi(), void 0 !== r ? r : new hi(), void 0 !== i ? i : new hi(), void 0 !== o ? o : new hi(), ] } var t = e.prototype return ( (t.set = function (e, t, n, r, i, o) { var a = this.planes return ( a[0].copy(e), a[1].copy(t), a[2].copy(n), a[3].copy(r), a[4].copy(i), a[5].copy(o), this ) }), (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { for (var t = this.planes, n = 0; n < 6; n++) t[n].copy(e.planes[n]) return this }), (t.setFromProjectionMatrix = function (e) { var t = this.planes, n = e.elements, r = n[0], i = n[1], o = n[2], a = n[3], s = n[4], l = n[5], c = n[6], u = n[7], h = n[8], d = n[9], p = n[10], f = n[11], m = n[12], v = n[13], g = n[14], y = n[15] return ( t[0].setComponents(a - r, u - s, f - h, y - m).normalize(), t[1].setComponents(a + r, u + s, f + h, y + m).normalize(), t[2].setComponents(a + i, u + l, f + d, y + v).normalize(), t[3].setComponents(a - i, u - l, f - d, y - v).normalize(), t[4].setComponents(a - o, u - c, f - p, y - g).normalize(), t[5].setComponents(a + o, u + c, f + p, y + g).normalize(), this ) }), (t.intersectsObject = function (e) { var t = e.geometry return ( null === t.boundingSphere && t.computeBoundingSphere(), Ho.copy(t.boundingSphere).applyMatrix4(e.matrixWorld), this.intersectsSphere(Ho) ) }), (t.intersectsSprite = function (e) { return ( Ho.center.set(0, 0, 0), (Ho.radius = 0.7071067811865476), Ho.applyMatrix4(e.matrixWorld), this.intersectsSphere(Ho) ) }), (t.intersectsSphere = function (e) { for ( var t = this.planes, n = e.center, r = -e.radius, i = 0; i < 6; i++ ) if (t[i].distanceToPoint(n) < r) return !1 return !0 }), (t.intersectsBox = function (e) { for (var t = this.planes, n = 0; n < 6; n++) { var r = t[n] if ( ((Go.x = r.normal.x > 0 ? e.max.x : e.min.x), (Go.y = r.normal.y > 0 ? e.max.y : e.min.y), (Go.z = r.normal.z > 0 ? e.max.z : e.min.z), r.distanceToPoint(Go) < 0) ) return !1 } return !0 }), (t.containsPoint = function (e) { for (var t = this.planes, n = 0; n < 6; n++) if (t[n].distanceToPoint(e) < 0) return !1 return !0 }), e ) })() function jo() { var e = null, t = !1, n = null, r = null function i(t, o) { n(t, o), (r = e.requestAnimationFrame(i)) } return { start: function () { !0 !== t && null !== n && ((r = e.requestAnimationFrame(i)), (t = !0)) }, stop: function () { e.cancelAnimationFrame(r), (t = !1) }, setAnimationLoop: function (e) { n = e }, setContext: function (t) { e = t }, } } function Vo(e, t) { var n = t.isWebGL2, r = new WeakMap() function i(t, r) { var i = t.array, o = t.usage, a = e.createBuffer() e.bindBuffer(r, a), e.bufferData(r, i, o), t.onUploadCallback() var s = 5126 return ( i instanceof Float32Array ? (s = 5126) : i instanceof Float64Array ? console.warn( 'THREE.WebGLAttributes: Unsupported data buffer format: Float64Array.', ) : i instanceof Uint16Array ? t.isFloat16BufferAttribute ? n ? (s = 5131) : console.warn( 'THREE.WebGLAttributes: Usage of Float16BufferAttribute requires WebGL2.', ) : (s = 5123) : i instanceof Int16Array ? (s = 5122) : i instanceof Uint32Array ? (s = 5125) : i instanceof Int32Array ? (s = 5124) : i instanceof Int8Array ? (s = 5120) : i instanceof Uint8Array && (s = 5121), { buffer: a, type: s, bytesPerElement: i.BYTES_PER_ELEMENT, version: t.version, } ) } function o(t, r, i) { var o = r.array, a = r.updateRange e.bindBuffer(i, t), -1 === a.count ? e.bufferSubData(i, 0, o) : (n ? e.bufferSubData( i, a.offset * o.BYTES_PER_ELEMENT, o, a.offset, a.count, ) : e.bufferSubData( i, a.offset * o.BYTES_PER_ELEMENT, o.subarray(a.offset, a.offset + a.count), ), (a.count = -1)) } function a(e) { return e.isInterleavedBufferAttribute && (e = e.data), r.get(e) } function s(t) { t.isInterleavedBufferAttribute && (t = t.data) var n = r.get(t) n && (e.deleteBuffer(n.buffer), r.delete(t)) } function l(e, t) { if (e.isGLBufferAttribute) { var n = r.get(e) ;(!n || n.version < e.version) && r.set(e, { buffer: e.buffer, type: e.type, bytesPerElement: e.elementSize, version: e.version, }) } else { e.isInterleavedBufferAttribute && (e = e.data) var a = r.get(e) void 0 === a ? r.set(e, i(e, t)) : a.version < e.version && (o(a.buffer, e, t), (a.version = e.version)) } } return { get: a, remove: s, update: l } } var Wo = (function (e) { function t(t, n, r, i) { var o void 0 === t && (t = 1), void 0 === n && (n = 1), void 0 === r && (r = 1), void 0 === i && (i = 1), ((o = e.call(this) || this).type = 'PlaneGeometry'), (o.parameters = { width: t, height: n, widthSegments: r, heightSegments: i, }) for ( var a = t / 2, s = n / 2, l = Math.floor(r), c = Math.floor(i), u = l + 1, h = c + 1, d = t / l, p = n / c, f = [], m = [], v = [], g = [], y = 0; y < h; y++ ) for (var b = y * p - s, A = 0; A < u; A++) { var w = A * d - a m.push(w, -b, 0), v.push(0, 0, 1), g.push(A / l), g.push(1 - y / c) } for (var x = 0; x < c; x++) for (var E = 0; E < l; E++) { var M = E + u * x, _ = E + u * (x + 1), T = E + 1 + u * (x + 1), S = E + 1 + u * x f.push(M, _, S), f.push(_, T, S) } return ( o.setIndex(f), o.setAttribute('position', new Wi(m, 3)), o.setAttribute('normal', new Wi(v, 3)), o.setAttribute('uv', new Wi(g, 2)), o ) } return Gn(t, e), t })(ro), qo = { 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: '#if defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR )\n\tvarying vec3 vColor;\n#endif', color_vertex: '#if defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR )\n\tvColor = vec3( 1.0 );\n#endif\n#ifdef USE_COLOR\n\tvColor.xyz *= color.xyz;\n#endif\n#ifdef USE_INSTANCING_COLOR\n\tvColor.xyz *= instanceColor.xyz;\n#endif', common: '#define PI 3.141592653589793\n#define PI2 6.283185307179586\n#define PI_HALF 1.5707963267948966\n#define RECIPROCAL_PI 0.3183098861837907\n#define RECIPROCAL_PI2 0.15915494309189535\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\treturn m[ 2 ][ 3 ] == - 1.0;\n}\nvec2 equirectUv( in vec3 dir ) {\n\tfloat u = atan( dir.z, dir.x ) * RECIPROCAL_PI2 + 0.5;\n\tfloat v = asin( clamp( dir.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\treturn vec2( u, v );\n}', cube_uv_reflection_fragment: '#ifdef ENVMAP_TYPE_CUBE_UV\n\t#define cubeUV_maxMipLevel 8.0\n\t#define cubeUV_minMipLevel 4.0\n\t#define cubeUV_maxTileSize 256.0\n\t#define cubeUV_minTileSize 16.0\n\tfloat getFace( vec3 direction ) {\n\t\tvec3 absDirection = abs( direction );\n\t\tfloat face = - 1.0;\n\t\tif ( absDirection.x > absDirection.z ) {\n\t\t\tif ( absDirection.x > absDirection.y )\n\t\t\t\tface = direction.x > 0.0 ? 0.0 : 3.0;\n\t\t\telse\n\t\t\t\tface = direction.y > 0.0 ? 1.0 : 4.0;\n\t\t} else {\n\t\t\tif ( absDirection.z > absDirection.y )\n\t\t\t\tface = direction.z > 0.0 ? 2.0 : 5.0;\n\t\t\telse\n\t\t\t\tface = direction.y > 0.0 ? 1.0 : 4.0;\n\t\t}\n\t\treturn face;\n\t}\n\tvec2 getUV( vec3 direction, float face ) {\n\t\tvec2 uv;\n\t\tif ( face == 0.0 ) {\n\t\t\tuv = vec2( direction.z, direction.y ) / abs( direction.x );\n\t\t} else if ( face == 1.0 ) {\n\t\t\tuv = vec2( - direction.x, - direction.z ) / abs( direction.y );\n\t\t} else if ( face == 2.0 ) {\n\t\t\tuv = vec2( - direction.x, direction.y ) / abs( direction.z );\n\t\t} else if ( face == 3.0 ) {\n\t\t\tuv = vec2( - direction.z, direction.y ) / abs( direction.x );\n\t\t} else if ( face == 4.0 ) {\n\t\t\tuv = vec2( - direction.x, direction.z ) / abs( direction.y );\n\t\t} else {\n\t\t\tuv = vec2( direction.x, direction.y ) / abs( direction.z );\n\t\t}\n\t\treturn 0.5 * ( uv + 1.0 );\n\t}\n\tvec3 bilinearCubeUV( sampler2D envMap, vec3 direction, float mipInt ) {\n\t\tfloat face = getFace( direction );\n\t\tfloat filterInt = max( cubeUV_minMipLevel - mipInt, 0.0 );\n\t\tmipInt = max( mipInt, cubeUV_minMipLevel );\n\t\tfloat faceSize = exp2( mipInt );\n\t\tfloat texelSize = 1.0 / ( 3.0 * cubeUV_maxTileSize );\n\t\tvec2 uv = getUV( direction, face ) * ( faceSize - 1.0 );\n\t\tvec2 f = fract( uv );\n\t\tuv += 0.5 - f;\n\t\tif ( face > 2.0 ) {\n\t\t\tuv.y += faceSize;\n\t\t\tface -= 3.0;\n\t\t}\n\t\tuv.x += face * faceSize;\n\t\tif ( mipInt < cubeUV_maxMipLevel ) {\n\t\t\tuv.y += 2.0 * cubeUV_maxTileSize;\n\t\t}\n\t\tuv.y += filterInt * 2.0 * cubeUV_minTileSize;\n\t\tuv.x += 3.0 * max( 0.0, cubeUV_maxTileSize - 2.0 * faceSize );\n\t\tuv *= texelSize;\n\t\tvec3 tl = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tuv.x += texelSize;\n\t\tvec3 tr = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tuv.y += texelSize;\n\t\tvec3 br = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tuv.x -= texelSize;\n\t\tvec3 bl = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tvec3 tm = mix( tl, tr, f.x );\n\t\tvec3 bm = mix( bl, br, f.x );\n\t\treturn mix( tm, bm, f.y );\n\t}\n\t#define r0 1.0\n\t#define v0 0.339\n\t#define m0 - 2.0\n\t#define r1 0.8\n\t#define v1 0.276\n\t#define m1 - 1.0\n\t#define r4 0.4\n\t#define v4 0.046\n\t#define m4 2.0\n\t#define r5 0.305\n\t#define v5 0.016\n\t#define m5 3.0\n\t#define r6 0.21\n\t#define v6 0.0038\n\t#define m6 4.0\n\tfloat roughnessToMip( float roughness ) {\n\t\tfloat mip = 0.0;\n\t\tif ( roughness >= r1 ) {\n\t\t\tmip = ( r0 - roughness ) * ( m1 - m0 ) / ( r0 - r1 ) + m0;\n\t\t} else if ( roughness >= r4 ) {\n\t\t\tmip = ( r1 - roughness ) * ( m4 - m1 ) / ( r1 - r4 ) + m1;\n\t\t} else if ( roughness >= r5 ) {\n\t\t\tmip = ( r4 - roughness ) * ( m5 - m4 ) / ( r4 - r5 ) + m4;\n\t\t} else if ( roughness >= r6 ) {\n\t\t\tmip = ( r5 - roughness ) * ( m6 - m5 ) / ( r5 - r6 ) + m5;\n\t\t} else {\n\t\t\tmip = - 2.0 * log2( 1.16 * roughness );\t\t}\n\t\treturn mip;\n\t}\n\tvec4 textureCubeUV( sampler2D envMap, vec3 sampleDir, float roughness ) {\n\t\tfloat mip = clamp( roughnessToMip( roughness ), m0, cubeUV_maxMipLevel );\n\t\tfloat mipF = fract( mip );\n\t\tfloat mipInt = floor( mip );\n\t\tvec3 color0 = bilinearCubeUV( envMap, sampleDir, mipInt );\n\t\tif ( mipF == 0.0 ) {\n\t\t\treturn vec4( color0, 1.0 );\n\t\t} else {\n\t\t\tvec3 color1 = bilinearCubeUV( envMap, sampleDir, mipInt + 1.0 );\n\t\t\treturn vec4( mix( color0, color1, mipF ), 1.0 );\n\t\t}\n\t}\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\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#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\tvec3 reflectVec = reflect( -viewDir, normal );\n\t\t\treflectVec = normalize( mix( reflectVec, normal, roughness * roughness) );\n\t\t#else\n\t\t\tvec3 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#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;\nvIndirectFront += getAmbientLightIrradiance( ambientLightColor );\nvIndirectFront += getLightProbeIrradiance( lightProbe, geometry );\n#ifdef DOUBLE_SIDED\n\tvIndirectBack += getAmbientLightIrradiance( ambientLightColor );\n\tvIndirectBack += getLightProbeIrradiance( lightProbe, backGeometry );\n#endif\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\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\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\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;', lights_toon_pars_fragment: 'varying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\nstruct ToonMaterial {\n\tvec3 diffuseColor;\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}\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 diffuseColor;\n\tvec3 specularColor;\n\tfloat specularShininess;\n\tfloat specularStrength;\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 diffuseColor;\n\tfloat specularRoughness;\n\tvec3 specularColor;\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(\t\t0, 1,\t\t0 ),\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\t\tuniform float morphTargetInfluences[ 8 ];\n\t#else\n\t\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\t\ttransformed += morphTarget4 * morphTargetInfluences[ 4 ];\n\t\ttransformed += morphTarget5 * morphTargetInfluences[ 5 ];\n\t\ttransformed += morphTarget6 * morphTargetInfluences[ 6 ];\n\t\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\tstruct DirectionalLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\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\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\tstruct SpotLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\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\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\tstruct PointLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\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\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\ttexture2DCompare( shadowMap, uv + vec2( 2.0 * dx, -dy ), shadowCoord.z ),\n\t\t\t\t\t\t\tf.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\ttexture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 2.0 * dy ), shadowCoord.z ),\n\t\t\t\t\t\t\tf.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\tstruct DirectionalLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\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\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\tstruct SpotLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\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\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\tstruct PointLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\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#endif', shadowmap_vertex: '#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHT_SHADOWS > 0 || NUM_SPOT_LIGHT_SHADOWS > 0 || NUM_POINT_LIGHT_SHADOWS > 0\n\t\tvec3 shadowWorldNormal = inverseTransformDirection( transformedNormal, viewMatrix );\n\t\tvec4 shadowWorldPosition;\n\t#endif\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\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * directionalLightShadows[ i ].shadowNormalBias, 0 );\n\t\tvDirectionalShadowCoord[ i ] = directionalShadowMatrix[ i ] * shadowWorldPosition;\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\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * spotLightShadows[ i ].shadowNormalBias, 0 );\n\t\tvSpotShadowCoord[ i ] = spotShadowMatrix[ i ] * shadowWorldPosition;\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\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * pointLightShadows[ i ].shadowNormalBias, 0 );\n\t\tvPointShadowCoord[ i ] = pointShadowMatrix[ i ] * shadowWorldPosition;\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;\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}\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 RRTAndODTFit( vec3 v ) {\n\tvec3 a = v * ( v + 0.0245786 ) - 0.000090537;\n\tvec3 b = v * ( 0.983729 * v + 0.4329510 ) + 0.238081;\n\treturn a / b;\n}\nvec3 ACESFilmicToneMapping( vec3 color ) {\n\tconst mat3 ACESInputMat = mat3(\n\t\tvec3( 0.59719, 0.07600, 0.02840 ),\t\tvec3( 0.35458, 0.90834, 0.13383 ),\n\t\tvec3( 0.04823, 0.01566, 0.83777 )\n\t);\n\tconst mat3 ACESOutputMat = mat3(\n\t\tvec3(\t1.60475, -0.10208, -0.00327 ),\t\tvec3( -0.53108,\t1.10813, -0.07276 ),\n\t\tvec3( -0.07367, -0.00605,\t1.07602 )\n\t);\n\tcolor *= toneMappingExposure / 0.6;\n\tcolor = ACESInputMat * color;\n\tcolor = RRTAndODTFit( color );\n\tcolor = ACESOutputMat * color;\n\treturn saturate( color );\n}\nvec3 CustomToneMapping( vec3 color ) { return color; }', transmissionmap_fragment: '#ifdef USE_TRANSMISSIONMAP\n\ttotalTransmission *= texture2D( transmissionMap, vUv ).r;\n#endif', transmissionmap_pars_fragment: '#ifdef USE_TRANSMISSIONMAP\n\tuniform sampler2D transmissionMap;\n#endif', 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 = equirectUv( direction );\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 \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\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 \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\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\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 \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\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 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 \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\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + 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 TRANSMISSION\n#endif\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float roughness;\nuniform float metalness;\nuniform float opacity;\n#ifdef TRANSMISSION\n\tuniform float transmission;\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 \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#ifdef TRANSMISSION\n\t\tfloat totalTransmission = transmission;\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\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 TRANSMISSION\n\t\tdiffuseColor.a *= mix( saturate( 1. - totalTransmission + linearToRelativeLuminance( reflectedLight.directSpecular + reflectedLight.indirectSpecular ) ), 1.0, metalness );\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 \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}', 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}', }, Xo = { common: { diffuse: { value: new Li(15658734) }, opacity: { value: 1 }, map: { value: null }, uvTransform: { value: new $n() }, uv2Transform: { value: new $n() }, alphaMap: { value: null }, }, specularmap: { specularMap: { value: null } }, envmap: { envMap: { value: null }, flipEnvMap: { value: -1 }, reflectivity: { value: 1 }, refractionRatio: { value: 0.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 Jn(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 Li(16777215) }, }, lights: { ambientLightColor: { value: [] }, lightProbe: { value: [] }, directionalLights: { value: [], properties: { direction: {}, color: {} }, }, directionalLightShadows: { value: [], properties: { shadowBias: {}, shadowNormalBias: {}, shadowRadius: {}, shadowMapSize: {}, }, }, directionalShadowMap: { value: [] }, directionalShadowMatrix: { value: [] }, spotLights: { value: [], properties: { color: {}, position: {}, direction: {}, distance: {}, coneCos: {}, penumbraCos: {}, decay: {}, }, }, spotLightShadows: { value: [], properties: { shadowBias: {}, shadowNormalBias: {}, shadowRadius: {}, shadowMapSize: {}, }, }, spotShadowMap: { value: [] }, spotShadowMatrix: { value: [] }, pointLights: { value: [], properties: { color: {}, position: {}, decay: {}, distance: {} }, }, pointLightShadows: { value: [], properties: { shadowBias: {}, shadowNormalBias: {}, shadowRadius: {}, shadowMapSize: {}, shadowCameraNear: {}, shadowCameraFar: {}, }, }, pointShadowMap: { value: [] }, pointShadowMatrix: { value: [] }, hemisphereLights: { value: [], properties: { direction: {}, skyColor: {}, groundColor: {} }, }, rectAreaLights: { value: [], properties: { color: {}, position: {}, width: {}, height: {} }, }, ltc_1: { value: null }, ltc_2: { value: null }, }, points: { diffuse: { value: new Li(15658734) }, opacity: { value: 1 }, size: { value: 1 }, scale: { value: 1 }, map: { value: null }, alphaMap: { value: null }, uvTransform: { value: new $n() }, }, sprite: { diffuse: { value: new Li(15658734) }, opacity: { value: 1 }, center: { value: new Jn(0.5, 0.5) }, rotation: { value: 0 }, map: { value: null }, alphaMap: { value: null }, uvTransform: { value: new $n() }, }, }, Yo = { basic: { uniforms: So([ Xo.common, Xo.specularmap, Xo.envmap, Xo.aomap, Xo.lightmap, Xo.fog, ]), vertexShader: qo.meshbasic_vert, fragmentShader: qo.meshbasic_frag, }, lambert: { uniforms: So([ Xo.common, Xo.specularmap, Xo.envmap, Xo.aomap, Xo.lightmap, Xo.emissivemap, Xo.fog, Xo.lights, { emissive: { value: new Li(0) } }, ]), vertexShader: qo.meshlambert_vert, fragmentShader: qo.meshlambert_frag, }, phong: { uniforms: So([ Xo.common, Xo.specularmap, Xo.envmap, Xo.aomap, Xo.lightmap, Xo.emissivemap, Xo.bumpmap, Xo.normalmap, Xo.displacementmap, Xo.fog, Xo.lights, { emissive: { value: new Li(0) }, specular: { value: new Li(1118481) }, shininess: { value: 30 }, }, ]), vertexShader: qo.meshphong_vert, fragmentShader: qo.meshphong_frag, }, standard: { uniforms: So([ Xo.common, Xo.envmap, Xo.aomap, Xo.lightmap, Xo.emissivemap, Xo.bumpmap, Xo.normalmap, Xo.displacementmap, Xo.roughnessmap, Xo.metalnessmap, Xo.fog, Xo.lights, { emissive: { value: new Li(0) }, roughness: { value: 1 }, metalness: { value: 0 }, envMapIntensity: { value: 1 }, }, ]), vertexShader: qo.meshphysical_vert, fragmentShader: qo.meshphysical_frag, }, toon: { uniforms: So([ Xo.common, Xo.aomap, Xo.lightmap, Xo.emissivemap, Xo.bumpmap, Xo.normalmap, Xo.displacementmap, Xo.gradientmap, Xo.fog, Xo.lights, { emissive: { value: new Li(0) } }, ]), vertexShader: qo.meshtoon_vert, fragmentShader: qo.meshtoon_frag, }, matcap: { uniforms: So([ Xo.common, Xo.bumpmap, Xo.normalmap, Xo.displacementmap, Xo.fog, { matcap: { value: null } }, ]), vertexShader: qo.meshmatcap_vert, fragmentShader: qo.meshmatcap_frag, }, points: { uniforms: So([Xo.points, Xo.fog]), vertexShader: qo.points_vert, fragmentShader: qo.points_frag, }, dashed: { uniforms: So([ Xo.common, Xo.fog, { scale: { value: 1 }, dashSize: { value: 1 }, totalSize: { value: 2 }, }, ]), vertexShader: qo.linedashed_vert, fragmentShader: qo.linedashed_frag, }, depth: { uniforms: So([Xo.common, Xo.displacementmap]), vertexShader: qo.depth_vert, fragmentShader: qo.depth_frag, }, normal: { uniforms: So([ Xo.common, Xo.bumpmap, Xo.normalmap, Xo.displacementmap, { opacity: { value: 1 } }, ]), vertexShader: qo.normal_vert, fragmentShader: qo.normal_frag, }, sprite: { uniforms: So([Xo.sprite, Xo.fog]), vertexShader: qo.sprite_vert, fragmentShader: qo.sprite_frag, }, background: { uniforms: { uvTransform: { value: new $n() }, t2D: { value: null } }, vertexShader: qo.background_vert, fragmentShader: qo.background_frag, }, cube: { uniforms: So([Xo.envmap, { opacity: { value: 1 } }]), vertexShader: qo.cube_vert, fragmentShader: qo.cube_frag, }, equirect: { uniforms: { tEquirect: { value: null } }, vertexShader: qo.equirect_vert, fragmentShader: qo.equirect_frag, }, distanceRGBA: { uniforms: So([ Xo.common, Xo.displacementmap, { referencePosition: { value: new lr() }, nearDistance: { value: 1 }, farDistance: { value: 1e3 }, }, ]), vertexShader: qo.distanceRGBA_vert, fragmentShader: qo.distanceRGBA_frag, }, shadow: { uniforms: So([ Xo.lights, Xo.fog, { color: { value: new Li(0) }, opacity: { value: 1 } }, ]), vertexShader: qo.shadow_vert, fragmentShader: qo.shadow_frag, }, } function Qo(e, t, n, r, i) { var o, a, s = new Li(0), l = 0, c = null, u = 0, h = null function d(n, i, d, f) { var g = !0 === i.isScene ? i.background : null g && g.isTexture && (g = t.get(g)) var y = e.xr, b = y.getSession && y.getSession() b && 'additive' === b.environmentBlendMode && (g = null), null === g ? p(s, l) : g && g.isColor && (p(g, 1), (f = !0)), (e.autoClear || f) && e.clear(e.autoClearColor, e.autoClearDepth, e.autoClearStencil), g && (g.isCubeTexture || g.isWebGLCubeRenderTarget || g.mapping === ue) ? (void 0 === a && ((a = new xo( new _o(1, 1, 1), new Po({ name: 'BackgroundCubeMaterial', uniforms: To(Yo.cube.uniforms), vertexShader: Yo.cube.vertexShader, fragmentShader: Yo.cube.fragmentShader, side: v, depthTest: !1, depthWrite: !1, fog: !1, }), )).geometry.deleteAttribute('normal'), a.geometry.deleteAttribute('uv'), (a.onBeforeRender = function (e, t, n) { this.matrixWorld.copyPosition(n.matrixWorld) }), Object.defineProperty(a.material, 'envMap', { get: function () { return this.uniforms.envMap.value }, }), r.update(a)), g.isWebGLCubeRenderTarget && (g = g.texture), (a.material.uniforms.envMap.value = g), (a.material.uniforms.flipEnvMap.value = g.isCubeTexture && g._needsFlipEnvMap ? -1 : 1), (c === g && u === g.version && h === e.toneMapping) || ((a.material.needsUpdate = !0), (c = g), (u = g.version), (h = e.toneMapping)), n.unshift(a, a.geometry, a.material, 0, 0, null)) : g && g.isTexture && (void 0 === o && ((o = new xo( new Wo(2, 2), new Po({ name: 'BackgroundMaterial', uniforms: To(Yo.background.uniforms), vertexShader: Yo.background.vertexShader, fragmentShader: Yo.background.fragmentShader, side: m, depthTest: !1, depthWrite: !1, fog: !1, }), )).geometry.deleteAttribute('normal'), Object.defineProperty(o.material, 'map', { get: function () { return this.uniforms.t2D.value }, }), r.update(o)), (o.material.uniforms.t2D.value = g), !0 === g.matrixAutoUpdate && g.updateMatrix(), o.material.uniforms.uvTransform.value.copy(g.matrix), (c === g && u === g.version && h === e.toneMapping) || ((o.material.needsUpdate = !0), (c = g), (u = g.version), (h = e.toneMapping)), n.unshift(o, o.geometry, o.material, 0, 0, null)) } function p(e, t) { n.buffers.color.setClear(e.r, e.g, e.b, t, i) } return { getClearColor: function () { return s }, setClearColor: function (e, t) { void 0 === t && (t = 1), s.set(e), p(s, (l = t)) }, getClearAlpha: function () { return l }, setClearAlpha: function (e) { p(s, (l = e)) }, render: d, } } function Zo(e, t, n, r) { var i = e.getParameter(34921), o = r.isWebGL2 ? null : t.get('OES_vertex_array_object'), a = r.isWebGL2 || null !== o, s = {}, l = m(null), c = l function u(t, r, i, o, s) { var l = !1 if (a) { var u = f(o, i, r) c !== u && d((c = u).object), (l = v(o, s)) && g(o, s) } else { var h = !0 === r.wireframe ;(c.geometry === o.id && c.program === i.id && c.wireframe === h) || ((c.geometry = o.id), (c.program = i.id), (c.wireframe = h), (l = !0)) } !0 === t.isInstancedMesh && (l = !0), null !== s && n.update(s, 34963), l && (E(t, r, i, o), null !== s && e.bindBuffer(34963, n.get(s).buffer)) } function h() { return r.isWebGL2 ? e.createVertexArray() : o.createVertexArrayOES() } function d(t) { return r.isWebGL2 ? e.bindVertexArray(t) : o.bindVertexArrayOES(t) } function p(t) { return r.isWebGL2 ? e.deleteVertexArray(t) : o.deleteVertexArrayOES(t) } function f(e, t, n) { var r = !0 === n.wireframe, i = s[e.id] void 0 === i && ((i = {}), (s[e.id] = i)) var o = i[t.id] void 0 === o && ((o = {}), (i[t.id] = o)) var a = o[r] return void 0 === a && ((a = m(h())), (o[r] = a)), a } function m(e) { for (var t = [], n = [], r = [], o = 0; o < i; o++) (t[o] = 0), (n[o] = 0), (r[o] = 0) return { geometry: null, program: null, wireframe: !1, newAttributes: t, enabledAttributes: n, attributeDivisors: r, object: e, attributes: {}, index: null, } } function v(e, t) { var n = c.attributes, r = e.attributes, i = 0 for (var o in r) { var a = n[o], s = r[o] if (void 0 === a) return !0 if (a.attribute !== s) return !0 if (a.data !== s.data) return !0 i++ } return c.attributesNum !== i || c.index !== t } function g(e, t) { var n = {}, r = e.attributes, i = 0 for (var o in r) { var a = r[o], s = {} ;(s.attribute = a), a.data && (s.data = a.data), (n[o] = s), i++ } ;(c.attributes = n), (c.attributesNum = i), (c.index = t) } function y() { for (var e = c.newAttributes, t = 0, n = e.length; t < n; t++) e[t] = 0 } function b(e) { A(e, 0) } function A(n, i) { var o = c.newAttributes, a = c.enabledAttributes, s = c.attributeDivisors ;(o[n] = 1), 0 === a[n] && (e.enableVertexAttribArray(n), (a[n] = 1)), s[n] !== i && ((r.isWebGL2 ? e : t.get('ANGLE_instanced_arrays'))[ r.isWebGL2 ? 'vertexAttribDivisor' : 'vertexAttribDivisorANGLE' ](n, i), (s[n] = i)) } function w() { for ( var t = c.newAttributes, n = c.enabledAttributes, r = 0, i = n.length; r < i; r++ ) n[r] !== t[r] && (e.disableVertexAttribArray(r), (n[r] = 0)) } function x(t, n, i, o, a, s) { !0 !== r.isWebGL2 || (5124 !== i && 5125 !== i) ? e.vertexAttribPointer(t, n, i, o, a, s) : e.vertexAttribIPointer(t, n, i, a, s) } function E(i, o, a, s) { if ( !1 !== r.isWebGL2 || (!i.isInstancedMesh && !s.isInstancedBufferGeometry) || null !== t.get('ANGLE_instanced_arrays') ) { y() var l = s.attributes, c = a.getAttributes(), u = o.defaultAttributeValues for (var h in c) { var d = c[h] if (d >= 0) { var p = l[h] if (void 0 !== p) { var f = p.normalized, m = p.itemSize, v = n.get(p) if (void 0 === v) continue var g = v.buffer, E = v.type, M = v.bytesPerElement if (p.isInterleavedBufferAttribute) { var _ = p.data, T = _.stride, S = p.offset _ && _.isInstancedInterleavedBuffer ? (A(d, _.meshPerAttribute), void 0 === s._maxInstanceCount && (s._maxInstanceCount = _.meshPerAttribute * _.count)) : b(d), e.bindBuffer(34962, g), x(d, m, E, f, T * M, S * M) } else p.isInstancedBufferAttribute ? (A(d, p.meshPerAttribute), void 0 === s._maxInstanceCount && (s._maxInstanceCount = p.meshPerAttribute * p.count)) : b(d), e.bindBuffer(34962, g), x(d, m, E, f, 0, 0) } else if ('instanceMatrix' === h) { var C = n.get(i.instanceMatrix) if (void 0 === C) continue var L = C.buffer, R = C.type A(d + 0, 1), A(d + 1, 1), A(d + 2, 1), A(d + 3, 1), e.bindBuffer(34962, L), e.vertexAttribPointer(d + 0, 4, R, !1, 64, 0), e.vertexAttribPointer(d + 1, 4, R, !1, 64, 16), e.vertexAttribPointer(d + 2, 4, R, !1, 64, 32), e.vertexAttribPointer(d + 3, 4, R, !1, 64, 48) } else if ('instanceColor' === h) { var P = n.get(i.instanceColor) if (void 0 === P) continue var D = P.buffer, O = P.type A(d, 1), e.bindBuffer(34962, D), e.vertexAttribPointer(d, 3, O, !1, 12, 0) } else if (void 0 !== u) { var I = u[h] if (void 0 !== I) switch (I.length) { case 2: e.vertexAttrib2fv(d, I) break case 3: e.vertexAttrib3fv(d, I) break case 4: e.vertexAttrib4fv(d, I) break default: e.vertexAttrib1fv(d, I) } } } } w() } } function M() { for (var e in (S(), s)) { var t = s[e] for (var n in t) { var r = t[n] for (var i in r) p(r[i].object), delete r[i] delete t[n] } delete s[e] } } function _(e) { if (void 0 !== s[e.id]) { var t = s[e.id] for (var n in t) { var r = t[n] for (var i in r) p(r[i].object), delete r[i] delete t[n] } delete s[e.id] } } function T(e) { for (var t in s) { var n = s[t] if (void 0 !== n[e.id]) { var r = n[e.id] for (var i in r) p(r[i].object), delete r[i] delete n[e.id] } } } function S() { C(), c !== l && d((c = l).object) } function C() { ;(l.geometry = null), (l.program = null), (l.wireframe = !1) } return { setup: u, reset: S, resetDefaultState: C, dispose: M, releaseStatesOfGeometry: _, releaseStatesOfProgram: T, initAttributes: y, enableAttribute: b, disableUnusedAttributes: w, } } function Ko(e, t, n, r) { var i, o = r.isWebGL2 function a(e) { i = e } function s(t, r) { e.drawArrays(i, t, r), n.update(r, i, 1) } function l(r, a, s) { if (0 !== s) { var l, c if (o) (l = e), (c = 'drawArraysInstanced') else if ( ((c = 'drawArraysInstancedANGLE'), null === (l = t.get('ANGLE_instanced_arrays'))) ) return void console.error( 'THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.', ) l[c](i, r, a, s), n.update(a, i, s) } } ;(this.setMode = a), (this.render = s), (this.renderInstances = l) } function Jo(e, t, n) { var r function i() { if (void 0 !== r) return r var n = t.get('EXT_texture_filter_anisotropic') return (r = null !== n ? e.getParameter(n.MAX_TEXTURE_MAX_ANISOTROPY_EXT) : 0) } function o(t) { if ('highp' === t) { if ( e.getShaderPrecisionFormat(35633, 36338).precision > 0 && e.getShaderPrecisionFormat(35632, 36338).precision > 0 ) return 'highp' t = 'mediump' } return 'mediump' === t && e.getShaderPrecisionFormat(35633, 36337).precision > 0 && e.getShaderPrecisionFormat(35632, 36337).precision > 0 ? 'mediump' : 'lowp' } var a = ('undefined' !== typeof WebGL2RenderingContext && e instanceof WebGL2RenderingContext) || ('undefined' !== typeof WebGL2ComputeRenderingContext && e instanceof WebGL2ComputeRenderingContext), s = void 0 !== n.precision ? n.precision : 'highp', l = o(s) l !== s && (console.warn( 'THREE.WebGLRenderer:', s, 'not supported, using', l, 'instead.', ), (s = l)) var c = !0 === n.logarithmicDepthBuffer, u = e.getParameter(34930), h = e.getParameter(35660), d = e.getParameter(3379), p = e.getParameter(34076), f = e.getParameter(34921), m = e.getParameter(36347), v = e.getParameter(36348), g = e.getParameter(36349), y = h > 0, b = a || !!t.get('OES_texture_float') return { isWebGL2: a, getMaxAnisotropy: i, getMaxPrecision: o, precision: s, logarithmicDepthBuffer: c, maxTextures: u, maxVertexTextures: h, maxTextureSize: d, maxCubemapSize: p, maxAttributes: f, maxVertexUniforms: m, maxVaryings: v, maxFragmentUniforms: g, vertexTextures: y, floatFragmentTextures: b, floatVertexTextures: y && b, maxSamples: a ? e.getParameter(36183) : 0, } } function $o(e) { var t = this, n = null, r = 0, i = !1, o = !1, a = new hi(), s = new $n(), l = { value: null, needsUpdate: !1 } function c() { l.value !== n && ((l.value = n), (l.needsUpdate = r > 0)), (t.numPlanes = r), (t.numIntersection = 0) } function u(e, n, r, i) { var o = null !== e ? e.length : 0, c = null if (0 !== o) { if (((c = l.value), !0 !== i || null === c)) { var u = r + 4 * o, h = n.matrixWorldInverse s.getNormalMatrix(h), (null === c || c.length < u) && (c = new Float32Array(u)) for (var d = 0, p = r; d !== o; ++d, p += 4) a.copy(e[d]).applyMatrix4(h, s), a.normal.toArray(c, p), (c[p + 3] = a.constant) } ;(l.value = c), (l.needsUpdate = !0) } return (t.numPlanes = o), (t.numIntersection = 0), c } ;(this.uniform = l), (this.numPlanes = 0), (this.numIntersection = 0), (this.init = function (e, t, o) { var a = 0 !== e.length || t || 0 !== r || i return (i = t), (n = u(e, o, 0)), (r = e.length), a }), (this.beginShadows = function () { ;(o = !0), u(null) }), (this.endShadows = function () { ;(o = !1), c() }), (this.setState = function (t, a, s) { var h = t.clippingPlanes, d = t.clipIntersection, p = t.clipShadows, f = e.get(t) if (!i || null === h || 0 === h.length || (o && !p)) o ? u(null) : c() else { var m = o ? 0 : r, v = 4 * m, g = f.clippingState || null ;(l.value = g), (g = u(h, a, v, s)) for (var y = 0; y !== v; ++y) g[y] = n[y] ;(f.clippingState = g), (this.numIntersection = d ? this.numPlanes : 0), (this.numPlanes += m) } }) } function ea(e) { var t = new WeakMap() function n(e, t) { return t === le ? (e.mapping = ae) : t === ce && (e.mapping = se), e } function r(r) { if (r && r.isTexture) { var o = r.mapping if (o === le || o === ce) { if (t.has(r)) return n(t.get(r).texture, r.mapping) var a = r.image if (a && a.height > 0) { var s = e.getRenderList(), l = e.getRenderTarget(), c = new No(a.height / 2) return ( c.fromEquirectangularTexture(e, r), t.set(r, c), e.setRenderTarget(l), e.setRenderList(s), r.addEventListener('dispose', i), n(c.texture, r.mapping) ) } return null } } return r } function i(e) { var n = e.target n.removeEventListener('dispose', i) var r = t.get(n) void 0 !== r && (t.delete(n), r.dispose()) } function o() { t = new WeakMap() } return { get: r, dispose: o } } function ta(e) { var t = {} function n(n) { if (void 0 !== t[n]) return t[n] var r switch (n) { case 'WEBGL_depth_texture': r = e.getExtension('WEBGL_depth_texture') || e.getExtension('MOZ_WEBGL_depth_texture') || e.getExtension('WEBKIT_WEBGL_depth_texture') break case 'EXT_texture_filter_anisotropic': r = e.getExtension('EXT_texture_filter_anisotropic') || e.getExtension('MOZ_EXT_texture_filter_anisotropic') || e.getExtension('WEBKIT_EXT_texture_filter_anisotropic') break case 'WEBGL_compressed_texture_s3tc': r = e.getExtension('WEBGL_compressed_texture_s3tc') || e.getExtension('MOZ_WEBGL_compressed_texture_s3tc') || e.getExtension('WEBKIT_WEBGL_compressed_texture_s3tc') break case 'WEBGL_compressed_texture_pvrtc': r = e.getExtension('WEBGL_compressed_texture_pvrtc') || e.getExtension('WEBKIT_WEBGL_compressed_texture_pvrtc') break default: r = e.getExtension(n) } return (t[n] = r), r } return { has: function (e) { return null !== n(e) }, init: function (e) { e.isWebGL2 ? n('EXT_color_buffer_float') : (n('WEBGL_depth_texture'), n('OES_texture_float'), n('OES_texture_half_float'), n('OES_texture_half_float_linear'), n('OES_standard_derivatives'), n('OES_element_index_uint'), n('OES_vertex_array_object'), n('ANGLE_instanced_arrays')), n('OES_texture_float_linear'), n('EXT_color_buffer_half_float') }, get: function (e) { var t = n(e) return ( null === t && console.warn( 'THREE.WebGLRenderer: ' + e + ' extension not supported.', ), t ) }, } } function na(e, t, n, r) { var i = {}, o = new WeakMap() function a(e) { var s = e.target for (var l in (null !== s.index && t.remove(s.index), s.attributes)) t.remove(s.attributes[l]) s.removeEventListener('dispose', a), delete i[s.id] var c = o.get(s) c && (t.remove(c), o.delete(s)), r.releaseStatesOfGeometry(s), !0 === s.isInstancedBufferGeometry && delete s._maxInstanceCount, n.memory.geometries-- } function s(e, t) { return ( !0 === i[t.id] || (t.addEventListener('dispose', a), (i[t.id] = !0), n.memory.geometries++), t ) } function l(e) { var n = e.attributes for (var r in n) t.update(n[r], 34962) var i = e.morphAttributes for (var o in i) for (var a = i[o], s = 0, l = a.length; s < l; s++) t.update(a[s], 34962) } function c(e) { var n = [], r = e.index, i = e.attributes.position, a = 0 if (null !== r) { var s = r.array a = r.version for (var l = 0, c = s.length; l < c; l += 3) { var u = s[l + 0], h = s[l + 1], d = s[l + 2] n.push(u, h, h, d, d, u) } } else { var p = i.array a = i.version for (var f = 0, m = p.length / 3 - 1; f < m; f += 3) { var v = f + 0, g = f + 1, y = f + 2 n.push(v, g, g, y, y, v) } } var b = new (Xi(n) > 65535 ? ji : Gi)(n, 1) b.version = a var A = o.get(e) A && t.remove(A), o.set(e, b) } function u(e) { var t = o.get(e) if (t) { var n = e.index null !== n && t.version < n.version && c(e) } else c(e) return o.get(e) } return { get: s, update: l, getWireframeAttribute: u } } function ra(e, t, n, r) { var i, o, a, s = r.isWebGL2 function l(e) { i = e } function c(e) { ;(o = e.type), (a = e.bytesPerElement) } function u(t, r) { e.drawElements(i, r, o, t * a), n.update(r, i, 1) } function h(r, l, c) { if (0 !== c) { var u, h if (s) (u = e), (h = 'drawElementsInstanced') else if ( ((h = 'drawElementsInstancedANGLE'), null === (u = t.get('ANGLE_instanced_arrays'))) ) return void console.error( 'THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.', ) u[h](i, l, o, r * a, c), n.update(l, i, c) } } ;(this.setMode = l), (this.setIndex = c), (this.render = u), (this.renderInstances = h) } function ia(e) { var t = { frame: 0, calls: 0, triangles: 0, points: 0, lines: 0 } function n(e, n, r) { switch ((t.calls++, n)) { case 4: t.triangles += r * (e / 3) break case 1: t.lines += r * (e / 2) break case 3: t.lines += r * (e - 1) break case 2: t.lines += r * e break case 0: t.points += r * e break default: console.error('THREE.WebGLInfo: Unknown draw mode:', n) } } function r() { t.frame++, (t.calls = 0), (t.triangles = 0), (t.points = 0), (t.lines = 0) } return { memory: { geometries: 0, textures: 0 }, render: t, programs: null, autoReset: !0, reset: r, update: n, } } function oa(e, t) { return e[0] - t[0] } function aa(e, t) { return Math.abs(t[1]) - Math.abs(e[1]) } function sa(e) { for (var t = {}, n = new Float32Array(8), r = [], i = 0; i < 8; i++) r[i] = [i, 0] function o(i, o, a, s) { var l = i.morphTargetInfluences, c = void 0 === l ? 0 : l.length, u = t[o.id] if (void 0 === u) { u = [] for (var h = 0; h < c; h++) u[h] = [h, 0] t[o.id] = u } for (var d = 0; d < c; d++) { var p = u[d] ;(p[0] = d), (p[1] = l[d]) } u.sort(aa) for (var f = 0; f < 8; f++) f < c && u[f][1] ? ((r[f][0] = u[f][0]), (r[f][1] = u[f][1])) : ((r[f][0] = Number.MAX_SAFE_INTEGER), (r[f][1] = 0)) r.sort(oa) for ( var m = a.morphTargets && o.morphAttributes.position, v = a.morphNormals && o.morphAttributes.normal, g = 0, y = 0; y < 8; y++ ) { var b = r[y], A = b[0], w = b[1] A !== Number.MAX_SAFE_INTEGER && w ? (m && o.getAttribute('morphTarget' + y) !== m[A] && o.setAttribute('morphTarget' + y, m[A]), v && o.getAttribute('morphNormal' + y) !== v[A] && o.setAttribute('morphNormal' + y, v[A]), (n[y] = w), (g += w)) : (m && !0 === o.hasAttribute('morphTarget' + y) && o.deleteAttribute('morphTarget' + y), v && !0 === o.hasAttribute('morphNormal' + y) && o.deleteAttribute('morphNormal' + y), (n[y] = 0)) } var x = o.morphTargetsRelative ? 1 : 1 - g s.getUniforms().setValue(e, 'morphTargetBaseInfluence', x), s.getUniforms().setValue(e, 'morphTargetInfluences', n) } return { update: o } } function la(e, t, n, r) { var i = new WeakMap() function o(e) { var o = r.render.frame, a = e.geometry, l = t.get(e, a) return ( i.get(l) !== o && (t.update(l), i.set(l, o)), e.isInstancedMesh && (!1 === e.hasEventListener('dispose', s) && e.addEventListener('dispose', s), n.update(e.instanceMatrix, 34962), null !== e.instanceColor && n.update(e.instanceColor, 34962)), l ) } function a() { i = new WeakMap() } function s(e) { var t = e.target t.removeEventListener('dispose', s), n.remove(t.instanceMatrix), null !== t.instanceColor && n.remove(t.instanceColor) } return { update: o, dispose: a } } function ca(e, t, n, r) { void 0 === e && (e = null), void 0 === t && (t = 1), void 0 === n && (n = 1), void 0 === r && (r = 1), nr.call(this, null), (this.image = { data: e, width: t, height: n, depth: r }), (this.magFilter = me), (this.minFilter = me), (this.wrapR = pe), (this.generateMipmaps = !1), (this.flipY = !1), (this.needsUpdate = !0) } function ua(e, t, n, r) { void 0 === e && (e = null), void 0 === t && (t = 1), void 0 === n && (n = 1), void 0 === r && (r = 1), nr.call(this, null), (this.image = { data: e, width: t, height: n, depth: r }), (this.magFilter = me), (this.minFilter = me), (this.wrapR = pe), (this.generateMipmaps = !1), (this.flipY = !1), (this.needsUpdate = !0) } ;(Yo.physical = { uniforms: So([ Yo.standard.uniforms, { clearcoat: { value: 0 }, clearcoatMap: { value: null }, clearcoatRoughness: { value: 0 }, clearcoatRoughnessMap: { value: null }, clearcoatNormalScale: { value: new Jn(1, 1) }, clearcoatNormalMap: { value: null }, sheen: { value: new Li(0) }, transmission: { value: 0 }, transmissionMap: { value: null }, }, ]), vertexShader: qo.meshphysical_vert, fragmentShader: qo.meshphysical_frag, }), (ca.prototype = Object.create(nr.prototype)), (ca.prototype.constructor = ca), (ca.prototype.isDataTexture2DArray = !0), (ua.prototype = Object.create(nr.prototype)), (ua.prototype.constructor = ua), (ua.prototype.isDataTexture3D = !0) var ha = new nr(), da = new ca(), pa = new ua(), fa = new ko(), ma = [], va = [], ga = new Float32Array(16), ya = new Float32Array(9), ba = new Float32Array(4) function Aa(e, t, n) { var r = e[0] if (r <= 0 || r > 0) return e var i = t * n, o = ma[i] if ((void 0 === o && ((o = new Float32Array(i)), (ma[i] = o)), 0 !== t)) { r.toArray(o, 0) for (var a = 1, s = 0; a !== t; ++a) (s += n), e[a].toArray(o, s) } return o } function wa(e, t) { if (e.length !== t.length) return !1 for (var n = 0, r = e.length; n < r; n++) if (e[n] !== t[n]) return !1 return !0 } function xa(e, t) { for (var n = 0, r = t.length; n < r; n++) e[n] = t[n] } function Ea(e, t) { var n = va[t] void 0 === n && ((n = new Int32Array(t)), (va[t] = n)) for (var r = 0; r !== t; ++r) n[r] = e.allocateTextureUnit() return n } function Ma(e, t) { var n = this.cache n[0] !== t && (e.uniform1f(this.addr, t), (n[0] = t)) } function _a(e, t) { var n = this.cache if (void 0 !== t.x) (n[0] === t.x && n[1] === t.y) || (e.uniform2f(this.addr, t.x, t.y), (n[0] = t.x), (n[1] = t.y)) else { if (wa(n, t)) return e.uniform2fv(this.addr, t), xa(n, t) } } function Ta(e, t) { var n = this.cache if (void 0 !== t.x) (n[0] === t.x && n[1] === t.y && n[2] === t.z) || (e.uniform3f(this.addr, t.x, t.y, t.z), (n[0] = t.x), (n[1] = t.y), (n[2] = t.z)) else if (void 0 !== t.r) (n[0] === t.r && n[1] === t.g && n[2] === t.b) || (e.uniform3f(this.addr, t.r, t.g, t.b), (n[0] = t.r), (n[1] = t.g), (n[2] = t.b)) else { if (wa(n, t)) return e.uniform3fv(this.addr, t), xa(n, t) } } function Sa(e, t) { var n = this.cache if (void 0 !== t.x) (n[0] === t.x && n[1] === t.y && n[2] === t.z && n[3] === t.w) || (e.uniform4f(this.addr, t.x, t.y, t.z, t.w), (n[0] = t.x), (n[1] = t.y), (n[2] = t.z), (n[3] = t.w)) else { if (wa(n, t)) return e.uniform4fv(this.addr, t), xa(n, t) } } function Ca(e, t) { var n = this.cache, r = t.elements if (void 0 === r) { if (wa(n, t)) return e.uniformMatrix2fv(this.addr, !1, t), xa(n, t) } else { if (wa(n, r)) return ba.set(r), e.uniformMatrix2fv(this.addr, !1, ba), xa(n, r) } } function La(e, t) { var n = this.cache, r = t.elements if (void 0 === r) { if (wa(n, t)) return e.uniformMatrix3fv(this.addr, !1, t), xa(n, t) } else { if (wa(n, r)) return ya.set(r), e.uniformMatrix3fv(this.addr, !1, ya), xa(n, r) } } function Ra(e, t) { var n = this.cache, r = t.elements if (void 0 === r) { if (wa(n, t)) return e.uniformMatrix4fv(this.addr, !1, t), xa(n, t) } else { if (wa(n, r)) return ga.set(r), e.uniformMatrix4fv(this.addr, !1, ga), xa(n, r) } } function Pa(e, t, n) { var r = this.cache, i = n.allocateTextureUnit() r[0] !== i && (e.uniform1i(this.addr, i), (r[0] = i)), n.safeSetTexture2D(t || ha, i) } function Da(e, t, n) { var r = this.cache, i = n.allocateTextureUnit() r[0] !== i && (e.uniform1i(this.addr, i), (r[0] = i)), n.setTexture2DArray(t || da, i) } function Oa(e, t, n) { var r = this.cache, i = n.allocateTextureUnit() r[0] !== i && (e.uniform1i(this.addr, i), (r[0] = i)), n.setTexture3D(t || pa, i) } function Ia(e, t, n) { var r = this.cache, i = n.allocateTextureUnit() r[0] !== i && (e.uniform1i(this.addr, i), (r[0] = i)), n.safeSetTextureCube(t || fa, i) } function Ba(e, t) { var n = this.cache n[0] !== t && (e.uniform1i(this.addr, t), (n[0] = t)) } function Fa(e, t) { var n = this.cache wa(n, t) || (e.uniform2iv(this.addr, t), xa(n, t)) } function ka(e, t) { var n = this.cache wa(n, t) || (e.uniform3iv(this.addr, t), xa(n, t)) } function Na(e, t) { var n = this.cache wa(n, t) || (e.uniform4iv(this.addr, t), xa(n, t)) } function Ua(e, t) { var n = this.cache n[0] !== t && (e.uniform1ui(this.addr, t), (n[0] = t)) } function Ha(e) { switch (e) { case 5126: return Ma case 35664: return _a case 35665: return Ta case 35666: return Sa case 35674: return Ca case 35675: return La case 35676: return Ra case 5124: case 35670: return Ba case 35667: case 35671: return Fa case 35668: case 35672: return ka case 35669: case 35673: return Na case 5125: return Ua case 35678: case 36198: case 36298: case 36306: case 35682: return Pa case 35679: case 36299: case 36307: return Oa case 35680: case 36300: case 36308: case 36293: return Ia case 36289: case 36303: case 36311: case 36292: return Da } } function Ga(e, t) { e.uniform1fv(this.addr, t) } function za(e, t) { e.uniform1iv(this.addr, t) } function ja(e, t) { e.uniform2iv(this.addr, t) } function Va(e, t) { e.uniform3iv(this.addr, t) } function Wa(e, t) { e.uniform4iv(this.addr, t) } function qa(e, t) { var n = Aa(t, this.size, 2) e.uniform2fv(this.addr, n) } function Xa(e, t) { var n = Aa(t, this.size, 3) e.uniform3fv(this.addr, n) } function Ya(e, t) { var n = Aa(t, this.size, 4) e.uniform4fv(this.addr, n) } function Qa(e, t) { var n = Aa(t, this.size, 4) e.uniformMatrix2fv(this.addr, !1, n) } function Za(e, t) { var n = Aa(t, this.size, 9) e.uniformMatrix3fv(this.addr, !1, n) } function Ka(e, t) { var n = Aa(t, this.size, 16) e.uniformMatrix4fv(this.addr, !1, n) } function Ja(e, t, n) { var r = t.length, i = Ea(n, r) e.uniform1iv(this.addr, i) for (var o = 0; o !== r; ++o) n.safeSetTexture2D(t[o] || ha, i[o]) } function $a(e, t, n) { var r = t.length, i = Ea(n, r) e.uniform1iv(this.addr, i) for (var o = 0; o !== r; ++o) n.safeSetTextureCube(t[o] || fa, i[o]) } function es(e) { switch (e) { case 5126: return Ga case 35664: return qa case 35665: return Xa case 35666: return Ya case 35674: return Qa case 35675: return Za case 35676: return Ka case 5124: case 35670: return za case 35667: case 35671: return ja case 35668: case 35672: return Va case 35669: case 35673: return Wa case 35678: case 36198: case 36298: case 36306: case 35682: return Ja case 35680: case 36300: case 36308: case 36293: return $a } } function ts(e, t, n) { ;(this.id = e), (this.addr = n), (this.cache = []), (this.setValue = Ha(t.type)) } function ns(e, t, n) { ;(this.id = e), (this.addr = n), (this.cache = []), (this.size = t.size), (this.setValue = es(t.type)) } function rs(e) { ;(this.id = e), (this.seq = []), (this.map = {}) } ;(ns.prototype.updateCache = function (e) { var t = this.cache e instanceof Float32Array && t.length !== e.length && (this.cache = new Float32Array(e.length)), xa(t, e) }), (rs.prototype.setValue = function (e, t, n) { for (var r = this.seq, i = 0, o = r.length; i !== o; ++i) { var a = r[i] a.setValue(e, t[a.id], n) } }) var is = /(\w+)(\])?(\[|\.)?/g function os(e, t) { e.seq.push(t), (e.map[t.id] = t) } function as(e, t, n) { var r = e.name, i = r.length for (is.lastIndex = 0; ; ) { var o = is.exec(r), a = is.lastIndex, s = o[1], l = ']' === o[2], c = o[3] if ((l && (s |= 0), void 0 === c || ('[' === c && a + 2 === i))) { os(n, void 0 === c ? new ts(s, e, t) : new ns(s, e, t)) break } var u = n.map[s] void 0 === u && os(n, (u = new rs(s))), (n = u) } } function ss(e, t) { ;(this.seq = []), (this.map = {}) for (var n = e.getProgramParameter(t, 35718), r = 0; r < n; ++r) { var i = e.getActiveUniform(t, r) as(i, e.getUniformLocation(t, i.name), this) } } function ls(e, t, n) { var r = e.createShader(t) return e.shaderSource(r, n), e.compileShader(r), r } ;(ss.prototype.setValue = function (e, t, n, r) { var i = this.map[t] void 0 !== i && i.setValue(e, n, r) }), (ss.prototype.setOptional = function (e, t, n) { var r = t[n] void 0 !== r && this.setValue(e, n, r) }), (ss.upload = function (e, t, n, r) { for (var i = 0, o = t.length; i !== o; ++i) { var a = t[i], s = n[a.id] !1 !== s.needsUpdate && a.setValue(e, s.value, r) } }), (ss.seqWithValue = function (e, t) { for (var n = [], r = 0, i = e.length; r !== i; ++r) { var o = e[r] o.id in t && n.push(o) } return n }) var cs = 0 function us(e) { for (var t = e.split('\n'), n = 0; n < t.length; n++) t[n] = n + 1 + ': ' + t[n] return t.join('\n') } function hs(e) { switch (e) { case Kt: return ['Linear', '( value )'] case Jt: return ['sRGB', '( value )'] case en: return ['RGBE', '( value )'] case nn: return ['RGBM', '( value, 7.0 )'] case rn: return ['RGBM', '( value, 16.0 )'] case on: return ['RGBD', '( value, 256.0 )'] case $t: return ['Gamma', '( value, float( GAMMA_FACTOR ) )'] case tn: return ['LogLuv', '( value )'] default: return ( console.warn('THREE.WebGLProgram: Unsupported encoding:', e), ['Linear', '( value )'] ) } } function ds(e, t, n) { var r = e.getShaderParameter(t, 35713), i = e.getShaderInfoLog(t).trim() return r && '' === i ? '' : 'THREE.WebGLShader: gl.getShaderInfoLog() ' + n + '\n' + i + us(e.getShaderSource(t)) } function ps(e, t) { var n = hs(t) return ( 'vec4 ' + e + '( vec4 value ) { return ' + n[0] + 'ToLinear' + n[1] + '; }' ) } function fs(e, t) { var n = hs(t) return 'vec4 ' + e + '( vec4 value ) { return LinearTo' + n[0] + n[1] + '; }' } function ms(e, t) { var n switch (t) { case ee: n = 'Linear' break case te: n = 'Reinhard' break case ne: n = 'OptimizedCineon' break case re: n = 'ACESFilmic' break case ie: n = 'Custom' break default: console.warn('THREE.WebGLProgram: Unsupported toneMapping:', t), (n = 'Linear') } return ( 'vec3 ' + e + '( vec3 color ) { return ' + n + 'ToneMapping( color ); }' ) } function vs(e) { return [ e.extensionDerivatives || e.envMapCubeUV || e.bumpMap || e.tangentSpaceNormalMap || e.clearcoatNormalMap || e.flatShading || 'physical' === e.shaderID ? '#extension GL_OES_standard_derivatives : enable' : '', (e.extensionFragDepth || e.logarithmicDepthBuffer) && e.rendererExtensionFragDepth ? '#extension GL_EXT_frag_depth : enable' : '', e.extensionDrawBuffers && e.rendererExtensionDrawBuffers ? '#extension GL_EXT_draw_buffers : require' : '', (e.extensionShaderTextureLOD || e.envMap) && e.rendererExtensionShaderTextureLod ? '#extension GL_EXT_shader_texture_lod : enable' : '', ] .filter(bs) .join('\n') } function gs(e) { var t = [] for (var n in e) { var r = e[n] !1 !== r && t.push('#define ' + n + ' ' + r) } return t.join('\n') } function ys(e, t) { for (var n = {}, r = e.getProgramParameter(t, 35721), i = 0; i < r; i++) { var o = e.getActiveAttrib(t, i).name n[o] = e.getAttribLocation(t, o) } return n } function bs(e) { return '' !== e } function As(e, t) { return e .replace(/NUM_DIR_LIGHTS/g, t.numDirLights) .replace(/NUM_SPOT_LIGHTS/g, t.numSpotLights) .replace(/NUM_RECT_AREA_LIGHTS/g, t.numRectAreaLights) .replace(/NUM_POINT_LIGHTS/g, t.numPointLights) .replace(/NUM_HEMI_LIGHTS/g, t.numHemiLights) .replace(/NUM_DIR_LIGHT_SHADOWS/g, t.numDirLightShadows) .replace(/NUM_SPOT_LIGHT_SHADOWS/g, t.numSpotLightShadows) .replace(/NUM_POINT_LIGHT_SHADOWS/g, t.numPointLightShadows) } function ws(e, t) { return e .replace(/NUM_CLIPPING_PLANES/g, t.numClippingPlanes) .replace( /UNION_CLIPPING_PLANES/g, t.numClippingPlanes - t.numClipIntersection, ) } var xs = /^[ \t]*#include +<([\w\d./]+)>/gm function Es(e) { return e.replace(xs, Ms) } function Ms(e, t) { var n = qo[t] if (void 0 === n) throw new Error('Can not resolve #include <' + t + '>') return Es(n) } var _s = /#pragma unroll_loop[\s]+?for \( int i \= (\d+)\; i < (\d+)\; i \+\+ \) \{([\s\S]+?)(?=\})\}/g, Ts = /#pragma unroll_loop_start\s+for\s*\(\s*int\s+i\s*=\s*(\d+)\s*;\s*i\s*<\s*(\d+)\s*;\s*i\s*\+\+\s*\)\s*{([\s\S]+?)}\s+#pragma unroll_loop_end/g function Ss(e) { return e.replace(Ts, Ls).replace(_s, Cs) } function Cs(e, t, n, r) { return ( console.warn( 'WebGLProgram: #pragma unroll_loop shader syntax is deprecated. Please use #pragma unroll_loop_start syntax instead.', ), Ls(e, t, n, r) ) } function Ls(e, t, n, r) { for (var i = '', o = parseInt(t); o < parseInt(n); o++) i += r .replace(/\[\s*i\s*\]/g, '[ ' + o + ' ]') .replace(/UNROLLED_LOOP_INDEX/g, o) return i } function Rs(e) { var t = 'precision ' + e.precision + ' float;\nprecision ' + e.precision + ' int;' return ( 'highp' === e.precision ? (t += '\n#define HIGH_PRECISION') : 'mediump' === e.precision ? (t += '\n#define MEDIUM_PRECISION') : 'lowp' === e.precision && (t += '\n#define LOW_PRECISION'), t ) } function Ps(e) { var t = 'SHADOWMAP_TYPE_BASIC' return ( e.shadowMapType === d ? (t = 'SHADOWMAP_TYPE_PCF') : e.shadowMapType === p ? (t = 'SHADOWMAP_TYPE_PCF_SOFT') : e.shadowMapType === f && (t = 'SHADOWMAP_TYPE_VSM'), t ) } function Ds(e) { var t = 'ENVMAP_TYPE_CUBE' if (e.envMap) switch (e.envMapMode) { case ae: case se: t = 'ENVMAP_TYPE_CUBE' break case ue: case he: t = 'ENVMAP_TYPE_CUBE_UV' } return t } function Os(e) { var t = 'ENVMAP_MODE_REFLECTION' if (e.envMap) switch (e.envMapMode) { case se: case he: t = 'ENVMAP_MODE_REFRACTION' } return t } function Is(e) { var t = 'ENVMAP_BLENDING_NONE' if (e.envMap) switch (e.combine) { case Z: t = 'ENVMAP_BLENDING_MULTIPLY' break case K: t = 'ENVMAP_BLENDING_MIX' break case J: t = 'ENVMAP_BLENDING_ADD' } return t } function Bs(e, t, n, r) { var i, o, a = e.getContext(), s = n.defines, l = n.vertexShader, c = n.fragmentShader, u = Ps(n), h = Ds(n), d = Os(n), p = Is(n), f = e.gammaFactor > 0 ? e.gammaFactor : 1, m = n.isWebGL2 ? '' : vs(n), v = gs(s), g = a.createProgram(), y = n.glslVersion ? '#version ' + n.glslVersion + '\n' : '' n.isRawShaderMaterial ? ((i = [v].filter(bs).join('\n')).length > 0 && (i += '\n'), (o = [m, v].filter(bs).join('\n')).length > 0 && (o += '\n')) : ((i = [ Rs(n), '#define SHADER_NAME ' + n.shaderName, v, n.instancing ? '#define USE_INSTANCING' : '', n.instancingColor ? '#define USE_INSTANCING_COLOR' : '', n.supportsVertexTextures ? '#define VERTEX_TEXTURES' : '', '#define GAMMA_FACTOR ' + f, '#define MAX_BONES ' + n.maxBones, n.useFog && n.fog ? '#define USE_FOG' : '', n.useFog && n.fogExp2 ? '#define FOG_EXP2' : '', n.map ? '#define USE_MAP' : '', n.envMap ? '#define USE_ENVMAP' : '', n.envMap ? '#define ' + d : '', n.lightMap ? '#define USE_LIGHTMAP' : '', n.aoMap ? '#define USE_AOMAP' : '', n.emissiveMap ? '#define USE_EMISSIVEMAP' : '', n.bumpMap ? '#define USE_BUMPMAP' : '', n.normalMap ? '#define USE_NORMALMAP' : '', n.normalMap && n.objectSpaceNormalMap ? '#define OBJECTSPACE_NORMALMAP' : '', n.normalMap && n.tangentSpaceNormalMap ? '#define TANGENTSPACE_NORMALMAP' : '', n.clearcoatMap ? '#define USE_CLEARCOATMAP' : '', n.clearcoatRoughnessMap ? '#define USE_CLEARCOAT_ROUGHNESSMAP' : '', n.clearcoatNormalMap ? '#define USE_CLEARCOAT_NORMALMAP' : '', n.displacementMap && n.supportsVertexTextures ? '#define USE_DISPLACEMENTMAP' : '', n.specularMap ? '#define USE_SPECULARMAP' : '', n.roughnessMap ? '#define USE_ROUGHNESSMAP' : '', n.metalnessMap ? '#define USE_METALNESSMAP' : '', n.alphaMap ? '#define USE_ALPHAMAP' : '', n.transmissionMap ? '#define USE_TRANSMISSIONMAP' : '', n.vertexTangents ? '#define USE_TANGENT' : '', n.vertexColors ? '#define USE_COLOR' : '', n.vertexUvs ? '#define USE_UV' : '', n.uvsVertexOnly ? '#define UVS_VERTEX_ONLY' : '', n.flatShading ? '#define FLAT_SHADED' : '', n.skinning ? '#define USE_SKINNING' : '', n.useVertexTexture ? '#define BONE_TEXTURE' : '', n.morphTargets ? '#define USE_MORPHTARGETS' : '', n.morphNormals && !1 === n.flatShading ? '#define USE_MORPHNORMALS' : '', n.doubleSided ? '#define DOUBLE_SIDED' : '', n.flipSided ? '#define FLIP_SIDED' : '', n.shadowMapEnabled ? '#define USE_SHADOWMAP' : '', n.shadowMapEnabled ? '#define ' + u : '', n.sizeAttenuation ? '#define USE_SIZEATTENUATION' : '', n.logarithmicDepthBuffer ? '#define USE_LOGDEPTHBUF' : '', n.logarithmicDepthBuffer && n.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', '\tattribute mat4 instanceMatrix;', '#endif', '#ifdef USE_INSTANCING_COLOR', '\tattribute vec3 instanceColor;', '#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(bs) .join('\n')), (o = [ m, Rs(n), '#define SHADER_NAME ' + n.shaderName, v, n.alphaTest ? '#define ALPHATEST ' + n.alphaTest + (n.alphaTest % 1 ? '' : '.0') : '', '#define GAMMA_FACTOR ' + f, n.useFog && n.fog ? '#define USE_FOG' : '', n.useFog && n.fogExp2 ? '#define FOG_EXP2' : '', n.map ? '#define USE_MAP' : '', n.matcap ? '#define USE_MATCAP' : '', n.envMap ? '#define USE_ENVMAP' : '', n.envMap ? '#define ' + h : '', n.envMap ? '#define ' + d : '', n.envMap ? '#define ' + p : '', n.lightMap ? '#define USE_LIGHTMAP' : '', n.aoMap ? '#define USE_AOMAP' : '', n.emissiveMap ? '#define USE_EMISSIVEMAP' : '', n.bumpMap ? '#define USE_BUMPMAP' : '', n.normalMap ? '#define USE_NORMALMAP' : '', n.normalMap && n.objectSpaceNormalMap ? '#define OBJECTSPACE_NORMALMAP' : '', n.normalMap && n.tangentSpaceNormalMap ? '#define TANGENTSPACE_NORMALMAP' : '', n.clearcoatMap ? '#define USE_CLEARCOATMAP' : '', n.clearcoatRoughnessMap ? '#define USE_CLEARCOAT_ROUGHNESSMAP' : '', n.clearcoatNormalMap ? '#define USE_CLEARCOAT_NORMALMAP' : '', n.specularMap ? '#define USE_SPECULARMAP' : '', n.roughnessMap ? '#define USE_ROUGHNESSMAP' : '', n.metalnessMap ? '#define USE_METALNESSMAP' : '', n.alphaMap ? '#define USE_ALPHAMAP' : '', n.sheen ? '#define USE_SHEEN' : '', n.transmissionMap ? '#define USE_TRANSMISSIONMAP' : '', n.vertexTangents ? '#define USE_TANGENT' : '', n.vertexColors || n.instancingColor ? '#define USE_COLOR' : '', n.vertexUvs ? '#define USE_UV' : '', n.uvsVertexOnly ? '#define UVS_VERTEX_ONLY' : '', n.gradientMap ? '#define USE_GRADIENTMAP' : '', n.flatShading ? '#define FLAT_SHADED' : '', n.doubleSided ? '#define DOUBLE_SIDED' : '', n.flipSided ? '#define FLIP_SIDED' : '', n.shadowMapEnabled ? '#define USE_SHADOWMAP' : '', n.shadowMapEnabled ? '#define ' + u : '', n.premultipliedAlpha ? '#define PREMULTIPLIED_ALPHA' : '', n.physicallyCorrectLights ? '#define PHYSICALLY_CORRECT_LIGHTS' : '', n.logarithmicDepthBuffer ? '#define USE_LOGDEPTHBUF' : '', n.logarithmicDepthBuffer && n.rendererExtensionFragDepth ? '#define USE_LOGDEPTHBUF_EXT' : '', (n.extensionShaderTextureLOD || n.envMap) && n.rendererExtensionShaderTextureLod ? '#define TEXTURE_LOD_EXT' : '', 'uniform mat4 viewMatrix;', 'uniform vec3 cameraPosition;', 'uniform bool isOrthographic;', n.toneMapping !== $ ? '#define TONE_MAPPING' : '', n.toneMapping !== $ ? qo.tonemapping_pars_fragment : '', n.toneMapping !== $ ? ms('toneMapping', n.toneMapping) : '', n.dithering ? '#define DITHERING' : '', qo.encodings_pars_fragment, n.map ? ps('mapTexelToLinear', n.mapEncoding) : '', n.matcap ? ps('matcapTexelToLinear', n.matcapEncoding) : '', n.envMap ? ps('envMapTexelToLinear', n.envMapEncoding) : '', n.emissiveMap ? ps('emissiveMapTexelToLinear', n.emissiveMapEncoding) : '', n.lightMap ? ps('lightMapTexelToLinear', n.lightMapEncoding) : '', fs('linearToOutputTexel', n.outputEncoding), n.depthPacking ? '#define DEPTH_PACKING ' + n.depthPacking : '', '\n', ] .filter(bs) .join('\n'))), (l = ws((l = As((l = Es(l)), n)), n)), (c = ws((c = As((c = Es(c)), n)), n)), (l = Ss(l)), (c = Ss(c)), n.isWebGL2 && !0 !== n.isRawShaderMaterial && ((y = '#version 300 es\n'), (i = [ '#define attribute in', '#define varying out', '#define texture2D texture', ].join('\n') + '\n' + i), (o = [ '#define varying in', n.glslVersion === Fn ? '' : 'out highp vec4 pc_fragColor;', n.glslVersion === Fn ? '' : '#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 b, A, w = y + o + c, x = ls(a, 35633, y + i + l), E = ls(a, 35632, w) if ( (a.attachShader(g, x), a.attachShader(g, E), void 0 !== n.index0AttributeName ? a.bindAttribLocation(g, 0, n.index0AttributeName) : !0 === n.morphTargets && a.bindAttribLocation(g, 0, 'position'), a.linkProgram(g), e.debug.checkShaderErrors) ) { var M = a.getProgramInfoLog(g).trim(), _ = a.getShaderInfoLog(x).trim(), T = a.getShaderInfoLog(E).trim(), S = !0, C = !0 if (!1 === a.getProgramParameter(g, 35714)) { S = !1 var L = ds(a, x, 'vertex'), R = ds(a, E, 'fragment') console.error( 'THREE.WebGLProgram: shader error: ', a.getError(), '35715', a.getProgramParameter(g, 35715), 'gl.getProgramInfoLog', M, L, R, ) } else '' !== M ? console.warn('THREE.WebGLProgram: gl.getProgramInfoLog()', M) : ('' !== _ && '' !== T) || (C = !1) C && (this.diagnostics = { runnable: S, programLog: M, vertexShader: { log: _, prefix: i }, fragmentShader: { log: T, prefix: o }, }) } return ( a.deleteShader(x), a.deleteShader(E), (this.getUniforms = function () { return void 0 === b && (b = new ss(a, g)), b }), (this.getAttributes = function () { return void 0 === A && (A = ys(a, g)), A }), (this.destroy = function () { r.releaseStatesOfProgram(this), a.deleteProgram(g), (this.program = void 0) }), (this.name = n.shaderName), (this.id = cs++), (this.cacheKey = t), (this.usedTimes = 1), (this.program = g), (this.vertexShader = x), (this.fragmentShader = E), this ) } function Fs(e, t, n, r, i, o) { var a = [], s = r.isWebGL2, l = r.logarithmicDepthBuffer, c = r.floatVertexTextures, u = r.maxVertexUniforms, h = r.vertexTextures, d = r.precision, p = { 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', }, f = [ 'precision', 'isWebGL2', 'supportsVertexTextures', 'outputEncoding', 'instancing', 'instancingColor', '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', 'transmissionMap', ] function m(e) { var t = e.skeleton.bones if (c) return 1024 var n = u, r = Math.floor((n - 20) / 4), i = Math.min(r, t.length) return i < t.length ? (console.warn( 'THREE.WebGLRenderer: Skeleton has ' + t.length + ' bones. This GPU supports ' + i + '.', ), 0) : i } function y(e) { var t return ( e && e.isTexture ? (t = e.encoding) : e && e.isWebGLRenderTarget ? (console.warn( "THREE.WebGLPrograms.getTextureEncodingFromMap: don't use render targets as textures. Use their .texture property instead.", ), (t = e.texture.encoding)) : (t = Kt), t ) } function b(i, a, u, f, b) { var A, w, x = f.fog, E = i.isMeshStandardMaterial ? f.environment : null, M = t.get(i.envMap || E), _ = p[i.type], T = b.isSkinnedMesh ? m(b) : 0 if ( (null !== i.precision && (d = r.getMaxPrecision(i.precision)) !== i.precision && console.warn( 'THREE.WebGLProgram.getParameters:', i.precision, 'not supported, using', d, 'instead.', ), _) ) { var S = Yo[_] ;(A = S.vertexShader), (w = S.fragmentShader) } else (A = i.vertexShader), (w = i.fragmentShader) var C = e.getRenderTarget() return { isWebGL2: s, shaderID: _, shaderName: i.type, vertexShader: A, fragmentShader: w, defines: i.defines, isRawShaderMaterial: !0 === i.isRawShaderMaterial, glslVersion: i.glslVersion, precision: d, instancing: !0 === b.isInstancedMesh, instancingColor: !0 === b.isInstancedMesh && null !== b.instanceColor, supportsVertexTextures: h, outputEncoding: null !== C ? y(C.texture) : e.outputEncoding, map: !!i.map, mapEncoding: y(i.map), matcap: !!i.matcap, matcapEncoding: y(i.matcap), envMap: !!M, envMapMode: M && M.mapping, envMapEncoding: y(M), envMapCubeUV: !!M && (M.mapping === ue || M.mapping === he), lightMap: !!i.lightMap, lightMapEncoding: y(i.lightMap), aoMap: !!i.aoMap, emissiveMap: !!i.emissiveMap, emissiveMapEncoding: y(i.emissiveMap), bumpMap: !!i.bumpMap, normalMap: !!i.normalMap, objectSpaceNormalMap: i.normalMapType === cn, tangentSpaceNormalMap: i.normalMapType === ln, 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, transmissionMap: !!i.transmissionMap, 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 || !!i.transmissionMap, uvsVertexOnly: !( i.map || i.bumpMap || i.normalMap || i.specularMap || i.alphaMap || i.emissiveMap || i.roughnessMap || i.metalnessMap || i.clearcoatNormalMap || i.transmissionMap ) && !!i.displacementMap, fog: !!x, useFog: i.fog, fogExp2: x && x.isFogExp2, flatShading: i.flatShading, sizeAttenuation: i.sizeAttenuation, logarithmicDepthBuffer: l, skinning: i.skinning && T > 0, maxBones: T, useVertexTexture: c, morphTargets: i.morphTargets, morphNormals: i.morphNormals, maxMorphTargets: e.maxMorphTargets, maxMorphNormals: e.maxMorphNormals, numDirLights: a.directional.length, numPointLights: a.point.length, numSpotLights: a.spot.length, numRectAreaLights: a.rectArea.length, numHemiLights: a.hemi.length, numDirLightShadows: a.directionalShadowMap.length, numPointLightShadows: a.pointShadowMap.length, numSpotLightShadows: a.spotShadowMap.length, numClippingPlanes: o.numPlanes, numClipIntersection: o.numIntersection, dithering: i.dithering, shadowMapEnabled: e.shadowMap.enabled && u.length > 0, shadowMapType: e.shadowMap.type, toneMapping: i.toneMapped ? e.toneMapping : $, physicallyCorrectLights: e.physicallyCorrectLights, premultipliedAlpha: i.premultipliedAlpha, alphaTest: i.alphaTest, doubleSided: i.side === g, flipSided: i.side === v, 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: s || n.has('EXT_frag_depth'), rendererExtensionDrawBuffers: s || n.has('WEBGL_draw_buffers'), rendererExtensionShaderTextureLod: s || n.has('EXT_shader_texture_lod'), customProgramCacheKey: i.customProgramCacheKey(), } } function A(t) { var n = [] if ( (t.shaderID ? n.push(t.shaderID) : (n.push(t.fragmentShader), n.push(t.vertexShader)), void 0 !== t.defines) ) for (var r in t.defines) n.push(r), n.push(t.defines[r]) if (!1 === t.isRawShaderMaterial) { for (var i = 0; i < f.length; i++) n.push(t[f[i]]) n.push(e.outputEncoding), n.push(e.gammaFactor) } return n.push(t.customProgramCacheKey), n.join() } function w(e) { var t, n = p[e.type] if (n) { var r = Yo[n] t = Co.clone(r.uniforms) } else t = e.uniforms return t } function x(t, n) { for (var r, o = 0, s = a.length; o < s; o++) { var l = a[o] if (l.cacheKey === n) { ++(r = l).usedTimes break } } return void 0 === r && ((r = new Bs(e, n, t, i)), a.push(r)), r } function E(e) { if (0 === --e.usedTimes) { var t = a.indexOf(e) ;(a[t] = a[a.length - 1]), a.pop(), e.destroy() } } return { getParameters: b, getProgramCacheKey: A, getUniforms: w, acquireProgram: x, releaseProgram: E, programs: a, } } function ks() { var e = new WeakMap() function t(t) { var n = e.get(t) return void 0 === n && ((n = {}), e.set(t, n)), n } function n(t) { e.delete(t) } function r(t, n, r) { e.get(t)[n] = r } function i() { e = new WeakMap() } return { get: t, remove: n, update: r, dispose: i } } function Ns(e, t) { return e.groupOrder !== t.groupOrder ? e.groupOrder - t.groupOrder : e.renderOrder !== t.renderOrder ? e.renderOrder - t.renderOrder : e.program !== t.program ? e.program.id - t.program.id : e.material.id !== t.material.id ? e.material.id - t.material.id : e.z !== t.z ? e.z - t.z : e.id - t.id } function Us(e, t) { return e.groupOrder !== t.groupOrder ? e.groupOrder - t.groupOrder : e.renderOrder !== t.renderOrder ? e.renderOrder - t.renderOrder : e.z !== t.z ? t.z - e.z : e.id - t.id } function Hs(e) { var t = [], n = 0, r = [], i = [], o = { id: -1 } function a() { ;(n = 0), (r.length = 0), (i.length = 0) } function s(r, i, a, s, l, c) { var u = t[n], h = e.get(a) return ( void 0 === u ? ((u = { id: r.id, object: r, geometry: i, material: a, program: h.program || o, groupOrder: s, renderOrder: r.renderOrder, z: l, group: c, }), (t[n] = u)) : ((u.id = r.id), (u.object = r), (u.geometry = i), (u.material = a), (u.program = h.program || o), (u.groupOrder = s), (u.renderOrder = r.renderOrder), (u.z = l), (u.group = c)), n++, u ) } function l(e, t, n, o, a, l) { var c = s(e, t, n, o, a, l) ;(!0 === n.transparent ? i : r).push(c) } function c(e, t, n, o, a, l) { var c = s(e, t, n, o, a, l) ;(!0 === n.transparent ? i : r).unshift(c) } function u(e, t) { r.length > 1 && r.sort(e || Ns), i.length > 1 && i.sort(t || Us) } function h() { for (var e = n, r = t.length; e < r; e++) { var i = t[e] if (null === i.id) break ;(i.id = null), (i.object = null), (i.geometry = null), (i.material = null), (i.program = null), (i.group = null) } } return { opaque: r, transparent: i, init: a, push: l, unshift: c, finish: h, sort: u, } } function Gs(e) { var t = new WeakMap() function n(n, r) { var i, o = t.get(n) return ( void 0 === o ? ((i = new Hs(e)), t.set(n, new WeakMap()), t.get(n).set(r, i)) : void 0 === (i = o.get(r)) && ((i = new Hs(e)), o.set(r, i)), i ) } function r() { t = new WeakMap() } return { get: n, dispose: r } } function zs() { var e = {} return { get: function (t) { if (void 0 !== e[t.id]) return e[t.id] var n switch (t.type) { case 'DirectionalLight': n = { direction: new lr(), color: new Li() } break case 'SpotLight': n = { position: new lr(), direction: new lr(), color: new Li(), distance: 0, coneCos: 0, penumbraCos: 0, decay: 0, } break case 'PointLight': n = { position: new lr(), color: new Li(), distance: 0, decay: 0 } break case 'HemisphereLight': n = { direction: new lr(), skyColor: new Li(), groundColor: new Li() } break case 'RectAreaLight': n = { color: new Li(), position: new lr(), halfWidth: new lr(), halfHeight: new lr(), } } return (e[t.id] = n), n }, } } function js() { var e = {} return { get: function (t) { if (void 0 !== e[t.id]) return e[t.id] var n switch (t.type) { case 'DirectionalLight': case 'SpotLight': n = { shadowBias: 0, shadowNormalBias: 0, shadowRadius: 1, shadowMapSize: new Jn(), } break case 'PointLight': n = { shadowBias: 0, shadowNormalBias: 0, shadowRadius: 1, shadowMapSize: new Jn(), shadowCameraNear: 1, shadowCameraFar: 1e3, } } return (e[t.id] = n), n }, } } var Vs = 0 function Ws(e, t) { return (t.castShadow ? 1 : 0) - (e.castShadow ? 1 : 0) } function qs(e, t) { for ( var n = new zs(), r = js(), 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: [], rectAreaLTC1: null, rectAreaLTC2: null, point: [], pointShadow: [], pointShadowMap: [], pointShadowMatrix: [], hemi: [], }, o = 0; o < 9; o++ ) i.probe.push(new lr()) var a = new lr(), s = new Fr(), l = new Fr() function c(o) { for (var a = 0, s = 0, l = 0, c = 0; c < 9; c++) i.probe[c].set(0, 0, 0) var u = 0, h = 0, d = 0, p = 0, f = 0, m = 0, v = 0, g = 0 o.sort(Ws) for (var y = 0, b = o.length; y < b; y++) { var A = o[y], w = A.color, x = A.intensity, E = A.distance, M = A.shadow && A.shadow.map ? A.shadow.map.texture : null if (A.isAmbientLight) (a += w.r * x), (s += w.g * x), (l += w.b * x) else if (A.isLightProbe) for (var _ = 0; _ < 9; _++) i.probe[_].addScaledVector(A.sh.coefficients[_], x) else if (A.isDirectionalLight) { var T = n.get(A) if ((T.color.copy(A.color).multiplyScalar(A.intensity), A.castShadow)) { var S = A.shadow, C = r.get(A) ;(C.shadowBias = S.bias), (C.shadowNormalBias = S.normalBias), (C.shadowRadius = S.radius), (C.shadowMapSize = S.mapSize), (i.directionalShadow[u] = C), (i.directionalShadowMap[u] = M), (i.directionalShadowMatrix[u] = A.shadow.matrix), m++ } ;(i.directional[u] = T), u++ } else if (A.isSpotLight) { var L = n.get(A) if ( (L.position.setFromMatrixPosition(A.matrixWorld), L.color.copy(w).multiplyScalar(x), (L.distance = E), (L.coneCos = Math.cos(A.angle)), (L.penumbraCos = Math.cos(A.angle * (1 - A.penumbra))), (L.decay = A.decay), A.castShadow) ) { var R = A.shadow, P = r.get(A) ;(P.shadowBias = R.bias), (P.shadowNormalBias = R.normalBias), (P.shadowRadius = R.radius), (P.shadowMapSize = R.mapSize), (i.spotShadow[d] = P), (i.spotShadowMap[d] = M), (i.spotShadowMatrix[d] = A.shadow.matrix), g++ } ;(i.spot[d] = L), d++ } else if (A.isRectAreaLight) { var D = n.get(A) D.color.copy(w).multiplyScalar(x), D.halfWidth.set(0.5 * A.width, 0, 0), D.halfHeight.set(0, 0.5 * A.height, 0), (i.rectArea[p] = D), p++ } else if (A.isPointLight) { var O = n.get(A) if ( (O.color.copy(A.color).multiplyScalar(A.intensity), (O.distance = A.distance), (O.decay = A.decay), A.castShadow) ) { var I = A.shadow, B = r.get(A) ;(B.shadowBias = I.bias), (B.shadowNormalBias = I.normalBias), (B.shadowRadius = I.radius), (B.shadowMapSize = I.mapSize), (B.shadowCameraNear = I.camera.near), (B.shadowCameraFar = I.camera.far), (i.pointShadow[h] = B), (i.pointShadowMap[h] = M), (i.pointShadowMatrix[h] = A.shadow.matrix), v++ } ;(i.point[h] = O), h++ } else if (A.isHemisphereLight) { var F = n.get(A) F.skyColor.copy(A.color).multiplyScalar(x), F.groundColor.copy(A.groundColor).multiplyScalar(x), (i.hemi[f] = F), f++ } } p > 0 && (t.isWebGL2 || !0 === e.has('OES_texture_float_linear') ? ((i.rectAreaLTC1 = Xo.LTC_FLOAT_1), (i.rectAreaLTC2 = Xo.LTC_FLOAT_2)) : !0 === e.has('OES_texture_half_float_linear') ? ((i.rectAreaLTC1 = Xo.LTC_HALF_1), (i.rectAreaLTC2 = Xo.LTC_HALF_2)) : console.error( 'THREE.WebGLRenderer: Unable to use RectAreaLight. Missing WebGL extensions.', )), (i.ambient[0] = a), (i.ambient[1] = s), (i.ambient[2] = l) var k = i.hash ;(k.directionalLength === u && k.pointLength === h && k.spotLength === d && k.rectAreaLength === p && k.hemiLength === f && k.numDirectionalShadows === m && k.numPointShadows === v && k.numSpotShadows === g) || ((i.directional.length = u), (i.spot.length = d), (i.rectArea.length = p), (i.point.length = h), (i.hemi.length = f), (i.directionalShadow.length = m), (i.directionalShadowMap.length = m), (i.pointShadow.length = v), (i.pointShadowMap.length = v), (i.spotShadow.length = g), (i.spotShadowMap.length = g), (i.directionalShadowMatrix.length = m), (i.pointShadowMatrix.length = v), (i.spotShadowMatrix.length = g), (k.directionalLength = u), (k.pointLength = h), (k.spotLength = d), (k.rectAreaLength = p), (k.hemiLength = f), (k.numDirectionalShadows = m), (k.numPointShadows = v), (k.numSpotShadows = g), (i.version = Vs++)) } function u(e, t) { for ( var n = 0, r = 0, o = 0, c = 0, u = 0, h = t.matrixWorldInverse, d = 0, p = e.length; d < p; d++ ) { var f = e[d] if (f.isDirectionalLight) { var m = i.directional[n] m.direction.setFromMatrixPosition(f.matrixWorld), a.setFromMatrixPosition(f.target.matrixWorld), m.direction.sub(a), m.direction.transformDirection(h), n++ } else if (f.isSpotLight) { var v = i.spot[o] v.position.setFromMatrixPosition(f.matrixWorld), v.position.applyMatrix4(h), v.direction.setFromMatrixPosition(f.matrixWorld), a.setFromMatrixPosition(f.target.matrixWorld), v.direction.sub(a), v.direction.transformDirection(h), o++ } else if (f.isRectAreaLight) { var g = i.rectArea[c] g.position.setFromMatrixPosition(f.matrixWorld), g.position.applyMatrix4(h), l.identity(), s.copy(f.matrixWorld), s.premultiply(h), l.extractRotation(s), g.halfWidth.set(0.5 * f.width, 0, 0), g.halfHeight.set(0, 0.5 * f.height, 0), g.halfWidth.applyMatrix4(l), g.halfHeight.applyMatrix4(l), c++ } else if (f.isPointLight) { var y = i.point[r] y.position.setFromMatrixPosition(f.matrixWorld), y.position.applyMatrix4(h), r++ } else if (f.isHemisphereLight) { var b = i.hemi[u] b.direction.setFromMatrixPosition(f.matrixWorld), b.direction.transformDirection(h), b.direction.normalize(), u++ } } } return { setup: c, setupView: u, state: i } } function Xs(e, t) { var n = new qs(e, t), r = [], i = [] function o() { ;(r.length = 0), (i.length = 0) } function a(e) { r.push(e) } function s(e) { i.push(e) } function l() { n.setup(r) } function c(e) { n.setupView(r, e) } return { init: o, state: { lightsArray: r, shadowsArray: i, lights: n }, setupLights: l, setupLightsView: c, pushLight: a, pushShadow: s, } } function Ys(e, t) { var n = new WeakMap() function r(r, i) { var o return ( void 0 === i && (i = 0), !1 === n.has(r) ? ((o = new Xs(e, t)), n.set(r, []), n.get(r).push(o)) : i >= n.get(r).length ? ((o = new Xs(e, t)), n.get(r).push(o)) : (o = n.get(r)[i]), o ) } function i() { n = new WeakMap() } return { get: r, dispose: i } } function Qs(e) { Di.call(this), (this.type = 'MeshDepthMaterial'), (this.depthPacking = an), (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(e) } function Zs(e) { Di.call(this), (this.type = 'MeshDistanceMaterial'), (this.referencePosition = new lr()), (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(e) } ;(Qs.prototype = Object.create(Di.prototype)), (Qs.prototype.constructor = Qs), (Qs.prototype.isMeshDepthMaterial = !0), (Qs.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), (this.depthPacking = e.depthPacking), (this.skinning = e.skinning), (this.morphTargets = e.morphTargets), (this.map = e.map), (this.alphaMap = e.alphaMap), (this.displacementMap = e.displacementMap), (this.displacementScale = e.displacementScale), (this.displacementBias = e.displacementBias), (this.wireframe = e.wireframe), (this.wireframeLinewidth = e.wireframeLinewidth), this ) }), (Zs.prototype = Object.create(Di.prototype)), (Zs.prototype.constructor = Zs), (Zs.prototype.isMeshDistanceMaterial = !0), (Zs.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), this.referencePosition.copy(e.referencePosition), (this.nearDistance = e.nearDistance), (this.farDistance = e.farDistance), (this.skinning = e.skinning), (this.morphTargets = e.morphTargets), (this.map = e.map), (this.alphaMap = e.alphaMap), (this.displacementMap = e.displacementMap), (this.displacementScale = e.displacementScale), (this.displacementBias = e.displacementBias), this ) }) var Ks = 'uniform sampler2D shadow_pass;\nuniform vec2 resolution;\nuniform float radius;\n#include \nvoid main() {\n\tfloat mean = 0.0;\n\tfloat squared_mean = 0.0;\n\tfloat depth = unpackRGBAToDepth( texture2D( shadow_pass, ( gl_FragCoord.xy ) / resolution ) );\n\tfor ( float i = -1.0; i < 1.0 ; i += SAMPLE_RATE) {\n\t\t#ifdef HORIZONTAL_PASS\n\t\t\tvec2 distribution = unpackRGBATo2Half( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( i, 0.0 ) * radius ) / resolution ) );\n\t\t\tmean += distribution.x;\n\t\t\tsquared_mean += distribution.y * distribution.y + distribution.x * distribution.x;\n\t\t#else\n\t\t\tfloat depth = unpackRGBAToDepth( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( 0.0, i ) * radius ) / resolution ) );\n\t\t\tmean += depth;\n\t\t\tsquared_mean += depth * depth;\n\t\t#endif\n\t}\n\tmean = mean * HALF_SAMPLE_RATE;\n\tsquared_mean = squared_mean * HALF_SAMPLE_RATE;\n\tfloat std_dev = sqrt( squared_mean - mean * mean );\n\tgl_FragColor = pack2HalfToRGBA( vec2( mean, std_dev ) );\n}', Js = 'void main() {\n\tgl_Position = vec4( position, 1.0 );\n}' function $s(e, t, n) { var r = new zo(), i = new Jn(), o = new Jn(), a = new ir(), s = [], l = [], c = {}, u = { 0: v, 1: m, 2: g }, h = new Po({ defines: { SAMPLE_RATE: 2 / 8, HALF_SAMPLE_RATE: 1 / 8 }, uniforms: { shadow_pass: { value: null }, resolution: { value: new Jn() }, radius: { value: 4 }, }, vertexShader: Js, fragmentShader: Ks, }), p = h.clone() p.defines.HORIZONTAL_PASS = 1 var y = new ro() y.setAttribute( 'position', new Fi(new Float32Array([-1, -1, 0.5, 3, -1, 0.5, -1, 3, 0.5]), 3), ) var b = new xo(y, h), w = this function x(n, r) { var i = t.update(b) ;(h.uniforms.shadow_pass.value = n.map.texture), (h.uniforms.resolution.value = n.mapSize), (h.uniforms.radius.value = n.radius), e.setRenderTarget(n.mapPass), e.clear(), e.renderBufferDirect(r, null, i, h, b, null), (p.uniforms.shadow_pass.value = n.mapPass.texture), (p.uniforms.resolution.value = n.mapSize), (p.uniforms.radius.value = n.radius), e.setRenderTarget(n.map), e.clear(), e.renderBufferDirect(r, null, i, p, b, null) } function E(e, t, n) { var r = (e << 0) | (t << 1) | (n << 2), i = s[r] return ( void 0 === i && ((i = new Qs({ depthPacking: sn, morphTargets: e, skinning: t })), (s[r] = i)), i ) } function M(e, t, n) { var r = (e << 0) | (t << 1) | (n << 2), i = l[r] return ( void 0 === i && ((i = new Zs({ morphTargets: e, skinning: t })), (l[r] = i)), i ) } function _(t, n, r, i, o, a, s) { var l = null, h = E, d = t.customDepthMaterial if ( (!0 === i.isPointLight && ((h = M), (d = t.customDistanceMaterial)), void 0 === d) ) { var p = !1 !0 === r.morphTargets && (p = n.morphAttributes && n.morphAttributes.position && n.morphAttributes.position.length > 0) var m = !1 !0 === t.isSkinnedMesh && (!0 === r.skinning ? (m = !0) : console.warn( 'THREE.WebGLShadowMap: THREE.SkinnedMesh with material.skinning set to false:', t, )), (l = h(p, m, !0 === t.isInstancedMesh)) } else l = d if ( e.localClippingEnabled && !0 === r.clipShadows && 0 !== r.clippingPlanes.length ) { var v = l.uuid, g = r.uuid, y = c[v] void 0 === y && ((y = {}), (c[v] = y)) var b = y[g] void 0 === b && ((b = l.clone()), (y[g] = b)), (l = b) } return ( (l.visible = r.visible), (l.wireframe = r.wireframe), (l.side = s === f ? null !== r.shadowSide ? r.shadowSide : r.side : null !== r.shadowSide ? r.shadowSide : u[r.side]), (l.clipShadows = r.clipShadows), (l.clippingPlanes = r.clippingPlanes), (l.clipIntersection = r.clipIntersection), (l.wireframeLinewidth = r.wireframeLinewidth), (l.linewidth = r.linewidth), !0 === i.isPointLight && !0 === l.isMeshDistanceMaterial && (l.referencePosition.setFromMatrixPosition(i.matrixWorld), (l.nearDistance = o), (l.farDistance = a)), l ) } function T(n, i, o, a, s) { if (!1 !== n.visible) { if ( n.layers.test(i.layers) && (n.isMesh || n.isLine || n.isPoints) && (n.castShadow || (n.receiveShadow && s === f)) && (!n.frustumCulled || r.intersectsObject(n)) ) { n.modelViewMatrix.multiplyMatrices(o.matrixWorldInverse, n.matrixWorld) var l = t.update(n), c = n.material if (Array.isArray(c)) for (var u = l.groups, h = 0, d = u.length; h < d; h++) { var p = u[h], m = c[p.materialIndex] if (m && m.visible) { var v = _(n, l, m, a, o.near, o.far, s) e.renderBufferDirect(o, null, l, v, n, p) } } else if (c.visible) { var g = _(n, l, c, a, o.near, o.far, s) e.renderBufferDirect(o, null, l, g, n, null) } } for (var y = n.children, b = 0, A = y.length; b < A; b++) T(y[b], i, o, a, s) } } ;(this.enabled = !1), (this.autoUpdate = !0), (this.needsUpdate = !1), (this.type = d), (this.render = function (t, s, l) { if ( !1 !== w.enabled && (!1 !== w.autoUpdate || !1 !== w.needsUpdate) && 0 !== t.length ) { var c = e.getRenderTarget(), u = e.getActiveCubeFace(), h = e.getActiveMipmapLevel(), d = e.state d.setBlending(A), d.buffers.color.setClear(1, 1, 1, 1), d.buffers.depth.setTest(!0), d.setScissorTest(!1) for (var p = 0, m = t.length; p < m; p++) { var v = t[p], g = v.shadow if (void 0 !== g) { if (!1 !== g.autoUpdate || !1 !== g.needsUpdate) { i.copy(g.mapSize) var y = g.getFrameExtents() if ( (i.multiply(y), o.copy(g.mapSize), (i.x > n || i.y > n) && (i.x > n && ((o.x = Math.floor(n / y.x)), (i.x = o.x * y.x), (g.mapSize.x = o.x)), i.y > n && ((o.y = Math.floor(n / y.y)), (i.y = o.y * y.y), (g.mapSize.y = o.y))), null === g.map && !g.isPointLightShadow && this.type === f) ) { var b = { minFilter: Ae, magFilter: Ae, format: Ue } ;(g.map = new or(i.x, i.y, b)), (g.map.texture.name = v.name + '.shadowMap'), (g.mapPass = new or(i.x, i.y, b)), g.camera.updateProjectionMatrix() } if (null === g.map) { var E = { minFilter: me, magFilter: me, format: Ue } ;(g.map = new or(i.x, i.y, E)), (g.map.texture.name = v.name + '.shadowMap'), g.camera.updateProjectionMatrix() } e.setRenderTarget(g.map), e.clear() for (var M = g.getViewportCount(), _ = 0; _ < M; _++) { var S = g.getViewport(_) a.set(o.x * S.x, o.y * S.y, o.x * S.z, o.y * S.w), d.viewport(a), g.updateMatrices(v, _), (r = g.getFrustum()), T(s, l, g.camera, v, this.type) } g.isPointLightShadow || this.type !== f || x(g, l), (g.needsUpdate = !1) } } else console.warn('THREE.WebGLShadowMap:', v, 'has no shadow.') } ;(w.needsUpdate = !1), e.setRenderTarget(c, u, h) } }) } function el(e, t, n) { var r, i, o = n.isWebGL2 function a() { var t = !1, n = new ir(), r = null, i = new ir(0, 0, 0, 0) return { setMask: function (n) { r === n || t || (e.colorMask(n, n, n, n), (r = n)) }, setLocked: function (e) { t = e }, setClear: function (t, r, o, a, s) { !0 === s && ((t *= a), (r *= a), (o *= a)), n.set(t, r, o, a), !1 === i.equals(n) && (e.clearColor(t, r, o, a), i.copy(n)) }, reset: function () { ;(t = !1), (r = null), i.set(-1, 0, 0, 0) }, } } function u() { var t = !1, n = null, r = null, i = null return { setTest: function (e) { e ? be(2929) : Ae(2929) }, setMask: function (r) { n === r || t || (e.depthMask(r), (n = r)) }, setFunc: function (t) { if (r !== t) { if (t) switch (t) { case z: e.depthFunc(512) break case j: e.depthFunc(519) break case V: e.depthFunc(513) break case W: e.depthFunc(515) break case q: e.depthFunc(514) break case X: e.depthFunc(518) break case Y: e.depthFunc(516) break case Q: e.depthFunc(517) break default: e.depthFunc(515) } else e.depthFunc(515) r = t } }, setLocked: function (e) { t = e }, setClear: function (t) { i !== t && (e.clearDepth(t), (i = t)) }, reset: function () { ;(t = !1), (n = null), (r = null), (i = null) }, } } function h() { var t = !1, n = null, r = null, i = null, o = null, a = null, s = null, l = null, c = null return { setTest: function (e) { t || (e ? be(2960) : Ae(2960)) }, setMask: function (r) { n === r || t || (e.stencilMask(r), (n = r)) }, setFunc: function (t, n, a) { ;(r === t && i === n && o === a) || (e.stencilFunc(t, n, a), (r = t), (i = n), (o = a)) }, setOp: function (t, n, r) { ;(a === t && s === n && l === r) || (e.stencilOp(t, n, r), (a = t), (s = n), (l = r)) }, setLocked: function (e) { t = e }, setClear: function (t) { c !== t && (e.clearStencil(t), (c = t)) }, reset: function () { ;(t = !1), (n = null), (r = null), (i = null), (o = null), (a = null), (s = null), (l = null), (c = null) }, } } var d = new a(), p = new u(), f = new h(), m = {}, y = null, b = null, Z = null, K = null, J = null, $ = null, ee = null, te = null, ne = null, re = !1, ie = null, oe = null, ae = null, se = null, le = null, ce = e.getParameter(35661), ue = !1, he = 0, de = e.getParameter(7938) ;-1 !== de.indexOf('WebGL') ? ((he = parseFloat(/^WebGL (\d)/.exec(de)[1])), (ue = he >= 1)) : -1 !== de.indexOf('OpenGL ES') && ((he = parseFloat(/^OpenGL ES (\d)/.exec(de)[1])), (ue = he >= 2)) var pe = null, fe = {}, me = new ir(), ve = new ir() function ge(t, n, r) { var i = new Uint8Array(4), o = e.createTexture() e.bindTexture(t, o), e.texParameteri(t, 10241, 9728), e.texParameteri(t, 10240, 9728) for (var a = 0; a < r; a++) e.texImage2D(n + a, 0, 6408, 1, 1, 0, 6408, 5121, i) return o } var ye = {} function be(t) { !0 !== m[t] && (e.enable(t), (m[t] = !0)) } function Ae(t) { !1 !== m[t] && (e.disable(t), (m[t] = !1)) } function we(t) { return y !== t && (e.useProgram(t), (y = t), !0) } ;(ye[3553] = ge(3553, 3553, 1)), (ye[34067] = ge(34067, 34069, 6)), d.setClear(0, 0, 0, 1), p.setClear(1), f.setClear(0), be(2929), p.setFunc(W), Se(!1), Ce(l), be(2884), _e(A) var xe = (((r = {})[T] = 32774), (r[S] = 32778), (r[C] = 32779), r) if (o) (xe[L] = 32775), (xe[R] = 32776) else { var Ee = t.get('EXT_blend_minmax') null !== Ee && ((xe[L] = Ee.MIN_EXT), (xe[R] = Ee.MAX_EXT)) } var Me = (((i = {})[P] = 0), (i[D] = 1), (i[O] = 768), (i[B] = 770), (i[G] = 776), (i[U] = 774), (i[k] = 772), (i[I] = 769), (i[F] = 771), (i[H] = 775), (i[N] = 773), i) function _e(t, n, r, i, o, a, s, l) { if (t !== A) { if ((b || (be(3042), (b = !0)), t === _)) (o = o || n), (a = a || r), (s = s || i), (n === K && o === ee) || (e.blendEquationSeparate(xe[n], xe[o]), (K = n), (ee = o)), (r === J && i === $ && a === te && s === ne) || (e.blendFuncSeparate(Me[r], Me[i], Me[a], Me[s]), (J = r), ($ = i), (te = a), (ne = s)), (Z = t), (re = null) else if (t !== Z || l !== re) { if ( ((K === T && ee === T) || (e.blendEquation(32774), (K = T), (ee = T)), l) ) switch (t) { case w: e.blendFuncSeparate(1, 771, 1, 771) break case x: e.blendFunc(1, 1) break case E: e.blendFuncSeparate(0, 0, 769, 771) break case M: e.blendFuncSeparate(0, 768, 0, 770) break default: console.error('THREE.WebGLState: Invalid blending: ', t) } else switch (t) { case w: e.blendFuncSeparate(770, 771, 1, 771) break case x: e.blendFunc(770, 1) break case E: e.blendFunc(0, 769) break case M: e.blendFunc(0, 768) break default: console.error('THREE.WebGLState: Invalid blending: ', t) } ;(J = null), ($ = null), (te = null), (ne = null), (Z = t), (re = l) } } else b && (Ae(3042), (b = !1)) } function Te(e, t) { e.side === g ? Ae(2884) : be(2884) var n = e.side === v t && (n = !n), Se(n), e.blending === w && !1 === e.transparent ? _e(A) : _e( e.blending, e.blendEquation, e.blendSrc, e.blendDst, e.blendEquationAlpha, e.blendSrcAlpha, e.blendDstAlpha, e.premultipliedAlpha, ), p.setFunc(e.depthFunc), p.setTest(e.depthTest), p.setMask(e.depthWrite), d.setMask(e.colorWrite) var r = e.stencilWrite f.setTest(r), r && (f.setMask(e.stencilWriteMask), f.setFunc(e.stencilFunc, e.stencilRef, e.stencilFuncMask), f.setOp(e.stencilFail, e.stencilZFail, e.stencilZPass)), Re(e.polygonOffset, e.polygonOffsetFactor, e.polygonOffsetUnits) } function Se(t) { ie !== t && (t ? e.frontFace(2304) : e.frontFace(2305), (ie = t)) } function Ce(t) { t !== s ? (be(2884), t !== oe && (t === l ? e.cullFace(1029) : t === c ? e.cullFace(1028) : e.cullFace(1032))) : Ae(2884), (oe = t) } function Le(t) { t !== ae && (ue && e.lineWidth(t), (ae = t)) } function Re(t, n, r) { t ? (be(32823), (se === n && le === r) || (e.polygonOffset(n, r), (se = n), (le = r))) : Ae(32823) } function Pe(e) { e ? be(3089) : Ae(3089) } function De(t) { void 0 === t && (t = 33984 + ce - 1), pe !== t && (e.activeTexture(t), (pe = t)) } function Oe(t, n) { null === pe && De() var r = fe[pe] void 0 === r && ((r = { type: void 0, texture: void 0 }), (fe[pe] = r)), (r.type === t && r.texture === n) || (e.bindTexture(t, n || ye[t]), (r.type = t), (r.texture = n)) } function Ie() { var t = fe[pe] void 0 !== t && void 0 !== t.type && (e.bindTexture(t.type, null), (t.type = void 0), (t.texture = void 0)) } function Be() { try { e.compressedTexImage2D.apply(e, arguments) } catch (t) { console.error('THREE.WebGLState:', t) } } function Fe() { try { e.texImage2D.apply(e, arguments) } catch (t) { console.error('THREE.WebGLState:', t) } } function ke() { try { e.texImage3D.apply(e, arguments) } catch (t) { console.error('THREE.WebGLState:', t) } } function Ne(t) { !1 === me.equals(t) && (e.scissor(t.x, t.y, t.z, t.w), me.copy(t)) } function Ue(t) { !1 === ve.equals(t) && (e.viewport(t.x, t.y, t.z, t.w), ve.copy(t)) } function He() { ;(m = {}), (pe = null), (fe = {}), (y = null), (b = null), (Z = null), (K = null), (J = null), ($ = null), (ee = null), (te = null), (ne = null), (re = !1), (ie = null), (oe = null), (ae = null), (se = null), (le = null), d.reset(), p.reset(), f.reset() } return { buffers: { color: d, depth: p, stencil: f }, enable: be, disable: Ae, useProgram: we, setBlending: _e, setMaterial: Te, setFlipSided: Se, setCullFace: Ce, setLineWidth: Le, setPolygonOffset: Re, setScissorTest: Pe, activeTexture: De, bindTexture: Oe, unbindTexture: Ie, compressedTexImage2D: Be, texImage2D: Fe, texImage3D: ke, scissor: Ne, viewport: Ue, reset: He, } } function tl(e, t, n, r, i, o, a) { var s, l, c, u = i.isWebGL2, h = i.maxTextures, d = i.maxCubemapSize, p = i.maxTextureSize, f = i.maxSamples, m = new WeakMap(), v = !1 try { v = 'undefined' !== typeof OffscreenCanvas && null !== new OffscreenCanvas(1, 1).getContext('2d') } catch (te) {} function g(e, t) { return v ? new OffscreenCanvas(e, t) : document.createElementNS('http://www.w3.org/1999/xhtml', 'canvas') } function y(e, t, n, r) { var i = 1 if ( ((e.width > r || e.height > r) && (i = r / Math.max(e.width, e.height)), i < 1 || !0 === t) ) { if ( ('undefined' !== typeof HTMLImageElement && e instanceof HTMLImageElement) || ('undefined' !== typeof HTMLCanvasElement && e instanceof HTMLCanvasElement) || ('undefined' !== typeof ImageBitmap && e instanceof ImageBitmap) ) { var o = t ? Kn.floorPowerOfTwo : Math.floor, a = o(i * e.width), s = o(i * e.height) void 0 === c && (c = g(a, s)) var l = n ? g(a, s) : c return ( (l.width = a), (l.height = s), l.getContext('2d').drawImage(e, 0, 0, a, s), console.warn( 'THREE.WebGLRenderer: Texture has been resized from (' + e.width + 'x' + e.height + ') to (' + a + 'x' + s + ').', ), l ) } return ( 'data' in e && console.warn( 'THREE.WebGLRenderer: Image in DataTexture is too big (' + e.width + 'x' + e.height + ').', ), e ) } return e } function b(e) { return Kn.isPowerOfTwo(e.width) && Kn.isPowerOfTwo(e.height) } function A(e) { return ( !u && (e.wrapS !== pe || e.wrapT !== pe || (e.minFilter !== me && e.minFilter !== Ae)) ) } function w(e, t) { return e.generateMipmaps && t && e.minFilter !== me && e.minFilter !== Ae } function x(t, n, i, o) { e.generateMipmap(t), (r.get(n).__maxMipLevel = Math.log(Math.max(i, o)) * Math.LOG2E) } function E(n, r, i) { if (!1 === u) return r if (null !== n) { if (void 0 !== e[n]) return e[n] console.warn( "THREE.WebGLRenderer: Attempt to use non-existing WebGL internal format '" + n + "'", ) } var o = r return ( 6403 === r && (5126 === i && (o = 33326), 5131 === i && (o = 33325), 5121 === i && (o = 33321)), 6407 === r && (5126 === i && (o = 34837), 5131 === i && (o = 34843), 5121 === i && (o = 32849)), 6408 === r && (5126 === i && (o = 34836), 5131 === i && (o = 34842), 5121 === i && (o = 32856)), (33325 !== o && 33326 !== o && 34842 !== o && 34836 !== o) || t.get('EXT_color_buffer_float'), o ) } function M(e) { return e === me || e === ve || e === ye ? 9728 : 9729 } function _(e) { var t = e.target t.removeEventListener('dispose', _), S(t), t.isVideoTexture && m.delete(t), a.memory.textures-- } function T(e) { var t = e.target t.removeEventListener('dispose', T), C(t), a.memory.textures-- } function S(t) { var n = r.get(t) void 0 !== n.__webglInit && (e.deleteTexture(n.__webglTexture), r.remove(t)) } function C(t) { var n = r.get(t), i = r.get(t.texture) if (t) { if ( (void 0 !== i.__webglTexture && e.deleteTexture(i.__webglTexture), t.depthTexture && t.depthTexture.dispose(), t.isWebGLCubeRenderTarget) ) for (var o = 0; o < 6; o++) e.deleteFramebuffer(n.__webglFramebuffer[o]), n.__webglDepthbuffer && e.deleteRenderbuffer(n.__webglDepthbuffer[o]) else e.deleteFramebuffer(n.__webglFramebuffer), n.__webglDepthbuffer && e.deleteRenderbuffer(n.__webglDepthbuffer), n.__webglMultisampledFramebuffer && e.deleteFramebuffer(n.__webglMultisampledFramebuffer), n.__webglColorRenderbuffer && e.deleteRenderbuffer(n.__webglColorRenderbuffer), n.__webglDepthRenderbuffer && e.deleteRenderbuffer(n.__webglDepthRenderbuffer) r.remove(t.texture), r.remove(t) } } var L = 0 function R() { L = 0 } function P() { var e = L return ( e >= h && console.warn( 'THREE.WebGLTextures: Trying to use ' + e + ' texture units while this GPU supports only ' + h, ), (L += 1), e ) } function D(e, t) { var i = r.get(e) if ( (e.isVideoTexture && Z(e), e.version > 0 && i.__version !== e.version) ) { var o = e.image if (void 0 === o) console.warn( 'THREE.WebGLRenderer: Texture marked for update but image is undefined', ) else { if (!1 !== o.complete) return void H(i, e, t) console.warn( 'THREE.WebGLRenderer: Texture marked for update but image is incomplete', ) } } n.activeTexture(33984 + t), n.bindTexture(3553, i.__webglTexture) } function O(e, t) { var i = r.get(e) e.version > 0 && i.__version !== e.version ? H(i, e, t) : (n.activeTexture(33984 + t), n.bindTexture(35866, i.__webglTexture)) } function I(e, t) { var i = r.get(e) e.version > 0 && i.__version !== e.version ? H(i, e, t) : (n.activeTexture(33984 + t), n.bindTexture(32879, i.__webglTexture)) } function B(e, t) { var i = r.get(e) e.version > 0 && i.__version !== e.version ? G(i, e, t) : (n.activeTexture(33984 + t), n.bindTexture(34067, i.__webglTexture)) } var F = (((s = {})[de] = 10497), (s[pe] = 33071), (s[fe] = 33648), s), k = (((l = {})[me] = 9728), (l[ve] = 9984), (l[ye] = 9986), (l[Ae] = 9729), (l[we] = 9985), (l[Ee] = 9987), l) function N(n, o, a) { a ? (e.texParameteri(n, 10242, F[o.wrapS]), e.texParameteri(n, 10243, F[o.wrapT]), (32879 !== n && 35866 !== n) || e.texParameteri(n, 32882, F[o.wrapR]), e.texParameteri(n, 10240, k[o.magFilter]), e.texParameteri(n, 10241, k[o.minFilter])) : (e.texParameteri(n, 10242, 33071), e.texParameteri(n, 10243, 33071), (32879 !== n && 35866 !== n) || e.texParameteri(n, 32882, 33071), (o.wrapS === pe && o.wrapT === pe) || console.warn( 'THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping.', ), e.texParameteri(n, 10240, M(o.magFilter)), e.texParameteri(n, 10241, M(o.minFilter)), o.minFilter !== me && o.minFilter !== Ae && console.warn( 'THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter.', )) var s = t.get('EXT_texture_filter_anisotropic') if (s) { if (o.type === Pe && null === t.get('OES_texture_float_linear')) return if ( o.type === De && null === (u || t.get('OES_texture_half_float_linear')) ) return ;(o.anisotropy > 1 || r.get(o).__currentAnisotropy) && (e.texParameterf( n, s.TEXTURE_MAX_ANISOTROPY_EXT, Math.min(o.anisotropy, i.getMaxAnisotropy()), ), (r.get(o).__currentAnisotropy = o.anisotropy)) } } function U(t, n) { void 0 === t.__webglInit && ((t.__webglInit = !0), n.addEventListener('dispose', _), (t.__webglTexture = e.createTexture()), a.memory.textures++) } function H(t, r, i) { var a = 3553 r.isDataTexture2DArray && (a = 35866), r.isDataTexture3D && (a = 32879), U(t, r), n.activeTexture(33984 + i), n.bindTexture(a, t.__webglTexture), e.pixelStorei(37440, r.flipY), e.pixelStorei(37441, r.premultiplyAlpha), e.pixelStorei(3317, r.unpackAlignment) var s, l = A(r) && !1 === b(r.image), c = y(r.image, l, !1, p), h = b(c) || u, d = o.convert(r.format), f = o.convert(r.type), m = E(r.internalFormat, d, f) N(a, r, h) var v = r.mipmaps if (r.isDepthTexture) (m = 6402), u ? (m = r.type === Pe ? 36012 : r.type === Re ? 33190 : r.type === Fe ? 35056 : 33189) : r.type === Pe && console.error( 'WebGLRenderer: Floating point depth texture requires WebGL2.', ), r.format === je && 6402 === m && r.type !== Ce && r.type !== Re && (console.warn( 'THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture.', ), (r.type = Ce), (f = o.convert(r.type))), r.format === Ve && 6402 === m && ((m = 34041), r.type !== Fe && (console.warn( 'THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture.', ), (r.type = Fe), (f = o.convert(r.type)))), n.texImage2D(3553, 0, m, c.width, c.height, 0, d, f, null) else if (r.isDataTexture) if (v.length > 0 && h) { for (var g = 0, M = v.length; g < M; g++) (s = v[g]), n.texImage2D(3553, g, m, s.width, s.height, 0, d, f, s.data) ;(r.generateMipmaps = !1), (t.__maxMipLevel = v.length - 1) } else n.texImage2D(3553, 0, m, c.width, c.height, 0, d, f, c.data), (t.__maxMipLevel = 0) else if (r.isCompressedTexture) { for (var _ = 0, T = v.length; _ < T; _++) (s = v[_]), r.format !== Ue && r.format !== Ne ? null !== d ? n.compressedTexImage2D(3553, _, m, s.width, s.height, 0, s.data) : console.warn( 'THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()', ) : n.texImage2D(3553, _, m, s.width, s.height, 0, d, f, s.data) t.__maxMipLevel = v.length - 1 } else if (r.isDataTexture2DArray) n.texImage3D(35866, 0, m, c.width, c.height, c.depth, 0, d, f, c.data), (t.__maxMipLevel = 0) else if (r.isDataTexture3D) n.texImage3D(32879, 0, m, c.width, c.height, c.depth, 0, d, f, c.data), (t.__maxMipLevel = 0) else if (v.length > 0 && h) { for (var S = 0, C = v.length; S < C; S++) (s = v[S]), n.texImage2D(3553, S, m, d, f, s) ;(r.generateMipmaps = !1), (t.__maxMipLevel = v.length - 1) } else n.texImage2D(3553, 0, m, d, f, c), (t.__maxMipLevel = 0) w(r, h) && x(a, r, c.width, c.height), (t.__version = r.version), r.onUpdate && r.onUpdate(r) } function G(t, r, i) { if (6 === r.image.length) { U(t, r), n.activeTexture(33984 + i), n.bindTexture(34067, t.__webglTexture), e.pixelStorei(37440, r.flipY), e.pixelStorei(37441, r.premultiplyAlpha), e.pixelStorei(3317, r.unpackAlignment) for ( var a = r && (r.isCompressedTexture || r.image[0].isCompressedTexture), s = r.image[0] && r.image[0].isDataTexture, l = [], c = 0; c < 6; c++ ) l[c] = a || s ? s ? r.image[c].image : r.image[c] : y(r.image[c], !1, !0, d) var h, p = l[0], f = b(p) || u, m = o.convert(r.format), v = o.convert(r.type), g = E(r.internalFormat, m, v) if ((N(34067, r, f), a)) { for (var A = 0; A < 6; A++) { h = l[A].mipmaps for (var M = 0; M < h.length; M++) { var _ = h[M] r.format !== Ue && r.format !== Ne ? null !== m ? n.compressedTexImage2D( 34069 + A, M, g, _.width, _.height, 0, _.data, ) : console.warn( 'THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()', ) : n.texImage2D( 34069 + A, M, g, _.width, _.height, 0, m, v, _.data, ) } } t.__maxMipLevel = h.length - 1 } else { h = r.mipmaps for (var T = 0; T < 6; T++) if (s) { n.texImage2D( 34069 + T, 0, g, l[T].width, l[T].height, 0, m, v, l[T].data, ) for (var S = 0; S < h.length; S++) { var C = h[S].image[T].image n.texImage2D( 34069 + T, S + 1, g, C.width, C.height, 0, m, v, C.data, ) } } else { n.texImage2D(34069 + T, 0, g, m, v, l[T]) for (var L = 0; L < h.length; L++) { var R = h[L] n.texImage2D(34069 + T, L + 1, g, m, v, R.image[T]) } } t.__maxMipLevel = h.length } w(r, f) && x(34067, r, p.width, p.height), (t.__version = r.version), r.onUpdate && r.onUpdate(r) } } function z(t, i, a, s) { var l = o.convert(i.texture.format), c = o.convert(i.texture.type), u = E(i.texture.internalFormat, l, c) n.texImage2D(s, 0, u, i.width, i.height, 0, l, c, null), e.bindFramebuffer(36160, t), e.framebufferTexture2D(36160, a, s, r.get(i.texture).__webglTexture, 0), e.bindFramebuffer(36160, null) } function j(t, n, r) { if ((e.bindRenderbuffer(36161, t), n.depthBuffer && !n.stencilBuffer)) { var i = 33189 if (r) { var a = n.depthTexture a && a.isDepthTexture && (a.type === Pe ? (i = 36012) : a.type === Re && (i = 33190)) var s = Q(n) e.renderbufferStorageMultisample(36161, s, i, n.width, n.height) } else e.renderbufferStorage(36161, i, n.width, n.height) e.framebufferRenderbuffer(36160, 36096, 36161, t) } else if (n.depthBuffer && n.stencilBuffer) { if (r) { var l = Q(n) e.renderbufferStorageMultisample(36161, l, 35056, n.width, n.height) } else e.renderbufferStorage(36161, 34041, n.width, n.height) e.framebufferRenderbuffer(36160, 33306, 36161, t) } else { var c = o.convert(n.texture.format), u = o.convert(n.texture.type), h = E(n.texture.internalFormat, c, u) if (r) { var d = Q(n) e.renderbufferStorageMultisample(36161, d, h, n.width, n.height) } else e.renderbufferStorage(36161, h, n.width, n.height) } e.bindRenderbuffer(36161, null) } function V(t, n) { if (n && n.isWebGLCubeRenderTarget) throw new Error('Depth Texture with cube render targets is not supported') if ( (e.bindFramebuffer(36160, t), !n.depthTexture || !n.depthTexture.isDepthTexture) ) throw new Error( 'renderTarget.depthTexture must be an instance of THREE.DepthTexture', ) ;(r.get(n.depthTexture).__webglTexture && n.depthTexture.image.width === n.width && n.depthTexture.image.height === n.height) || ((n.depthTexture.image.width = n.width), (n.depthTexture.image.height = n.height), (n.depthTexture.needsUpdate = !0)), D(n.depthTexture, 0) var i = r.get(n.depthTexture).__webglTexture if (n.depthTexture.format === je) e.framebufferTexture2D(36160, 36096, 3553, i, 0) else { if (n.depthTexture.format !== Ve) throw new Error('Unknown depthTexture format') e.framebufferTexture2D(36160, 33306, 3553, i, 0) } } function W(t) { var n = r.get(t), i = !0 === t.isWebGLCubeRenderTarget if (t.depthTexture) { if (i) throw new Error( 'target.depthTexture not supported in Cube render targets', ) V(n.__webglFramebuffer, t) } else if (i) { n.__webglDepthbuffer = [] for (var o = 0; o < 6; o++) e.bindFramebuffer(36160, n.__webglFramebuffer[o]), (n.__webglDepthbuffer[o] = e.createRenderbuffer()), j(n.__webglDepthbuffer[o], t, !1) } else e.bindFramebuffer(36160, n.__webglFramebuffer), (n.__webglDepthbuffer = e.createRenderbuffer()), j(n.__webglDepthbuffer, t, !1) e.bindFramebuffer(36160, null) } function q(t) { var i = r.get(t), s = r.get(t.texture) t.addEventListener('dispose', T), (s.__webglTexture = e.createTexture()), a.memory.textures++ var l = !0 === t.isWebGLCubeRenderTarget, c = !0 === t.isWebGLMultisampleRenderTarget, h = b(t) || u if ( (!u || t.texture.format !== Ne || (t.texture.type !== Pe && t.texture.type !== De) || ((t.texture.format = Ue), console.warn( 'THREE.WebGLRenderer: Rendering to textures with RGB format is not supported. Using RGBA format instead.', )), l) ) { i.__webglFramebuffer = [] for (var d = 0; d < 6; d++) i.__webglFramebuffer[d] = e.createFramebuffer() } else if (((i.__webglFramebuffer = e.createFramebuffer()), c)) if (u) { ;(i.__webglMultisampledFramebuffer = e.createFramebuffer()), (i.__webglColorRenderbuffer = e.createRenderbuffer()), e.bindRenderbuffer(36161, i.__webglColorRenderbuffer) var p = o.convert(t.texture.format), f = o.convert(t.texture.type), m = E(t.texture.internalFormat, p, f), v = Q(t) e.renderbufferStorageMultisample(36161, v, m, t.width, t.height), e.bindFramebuffer(36160, i.__webglMultisampledFramebuffer), e.framebufferRenderbuffer( 36160, 36064, 36161, i.__webglColorRenderbuffer, ), e.bindRenderbuffer(36161, null), t.depthBuffer && ((i.__webglDepthRenderbuffer = e.createRenderbuffer()), j(i.__webglDepthRenderbuffer, t, !0)), e.bindFramebuffer(36160, null) } else console.warn( 'THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.', ) if (l) { n.bindTexture(34067, s.__webglTexture), N(34067, t.texture, h) for (var g = 0; g < 6; g++) z(i.__webglFramebuffer[g], t, 36064, 34069 + g) w(t.texture, h) && x(34067, t.texture, t.width, t.height), n.bindTexture(34067, null) } else n.bindTexture(3553, s.__webglTexture), N(3553, t.texture, h), z(i.__webglFramebuffer, t, 36064, 3553), w(t.texture, h) && x(3553, t.texture, t.width, t.height), n.bindTexture(3553, null) t.depthBuffer && W(t) } function X(e) { var t = e.texture if (w(t, b(e) || u)) { var i = e.isWebGLCubeRenderTarget ? 34067 : 3553, o = r.get(t).__webglTexture n.bindTexture(i, o), x(i, t, e.width, e.height), n.bindTexture(i, null) } } function Y(t) { if (t.isWebGLMultisampleRenderTarget) if (u) { var n = r.get(t) e.bindFramebuffer(36008, n.__webglMultisampledFramebuffer), e.bindFramebuffer(36009, n.__webglFramebuffer) var i = t.width, o = t.height, a = 16384 t.depthBuffer && (a |= 256), t.stencilBuffer && (a |= 1024), e.blitFramebuffer(0, 0, i, o, 0, 0, i, o, a, 9728), e.bindFramebuffer(36160, n.__webglMultisampledFramebuffer) } else console.warn( 'THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.', ) } function Q(e) { return u && e.isWebGLMultisampleRenderTarget ? Math.min(f, e.samples) : 0 } function Z(e) { var t = a.render.frame m.get(e) !== t && (m.set(e, t), e.update()) } var K = !1, J = !1 function $(e, t) { e && e.isWebGLRenderTarget && (!1 === K && (console.warn( "THREE.WebGLTextures.safeSetTexture2D: don't use render targets as textures. Use their .texture property instead.", ), (K = !0)), (e = e.texture)), D(e, t) } function ee(e, t) { e && e.isWebGLCubeRenderTarget && (!1 === J && (console.warn( "THREE.WebGLTextures.safeSetTextureCube: don't use cube render targets as textures. Use their .texture property instead.", ), (J = !0)), (e = e.texture)), B(e, t) } ;(this.allocateTextureUnit = P), (this.resetTextureUnits = R), (this.setTexture2D = D), (this.setTexture2DArray = O), (this.setTexture3D = I), (this.setTextureCube = B), (this.setupRenderTarget = q), (this.updateRenderTargetMipmap = X), (this.updateMultisampleRenderTarget = Y), (this.safeSetTexture2D = $), (this.safeSetTextureCube = ee) } function nl(e, t, n) { var r = n.isWebGL2 function i(e) { var n if (e === _e) return 5121 if (e === Oe) return 32819 if (e === Ie) return 32820 if (e === Be) return 33635 if (e === Te) return 5120 if (e === Se) return 5122 if (e === Ce) return 5123 if (e === Le) return 5124 if (e === Re) return 5125 if (e === Pe) return 5126 if (e === De) return r ? 5131 : null !== (n = t.get('OES_texture_half_float')) ? n.HALF_FLOAT_OES : null if (e === ke) return 6406 if (e === Ne) return 6407 if (e === Ue) return 6408 if (e === He) return 6409 if (e === Ge) return 6410 if (e === je) return 6402 if (e === Ve) return 34041 if (e === We) return 6403 if (e === qe) return 36244 if (e === Xe) return 33319 if (e === Ye) return 33320 if (e === Qe) return 36248 if (e === Ze) return 36249 if (e === Ke || e === Je || e === $e || e === et) { if (null === (n = t.get('WEBGL_compressed_texture_s3tc'))) return null if (e === Ke) return n.COMPRESSED_RGB_S3TC_DXT1_EXT if (e === Je) return n.COMPRESSED_RGBA_S3TC_DXT1_EXT if (e === $e) return n.COMPRESSED_RGBA_S3TC_DXT3_EXT if (e === et) return n.COMPRESSED_RGBA_S3TC_DXT5_EXT } if (e === tt || e === nt || e === rt || e === it) { if (null === (n = t.get('WEBGL_compressed_texture_pvrtc'))) return null if (e === tt) return n.COMPRESSED_RGB_PVRTC_4BPPV1_IMG if (e === nt) return n.COMPRESSED_RGB_PVRTC_2BPPV1_IMG if (e === rt) return n.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG if (e === it) return n.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG } if (e === ot) return null !== (n = t.get('WEBGL_compressed_texture_etc1')) ? n.COMPRESSED_RGB_ETC1_WEBGL : null if ( (e === at || e === st) && null !== (n = t.get('WEBGL_compressed_texture_etc')) ) { if (e === at) return n.COMPRESSED_RGB8_ETC2 if (e === st) return n.COMPRESSED_RGBA8_ETC2_EAC } return e === lt || e === ct || e === ut || e === ht || e === dt || e === pt || e === ft || e === mt || e === vt || e === gt || e === yt || e === bt || e === At || e === wt || e === Et || e === Mt || e === _t || e === Tt || e === St || e === Ct || e === Lt || e === Rt || e === Pt || e === Dt || e === Ot || e === It || e === Bt || e === Ft ? null !== (n = t.get('WEBGL_compressed_texture_astc')) ? e : null : e === xt ? null !== (n = t.get('EXT_texture_compression_bptc')) ? e : null : e === Fe ? r ? 34042 : null !== (n = t.get('WEBGL_depth_texture')) ? n.UNSIGNED_INT_24_8_WEBGL : null : void 0 } return { convert: i } } function rl() { si.call(this), (this.type = 'Group') } function il(e) { void 0 === e && (e = []), Oo.call(this), (this.cameras = e) } ;(rl.prototype = Object.assign(Object.create(si.prototype), { constructor: rl, isGroup: !0, })), (il.prototype = Object.assign(Object.create(Oo.prototype), { constructor: il, isArrayCamera: !0, })) var ol = new lr(), al = new lr() function sl(e, t, n) { ol.setFromMatrixPosition(t.matrixWorld), al.setFromMatrixPosition(n.matrixWorld) var r = ol.distanceTo(al), i = t.projectionMatrix.elements, o = n.projectionMatrix.elements, a = i[14] / (i[10] - 1), s = i[14] / (i[10] + 1), l = (i[9] + 1) / i[5], c = (i[9] - 1) / i[5], u = (i[8] - 1) / i[0], h = (o[8] + 1) / o[0], d = a * u, p = a * h, f = r / (-u + h), m = f * -u t.matrixWorld.decompose(e.position, e.quaternion, e.scale), e.translateX(m), e.translateZ(f), e.matrixWorld.compose(e.position, e.quaternion, e.scale), e.matrixWorldInverse.getInverse(e.matrixWorld) var v = a + f, g = s + f, y = d - m, b = p + (r - m), A = ((l * s) / g) * v, w = ((c * s) / g) * v e.projectionMatrix.makePerspective(y, b, A, w, v, g) } function ll(e) { var t, n, r = this, i = null, o = null, a = null, s = [], l = new Fr(), c = new Fr(), u = 1, h = 'local-floor' 'undefined' !== typeof window && 'VRFrameData' in window && ((o = new window.VRFrameData()), window.addEventListener('vrdisplaypresentchange', A, !1)) var d = new Fr(), p = new sr(), f = new lr(), m = new Oo() ;(m.viewport = new ir()), m.layers.enable(1) var v = new Oo() ;(v.viewport = new ir()), v.layers.enable(2) var g = new il([m, v]) g.layers.enable(1), g.layers.enable(2) var y, b = new Jn() function A() { if ((r.isPresenting = null !== i && !0 === i.isPresenting)) { var o = i.getEyeParameters('left') ;(t = 2 * o.renderWidth * u), (n = o.renderHeight * u), (y = e.getPixelRatio()), e.getSize(b), e.setDrawingBufferSize(t, n, 1), m.viewport.set(0, 0, t / 2, n), v.viewport.set(t / 2, 0, t / 2, n), T.start(), r.dispatchEvent({ type: 'sessionstart' }) } else r.enabled && e.setDrawingBufferSize(b.width, b.height, y), T.stop(), r.dispatchEvent({ type: 'sessionend' }) } var w = [], x = [] function E(e) { for ( var t = navigator.getGamepads && navigator.getGamepads(), n = 0, r = t.length; n < r; n++ ) { var i = t[n] if ( i && ('Daydream Controller' === i.id || 'Gear VR Controller' === i.id || 'Oculus Go Controller' === i.id || 'OpenVR Gamepad' === i.id || i.id.startsWith('Oculus Touch') || i.id.startsWith('HTC Vive Focus') || i.id.startsWith('Spatial Controller')) ) { var o = i.hand if (0 === e && ('' === o || 'right' === o)) return i if (1 === e && 'left' === o) return i } } } function M() { for (var e = 0; e < s.length; e++) { var t = s[e], n = E(e) if (void 0 !== n && void 0 !== n.pose) { if (null === n.pose) return var r = n.pose !1 === r.hasPosition && t.position.set(0.2, -0.6, -0.05), null !== r.position && t.position.fromArray(r.position), null !== r.orientation && t.quaternion.fromArray(r.orientation), t.matrix.compose(t.position, t.quaternion, t.scale), t.matrix.premultiply(l), t.matrix.decompose(t.position, t.quaternion, t.scale), (t.matrixWorldNeedsUpdate = !0), (t.visible = !0) var i = 'Daydream Controller' === n.id ? 0 : 1 void 0 === w[e] && (w[e] = !1), w[e] !== n.buttons[i].pressed && ((w[e] = n.buttons[i].pressed), !0 === w[e] ? t.dispatchEvent({ type: 'selectstart' }) : (t.dispatchEvent({ type: 'selectend' }), t.dispatchEvent({ type: 'select' }))), (i = 2), void 0 === x[e] && (x[e] = !1), void 0 !== n.buttons[i] && x[e] !== n.buttons[i].pressed && ((x[e] = n.buttons[i].pressed), !0 === x[e] ? t.dispatchEvent({ type: 'squeezestart' }) : (t.dispatchEvent({ type: 'squeezeend' }), t.dispatchEvent({ type: 'squeeze' }))) } else t.visible = !1 } } function _(e, r) { null !== r && 4 === r.length && e.set(r[0] * t, r[1] * n, r[2] * t, r[3] * n) } ;(this.enabled = !1), (this.getController = function (e) { var t = s[e] return ( void 0 === t && (((t = new rl()).matrixAutoUpdate = !1), (t.visible = !1), (s[e] = t)), t ) }), (this.getDevice = function () { return i }), (this.setDevice = function (e) { void 0 !== e && (i = e), T.setContext(e) }), (this.setFramebufferScaleFactor = function (e) { u = e }), (this.setReferenceSpaceType = function (e) { h = e }), (this.setPoseTarget = function (e) { void 0 !== e && (a = e) }), (this.getCamera = function (e) { var t = 'local-floor' === h ? 1.6 : 0 if ( ((i.depthNear = e.near), (i.depthFar = e.far), i.getFrameData(o), 'local-floor' === h) ) { var n = i.stageParameters n ? l.fromArray(n.sittingToStandingTransform) : l.makeTranslation(0, t, 0) } var r = o.pose, s = null !== a ? a : e s.matrix.copy(l), s.matrix.decompose(s.position, s.quaternion, s.scale), null !== r.orientation && (p.fromArray(r.orientation), s.quaternion.multiply(p)), null !== r.position && (p.setFromRotationMatrix(l), f.fromArray(r.position), f.applyQuaternion(p), s.position.add(f)), s.updateMatrixWorld() for (var u = s.children, y = 0, b = u.length; y < b; y++) u[y].updateMatrixWorld(!0) ;(m.near = e.near), (v.near = e.near), (m.far = e.far), (v.far = e.far), m.matrixWorldInverse.fromArray(o.leftViewMatrix), v.matrixWorldInverse.fromArray(o.rightViewMatrix), c.getInverse(l), 'local-floor' === h && (m.matrixWorldInverse.multiply(c), v.matrixWorldInverse.multiply(c)) var A = s.parent null !== A && (d.getInverse(A.matrixWorld), m.matrixWorldInverse.multiply(d), v.matrixWorldInverse.multiply(d)), m.matrixWorld.getInverse(m.matrixWorldInverse), v.matrixWorld.getInverse(v.matrixWorldInverse), m.projectionMatrix.fromArray(o.leftProjectionMatrix), v.projectionMatrix.fromArray(o.rightProjectionMatrix), sl(g, m, v) var w = i.getLayers() if (w.length) { var x = w[0] _(m.viewport, x.leftBounds), _(v.viewport, x.rightBounds) } return M(), g }), (this.getStandingMatrix = function () { return l }), (this.isPresenting = !1) var T = new jo() ;(this.setAnimationLoop = function (e) { T.setAnimationLoop(e), this.isPresenting && T.start() }), (this.submitFrame = function () { this.isPresenting && i.submitFrame() }), (this.dispose = function () { 'undefined' !== typeof window && window.removeEventListener('vrdisplaypresentchange', A) }), (this.setFrameOfReferenceType = function () { console.warn( 'THREE.WebVRManager: setFrameOfReferenceType() has been deprecated.', ) }) } function cl() { ;(this._targetRay = null), (this._grip = null), (this._hand = null) } function ul(e, t) { var n, r = this, i = null, o = 1, a = null, s = 'local-floor', l = null, c = null, u = [], h = new Map(), d = [], p = new Oo() p.layers.enable(1), (p.viewport = new ir()) var f = new Oo() f.layers.enable(2), (f.viewport = new ir()) var m = [p, f], v = new il() v.layers.enable(1), v.layers.enable(2) var g = null, y = null function b(e) { var t = h.get(e.inputSource) t && t.dispatchEvent({ type: e.type, data: e.inputSource }) } function A() { h.forEach(function (e, t) { e.disconnect(t) }), h.clear(), (g = null), (y = null), e.setFramebuffer(null), e.setRenderTarget(e.getRenderTarget()), C.stop(), (r.isPresenting = !1), r.dispatchEvent({ type: 'sessionend' }) } function w(e) { for (var t = i.inputSources, n = 0; n < u.length; n++) h.set(t[n], u[n]) for (var r = 0; r < e.removed.length; r++) { var o = e.removed[r], a = h.get(o) a && (a.dispatchEvent({ type: 'disconnected', data: o }), h.delete(o)) } for (var s = 0; s < e.added.length; s++) { var l = e.added[s], c = h.get(l) c && c.dispatchEvent({ type: 'connected', data: l }) } } ;(this.layersEnabled = !1), (this.enabled = !1), (this.isPresenting = !1), (this.getCameraPose = function () { return l }), (this.getController = function (e) { var t = u[e] return void 0 === t && ((t = new cl()), (u[e] = t)), t.getTargetRaySpace() }), (this.getControllerGrip = function (e) { var t = u[e] return void 0 === t && ((t = new cl()), (u[e] = t)), t.getGripSpace() }), (this.getHand = function (e) { var t = u[e] return void 0 === t && ((t = new cl()), (u[e] = t)), t.getHandSpace() }), (this.setFramebufferScaleFactor = function (e) { ;(o = e), !0 === r.isPresenting && console.warn( 'THREE.WebXRManager: Cannot change framebuffer scale while presenting.', ) }), (this.setReferenceSpaceType = function (e) { ;(s = e), !0 === r.isPresenting && console.warn( 'THREE.WebXRManager: Cannot change reference space type while presenting.', ) }), (this.getReferenceSpace = function () { return a }), (this.getSession = function () { return i }), (this.setSession = (function () { var e = Nn( regeneratorRuntime.mark(function e(l) { var c, u return regeneratorRuntime.wrap( function (e) { for (;;) switch ((e.prev = e.next)) { case 0: if (null === (i = l)) { e.next = 24 break } if ( (i.addEventListener('select', b), i.addEventListener('selectstart', b), i.addEventListener('selectend', b), i.addEventListener('squeeze', b), i.addEventListener('squeezestart', b), i.addEventListener('squeezeend', b), i.addEventListener('end', A), i.addEventListener('inputsourceschange', w), !0 === (c = t.getContextAttributes()).xrCompatible) ) { e.next = 14 break } return (e.next = 14), t.makeXRCompatible() case 14: return ( (u = { antialias: c.antialias, alpha: c.alpha, depth: c.depth, stencil: c.stencil, framebufferScaleFactor: o, }), (n = new XRWebGLLayer(i, t, u)), window.XRWebGLBinding && this.layersEnabled ? this.addLayer(n) : i.updateRenderState({ baseLayer: n }), (e.next = 19), i.requestReferenceSpace(s) ) case 19: ;(a = e.sent), C.setContext(i), C.start(), (r.isPresenting = !0), r.dispatchEvent({ type: 'sessionstart' }) case 24: case 'end': return e.stop() } }, e, this, ) }), ) return function (t) { return e.apply(this, arguments) } })()), (this.addLayer = function (e) { window.XRWebGLBinding && this.layersEnabled && i && (d.push(e), i.updateRenderState({ layers: d })) }), (this.removeLayer = function (e) { window.XRWebGLBinding && this.layersEnabled && i && (d.splice(d.indexOf(e), 1), i.updateRenderState({ layers: d })) }) var x = new lr(), E = new lr() function M(e, t, n) { x.setFromMatrixPosition(t.matrixWorld), E.setFromMatrixPosition(n.matrixWorld) var r = x.distanceTo(E), i = t.projectionMatrix.elements, o = n.projectionMatrix.elements, a = i[14] / (i[10] - 1), s = i[14] / (i[10] + 1), l = (i[9] + 1) / i[5], c = (i[9] - 1) / i[5], u = (i[8] - 1) / i[0], h = (o[8] + 1) / o[0], d = a * u, p = a * h, f = r / (-u + h), m = f * -u t.matrixWorld.decompose(e.position, e.quaternion, e.scale), e.translateX(m), e.translateZ(f), e.matrixWorld.compose(e.position, e.quaternion, e.scale), e.matrixWorldInverse.copy(e.matrixWorld).invert() var v = a + f, g = s + f, y = d - m, b = p + (r - m), A = ((l * s) / g) * v, w = ((c * s) / g) * v e.projectionMatrix.makePerspective(y, b, A, w, v, g) } function _(e, t) { null === t ? e.matrixWorld.copy(e.matrix) : e.matrixWorld.multiplyMatrices(t.matrixWorld, e.matrix), e.matrixWorldInverse.copy(e.matrixWorld).invert() } ;(this.setPoseTarget = function (e) { void 0 !== e && (c = e) }), (this.getCamera = function (e) { ;(v.near = f.near = p.near = e.near), (v.far = f.far = p.far = e.far), (g === v.near && y === v.far) || (i.updateRenderState({ depthNear: v.near, depthFar: v.far }), (g = v.near), (y = v.far)) var t = e.parent, n = v.cameras, r = c || e _(v, t) for (var o = 0; o < n.length; o++) _(n[o], t) r.matrixWorld.copy(v.matrixWorld) for (var a = r.children, s = 0, l = a.length; s < l; s++) a[s].updateMatrixWorld(!0) return ( 2 === n.length ? M(v, p, f) : v.projectionMatrix.copy(p.projectionMatrix), v ) }) var T = null function S(t, r) { if (null !== (l = r.getViewerPose(a))) { var o = l.views e.setFramebuffer(n.framebuffer) var s = !1 o.length !== v.cameras.length && ((v.cameras.length = 0), (s = !0)) for (var c = 0; c < o.length; c++) { var h = o[c], d = n.getViewport(h), p = m[c] p.matrix.fromArray(h.transform.matrix), p.projectionMatrix.fromArray(h.projectionMatrix), p.viewport.set(d.x, d.y, d.width, d.height), 0 === c && v.matrix.copy(p.matrix), !0 === s && v.cameras.push(p) } } for (var f = i.inputSources, g = 0; g < u.length; g++) { var y = u[g], b = f[g] y.update(b, r, a) } T && T(t, r) } var C = new jo() C.setAnimationLoop(S), (this.setAnimationLoop = function (e) { T = e }), (this.dispose = function () {}) } function hl(e) { function t(e, t) { e.fogColor.value.copy(t.color), t.isFog ? ((e.fogNear.value = t.near), (e.fogFar.value = t.far)) : t.isFogExp2 && (e.fogDensity.value = t.density) } function n(e, t, n, v) { t.isMeshBasicMaterial ? r(e, t) : t.isMeshLambertMaterial ? (r(e, t), l(e, t)) : t.isMeshToonMaterial ? (r(e, t), u(e, t)) : t.isMeshPhongMaterial ? (r(e, t), c(e, t)) : t.isMeshStandardMaterial ? (r(e, t), t.isMeshPhysicalMaterial ? d(e, t) : h(e, t)) : t.isMeshMatcapMaterial ? (r(e, t), p(e, t)) : t.isMeshDepthMaterial ? (r(e, t), f(e, t)) : t.isMeshDistanceMaterial ? (r(e, t), m(e, t)) : t.isMeshNormalMaterial ? (r(e, t), g(e, t)) : t.isLineBasicMaterial ? (i(e, t), t.isLineDashedMaterial && o(e, t)) : t.isPointsMaterial ? a(e, t, n, v) : t.isSpriteMaterial ? s(e, t) : t.isShadowMaterial ? (e.color.value.copy(t.color), (e.opacity.value = t.opacity)) : t.isShaderMaterial && (t.uniformsNeedUpdate = !1) } function r(t, n) { ;(t.opacity.value = n.opacity), n.color && t.diffuse.value.copy(n.color), n.emissive && t.emissive.value.copy(n.emissive).multiplyScalar(n.emissiveIntensity), n.map && (t.map.value = n.map), n.alphaMap && (t.alphaMap.value = n.alphaMap), n.specularMap && (t.specularMap.value = n.specularMap) var r, i, o = e.get(n).envMap if (o) { ;(t.envMap.value = o), (t.flipEnvMap.value = o.isCubeTexture && o._needsFlipEnvMap ? -1 : 1), (t.reflectivity.value = n.reflectivity), (t.refractionRatio.value = n.refractionRatio) var a = e.get(o).__maxMipLevel void 0 !== a && (t.maxMipLevel.value = a) } n.lightMap && ((t.lightMap.value = n.lightMap), (t.lightMapIntensity.value = n.lightMapIntensity)), n.aoMap && ((t.aoMap.value = n.aoMap), (t.aoMapIntensity.value = n.aoMapIntensity)), n.map ? (r = n.map) : n.specularMap ? (r = n.specularMap) : n.displacementMap ? (r = n.displacementMap) : n.normalMap ? (r = n.normalMap) : n.bumpMap ? (r = n.bumpMap) : n.roughnessMap ? (r = n.roughnessMap) : n.metalnessMap ? (r = n.metalnessMap) : n.alphaMap ? (r = n.alphaMap) : n.emissiveMap ? (r = n.emissiveMap) : n.clearcoatMap ? (r = n.clearcoatMap) : n.clearcoatNormalMap ? (r = n.clearcoatNormalMap) : n.clearcoatRoughnessMap && (r = n.clearcoatRoughnessMap), void 0 !== r && (r.isWebGLRenderTarget && (r = r.texture), !0 === r.matrixAutoUpdate && r.updateMatrix(), t.uvTransform.value.copy(r.matrix)), n.aoMap ? (i = n.aoMap) : n.lightMap && (i = n.lightMap), void 0 !== i && (i.isWebGLRenderTarget && (i = i.texture), !0 === i.matrixAutoUpdate && i.updateMatrix(), t.uv2Transform.value.copy(i.matrix)) } function i(e, t) { e.diffuse.value.copy(t.color), (e.opacity.value = t.opacity) } function o(e, t) { ;(e.dashSize.value = t.dashSize), (e.totalSize.value = t.dashSize + t.gapSize), (e.scale.value = t.scale) } function a(e, t, n, r) { var i e.diffuse.value.copy(t.color), (e.opacity.value = t.opacity), (e.size.value = t.size * n), (e.scale.value = 0.5 * r), t.map && (e.map.value = t.map), t.alphaMap && (e.alphaMap.value = t.alphaMap), t.map ? (i = t.map) : t.alphaMap && (i = t.alphaMap), void 0 !== i && (!0 === i.matrixAutoUpdate && i.updateMatrix(), e.uvTransform.value.copy(i.matrix)) } function s(e, t) { var n e.diffuse.value.copy(t.color), (e.opacity.value = t.opacity), (e.rotation.value = t.rotation), t.map && (e.map.value = t.map), t.alphaMap && (e.alphaMap.value = t.alphaMap), t.map ? (n = t.map) : t.alphaMap && (n = t.alphaMap), void 0 !== n && (!0 === n.matrixAutoUpdate && n.updateMatrix(), e.uvTransform.value.copy(n.matrix)) } function l(e, t) { t.emissiveMap && (e.emissiveMap.value = t.emissiveMap) } function c(e, t) { e.specular.value.copy(t.specular), (e.shininess.value = Math.max(t.shininess, 1e-4)), t.emissiveMap && (e.emissiveMap.value = t.emissiveMap), t.bumpMap && ((e.bumpMap.value = t.bumpMap), (e.bumpScale.value = t.bumpScale), t.side === v && (e.bumpScale.value *= -1)), t.normalMap && ((e.normalMap.value = t.normalMap), e.normalScale.value.copy(t.normalScale), t.side === v && e.normalScale.value.negate()), t.displacementMap && ((e.displacementMap.value = t.displacementMap), (e.displacementScale.value = t.displacementScale), (e.displacementBias.value = t.displacementBias)) } function u(e, t) { t.gradientMap && (e.gradientMap.value = t.gradientMap), t.emissiveMap && (e.emissiveMap.value = t.emissiveMap), t.bumpMap && ((e.bumpMap.value = t.bumpMap), (e.bumpScale.value = t.bumpScale), t.side === v && (e.bumpScale.value *= -1)), t.normalMap && ((e.normalMap.value = t.normalMap), e.normalScale.value.copy(t.normalScale), t.side === v && e.normalScale.value.negate()), t.displacementMap && ((e.displacementMap.value = t.displacementMap), (e.displacementScale.value = t.displacementScale), (e.displacementBias.value = t.displacementBias)) } function h(t, n) { ;(t.roughness.value = n.roughness), (t.metalness.value = n.metalness), n.roughnessMap && (t.roughnessMap.value = n.roughnessMap), n.metalnessMap && (t.metalnessMap.value = n.metalnessMap), n.emissiveMap && (t.emissiveMap.value = n.emissiveMap), n.bumpMap && ((t.bumpMap.value = n.bumpMap), (t.bumpScale.value = n.bumpScale), n.side === v && (t.bumpScale.value *= -1)), n.normalMap && ((t.normalMap.value = n.normalMap), t.normalScale.value.copy(n.normalScale), n.side === v && t.normalScale.value.negate()), n.displacementMap && ((t.displacementMap.value = n.displacementMap), (t.displacementScale.value = n.displacementScale), (t.displacementBias.value = n.displacementBias)), e.get(n).envMap && (t.envMapIntensity.value = n.envMapIntensity) } function d(e, t) { h(e, t), (e.reflectivity.value = t.reflectivity), (e.clearcoat.value = t.clearcoat), (e.clearcoatRoughness.value = t.clearcoatRoughness), t.sheen && e.sheen.value.copy(t.sheen), t.clearcoatMap && (e.clearcoatMap.value = t.clearcoatMap), t.clearcoatRoughnessMap && (e.clearcoatRoughnessMap.value = t.clearcoatRoughnessMap), t.clearcoatNormalMap && (e.clearcoatNormalScale.value.copy(t.clearcoatNormalScale), (e.clearcoatNormalMap.value = t.clearcoatNormalMap), t.side === v && e.clearcoatNormalScale.value.negate()), (e.transmission.value = t.transmission), t.transmissionMap && (e.transmissionMap.value = t.transmissionMap) } function p(e, t) { t.matcap && (e.matcap.value = t.matcap), t.bumpMap && ((e.bumpMap.value = t.bumpMap), (e.bumpScale.value = t.bumpScale), t.side === v && (e.bumpScale.value *= -1)), t.normalMap && ((e.normalMap.value = t.normalMap), e.normalScale.value.copy(t.normalScale), t.side === v && e.normalScale.value.negate()), t.displacementMap && ((e.displacementMap.value = t.displacementMap), (e.displacementScale.value = t.displacementScale), (e.displacementBias.value = t.displacementBias)) } function f(e, t) { t.displacementMap && ((e.displacementMap.value = t.displacementMap), (e.displacementScale.value = t.displacementScale), (e.displacementBias.value = t.displacementBias)) } function m(e, t) { t.displacementMap && ((e.displacementMap.value = t.displacementMap), (e.displacementScale.value = t.displacementScale), (e.displacementBias.value = t.displacementBias)), e.referencePosition.value.copy(t.referencePosition), (e.nearDistance.value = t.nearDistance), (e.farDistance.value = t.farDistance) } function g(e, t) { t.bumpMap && ((e.bumpMap.value = t.bumpMap), (e.bumpScale.value = t.bumpScale), t.side === v && (e.bumpScale.value *= -1)), t.normalMap && ((e.normalMap.value = t.normalMap), e.normalScale.value.copy(t.normalScale), t.side === v && e.normalScale.value.negate()), t.displacementMap && ((e.displacementMap.value = t.displacementMap), (e.displacementScale.value = t.displacementScale), (e.displacementBias.value = t.displacementBias)) } return { refreshFogUniforms: t, refreshMaterialUniforms: n } } function dl() { var e = document.createElementNS('http://www.w3.org/1999/xhtml', 'canvas') return (e.style.display = 'block'), e } function pl(e) { var t = void 0 !== (e = e || {}).canvas ? e.canvas : dl(), n = void 0 !== e.context ? e.context : null, r = void 0 !== e.alpha && e.alpha, i = void 0 === e.depth || e.depth, o = void 0 === e.stencil || e.stencil, a = void 0 !== e.antialias && e.antialias, s = void 0 === e.premultipliedAlpha || e.premultipliedAlpha, l = void 0 !== e.preserveDrawingBuffer && e.preserveDrawingBuffer, c = void 0 !== e.powerPreference ? e.powerPreference : 'default', u = void 0 !== e.failIfMajorPerformanceCaveat && e.failIfMajorPerformanceCaveat, h = null, d = null, p = [] ;(this.domElement = t), (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 = Kt), (this.physicallyCorrectLights = !1), (this.toneMapping = $), (this.toneMappingExposure = 1), (this.maxMorphTargets = 8), (this.maxMorphNormals = 4) var f = this, m = !1, v = null, g = 0, y = 0, b = null, A = null, w = -1, x = null, E = new ir(), M = new ir(), _ = null, T = t.width, S = t.height, C = 1, L = null, R = null, P = new ir(0, 0, T, S), D = new ir(0, 0, T, S), O = !1, I = new zo(), B = !1, F = !1, k = new Fr(), N = new lr(), U = { background: null, fog: null, environment: null, overrideMaterial: null, isScene: !0, } function H() { return null === b ? C : 1 } var G, z, j, V, W, q, X, Y, Q, Z, K, J, ee, te, ne, re, ie, oe, ae, se, le, ce = n function ue(e, n) { for (var r = 0; r < e.length; r++) { var i = e[r], o = t.getContext(i, n) if (null !== o) return o } return null } try { var he = { alpha: r, depth: i, stencil: o, antialias: a, premultipliedAlpha: s, preserveDrawingBuffer: l, powerPreference: c, failIfMajorPerformanceCaveat: u, } if ( (t.addEventListener('webglcontextlost', ve, !1), t.addEventListener('webglcontextrestored', ge, !1), null === ce) ) { var de = ['webgl2', 'webgl', 'experimental-webgl'] if ((!0 === f.isWebGL1Renderer && de.shift(), null === (ce = ue(de, he)))) throw ue(de) ? new Error( 'Error creating WebGL context with your selected attributes.', ) : new Error('Error creating WebGL context.') } void 0 === ce.getShaderPrecisionFormat && (ce.getShaderPrecisionFormat = function () { return { rangeMin: 1, rangeMax: 1, precision: 1 } }) } catch (Be) { throw (console.error('THREE.WebGLRenderer: ' + Be.message), Be) } function pe() { ;(G = new ta(ce)), (z = new Jo(ce, G, e)), G.init(z), (se = new nl(ce, G, z)), (j = new el(ce, G, z)).scissor(M.copy(D).multiplyScalar(C).floor()), j.viewport(E.copy(P).multiplyScalar(C).floor()), (V = new ia(ce)), (W = new ks()), (q = new tl(ce, G, j, W, z, se, V)), (X = new ea(f)), (Y = new Vo(ce, z)), (le = new Zo(ce, G, Y, z)), (Q = new na(ce, Y, V, le)), (Z = new la(ce, Q, Y, V)), (ie = new sa(ce)), (ne = new $o(W)), (K = new Fs(f, X, G, z, le, ne)), (J = new hl(W)), (ee = new Gs(W)), (te = new Ys(G, z)), (re = new Qo(f, X, j, Z, s)), (oe = new Ko(ce, G, V, z)), (ae = new ra(ce, G, V, z)), (V.programs = K.programs), (f.capabilities = z), (f.extensions = G), (f.properties = W), (f.renderLists = ee), (f.state = j), (f.info = V) } pe() var fe = 'undefined' !== typeof navigator && 'xr' in navigator ? new ul(f, ce) : new ll(f) this.xr = fe var me = new $s(f, Z, z.maxTextureSize) function ve(e) { e.preventDefault(), console.log('THREE.WebGLRenderer: Context Lost.'), (m = !0) } function ge() { console.log('THREE.WebGLRenderer: Context Restored.'), (m = !1), pe() } function ye(e) { var t = e.target t.removeEventListener('dispose', ye), be(t) } function be(e) { Ae(e), W.remove(e) } function Ae(e) { var t = W.get(e).program void 0 !== t && K.releaseProgram(t) } function we(e, t) { e.render(function (e) { f.renderBufferImmediate(e, t) }) } ;(this.shadowMap = me), (this.getContext = function () { return ce }), (this.getContextAttributes = function () { return ce.getContextAttributes() }), (this.forceContextLoss = function () { var e = G.get('WEBGL_lose_context') e && e.loseContext() }), (this.forceContextRestore = function () { var e = G.get('WEBGL_lose_context') e && e.restoreContext() }), (this.getPixelRatio = function () { return C }), (this.setPixelRatio = function (e) { void 0 !== e && ((C = e), this.setSize(T, S, !1)) }), (this.getSize = function (e) { return ( void 0 === e && (console.warn( 'WebGLRenderer: .getsize() now requires a Vector2 as an argument', ), (e = new Jn())), e.set(T, S) ) }), (this.setSize = function (e, n, r) { fe.isPresenting ? console.warn( "THREE.WebGLRenderer: Can't change size while VR device is presenting.", ) : ((T = e), (S = n), (t.width = Math.floor(e * C)), (t.height = Math.floor(n * C)), !1 !== r && ((t.style.width = e + 'px'), (t.style.height = n + 'px')), this.setViewport(0, 0, e, n)) }), (this.getDrawingBufferSize = function (e) { return ( void 0 === e && (console.warn( 'WebGLRenderer: .getdrawingBufferSize() now requires a Vector2 as an argument', ), (e = new Jn())), e.set(T * C, S * C).floor() ) }), (this.setDrawingBufferSize = function (e, n, r) { ;(T = e), (S = n), (C = r), (t.width = Math.floor(e * r)), (t.height = Math.floor(n * r)), this.setViewport(0, 0, e, n) }), (this.getCurrentViewport = function (e) { return ( void 0 === e && (console.warn( 'WebGLRenderer: .getCurrentViewport() now requires a Vector4 as an argument', ), (e = new ir())), e.copy(E) ) }), (this.getViewport = function (e) { return e.copy(P) }), (this.setViewport = function (e, t, n, r) { e.isVector4 ? P.set(e.x, e.y, e.z, e.w) : P.set(e, t, n, r), j.viewport(E.copy(P).multiplyScalar(C).floor()) }), (this.getScissor = function (e) { return e.copy(D) }), (this.setScissor = function (e, t, n, r) { e.isVector4 ? D.set(e.x, e.y, e.z, e.w) : D.set(e, t, n, r), j.scissor(M.copy(D).multiplyScalar(C).floor()) }), (this.getScissorTest = function () { return O }), (this.setScissorTest = function (e) { j.setScissorTest((O = e)) }), (this.setOpaqueSort = function (e) { L = e }), (this.setTransparentSort = function (e) { R = e }), (this.getClearColor = function (e) { return ( void 0 === e && (console.warn( 'WebGLRenderer: .getClearColor() now requires a Color as an argument', ), (e = new Li())), e.copy(re.getClearColor()) ) }), (this.setClearColor = function () { re.setClearColor.apply(re, arguments) }), (this.getClearAlpha = function () { return re.getClearAlpha() }), (this.setClearAlpha = function () { re.setClearAlpha.apply(re, arguments) }), (this.clear = function (e, t, n) { var r = 0 ;(void 0 === e || e) && (r |= 16384), (void 0 === t || t) && (r |= 256), (void 0 === n || n) && (r |= 1024), ce.clear(r) }), (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 () { t.removeEventListener('webglcontextlost', ve, !1), t.removeEventListener('webglcontextrestored', ge, !1), ee.dispose(), te.dispose(), W.dispose(), X.dispose(), Z.dispose(), le.dispose(), fe.dispose(), Me.stop() }), (this.renderBufferImmediate = function (e, t) { le.initAttributes() var n = W.get(e) e.hasPositions && !n.position && (n.position = ce.createBuffer()), e.hasNormals && !n.normal && (n.normal = ce.createBuffer()), e.hasUvs && !n.uv && (n.uv = ce.createBuffer()), e.hasColors && !n.color && (n.color = ce.createBuffer()) var r = t.getAttributes() e.hasPositions && (ce.bindBuffer(34962, n.position), ce.bufferData(34962, e.positionArray, 35048), le.enableAttribute(r.position), ce.vertexAttribPointer(r.position, 3, 5126, !1, 0, 0)), e.hasNormals && (ce.bindBuffer(34962, n.normal), ce.bufferData(34962, e.normalArray, 35048), le.enableAttribute(r.normal), ce.vertexAttribPointer(r.normal, 3, 5126, !1, 0, 0)), e.hasUvs && (ce.bindBuffer(34962, n.uv), ce.bufferData(34962, e.uvArray, 35048), le.enableAttribute(r.uv), ce.vertexAttribPointer(r.uv, 2, 5126, !1, 0, 0)), e.hasColors && (ce.bindBuffer(34962, n.color), ce.bufferData(34962, e.colorArray, 35048), le.enableAttribute(r.color), ce.vertexAttribPointer(r.color, 3, 5126, !1, 0, 0)), le.disableUnusedAttributes(), ce.drawArrays(4, 0, e.count), (e.count = 0) }), (this.renderBufferDirect = function (e, t, n, r, i, o) { null === t && (t = U) var a = i.isMesh && i.matrixWorld.determinant() < 0, s = Re(e, t, r, i) j.setMaterial(r, a) var l = n.index, c = n.attributes.position if (null === l) { if (void 0 === c || 0 === c.count) return } else if (0 === l.count) return var u, h = 1 !0 === r.wireframe && ((l = Q.getWireframeAttribute(n)), (h = 2)), (r.morphTargets || r.morphNormals) && ie.update(i, n, r, s), le.setup(i, r, s, n, l) var d = oe null !== l && ((u = Y.get(l)), (d = ae).setIndex(u)) var p = null !== l ? l.count : c.count, f = n.drawRange.start * h, m = n.drawRange.count * h, v = null !== o ? o.start * h : 0, g = null !== o ? o.count * h : 1 / 0, y = Math.max(f, v), b = Math.min(p, f + m, v + g) - 1, A = Math.max(0, b - y + 1) if (0 !== A) { if (i.isMesh) !0 === r.wireframe ? (j.setLineWidth(r.wireframeLinewidth * H()), d.setMode(1)) : d.setMode(4) else if (i.isLine) { var w = r.linewidth void 0 === w && (w = 1), j.setLineWidth(w * H()), i.isLineSegments ? d.setMode(1) : i.isLineLoop ? d.setMode(2) : d.setMode(3) } else i.isPoints ? d.setMode(0) : i.isSprite && d.setMode(4) if (i.isInstancedMesh) d.renderInstances(y, A, i.count) else if (n.isInstancedBufferGeometry) { var x = Math.min(n.instanceCount, n._maxInstanceCount) d.renderInstances(y, A, x) } else d.render(y, A) } }), (this.compile = function (e, t) { ;(d = te.get(e)).init(), e.traverseVisible(function (e) { e.isLight && e.layers.test(t.layers) && (d.pushLight(e), e.castShadow && d.pushShadow(e)) }), d.setupLights() var n = new WeakMap() e.traverse(function (t) { var r = t.material if (r) if (Array.isArray(r)) for (var i = 0; i < r.length; i++) { var o = r[i] !1 === n.has(o) && (Le(o, e, t), n.set(o)) } else !1 === n.has(r) && (Le(r, e, t), n.set(r)) }) }) var xe = null function Ee(e) { fe.isPresenting || (xe && xe(e)) } var Me = new jo() function Te(e, t, n, r) { if (!1 !== e.visible) { if (e.layers.test(t.layers)) if (e.isGroup) n = e.renderOrder else if (e.isLOD) !0 === e.autoUpdate && e.update(t) else if (e.isLight) d.pushLight(e), e.castShadow && d.pushShadow(e) else if (e.isSprite) { if (!e.frustumCulled || I.intersectsSprite(e)) { r && N.setFromMatrixPosition(e.matrixWorld).applyMatrix4(k) var i = Z.update(e), o = e.material o.visible && h.push(e, i, o, n, N.z, null) } } else if (e.isImmediateRenderObject) r && N.setFromMatrixPosition(e.matrixWorld).applyMatrix4(k), h.push(e, null, e.material, n, N.z, null) else if ( (e.isMesh || e.isLine || e.isPoints) && (e.isSkinnedMesh && e.skeleton.frame !== V.render.frame && (e.skeleton.update(), (e.skeleton.frame = V.render.frame)), !e.frustumCulled || I.intersectsObject(e)) ) { r && N.setFromMatrixPosition(e.matrixWorld).applyMatrix4(k) var a = Z.update(e), s = e.material if (Array.isArray(s)) for (var l = a.groups, c = 0, u = l.length; c < u; c++) { var p = l[c], f = s[p.materialIndex] f && f.visible && h.push(e, a, f, n, N.z, p) } else s.visible && h.push(e, a, s, n, N.z, null) } for (var m = e.children, v = 0, g = m.length; v < g; v++) Te(m[v], t, n, r) } } function Se(e, t, n) { for ( var r = !0 === t.isScene ? t.overrideMaterial : null, i = 0, o = e.length; i < o; i++ ) { var a = e[i], s = a.object, l = a.geometry, c = null === r ? a.material : r, u = a.group if (n.isArrayCamera) for (var h = n.cameras, p = 0, f = h.length; p < f; p++) { var m = h[p] s.layers.test(m.layers) && (j.viewport(E.copy(m.viewport)), d.setupLightsView(m), Ce(s, t, m, l, c, u)) } else Ce(s, t, n, l, c, u) } } function Ce(e, t, n, r, i, o) { if ( (e.onBeforeRender(f, t, n, r, i, o), e.modelViewMatrix.multiplyMatrices(n.matrixWorldInverse, e.matrixWorld), e.normalMatrix.getNormalMatrix(e.modelViewMatrix), e.isImmediateRenderObject) ) { var a = Re(n, t, i, e) j.setMaterial(i), le.reset(), we(e, a) } else f.renderBufferDirect(n, t, r, i, e, o) e.onAfterRender(f, t, n, r, i, o) } function Le(e, t, n) { !0 !== t.isScene && (t = U) var r = W.get(e), i = d.state.lights, o = d.state.shadowsArray, a = i.state.version, s = K.getParameters(e, i.state, o, t, n), l = K.getProgramCacheKey(s), c = r.program, u = !0 if ( ((r.environment = e.isMeshStandardMaterial ? t.environment : null), (r.fog = t.fog), (r.envMap = X.get(e.envMap || r.environment)), void 0 === c) ) e.addEventListener('dispose', ye) else if (c.cacheKey !== l) Ae(e) else if (r.lightsStateVersion !== a) u = !1 else { if (void 0 !== s.shaderID) return u = !1 } u && ((s.uniforms = K.getUniforms(e)), e.onBeforeCompile(s, f), (c = K.acquireProgram(s, l)), (r.program = c), (r.uniforms = s.uniforms), (r.outputEncoding = s.outputEncoding)) var h = r.uniforms ;((e.isShaderMaterial || e.isRawShaderMaterial) && !0 !== e.clipping) || ((r.numClippingPlanes = ne.numPlanes), (r.numIntersection = ne.numIntersection), (h.clippingPlanes = ne.uniform)), (r.needsLights = Ie(e)), (r.lightsStateVersion = a), r.needsLights && ((h.ambientLightColor.value = i.state.ambient), (h.lightProbe.value = i.state.probe), (h.directionalLights.value = i.state.directional), (h.directionalLightShadows.value = i.state.directionalShadow), (h.spotLights.value = i.state.spot), (h.spotLightShadows.value = i.state.spotShadow), (h.rectAreaLights.value = i.state.rectArea), (h.ltc_1.value = i.state.rectAreaLTC1), (h.ltc_2.value = i.state.rectAreaLTC2), (h.pointLights.value = i.state.point), (h.pointLightShadows.value = i.state.pointShadow), (h.hemisphereLights.value = i.state.hemi), (h.directionalShadowMap.value = i.state.directionalShadowMap), (h.directionalShadowMatrix.value = i.state.directionalShadowMatrix), (h.spotShadowMap.value = i.state.spotShadowMap), (h.spotShadowMatrix.value = i.state.spotShadowMatrix), (h.pointShadowMap.value = i.state.pointShadowMap), (h.pointShadowMatrix.value = i.state.pointShadowMatrix)) var p = r.program.getUniforms(), m = ss.seqWithValue(p.seq, h) r.uniformsList = m } function Re(e, t, n, r) { !0 !== t.isScene && (t = U), q.resetTextureUnits() var i = t.fog, o = n.isMeshStandardMaterial ? t.environment : null, a = null === b ? f.outputEncoding : b.texture.encoding, s = X.get(n.envMap || o), l = W.get(n), c = d.state.lights if (!0 === B && (!0 === F || e !== x)) { var u = e === x && n.id === w ne.setState(n, e, u) } n.version === l.__version ? (n.fog && l.fog !== i) || l.environment !== o || (l.needsLights && l.lightsStateVersion !== c.state.version) ? Le(n, t, r) : void 0 === l.numClippingPlanes || (l.numClippingPlanes === ne.numPlanes && l.numIntersection === ne.numIntersection) ? (l.outputEncoding !== a || l.envMap !== s) && Le(n, t, r) : Le(n, t, r) : (Le(n, t, r), (l.__version = n.version)) var h = !1, p = !1, m = !1, v = l.program, g = v.getUniforms(), y = l.uniforms if ( (j.useProgram(v.program) && ((h = !0), (p = !0), (m = !0)), n.id !== w && ((w = n.id), (p = !0)), h || x !== e) ) { if ( (g.setValue(ce, 'projectionMatrix', e.projectionMatrix), z.logarithmicDepthBuffer && g.setValue(ce, 'logDepthBufFC', 2 / (Math.log(e.far + 1) / Math.LN2)), x !== e && ((x = e), (p = !0), (m = !0)), n.isShaderMaterial || n.isMeshPhongMaterial || n.isMeshToonMaterial || n.isMeshStandardMaterial || n.envMap) ) { var A = g.map.cameraPosition void 0 !== A && A.setValue(ce, N.setFromMatrixPosition(e.matrixWorld)) } ;(n.isMeshPhongMaterial || n.isMeshToonMaterial || n.isMeshLambertMaterial || n.isMeshBasicMaterial || n.isMeshStandardMaterial || n.isShaderMaterial) && g.setValue(ce, 'isOrthographic', !0 === e.isOrthographicCamera), (n.isMeshPhongMaterial || n.isMeshToonMaterial || n.isMeshLambertMaterial || n.isMeshBasicMaterial || n.isMeshStandardMaterial || n.isShaderMaterial || n.isShadowMaterial || n.skinning) && g.setValue(ce, 'viewMatrix', e.matrixWorldInverse) } if (n.skinning) { g.setOptional(ce, r, 'bindMatrix'), g.setOptional(ce, r, 'bindMatrixInverse') var E = r.skeleton if (E) { var M = E.bones if (z.floatVertexTextures) { if (null === E.boneTexture) { var _ = Math.sqrt(4 * M.length) ;(_ = Kn.ceilPowerOfTwo(_)), (_ = Math.max(_, 4)) var T = new Float32Array(_ * _ * 4) T.set(E.boneMatrices) var L = new Uo(T, _, _, Ue, Pe) ;(E.boneMatrices = T), (E.boneTexture = L), (E.boneTextureSize = _) } g.setValue(ce, 'boneTexture', E.boneTexture, q), g.setValue(ce, 'boneTextureSize', E.boneTextureSize) } else g.setOptional(ce, E, 'boneMatrices') } } return ( (p || l.receiveShadow !== r.receiveShadow) && ((l.receiveShadow = r.receiveShadow), g.setValue(ce, 'receiveShadow', r.receiveShadow)), p && (g.setValue(ce, 'toneMappingExposure', f.toneMappingExposure), l.needsLights && Oe(y, m), i && n.fog && J.refreshFogUniforms(y, i), J.refreshMaterialUniforms(y, n, C, S), ss.upload(ce, l.uniformsList, y, q)), n.isShaderMaterial && !0 === n.uniformsNeedUpdate && (ss.upload(ce, l.uniformsList, y, q), (n.uniformsNeedUpdate = !1)), n.isSpriteMaterial && g.setValue(ce, 'center', r.center), g.setValue(ce, 'modelViewMatrix', r.modelViewMatrix), g.setValue(ce, 'normalMatrix', r.normalMatrix), g.setValue(ce, 'modelMatrix', r.matrixWorld), v ) } function Oe(e, t) { ;(e.ambientLightColor.needsUpdate = t), (e.lightProbe.needsUpdate = t), (e.directionalLights.needsUpdate = t), (e.directionalLightShadows.needsUpdate = t), (e.pointLights.needsUpdate = t), (e.pointLightShadows.needsUpdate = t), (e.spotLights.needsUpdate = t), (e.spotLightShadows.needsUpdate = t), (e.rectAreaLights.needsUpdate = t), (e.hemisphereLights.needsUpdate = t) } function Ie(e) { return ( e.isMeshLambertMaterial || e.isMeshToonMaterial || e.isMeshPhongMaterial || e.isMeshStandardMaterial || e.isShadowMaterial || (e.isShaderMaterial && !0 === e.lights) ) } Me.setAnimationLoop(Ee), 'undefined' !== typeof window && Me.setContext(window), (this.setAnimationLoop = function (e) { ;(xe = e), fe.setAnimationLoop(e), null === e ? Me.stop() : Me.start() }), (this.render = function (e, t) { var n, r if ( (void 0 !== arguments[2] && (console.warn( 'THREE.WebGLRenderer.render(): the renderTarget argument has been removed. Use .setRenderTarget() instead.', ), (n = arguments[2])), void 0 !== arguments[3] && (console.warn( 'THREE.WebGLRenderer.render(): the forceClear argument has been removed. Use .clear() instead.', ), (r = arguments[3])), void 0 === t || !0 === t.isCamera) ) { if (!0 !== m) { le.resetDefaultState(), (w = -1), (x = null), !0 === e.autoUpdate && e.updateMatrixWorld(), null === t.parent && t.updateMatrixWorld(), !0 === fe.enabled && !0 === fe.isPresenting && (t = fe.getCamera(t)), !0 === e.isScene && e.onBeforeRender(f, e, t, n || b), (d = te.get(e, p.length)).init(), p.push(d), k.multiplyMatrices(t.projectionMatrix, t.matrixWorldInverse), I.setFromProjectionMatrix(k), (F = this.localClippingEnabled), (B = ne.init(this.clippingPlanes, F, t)), (h = ee.get(e, t)).init(), Te(e, t, 0, f.sortObjects), h.finish(), !0 === f.sortObjects && h.sort(L, R), !0 === B && ne.beginShadows() var i = d.state.shadowsArray me.render(i, e, t), d.setupLights(), d.setupLightsView(t), !0 === B && ne.endShadows(), !0 === this.info.autoReset && this.info.reset(), void 0 !== n && this.setRenderTarget(n), re.render(h, e, t, r) var o = h.opaque, a = h.transparent o.length > 0 && Se(o, e, t), a.length > 0 && Se(a, e, t), !0 === e.isScene && e.onAfterRender(f, e, t), null !== b && (q.updateRenderTargetMipmap(b), q.updateMultisampleRenderTarget(b)), j.buffers.depth.setTest(!0), j.buffers.depth.setMask(!0), j.buffers.color.setMask(!0), j.setPolygonOffset(!1), fe.enabled && fe.submitFrame && fe.submitFrame(), p.pop(), (d = p.length > 0 ? p[p.length - 1] : null), (h = null) } } else console.error( 'THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.', ) }), (this.setTexture2D = (function () { var e = !1 return function (t, n) { t && t.isWebGLRenderTarget && (e || (console.warn( "THREE.WebGLRenderer.setTexture2D: don't use render targets as textures. Use their .texture property instead.", ), (e = !0)), (t = t.texture)), q.setTexture2D(t, n) } })()), (this.setFramebuffer = function (e) { v !== e && null === b && ce.bindFramebuffer(36160, e), (v = e) }), (this.getActiveCubeFace = function () { return g }), (this.getActiveMipmapLevel = function () { return y }), (this.getRenderList = function () { return h }), (this.setRenderList = function (e) { h = e }), (this.getRenderTarget = function () { return b }), (this.setRenderTarget = function (e, t, n) { void 0 === t && (t = 0), void 0 === n && (n = 0), (b = e), (g = t), (y = n), e && void 0 === W.get(e).__webglFramebuffer && q.setupRenderTarget(e) var r = v, i = !1 if (e) { var o = W.get(e).__webglFramebuffer e.isWebGLCubeRenderTarget ? ((r = o[t]), (i = !0)) : (r = e.isWebGLMultisampleRenderTarget ? W.get(e).__webglMultisampledFramebuffer : o), E.copy(e.viewport), M.copy(e.scissor), (_ = e.scissorTest) } else E.copy(P).multiplyScalar(C).floor(), M.copy(D).multiplyScalar(C).floor(), (_ = O) if ( (A !== r && (ce.bindFramebuffer(36160, r), (A = r)), j.viewport(E), j.scissor(M), j.setScissorTest(_), i) ) { var a = W.get(e.texture) ce.framebufferTexture2D(36160, 36064, 34069 + t, a.__webglTexture, n) } }), (this.readRenderTargetPixels = function (e, t, n, r, i, o, a) { if (e && e.isWebGLRenderTarget) { var s = W.get(e).__webglFramebuffer if ((e.isWebGLCubeRenderTarget && void 0 !== a && (s = s[a]), s)) { var l = !1 s !== A && (ce.bindFramebuffer(36160, s), (l = !0)) try { var c = e.texture, u = c.format, h = c.type if (u !== Ue && se.convert(u) !== ce.getParameter(35739)) return void console.error( 'THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format.', ) var d = h === De && (G.has('EXT_color_buffer_half_float') || (z.isWebGL2 && G.has('EXT_color_buffer_float'))) if ( h !== _e && se.convert(h) !== ce.getParameter(35738) && (h !== Pe || !( z.isWebGL2 || G.has('OES_texture_float') || G.has('WEBGL_color_buffer_float') )) && !d ) return void console.error( 'THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type.', ) 36053 === ce.checkFramebufferStatus(36160) ? t >= 0 && t <= e.width - r && n >= 0 && n <= e.height - i && ce.readPixels(t, n, r, i, se.convert(u), se.convert(h), o) : console.error( 'THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete.', ) } finally { l && ce.bindFramebuffer(36160, A) } } } else console.error( 'THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.', ) }), (this.copyFramebufferToTexture = function (e, t, n) { void 0 === n && (n = 0) var r = Math.pow(2, -n), i = Math.floor(t.image.width * r), o = Math.floor(t.image.height * r), a = se.convert(t.format) q.setTexture2D(t, 0), ce.copyTexImage2D(3553, n, a, e.x, e.y, i, o, 0), j.unbindTexture() }), (this.copyTextureToTexture = function (e, t, n, r) { void 0 === r && (r = 0) var i = t.image.width, o = t.image.height, a = se.convert(n.format), s = se.convert(n.type) q.setTexture2D(n, 0), ce.pixelStorei(37440, n.flipY), ce.pixelStorei(37441, n.premultiplyAlpha), ce.pixelStorei(3317, n.unpackAlignment), t.isDataTexture ? ce.texSubImage2D(3553, r, e.x, e.y, i, o, a, s, t.image.data) : t.isCompressedTexture ? ce.compressedTexSubImage2D( 3553, r, e.x, e.y, t.mipmaps[0].width, t.mipmaps[0].height, a, t.mipmaps[0].data, ) : ce.texSubImage2D(3553, r, e.x, e.y, a, s, t.image), 0 === r && n.generateMipmaps && ce.generateMipmap(3553), j.unbindTexture() }), (this.initTexture = function (e) { q.setTexture2D(e, 0), j.unbindTexture() }), (this.resetState = function () { j.reset(), le.reset() }), 'undefined' !== typeof __THREE_DEVTOOLS__ && __THREE_DEVTOOLS__.dispatchEvent( new CustomEvent('observe', { detail: this }), ) } function fl(e) { pl.call(this, e) } Object.assign(ll.prototype, qn.prototype), Object.assign(cl.prototype, { constructor: cl, getHandSpace: function () { return ( null === this._hand && ((this._hand = new rl()), (this._hand.matrixAutoUpdate = !1), (this._hand.visible = !1), (this._hand.joints = {}), (this._hand.inputState = { pinching: !1 })), this._hand ) }, getTargetRaySpace: function () { return ( null === this._targetRay && ((this._targetRay = new rl()), (this._targetRay.matrixAutoUpdate = !1), (this._targetRay.visible = !1)), this._targetRay ) }, getGripSpace: function () { return ( null === this._grip && ((this._grip = new rl()), (this._grip.matrixAutoUpdate = !1), (this._grip.visible = !1)), this._grip ) }, dispatchEvent: function (e) { return ( null !== this._targetRay && this._targetRay.dispatchEvent(e), null !== this._grip && this._grip.dispatchEvent(e), null !== this._hand && this._hand.dispatchEvent(e), this ) }, disconnect: function (e) { return ( this.dispatchEvent({ type: 'disconnected', data: e }), null !== this._targetRay && (this._targetRay.visible = !1), null !== this._grip && (this._grip.visible = !1), null !== this._hand && (this._hand.visible = !1), this ) }, update: function (e, t, n) { var r = null, i = null, o = null, a = this._targetRay, s = this._grip, l = this._hand if (e && 'visible-blurred' !== t.session.visibilityState) if (l && e.hand) { o = !0 for (var c, u = Wn(e.hand.values()); !(c = u()).done; ) { var h = c.value, d = t.getJointPose(h, n) if (void 0 === l.joints[h.jointName]) { var p = new rl() ;(p.matrixAutoUpdate = !1), (p.visible = !1), (l.joints[h.jointName] = p), l.add(p) } var f = l.joints[h.jointName] null !== d && (f.matrix.fromArray(d.transform.matrix), f.matrix.decompose(f.position, f.rotation, f.scale), (f.jointRadius = d.radius)), (f.visible = null !== d) } var m = l.joints['index-finger-tip'], v = l.joints['thumb-tip'], g = m.position.distanceTo(v.position), y = 0.02, b = 0.005 l.inputState.pinching && g > y + b ? ((l.inputState.pinching = !1), this.dispatchEvent({ type: 'pinchend', handedness: e.handedness, target: this, })) : !l.inputState.pinching && g <= y - b && ((l.inputState.pinching = !0), this.dispatchEvent({ type: 'pinchstart', handedness: e.handedness, target: this, })) } else null !== a && null !== (r = t.getPose(e.targetRaySpace, n)) && (a.matrix.fromArray(r.transform.matrix), a.matrix.decompose(a.position, a.rotation, a.scale)), null !== s && e.gripSpace && null !== (i = t.getPose(e.gripSpace, n)) && (s.matrix.fromArray(i.transform.matrix), s.matrix.decompose(s.position, s.rotation, s.scale)) return ( null !== a && (a.visible = null !== r), null !== s && (s.visible = null !== i), null !== l && (l.visible = null !== o), this ) }, }), Object.assign(ul.prototype, qn.prototype), (fl.prototype = Object.assign(Object.create(pl.prototype), { constructor: fl, isWebGL1Renderer: !0, })) var ml = (function () { function e(e, t) { Object.defineProperty(this, 'isFogExp2', { value: !0 }), (this.name = ''), (this.color = new Li(e)), (this.density = void 0 !== t ? t : 25e-5) } var t = e.prototype return ( (t.clone = function () { return new e(this.color, this.density) }), (t.toJSON = function () { return { type: 'FogExp2', color: this.color.getHex(), density: this.density, } }), e ) })(), vl = (function () { function e(e, t, n) { Object.defineProperty(this, 'isFog', { value: !0 }), (this.name = ''), (this.color = new Li(e)), (this.near = void 0 !== t ? t : 1), (this.far = void 0 !== n ? n : 1e3) } var t = e.prototype return ( (t.clone = function () { return new e(this.color, this.near, this.far) }), (t.toJSON = function () { return { type: 'Fog', color: this.color.getHex(), near: this.near, far: this.far, } }), e ) })(), gl = (function (e) { function t() { var t return ( (t = e.call(this) || this), Object.defineProperty(zn(t), 'isScene', { value: !0 }), (t.type = 'Scene'), (t.background = null), (t.environment = null), (t.fog = null), (t.overrideMaterial = null), (t.autoUpdate = !0), 'undefined' !== typeof __THREE_DEVTOOLS__ && __THREE_DEVTOOLS__.dispatchEvent( new CustomEvent('observe', { detail: zn(t) }), ), t ) } Gn(t, e) var n = t.prototype return ( (n.copy = function (t, n) { return ( e.prototype.copy.call(this, t, n), null !== t.background && (this.background = t.background.clone()), null !== t.environment && (this.environment = t.environment.clone()), null !== t.fog && (this.fog = t.fog.clone()), null !== t.overrideMaterial && (this.overrideMaterial = t.overrideMaterial.clone()), (this.autoUpdate = t.autoUpdate), (this.matrixAutoUpdate = t.matrixAutoUpdate), this ) }), (n.toJSON = function (t) { var n = e.prototype.toJSON.call(this, t) return ( null !== this.background && (n.object.background = this.background.toJSON(t)), null !== this.environment && (n.object.environment = this.environment.toJSON(t)), null !== this.fog && (n.object.fog = this.fog.toJSON()), n ) }), t ) })(si) function yl(e, t) { ;(this.array = e), (this.stride = t), (this.count = void 0 !== e ? e.length / t : 0), (this.usage = Tn), (this.updateRange = { offset: 0, count: -1 }), (this.version = 0), (this.uuid = Kn.generateUUID()) } Object.defineProperty(yl.prototype, 'needsUpdate', { set: function (e) { !0 === e && this.version++ }, }), Object.assign(yl.prototype, { isInterleavedBuffer: !0, onUploadCallback: function () {}, setUsage: function (e) { return (this.usage = e), this }, copy: function (e) { return ( (this.array = new e.array.constructor(e.array)), (this.count = e.count), (this.stride = e.stride), (this.usage = e.usage), this ) }, copyAt: function (e, t, n) { ;(e *= this.stride), (n *= t.stride) for (var r = 0, i = this.stride; r < i; r++) this.array[e + r] = t.array[n + r] return this }, set: function (e, t) { return void 0 === t && (t = 0), this.array.set(e, t), this }, clone: function (e) { void 0 === e.arrayBuffers && (e.arrayBuffers = {}), void 0 === this.array.buffer._uuid && (this.array.buffer._uuid = Kn.generateUUID()), void 0 === e.arrayBuffers[this.array.buffer._uuid] && (e.arrayBuffers[this.array.buffer._uuid] = this.array.slice(0).buffer) var t = new yl( new this.array.constructor(e.arrayBuffers[this.array.buffer._uuid]), this.stride, ) return t.setUsage(this.usage), t }, onUpload: function (e) { return (this.onUploadCallback = e), this }, toJSON: function (e) { return ( void 0 === e.arrayBuffers && (e.arrayBuffers = {}), void 0 === this.array.buffer._uuid && (this.array.buffer._uuid = Kn.generateUUID()), void 0 === e.arrayBuffers[this.array.buffer._uuid] && (e.arrayBuffers[this.array.buffer._uuid] = Array.prototype.slice.call( new Uint32Array(this.array.buffer), )), { uuid: this.uuid, buffer: this.array.buffer._uuid, type: this.array.constructor.name, stride: this.stride, } ) }, }) var bl, Al = new lr() function wl(e, t, n, r) { ;(this.name = ''), (this.data = e), (this.itemSize = t), (this.offset = n), (this.normalized = !0 === r) } function xl(e) { Di.call(this), (this.type = 'SpriteMaterial'), (this.color = new Li(16777215)), (this.map = null), (this.alphaMap = null), (this.rotation = 0), (this.sizeAttenuation = !0), (this.transparent = !0), this.setValues(e) } Object.defineProperties(wl.prototype, { count: { get: function () { return this.data.count }, }, array: { get: function () { return this.data.array }, }, needsUpdate: { set: function (e) { this.data.needsUpdate = e }, }, }), Object.assign(wl.prototype, { isInterleavedBufferAttribute: !0, applyMatrix4: function (e) { for (var t = 0, n = this.data.count; t < n; t++) (Al.x = this.getX(t)), (Al.y = this.getY(t)), (Al.z = this.getZ(t)), Al.applyMatrix4(e), this.setXYZ(t, Al.x, Al.y, Al.z) return this }, setX: function (e, t) { return (this.data.array[e * this.data.stride + this.offset] = t), this }, setY: function (e, t) { return (this.data.array[e * this.data.stride + this.offset + 1] = t), this }, setZ: function (e, t) { return (this.data.array[e * this.data.stride + this.offset + 2] = t), this }, setW: function (e, t) { return (this.data.array[e * this.data.stride + this.offset + 3] = t), this }, getX: function (e) { return this.data.array[e * this.data.stride + this.offset] }, getY: function (e) { return this.data.array[e * this.data.stride + this.offset + 1] }, getZ: function (e) { return this.data.array[e * this.data.stride + this.offset + 2] }, getW: function (e) { return this.data.array[e * this.data.stride + this.offset + 3] }, setXY: function (e, t, n) { return ( (e = e * this.data.stride + this.offset), (this.data.array[e + 0] = t), (this.data.array[e + 1] = n), this ) }, setXYZ: function (e, t, n, r) { return ( (e = e * this.data.stride + this.offset), (this.data.array[e + 0] = t), (this.data.array[e + 1] = n), (this.data.array[e + 2] = r), this ) }, setXYZW: function (e, t, n, r, i) { return ( (e = e * this.data.stride + this.offset), (this.data.array[e + 0] = t), (this.data.array[e + 1] = n), (this.data.array[e + 2] = r), (this.data.array[e + 3] = i), this ) }, clone: function (e) { if (void 0 === e) { console.log( 'THREE.InterleavedBufferAttribute.clone(): Cloning an interlaved buffer attribute will deinterleave buffer data.', ) for (var t = [], n = 0; n < this.count; n++) for ( var r = n * this.data.stride + this.offset, i = 0; i < this.itemSize; i++ ) t.push(this.data.array[r + i]) return new Fi( new this.array.constructor(t), this.itemSize, this.normalized, ) } return ( void 0 === e.interleavedBuffers && (e.interleavedBuffers = {}), void 0 === e.interleavedBuffers[this.data.uuid] && (e.interleavedBuffers[this.data.uuid] = this.data.clone(e)), new wl( e.interleavedBuffers[this.data.uuid], this.itemSize, this.offset, this.normalized, ) ) }, toJSON: function (e) { if (void 0 === e) { console.log( 'THREE.InterleavedBufferAttribute.toJSON(): Serializing an interlaved buffer attribute will deinterleave buffer data.', ) for (var t = [], n = 0; n < this.count; n++) for ( var r = n * this.data.stride + this.offset, i = 0; i < this.itemSize; i++ ) t.push(this.data.array[r + i]) return { itemSize: this.itemSize, type: this.array.constructor.name, array: t, normalized: this.normalized, } } return ( void 0 === e.interleavedBuffers && (e.interleavedBuffers = {}), void 0 === e.interleavedBuffers[this.data.uuid] && (e.interleavedBuffers[this.data.uuid] = this.data.toJSON(e)), { isInterleavedBufferAttribute: !0, itemSize: this.itemSize, data: this.data.uuid, offset: this.offset, normalized: this.normalized, } ) }, }), (xl.prototype = Object.create(Di.prototype)), (xl.prototype.constructor = xl), (xl.prototype.isSpriteMaterial = !0), (xl.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), this.color.copy(e.color), (this.map = e.map), (this.alphaMap = e.alphaMap), (this.rotation = e.rotation), (this.sizeAttenuation = e.sizeAttenuation), this ) }) var El = new lr(), Ml = new lr(), _l = new lr(), Tl = new Jn(), Sl = new Jn(), Cl = new Fr(), Ll = new lr(), Rl = new lr(), Pl = new lr(), Dl = new Jn(), Ol = new Jn(), Il = new Jn() function Bl(e) { if ((si.call(this), (this.type = 'Sprite'), void 0 === bl)) { bl = new ro() var t = new yl( new Float32Array([ -0.5, -0.5, 0, 0, 0, 0.5, -0.5, 0, 1, 0, 0.5, 0.5, 0, 1, 1, -0.5, 0.5, 0, 0, 1, ]), 5, ) bl.setIndex([0, 1, 2, 0, 2, 3]), bl.setAttribute('position', new wl(t, 3, 0, !1)), bl.setAttribute('uv', new wl(t, 2, 3, !1)) } ;(this.geometry = bl), (this.material = void 0 !== e ? e : new xl()), (this.center = new Jn(0.5, 0.5)) } function Fl(e, t, n, r, i, o) { Tl.subVectors(e, n).addScalar(0.5).multiply(r), void 0 !== i ? ((Sl.x = o * Tl.x - i * Tl.y), (Sl.y = i * Tl.x + o * Tl.y)) : Sl.copy(Tl), e.copy(t), (e.x += Sl.x), (e.y += Sl.y), e.applyMatrix4(Cl) } Bl.prototype = Object.assign(Object.create(si.prototype), { constructor: Bl, isSprite: !0, raycast: function (e, t) { null === e.camera && console.error( 'THREE.Sprite: "Raycaster.camera" needs to be set in order to raycast against sprites.', ), Ml.setFromMatrixScale(this.matrixWorld), Cl.copy(e.camera.matrixWorld), this.modelViewMatrix.multiplyMatrices( e.camera.matrixWorldInverse, this.matrixWorld, ), _l.setFromMatrixPosition(this.modelViewMatrix), e.camera.isPerspectiveCamera && !1 === this.material.sizeAttenuation && Ml.multiplyScalar(-_l.z) var n, r, i = this.material.rotation 0 !== i && ((r = Math.cos(i)), (n = Math.sin(i))) var o = this.center Fl(Ll.set(-0.5, -0.5, 0), _l, o, Ml, n, r), Fl(Rl.set(0.5, -0.5, 0), _l, o, Ml, n, r), Fl(Pl.set(0.5, 0.5, 0), _l, o, Ml, n, r), Dl.set(0, 0), Ol.set(1, 0), Il.set(1, 1) var a = e.ray.intersectTriangle(Ll, Rl, Pl, !1, El) if ( null !== a || (Fl(Rl.set(-0.5, 0.5, 0), _l, o, Ml, n, r), Ol.set(0, 1), null !== (a = e.ray.intersectTriangle(Ll, Pl, Rl, !1, El))) ) { var s = e.ray.origin.distanceTo(El) s < e.near || s > e.far || t.push({ distance: s, point: El.clone(), uv: xi.getUV(El, Ll, Rl, Pl, Dl, Ol, Il, new Jn()), face: null, object: this, }) } }, copy: function (e) { return ( si.prototype.copy.call(this, e), void 0 !== e.center && this.center.copy(e.center), (this.material = e.material), this ) }, }) var kl = new lr(), Nl = new lr() function Ul() { si.call(this), (this._currentLevel = 0), (this.type = 'LOD'), Object.defineProperties(this, { levels: { enumerable: !0, value: [] } }), (this.autoUpdate = !0) } Ul.prototype = Object.assign(Object.create(si.prototype), { constructor: Ul, isLOD: !0, copy: function (e) { si.prototype.copy.call(this, e, !1) for (var t = e.levels, n = 0, r = t.length; n < r; n++) { var i = t[n] this.addLevel(i.object.clone(), i.distance) } return (this.autoUpdate = e.autoUpdate), this }, addLevel: function (e, t) { void 0 === t && (t = 0), (t = Math.abs(t)) var n, r = this.levels for (n = 0; n < r.length && !(t < r[n].distance); n++); return r.splice(n, 0, { distance: t, object: e }), this.add(e), this }, getCurrentLevel: function () { return this._currentLevel }, getObjectForDistance: function (e) { var t = this.levels if (t.length > 0) { var n, r for (n = 1, r = t.length; n < r && !(e < t[n].distance); n++); return t[n - 1].object } return null }, raycast: function (e, t) { if (this.levels.length > 0) { kl.setFromMatrixPosition(this.matrixWorld) var n = e.ray.origin.distanceTo(kl) this.getObjectForDistance(n).raycast(e, t) } }, update: function (e) { var t = this.levels if (t.length > 1) { kl.setFromMatrixPosition(e.matrixWorld), Nl.setFromMatrixPosition(this.matrixWorld) var n, r, i = kl.distanceTo(Nl) / e.zoom for ( t[0].object.visible = !0, n = 1, r = t.length; n < r && i >= t[n].distance; n++ ) (t[n - 1].object.visible = !1), (t[n].object.visible = !0) for (this._currentLevel = n - 1; n < r; n++) t[n].object.visible = !1 } }, toJSON: function (e) { var t = si.prototype.toJSON.call(this, e) !1 === this.autoUpdate && (t.object.autoUpdate = !1), (t.object.levels = []) for (var n = this.levels, r = 0, i = n.length; r < i; r++) { var o = n[r] t.object.levels.push({ object: o.object.uuid, distance: o.distance }) } return t }, }) var Hl = new lr(), Gl = new ir(), zl = new ir(), jl = new lr(), Vl = new Fr() function Wl(e, t) { e && e.isGeometry && console.error( 'THREE.SkinnedMesh no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.', ), xo.call(this, e, t), (this.type = 'SkinnedMesh'), (this.bindMode = 'attached'), (this.bindMatrix = new Fr()), (this.bindMatrixInverse = new Fr()) } function ql() { si.call(this), (this.type = 'Bone') } ;(Wl.prototype = Object.assign(Object.create(xo.prototype), { constructor: Wl, isSkinnedMesh: !0, copy: function (e) { return ( xo.prototype.copy.call(this, e), (this.bindMode = e.bindMode), this.bindMatrix.copy(e.bindMatrix), this.bindMatrixInverse.copy(e.bindMatrixInverse), (this.skeleton = e.skeleton), this ) }, bind: function (e, t) { ;(this.skeleton = e), void 0 === t && (this.updateMatrixWorld(!0), this.skeleton.calculateInverses(), (t = this.matrixWorld)), this.bindMatrix.copy(t), this.bindMatrixInverse.copy(t).invert() }, pose: function () { this.skeleton.pose() }, normalizeSkinWeights: function () { for ( var e = new ir(), t = this.geometry.attributes.skinWeight, n = 0, r = t.count; n < r; n++ ) { ;(e.x = t.getX(n)), (e.y = t.getY(n)), (e.z = t.getZ(n)), (e.w = t.getW(n)) var i = 1 / e.manhattanLength() i !== 1 / 0 ? e.multiplyScalar(i) : e.set(1, 0, 0, 0), t.setXYZW(n, e.x, e.y, e.z, e.w) } }, updateMatrixWorld: function (e) { xo.prototype.updateMatrixWorld.call(this, e), 'attached' === this.bindMode ? this.bindMatrixInverse.copy(this.matrixWorld).invert() : 'detached' === this.bindMode ? this.bindMatrixInverse.copy(this.bindMatrix).invert() : console.warn( 'THREE.SkinnedMesh: Unrecognized bindMode: ' + this.bindMode, ) }, boneTransform: function (e, t) { var n = this.skeleton, r = this.geometry Gl.fromBufferAttribute(r.attributes.skinIndex, e), zl.fromBufferAttribute(r.attributes.skinWeight, e), Hl.fromBufferAttribute(r.attributes.position, e).applyMatrix4( this.bindMatrix, ), t.set(0, 0, 0) for (var i = 0; i < 4; i++) { var o = zl.getComponent(i) if (0 !== o) { var a = Gl.getComponent(i) Vl.multiplyMatrices(n.bones[a].matrixWorld, n.boneInverses[a]), t.addScaledVector(jl.copy(Hl).applyMatrix4(Vl), o) } } return t.applyMatrix4(this.bindMatrixInverse) }, })), (ql.prototype = Object.assign(Object.create(si.prototype), { constructor: ql, isBone: !0, })) var Xl = new Fr(), Yl = new Fr() function Ql(e, t) { void 0 === e && (e = []), void 0 === t && (t = []), (this.uuid = Kn.generateUUID()), (this.bones = e.slice(0)), (this.boneInverses = t), (this.boneMatrices = null), (this.boneTexture = null), (this.boneTextureSize = 0), (this.frame = -1), this.init() } Object.assign(Ql.prototype, { init: function () { var e = this.bones, t = this.boneInverses if (((this.boneMatrices = new Float32Array(16 * e.length)), 0 === t.length)) this.calculateInverses() else if (e.length !== t.length) { console.warn( 'THREE.Skeleton: Number of inverse bone matrices does not match amount of bones.', ), (this.boneInverses = []) for (var n = 0, r = this.bones.length; n < r; n++) this.boneInverses.push(new Fr()) } }, calculateInverses: function () { this.boneInverses.length = 0 for (var e = 0, t = this.bones.length; e < t; e++) { var n = new Fr() this.bones[e] && n.copy(this.bones[e].matrixWorld).invert(), this.boneInverses.push(n) } }, pose: function () { for (var e = 0, t = this.bones.length; e < t; e++) { var n = this.bones[e] n && n.matrixWorld.copy(this.boneInverses[e]).invert() } for (var r = 0, i = this.bones.length; r < i; r++) { var o = this.bones[r] o && (o.parent && o.parent.isBone ? (o.matrix.copy(o.parent.matrixWorld).invert(), o.matrix.multiply(o.matrixWorld)) : o.matrix.copy(o.matrixWorld), o.matrix.decompose(o.position, o.quaternion, o.scale)) } }, update: function () { for ( var e = this.bones, t = this.boneInverses, n = this.boneMatrices, r = this.boneTexture, i = 0, o = e.length; i < o; i++ ) { var a = e[i] ? e[i].matrixWorld : Yl Xl.multiplyMatrices(a, t[i]), Xl.toArray(n, 16 * i) } null !== r && (r.needsUpdate = !0) }, clone: function () { return new Ql(this.bones, this.boneInverses) }, getBoneByName: function (e) { for (var t = 0, n = this.bones.length; t < n; t++) { var r = this.bones[t] if (r.name === e) return r } }, dispose: function () { null !== this.boneTexture && (this.boneTexture.dispose(), (this.boneTexture = null)) }, fromJSON: function (e, t) { this.uuid = e.uuid for (var n = 0, r = e.bones.length; n < r; n++) { var i = e.bones[n], o = t[i] void 0 === o && (console.warn('THREE.Skeleton: No bone found with UUID:', i), (o = new ql())), this.bones.push(o), this.boneInverses.push(new Fr().fromArray(e.boneInverses[n])) } return this.init(), this }, toJSON: function () { var e = { metadata: { version: 4.5, type: 'Skeleton', generator: 'Skeleton.toJSON', }, bones: [], boneInverses: [], } e.uuid = this.uuid for ( var t = this.bones, n = this.boneInverses, r = 0, i = t.length; r < i; r++ ) { var o = t[r] e.bones.push(o.uuid) var a = n[r] e.boneInverses.push(a.toArray()) } return e }, }) var Zl = new Fr(), Kl = new Fr(), Jl = [], $l = new xo() function ec(e, t, n) { xo.call(this, e, t), (this.instanceMatrix = new Fi(new Float32Array(16 * n), 16)), (this.instanceColor = null), (this.count = n), (this.frustumCulled = !1) } function tc(e) { Di.call(this), (this.type = 'LineBasicMaterial'), (this.color = new Li(16777215)), (this.linewidth = 1), (this.linecap = 'round'), (this.linejoin = 'round'), (this.morphTargets = !1), this.setValues(e) } ;(ec.prototype = Object.assign(Object.create(xo.prototype), { constructor: ec, isInstancedMesh: !0, copy: function (e) { return ( xo.prototype.copy.call(this, e), this.instanceMatrix.copy(e.instanceMatrix), null !== e.instanceColor && (this.instanceColor = e.instanceColor.clone()), (this.count = e.count), this ) }, getColorAt: function (e, t) { t.fromArray(this.instanceColor.array, 3 * e) }, getMatrixAt: function (e, t) { t.fromArray(this.instanceMatrix.array, 16 * e) }, raycast: function (e, t) { var n = this.matrixWorld, r = this.count if ( (($l.geometry = this.geometry), ($l.material = this.material), void 0 !== $l.material) ) for (var i = 0; i < r; i++) { this.getMatrixAt(i, Zl), Kl.multiplyMatrices(n, Zl), ($l.matrixWorld = Kl), $l.raycast(e, Jl) for (var o = 0, a = Jl.length; o < a; o++) { var s = Jl[o] ;(s.instanceId = i), (s.object = this), t.push(s) } Jl.length = 0 } }, setColorAt: function (e, t) { null === this.instanceColor && (this.instanceColor = new Fi(new Float32Array(3 * this.count), 3)), t.toArray(this.instanceColor.array, 3 * e) }, setMatrixAt: function (e, t) { t.toArray(this.instanceMatrix.array, 16 * e) }, updateMorphTargets: function () {}, dispose: function () { this.dispatchEvent({ type: 'dispose' }) }, })), (tc.prototype = Object.create(Di.prototype)), (tc.prototype.constructor = tc), (tc.prototype.isLineBasicMaterial = !0), (tc.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), this.color.copy(e.color), (this.linewidth = e.linewidth), (this.linecap = e.linecap), (this.linejoin = e.linejoin), (this.morphTargets = e.morphTargets), this ) }) var nc = new lr(), rc = new lr(), ic = new Fr(), oc = new Br(), ac = new Sr() function sc(e, t) { void 0 === e && (e = new ro()), void 0 === t && (t = new tc()), si.call(this), (this.type = 'Line'), (this.geometry = e), (this.material = t), this.updateMorphTargets() } sc.prototype = Object.assign(Object.create(si.prototype), { constructor: sc, isLine: !0, copy: function (e) { return ( si.prototype.copy.call(this, e), (this.material = e.material), (this.geometry = e.geometry), this ) }, computeLineDistances: function () { var e = this.geometry if (e.isBufferGeometry) if (null === e.index) { for ( var t = e.attributes.position, n = [0], r = 1, i = t.count; r < i; r++ ) nc.fromBufferAttribute(t, r - 1), rc.fromBufferAttribute(t, r), (n[r] = n[r - 1]), (n[r] += nc.distanceTo(rc)) e.setAttribute('lineDistance', new Wi(n, 1)) } else console.warn( 'THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.', ) else e.isGeometry && console.error( 'THREE.Line.computeLineDistances() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.', ) return this }, raycast: function (e, t) { var n = this.geometry, r = this.matrixWorld, i = e.params.Line.threshold if ( (null === n.boundingSphere && n.computeBoundingSphere(), ac.copy(n.boundingSphere), ac.applyMatrix4(r), (ac.radius += i), !1 !== e.ray.intersectsSphere(ac)) ) { ic.copy(r).invert(), oc.copy(e.ray).applyMatrix4(ic) var o = i / ((this.scale.x + this.scale.y + this.scale.z) / 3), a = o * o, s = new lr(), l = new lr(), c = new lr(), u = new lr(), h = this.isLineSegments ? 2 : 1 if (n.isBufferGeometry) { var d = n.index, p = n.attributes.position if (null !== d) for (var f = d.array, m = 0, v = f.length - 1; m < v; m += h) { var g = f[m], y = f[m + 1] if ( (s.fromBufferAttribute(p, g), l.fromBufferAttribute(p, y), !(oc.distanceSqToSegment(s, l, u, c) > a)) ) { u.applyMatrix4(this.matrixWorld) var b = e.ray.origin.distanceTo(u) b < e.near || b > e.far || t.push({ distance: b, point: c.clone().applyMatrix4(this.matrixWorld), index: m, face: null, faceIndex: null, object: this, }) } } else for (var A = 0, w = p.count - 1; A < w; A += h) if ( (s.fromBufferAttribute(p, A), l.fromBufferAttribute(p, A + 1), !(oc.distanceSqToSegment(s, l, u, c) > a)) ) { u.applyMatrix4(this.matrixWorld) var x = e.ray.origin.distanceTo(u) x < e.near || x > e.far || t.push({ distance: x, point: c.clone().applyMatrix4(this.matrixWorld), index: A, face: null, faceIndex: null, object: this, }) } } else n.isGeometry && console.error( 'THREE.Line.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.', ) } }, updateMorphTargets: function () { var e = this.geometry if (e.isBufferGeometry) { var t = e.morphAttributes, n = Object.keys(t) if (n.length > 0) { var r = t[n[0]] if (void 0 !== r) { ;(this.morphTargetInfluences = []), (this.morphTargetDictionary = {}) for (var i = 0, o = r.length; i < o; i++) { var a = r[i].name || String(i) this.morphTargetInfluences.push(0), (this.morphTargetDictionary[a] = i) } } } } else { var s = e.morphTargets void 0 !== s && s.length > 0 && console.error( 'THREE.Line.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead.', ) } }, }) var lc = new lr(), cc = new lr() function uc(e, t) { sc.call(this, e, t), (this.type = 'LineSegments') } function hc(e, t) { sc.call(this, e, t), (this.type = 'LineLoop') } function dc(e) { Di.call(this), (this.type = 'PointsMaterial'), (this.color = new Li(16777215)), (this.map = null), (this.alphaMap = null), (this.size = 1), (this.sizeAttenuation = !0), (this.morphTargets = !1), this.setValues(e) } ;(uc.prototype = Object.assign(Object.create(sc.prototype), { constructor: uc, isLineSegments: !0, computeLineDistances: function () { var e = this.geometry if (e.isBufferGeometry) if (null === e.index) { for ( var t = e.attributes.position, n = [], r = 0, i = t.count; r < i; r += 2 ) lc.fromBufferAttribute(t, r), cc.fromBufferAttribute(t, r + 1), (n[r] = 0 === r ? 0 : n[r - 1]), (n[r + 1] = n[r] + lc.distanceTo(cc)) e.setAttribute('lineDistance', new Wi(n, 1)) } else console.warn( 'THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.', ) else e.isGeometry && console.error( 'THREE.LineSegments.computeLineDistances() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.', ) return this }, })), (hc.prototype = Object.assign(Object.create(sc.prototype), { constructor: hc, isLineLoop: !0, })), (dc.prototype = Object.create(Di.prototype)), (dc.prototype.constructor = dc), (dc.prototype.isPointsMaterial = !0), (dc.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), this.color.copy(e.color), (this.map = e.map), (this.alphaMap = e.alphaMap), (this.size = e.size), (this.sizeAttenuation = e.sizeAttenuation), (this.morphTargets = e.morphTargets), this ) }) var pc = new Fr(), fc = new Br(), mc = new Sr(), vc = new lr() function gc(e, t) { void 0 === e && (e = new ro()), void 0 === t && (t = new dc()), si.call(this), (this.type = 'Points'), (this.geometry = e), (this.material = t), this.updateMorphTargets() } function yc(e, t, n, r, i, o, a) { var s = fc.distanceSqToPoint(e) if (s < n) { var l = new lr() fc.closestPointToPoint(e, l), l.applyMatrix4(r) var c = i.ray.origin.distanceTo(l) if (c < i.near || c > i.far) return o.push({ distance: c, distanceToRay: Math.sqrt(s), point: l, index: t, face: null, object: a, }) } } function bc(e, t, n, r, i, o, a, s, l) { nr.call(this, e, t, n, r, i, o, a, s, l), (this.format = void 0 !== a ? a : Ne), (this.minFilter = void 0 !== o ? o : Ae), (this.magFilter = void 0 !== i ? i : Ae), (this.generateMipmaps = !1) var c = this function u() { ;(c.needsUpdate = !0), e.requestVideoFrameCallback(u) } 'requestVideoFrameCallback' in e && e.requestVideoFrameCallback(u) } function Ac(e, t, n, r, i, o, a, s, l, c, u, h) { nr.call(this, null, o, a, s, l, c, r, i, u, h), (this.image = { width: t, height: n }), (this.mipmaps = e), (this.flipY = !1), (this.generateMipmaps = !1) } function wc(e, t, n, r, i, o, a, s, l) { nr.call(this, e, t, n, r, i, o, a, s, l), (this.needsUpdate = !0) } function xc(e, t, n, r, i, o, a, s, l, c) { if ((c = void 0 !== c ? c : je) !== je && c !== Ve) throw new Error( 'DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat', ) void 0 === n && c === je && (n = Ce), void 0 === n && c === Ve && (n = Fe), nr.call(this, null, r, i, o, a, s, c, n, l), (this.image = { width: e, height: t }), (this.magFilter = void 0 !== a ? a : me), (this.minFilter = void 0 !== s ? s : me), (this.flipY = !1), (this.generateMipmaps = !1) } ;(gc.prototype = Object.assign(Object.create(si.prototype), { constructor: gc, isPoints: !0, copy: function (e) { return ( si.prototype.copy.call(this, e), (this.material = e.material), (this.geometry = e.geometry), this ) }, raycast: function (e, t) { var n = this.geometry, r = this.matrixWorld, i = e.params.Points.threshold if ( (null === n.boundingSphere && n.computeBoundingSphere(), mc.copy(n.boundingSphere), mc.applyMatrix4(r), (mc.radius += i), !1 !== e.ray.intersectsSphere(mc)) ) { pc.copy(r).invert(), fc.copy(e.ray).applyMatrix4(pc) var o = i / ((this.scale.x + this.scale.y + this.scale.z) / 3), a = o * o if (n.isBufferGeometry) { var s = n.index, l = n.attributes.position if (null !== s) for (var c = s.array, u = 0, h = c.length; u < h; u++) { var d = c[u] vc.fromBufferAttribute(l, d), yc(vc, d, a, r, e, t, this) } else for (var p = 0, f = l.count; p < f; p++) vc.fromBufferAttribute(l, p), yc(vc, p, a, r, e, t, this) } else console.error( 'THREE.Points.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.', ) } }, updateMorphTargets: function () { var e = this.geometry if (e.isBufferGeometry) { var t = e.morphAttributes, n = Object.keys(t) if (n.length > 0) { var r = t[n[0]] if (void 0 !== r) { ;(this.morphTargetInfluences = []), (this.morphTargetDictionary = {}) for (var i = 0, o = r.length; i < o; i++) { var a = r[i].name || String(i) this.morphTargetInfluences.push(0), (this.morphTargetDictionary[a] = i) } } } } else { var s = e.morphTargets void 0 !== s && s.length > 0 && console.error( 'THREE.Points.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead.', ) } }, })), (bc.prototype = Object.assign(Object.create(nr.prototype), { constructor: bc, clone: function () { return new this.constructor(this.image).copy(this) }, isVideoTexture: !0, update: function () { var e = this.image !1 === 'requestVideoFrameCallback' in e && e.readyState >= e.HAVE_CURRENT_DATA && (this.needsUpdate = !0) }, })), (Ac.prototype = Object.create(nr.prototype)), (Ac.prototype.constructor = Ac), (Ac.prototype.isCompressedTexture = !0), (wc.prototype = Object.create(nr.prototype)), (wc.prototype.constructor = wc), (wc.prototype.isCanvasTexture = !0), (xc.prototype = Object.create(nr.prototype)), (xc.prototype.constructor = xc), (xc.prototype.isDepthTexture = !0) var Ec = (function (e) { function t(t, n, r, i) { var o void 0 === t && (t = 1), void 0 === n && (n = 8), void 0 === r && (r = 0), void 0 === i && (i = 2 * Math.PI), ((o = e.call(this) || this).type = 'CircleGeometry'), (o.parameters = { radius: t, segments: n, thetaStart: r, thetaLength: i, }), (n = Math.max(3, n)) var a = [], s = [], l = [], c = [], u = new lr(), h = new Jn() s.push(0, 0, 0), l.push(0, 0, 1), c.push(0.5, 0.5) for (var d = 0, p = 3; d <= n; d++, p += 3) { var f = r + (d / n) * i ;(u.x = t * Math.cos(f)), (u.y = t * Math.sin(f)), s.push(u.x, u.y, u.z), l.push(0, 0, 1), (h.x = (s[p] / t + 1) / 2), (h.y = (s[p + 1] / t + 1) / 2), c.push(h.x, h.y) } for (var m = 1; m <= n; m++) a.push(m, m + 1, 0) return ( o.setIndex(a), o.setAttribute('position', new Wi(s, 3)), o.setAttribute('normal', new Wi(l, 3)), o.setAttribute('uv', new Wi(c, 2)), o ) } return Gn(t, e), t })(ro), Mc = (function (e) { function t(t, n, r, i, o, a, s, l) { var c void 0 === t && (t = 1), void 0 === n && (n = 1), void 0 === r && (r = 1), void 0 === i && (i = 8), void 0 === o && (o = 1), void 0 === a && (a = !1), void 0 === s && (s = 0), void 0 === l && (l = 2 * Math.PI), ((c = e.call(this) || this).type = 'CylinderGeometry'), (c.parameters = { radiusTop: t, radiusBottom: n, height: r, radialSegments: i, heightSegments: o, openEnded: a, thetaStart: s, thetaLength: l, }) var u = zn(c) ;(i = Math.floor(i)), (o = Math.floor(o)) var h = [], d = [], p = [], f = [], m = 0, v = [], g = r / 2, y = 0 function b() { for ( var e = new lr(), a = new lr(), c = 0, b = (n - t) / r, A = 0; A <= o; A++ ) { for (var w = [], x = A / o, E = x * (n - t) + t, M = 0; M <= i; M++) { var _ = M / i, T = _ * l + s, S = Math.sin(T), C = Math.cos(T) ;(a.x = E * S), (a.y = -x * r + g), (a.z = E * C), d.push(a.x, a.y, a.z), e.set(S, b, C).normalize(), p.push(e.x, e.y, e.z), f.push(_, 1 - x), w.push(m++) } v.push(w) } for (var L = 0; L < i; L++) for (var R = 0; R < o; R++) { var P = v[R][L], D = v[R + 1][L], O = v[R + 1][L + 1], I = v[R][L + 1] h.push(P, D, I), h.push(D, O, I), (c += 6) } u.addGroup(y, c, 0), (y += c) } function A(e) { for ( var r = m, o = new Jn(), a = new lr(), c = 0, v = !0 === e ? t : n, b = !0 === e ? 1 : -1, A = 1; A <= i; A++ ) d.push(0, g * b, 0), p.push(0, b, 0), f.push(0.5, 0.5), m++ for (var w = m, x = 0; x <= i; x++) { var E = (x / i) * l + s, M = Math.cos(E), _ = Math.sin(E) ;(a.x = v * _), (a.y = g * b), (a.z = v * M), d.push(a.x, a.y, a.z), p.push(0, b, 0), (o.x = 0.5 * M + 0.5), (o.y = 0.5 * _ * b + 0.5), f.push(o.x, o.y), m++ } for (var T = 0; T < i; T++) { var S = r + T, C = w + T !0 === e ? h.push(C, C + 1, S) : h.push(C + 1, C, S), (c += 3) } u.addGroup(y, c, !0 === e ? 1 : 2), (y += c) } return ( b(), !1 === a && (t > 0 && A(!0), n > 0 && A(!1)), c.setIndex(h), c.setAttribute('position', new Wi(d, 3)), c.setAttribute('normal', new Wi(p, 3)), c.setAttribute('uv', new Wi(f, 2)), c ) } return Gn(t, e), t })(ro), _c = (function (e) { function t(t, n, r, i, o, a, s) { var l return ( void 0 === t && (t = 1), void 0 === n && (n = 1), void 0 === r && (r = 8), void 0 === i && (i = 1), void 0 === o && (o = !1), void 0 === a && (a = 0), void 0 === s && (s = 2 * Math.PI), ((l = e.call(this, 0, t, n, r, i, o, a, s) || this).type = 'ConeGeometry'), (l.parameters = { radius: t, height: n, radialSegments: r, heightSegments: i, openEnded: o, thetaStart: a, thetaLength: s, }), l ) } return Gn(t, e), t })(Mc), Tc = (function (e) { function t(t, n, r, i) { var o void 0 === r && (r = 1), void 0 === i && (i = 0), ((o = e.call(this) || this).type = 'PolyhedronGeometry'), (o.parameters = { vertices: t, indices: n, radius: r, detail: i }) var a = [], s = [] function l(e) { for ( var t = new lr(), r = new lr(), i = new lr(), o = 0; o < n.length; o += 3 ) f(n[o + 0], t), f(n[o + 1], r), f(n[o + 2], i), c(t, r, i, e) } function c(e, t, n, r) { for (var i = r + 1, o = [], a = 0; a <= i; a++) { o[a] = [] for ( var s = e.clone().lerp(n, a / i), l = t.clone().lerp(n, a / i), c = i - a, u = 0; u <= c; u++ ) o[a][u] = 0 === u && a === i ? s : s.clone().lerp(l, u / c) } for (var h = 0; h < i; h++) for (var d = 0; d < 2 * (i - h) - 1; d++) { var f = Math.floor(d / 2) d % 2 === 0 ? (p(o[h][f + 1]), p(o[h + 1][f]), p(o[h][f])) : (p(o[h][f + 1]), p(o[h + 1][f + 1]), p(o[h + 1][f])) } } function u(e) { for (var t = new lr(), n = 0; n < a.length; n += 3) (t.x = a[n + 0]), (t.y = a[n + 1]), (t.z = a[n + 2]), t.normalize().multiplyScalar(e), (a[n + 0] = t.x), (a[n + 1] = t.y), (a[n + 2] = t.z) } function h() { for (var e = new lr(), t = 0; t < a.length; t += 3) { ;(e.x = a[t + 0]), (e.y = a[t + 1]), (e.z = a[t + 2]) var n = g(e) / 2 / Math.PI + 0.5, r = y(e) / Math.PI + 0.5 s.push(n, 1 - r) } m(), d() } function d() { for (var e = 0; e < s.length; e += 6) { var t = s[e + 0], n = s[e + 2], r = s[e + 4], i = Math.max(t, n, r), o = Math.min(t, n, r) i > 0.9 && o < 0.1 && (t < 0.2 && (s[e + 0] += 1), n < 0.2 && (s[e + 2] += 1), r < 0.2 && (s[e + 4] += 1)) } } function p(e) { a.push(e.x, e.y, e.z) } function f(e, n) { var r = 3 * e ;(n.x = t[r + 0]), (n.y = t[r + 1]), (n.z = t[r + 2]) } function m() { for ( var e = new lr(), t = new lr(), n = new lr(), r = new lr(), i = new Jn(), o = new Jn(), l = new Jn(), c = 0, u = 0; c < a.length; c += 9, u += 6 ) { e.set(a[c + 0], a[c + 1], a[c + 2]), t.set(a[c + 3], a[c + 4], a[c + 5]), n.set(a[c + 6], a[c + 7], a[c + 8]), i.set(s[u + 0], s[u + 1]), o.set(s[u + 2], s[u + 3]), l.set(s[u + 4], s[u + 5]), r.copy(e).add(t).add(n).divideScalar(3) var h = g(r) v(i, u + 0, e, h), v(o, u + 2, t, h), v(l, u + 4, n, h) } } function v(e, t, n, r) { r < 0 && 1 === e.x && (s[t] = e.x - 1), 0 === n.x && 0 === n.z && (s[t] = r / 2 / Math.PI + 0.5) } function g(e) { return Math.atan2(e.z, -e.x) } function y(e) { return Math.atan2(-e.y, Math.sqrt(e.x * e.x + e.z * e.z)) } return ( l(i), u(r), h(), o.setAttribute('position', new Wi(a, 3)), o.setAttribute('normal', new Wi(a.slice(), 3)), o.setAttribute('uv', new Wi(s, 2)), 0 === i ? o.computeVertexNormals() : o.normalizeNormals(), o ) } return Gn(t, e), t })(ro), Sc = (function (e) { function t(t, n) { var r void 0 === t && (t = 1), void 0 === n && (n = 0) var i = (1 + Math.sqrt(5)) / 2, o = 1 / i, a = [ -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, -o, -i, 0, -o, i, 0, o, -i, 0, o, i, -o, -i, 0, -o, i, 0, o, -i, 0, o, i, 0, -i, 0, -o, i, 0, -o, -i, 0, o, i, 0, o, ], s = [ 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, ] return ( ((r = e.call(this, a, s, t, n) || this).type = 'DodecahedronGeometry'), (r.parameters = { radius: t, detail: n }), r ) } return Gn(t, e), t })(Tc), Cc = new lr(), Lc = new lr(), Rc = new lr(), Pc = new xi(), Dc = (function (e) { function t(t, n) { var r if ( (((r = e.call(this) || this).type = 'EdgesGeometry'), (r.parameters = { thresholdAngle: n }), (n = void 0 !== n ? n : 1), !0 === t.isGeometry) ) return ( console.error( 'THREE.EdgesGeometry no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.', ), zn(r) ) for ( var i = 4, o = Math.pow(10, i), a = Math.cos(Kn.DEG2RAD * n), s = t.getIndex(), l = t.getAttribute('position'), c = s ? s.count : l.count, u = [0, 0, 0], h = ['a', 'b', 'c'], d = new Array(3), p = {}, f = [], m = 0; m < c; m += 3 ) { s ? ((u[0] = s.getX(m)), (u[1] = s.getX(m + 1)), (u[2] = s.getX(m + 2))) : ((u[0] = m), (u[1] = m + 1), (u[2] = m + 2)) var v = Pc.a, g = Pc.b, y = Pc.c if ( (v.fromBufferAttribute(l, u[0]), g.fromBufferAttribute(l, u[1]), y.fromBufferAttribute(l, u[2]), Pc.getNormal(Rc), (d[0] = Math.round(v.x * o) + ',' + Math.round(v.y * o) + ',' + Math.round(v.z * o)), (d[1] = Math.round(g.x * o) + ',' + Math.round(g.y * o) + ',' + Math.round(g.z * o)), (d[2] = Math.round(y.x * o) + ',' + Math.round(y.y * o) + ',' + Math.round(y.z * o)), d[0] !== d[1] && d[1] !== d[2] && d[2] !== d[0]) ) for (var b = 0; b < 3; b++) { var A = (b + 1) % 3, w = d[b], x = d[A], E = Pc[h[b]], M = Pc[h[A]], _ = w + '_' + x, T = x + '_' + w T in p && p[T] ? (Rc.dot(p[T].normal) <= a && (f.push(E.x, E.y, E.z), f.push(M.x, M.y, M.z)), (p[T] = null)) : _ in p || (p[_] = { index0: u[b], index1: u[A], normal: Rc.clone() }) } } for (var S in p) if (p[S]) { var C = p[S], L = C.index0, R = C.index1 Cc.fromBufferAttribute(l, L), Lc.fromBufferAttribute(l, R), f.push(Cc.x, Cc.y, Cc.z), f.push(Lc.x, Lc.y, Lc.z) } return r.setAttribute('position', new Wi(f, 3)), r } return Gn(t, e), t })(ro), Oc = { triangulate: function (e, t, n) { n = n || 2 var r, i, o, a, s, l, c, u = t && t.length, h = u ? t[0] * n : e.length, d = Ic(e, 0, h, n, !0), p = [] if (!d || d.next === d.prev) return p if ((u && (d = Gc(e, t, d, n)), e.length > 80 * n)) { ;(r = o = e[0]), (i = a = e[1]) for (var f = n; f < h; f += n) (s = e[f]) < r && (r = s), (l = e[f + 1]) < i && (i = l), s > o && (o = s), l > a && (a = l) c = 0 !== (c = Math.max(o - r, a - i)) ? 1 / c : 0 } return Fc(d, p, n, r, i, c), p }, } function Ic(e, t, n, r, i) { var o, a if (i === uu(e, t, n, r) > 0) for (o = t; o < n; o += r) a = su(o, e[o], e[o + 1], a) else for (o = n - r; o >= t; o -= r) a = su(o, e[o], e[o + 1], a) return a && $c(a, a.next) && (lu(a), (a = a.next)), a } function Bc(e, t) { if (!e) return e t || (t = e) var n, r = e do { if ( ((n = !1), r.steiner || (!$c(r, r.next) && 0 !== Jc(r.prev, r, r.next))) ) r = r.next else { if ((lu(r), (r = t = r.prev) === r.next)) break n = !0 } } while (n || r !== t) return t } function Fc(e, t, n, r, i, o, a) { if (e) { !a && o && qc(e, r, i, o) for (var s, l, c = e; e.prev !== e.next; ) if (((s = e.prev), (l = e.next), o ? Nc(e, r, i, o) : kc(e))) t.push(s.i / n), t.push(e.i / n), t.push(l.i / n), lu(e), (e = l.next), (c = l.next) else if ((e = l) === c) { a ? 1 === a ? Fc((e = Uc(Bc(e), t, n)), t, n, r, i, o, 2) : 2 === a && Hc(e, t, n, r, i, o) : Fc(Bc(e), t, n, r, i, o, 1) break } } } function kc(e) { var t = e.prev, n = e, r = e.next if (Jc(t, n, r) >= 0) return !1 for (var i = e.next.next; i !== e.prev; ) { if ( Zc(t.x, t.y, n.x, n.y, r.x, r.y, i.x, i.y) && Jc(i.prev, i, i.next) >= 0 ) return !1 i = i.next } return !0 } function Nc(e, t, n, r) { var i = e.prev, o = e, a = e.next if (Jc(i, o, a) >= 0) return !1 for ( var s = i.x < o.x ? (i.x < a.x ? i.x : a.x) : o.x < a.x ? o.x : a.x, l = i.y < o.y ? (i.y < a.y ? i.y : a.y) : o.y < a.y ? o.y : a.y, c = i.x > o.x ? (i.x > a.x ? i.x : a.x) : o.x > a.x ? o.x : a.x, u = i.y > o.y ? (i.y > a.y ? i.y : a.y) : o.y > a.y ? o.y : a.y, h = Yc(s, l, t, n, r), d = Yc(c, u, t, n, r), p = e.prevZ, f = e.nextZ; p && p.z >= h && f && f.z <= d; ) { if ( p !== e.prev && p !== e.next && Zc(i.x, i.y, o.x, o.y, a.x, a.y, p.x, p.y) && Jc(p.prev, p, p.next) >= 0 ) return !1 if ( ((p = p.prevZ), f !== e.prev && f !== e.next && Zc(i.x, i.y, o.x, o.y, a.x, a.y, f.x, f.y) && Jc(f.prev, f, f.next) >= 0) ) return !1 f = f.nextZ } for (; p && p.z >= h; ) { if ( p !== e.prev && p !== e.next && Zc(i.x, i.y, o.x, o.y, a.x, a.y, p.x, p.y) && Jc(p.prev, p, p.next) >= 0 ) return !1 p = p.prevZ } for (; f && f.z <= d; ) { if ( f !== e.prev && f !== e.next && Zc(i.x, i.y, o.x, o.y, a.x, a.y, f.x, f.y) && Jc(f.prev, f, f.next) >= 0 ) return !1 f = f.nextZ } return !0 } function Uc(e, t, n) { var r = e do { var i = r.prev, o = r.next.next !$c(i, o) && eu(i, r, r.next, o) && iu(i, o) && iu(o, i) && (t.push(i.i / n), t.push(r.i / n), t.push(o.i / n), lu(r), lu(r.next), (r = e = o)), (r = r.next) } while (r !== e) return Bc(r) } function Hc(e, t, n, r, i, o) { var a = e do { for (var s = a.next.next; s !== a.prev; ) { if (a.i !== s.i && Kc(a, s)) { var l = au(a, s) return ( (a = Bc(a, a.next)), (l = Bc(l, l.next)), Fc(a, t, n, r, i, o), void Fc(l, t, n, r, i, o) ) } s = s.next } a = a.next } while (a !== e) } function Gc(e, t, n, r) { var i, o, a, s = [] for (i = 0, o = t.length; i < o; i++) (a = Ic(e, t[i] * r, i < o - 1 ? t[i + 1] * r : e.length, r, !1)) === a.next && (a.steiner = !0), s.push(Qc(a)) for (s.sort(zc), i = 0; i < s.length; i++) jc(s[i], n), (n = Bc(n, n.next)) return n } function zc(e, t) { return e.x - t.x } function jc(e, t) { if ((t = Vc(e, t))) { var n = au(t, e) Bc(t, t.next), Bc(n, n.next) } } function Vc(e, t) { var n, r = t, i = e.x, o = e.y, a = -1 / 0 do { if (o <= r.y && o >= r.next.y && r.next.y !== r.y) { var s = r.x + ((o - r.y) * (r.next.x - r.x)) / (r.next.y - r.y) if (s <= i && s > a) { if (((a = s), s === i)) { if (o === r.y) return r if (o === r.next.y) return r.next } n = r.x < r.next.x ? r : r.next } } r = r.next } while (r !== t) if (!n) return null if (i === a) return n var l, c = n, u = n.x, h = n.y, d = 1 / 0 r = n do { i >= r.x && r.x >= u && i !== r.x && Zc(o < h ? i : a, o, u, h, o < h ? a : i, o, r.x, r.y) && ((l = Math.abs(o - r.y) / (i - r.x)), iu(r, e) && (l < d || (l === d && (r.x > n.x || (r.x === n.x && Wc(n, r))))) && ((n = r), (d = l))), (r = r.next) } while (r !== c) return n } function Wc(e, t) { return Jc(e.prev, e, t.prev) < 0 && Jc(t.next, e, e.next) < 0 } function qc(e, t, n, r) { var i = e do { null === i.z && (i.z = Yc(i.x, i.y, t, n, r)), (i.prevZ = i.prev), (i.nextZ = i.next), (i = i.next) } while (i !== e) ;(i.prevZ.nextZ = null), (i.prevZ = null), Xc(i) } function Xc(e) { var t, n, r, i, o, a, s, l, c = 1 do { for (n = e, e = null, o = null, a = 0; n; ) { for (a++, r = n, s = 0, t = 0; t < c && (s++, (r = r.nextZ)); t++); for (l = c; s > 0 || (l > 0 && r); ) 0 !== s && (0 === l || !r || n.z <= r.z) ? ((i = n), (n = n.nextZ), s--) : ((i = r), (r = r.nextZ), l--), o ? (o.nextZ = i) : (e = i), (i.prevZ = o), (o = i) n = r } ;(o.nextZ = null), (c *= 2) } while (a > 1) return e } function Yc(e, t, n, r, i) { return ( (e = 1431655765 & ((e = 858993459 & ((e = 252645135 & ((e = 16711935 & ((e = 32767 * (e - n) * i) | (e << 8))) | (e << 4))) | (e << 2))) | (e << 1))) | ((t = 1431655765 & ((t = 858993459 & ((t = 252645135 & ((t = 16711935 & ((t = 32767 * (t - r) * i) | (t << 8))) | (t << 4))) | (t << 2))) | (t << 1))) << 1) ) } function Qc(e) { var t = e, n = e do { ;(t.x < n.x || (t.x === n.x && t.y < n.y)) && (n = t), (t = t.next) } while (t !== e) return n } function Zc(e, t, n, r, i, o, a, s) { return ( (i - a) * (t - s) - (e - a) * (o - s) >= 0 && (e - a) * (r - s) - (n - a) * (t - s) >= 0 && (n - a) * (o - s) - (i - a) * (r - s) >= 0 ) } function Kc(e, t) { return ( e.next.i !== t.i && e.prev.i !== t.i && !ru(e, t) && ((iu(e, t) && iu(t, e) && ou(e, t) && (Jc(e.prev, e, t.prev) || Jc(e, t.prev, t))) || ($c(e, t) && Jc(e.prev, e, e.next) > 0 && Jc(t.prev, t, t.next) > 0)) ) } function Jc(e, t, n) { return (t.y - e.y) * (n.x - t.x) - (t.x - e.x) * (n.y - t.y) } function $c(e, t) { return e.x === t.x && e.y === t.y } function eu(e, t, n, r) { var i = nu(Jc(e, t, n)), o = nu(Jc(e, t, r)), a = nu(Jc(n, r, e)), s = nu(Jc(n, r, t)) return ( (i !== o && a !== s) || !(0 !== i || !tu(e, n, t)) || !(0 !== o || !tu(e, r, t)) || !(0 !== a || !tu(n, e, r)) || !(0 !== s || !tu(n, t, r)) ) } function tu(e, t, n) { return ( t.x <= Math.max(e.x, n.x) && t.x >= Math.min(e.x, n.x) && t.y <= Math.max(e.y, n.y) && t.y >= Math.min(e.y, n.y) ) } function nu(e) { return e > 0 ? 1 : e < 0 ? -1 : 0 } function ru(e, t) { var n = e do { if ( n.i !== e.i && n.next.i !== e.i && n.i !== t.i && n.next.i !== t.i && eu(n, n.next, e, t) ) return !0 n = n.next } while (n !== e) return !1 } function iu(e, t) { return Jc(e.prev, e, e.next) < 0 ? Jc(e, t, e.next) >= 0 && Jc(e, e.prev, t) >= 0 : Jc(e, t, e.prev) < 0 || Jc(e, e.next, t) < 0 } function ou(e, t) { var n = e, r = !1, i = (e.x + t.x) / 2, o = (e.y + t.y) / 2 do { n.y > o !== n.next.y > o && n.next.y !== n.y && i < ((n.next.x - n.x) * (o - n.y)) / (n.next.y - n.y) + n.x && (r = !r), (n = n.next) } while (n !== e) return r } function au(e, t) { var n = new cu(e.i, e.x, e.y), r = new cu(t.i, t.x, t.y), i = e.next, o = t.prev return ( (e.next = t), (t.prev = e), (n.next = i), (i.prev = n), (r.next = n), (n.prev = r), (o.next = r), (r.prev = o), r ) } function su(e, t, n, r) { var i = new cu(e, t, n) return ( r ? ((i.next = r.next), (i.prev = r), (r.next.prev = i), (r.next = i)) : ((i.prev = i), (i.next = i)), i ) } function lu(e) { ;(e.next.prev = e.prev), (e.prev.next = e.next), e.prevZ && (e.prevZ.nextZ = e.nextZ), e.nextZ && (e.nextZ.prevZ = e.prevZ) } function cu(e, t, n) { ;(this.i = e), (this.x = t), (this.y = n), (this.prev = null), (this.next = null), (this.z = null), (this.prevZ = null), (this.nextZ = null), (this.steiner = !1) } function uu(e, t, n, r) { for (var i = 0, o = t, a = n - r; o < n; o += r) (i += (e[a] - e[o]) * (e[o + 1] + e[a + 1])), (a = o) return i } var hu = { area: function (e) { for (var t = e.length, n = 0, r = t - 1, i = 0; i < t; r = i++) n += e[r].x * e[i].y - e[i].x * e[r].y return 0.5 * n }, isClockWise: function (e) { return hu.area(e) < 0 }, triangulateShape: function (e, t) { var n = [], r = [], i = [] du(e), pu(n, e) var o = e.length t.forEach(du) for (var a = 0; a < t.length; a++) r.push(o), (o += t[a].length), pu(n, t[a]) for (var s = Oc.triangulate(n, r), l = 0; l < s.length; l += 3) i.push(s.slice(l, l + 3)) return i }, } function du(e) { var t = e.length t > 2 && e[t - 1].equals(e[0]) && e.pop() } function pu(e, t) { for (var n = 0; n < t.length; n++) e.push(t[n].x), e.push(t[n].y) } var fu = (function (e) { function t(t, n) { var r ;((r = e.call(this) || this).type = 'ExtrudeGeometry'), (r.parameters = { shapes: t, options: n }), (t = Array.isArray(t) ? t : [t]) for (var i = zn(r), o = [], a = [], s = 0, l = t.length; s < l; s++) c(t[s]) function c(e) { var t = [], r = void 0 !== n.curveSegments ? n.curveSegments : 12, s = void 0 !== n.steps ? n.steps : 1, l = void 0 !== n.depth ? n.depth : 100, c = void 0 === n.bevelEnabled || n.bevelEnabled, u = void 0 !== n.bevelThickness ? n.bevelThickness : 6, h = void 0 !== n.bevelSize ? n.bevelSize : u - 2, d = void 0 !== n.bevelOffset ? n.bevelOffset : 0, p = void 0 !== n.bevelSegments ? n.bevelSegments : 3, f = n.extrudePath, m = void 0 !== n.UVGenerator ? n.UVGenerator : mu void 0 !== n.amount && (console.warn( 'THREE.ExtrudeBufferGeometry: amount has been renamed to depth.', ), (l = n.amount)) var v, g, y, b, A, w = !1 f && ((v = f.getSpacedPoints(s)), (w = !0), (c = !1), (g = f.computeFrenetFrames(s, !1)), (y = new lr()), (b = new lr()), (A = new lr())), c || ((p = 0), (u = 0), (h = 0), (d = 0)) var x = e.extractPoints(r), E = x.shape, M = x.holes if (!hu.isClockWise(E)) { E = E.reverse() for (var _ = 0, T = M.length; _ < T; _++) { var S = M[_] hu.isClockWise(S) && (M[_] = S.reverse()) } } for ( var C = hu.triangulateShape(E, M), L = E, R = 0, P = M.length; R < P; R++ ) { var D = M[R] E = E.concat(D) } function O(e, t, n) { return ( t || console.error('THREE.ExtrudeGeometry: vec does not exist'), t.clone().multiplyScalar(n).add(e) ) } var I = E.length, B = C.length function F(e, t, n) { var r, i, o, a = e.x - t.x, s = e.y - t.y, l = n.x - e.x, c = n.y - e.y, u = a * a + s * s, h = a * c - s * l if (Math.abs(h) > Number.EPSILON) { var d = Math.sqrt(u), p = Math.sqrt(l * l + c * c), f = t.x - s / d, m = t.y + a / d, v = ((n.x - c / p - f) * c - (n.y + l / p - m) * l) / (a * c - s * l), g = (r = f + a * v - e.x) * r + (i = m + s * v - e.y) * i if (g <= 2) return new Jn(r, i) o = Math.sqrt(g / 2) } else { var y = !1 a > Number.EPSILON ? l > Number.EPSILON && (y = !0) : a < -Number.EPSILON ? l < -Number.EPSILON && (y = !0) : Math.sign(s) === Math.sign(c) && (y = !0), y ? ((r = -s), (i = a), (o = Math.sqrt(u))) : ((r = a), (i = s), (o = Math.sqrt(u / 2))) } return new Jn(r / o, i / o) } for ( var k = [], N = 0, U = L.length, H = U - 1, G = N + 1; N < U; N++, H++, G++ ) H === U && (H = 0), G === U && (G = 0), (k[N] = F(L[N], L[H], L[G])) for (var z, j = [], V = k.concat(), W = 0, q = M.length; W < q; W++) { var X = M[W] z = [] for ( var Y = 0, Q = X.length, Z = Q - 1, K = Y + 1; Y < Q; Y++, Z++, K++ ) Z === Q && (Z = 0), K === Q && (K = 0), (z[Y] = F(X[Y], X[Z], X[K])) j.push(z), (V = V.concat(z)) } for (var J = 0; J < p; J++) { for ( var $ = J / p, ee = u * Math.cos(($ * Math.PI) / 2), te = h * Math.sin(($ * Math.PI) / 2) + d, ne = 0, re = L.length; ne < re; ne++ ) { var ie = O(L[ne], k[ne], te) Oe(ie.x, ie.y, -ee) } for (var oe = 0, ae = M.length; oe < ae; oe++) { var se = M[oe] z = j[oe] for (var le = 0, ce = se.length; le < ce; le++) { var ue = O(se[le], z[le], te) Oe(ue.x, ue.y, -ee) } } } for (var he = h + d, de = 0; de < I; de++) { var pe = c ? O(E[de], V[de], he) : E[de] w ? (b.copy(g.normals[0]).multiplyScalar(pe.x), y.copy(g.binormals[0]).multiplyScalar(pe.y), A.copy(v[0]).add(b).add(y), Oe(A.x, A.y, A.z)) : Oe(pe.x, pe.y, 0) } for (var fe = 1; fe <= s; fe++) for (var me = 0; me < I; me++) { var ve = c ? O(E[me], V[me], he) : E[me] w ? (b.copy(g.normals[fe]).multiplyScalar(ve.x), y.copy(g.binormals[fe]).multiplyScalar(ve.y), A.copy(v[fe]).add(b).add(y), Oe(A.x, A.y, A.z)) : Oe(ve.x, ve.y, (l / s) * fe) } for (var ge = p - 1; ge >= 0; ge--) { for ( var ye = ge / p, be = u * Math.cos((ye * Math.PI) / 2), Ae = h * Math.sin((ye * Math.PI) / 2) + d, we = 0, xe = L.length; we < xe; we++ ) { var Ee = O(L[we], k[we], Ae) Oe(Ee.x, Ee.y, l + be) } for (var Me = 0, _e = M.length; Me < _e; Me++) { var Te = M[Me] z = j[Me] for (var Se = 0, Ce = Te.length; Se < Ce; Se++) { var Le = O(Te[Se], z[Se], Ae) w ? Oe(Le.x, Le.y + v[s - 1].y, v[s - 1].x + be) : Oe(Le.x, Le.y, l + be) } } } function Re() { var e = o.length / 3 if (c) { for (var t = 0, n = I * t, r = 0; r < B; r++) { var a = C[r] Ie(a[2] + n, a[1] + n, a[0] + n) } n = I * (t = s + 2 * p) for (var l = 0; l < B; l++) { var u = C[l] Ie(u[0] + n, u[1] + n, u[2] + n) } } else { for (var h = 0; h < B; h++) { var d = C[h] Ie(d[2], d[1], d[0]) } for (var f = 0; f < B; f++) { var m = C[f] Ie(m[0] + I * s, m[1] + I * s, m[2] + I * s) } } i.addGroup(e, o.length / 3 - e, 0) } function Pe() { var e = o.length / 3, t = 0 De(L, t), (t += L.length) for (var n = 0, r = M.length; n < r; n++) { var a = M[n] De(a, t), (t += a.length) } i.addGroup(e, o.length / 3 - e, 1) } function De(e, t) { for (var n = e.length; --n >= 0; ) { var r = n, i = n - 1 i < 0 && (i = e.length - 1) for (var o = 0, a = s + 2 * p; o < a; o++) { var l = I * o, c = I * (o + 1) Be(t + r + l, t + i + l, t + i + c, t + r + c) } } } function Oe(e, n, r) { t.push(e), t.push(n), t.push(r) } function Ie(e, t, n) { Fe(e), Fe(t), Fe(n) var r = o.length / 3, a = m.generateTopUV(i, o, r - 3, r - 2, r - 1) ke(a[0]), ke(a[1]), ke(a[2]) } function Be(e, t, n, r) { Fe(e), Fe(t), Fe(r), Fe(t), Fe(n), Fe(r) var a = o.length / 3, s = m.generateSideWallUV(i, o, a - 6, a - 3, a - 2, a - 1) ke(s[0]), ke(s[1]), ke(s[3]), ke(s[1]), ke(s[2]), ke(s[3]) } function Fe(e) { o.push(t[3 * e + 0]), o.push(t[3 * e + 1]), o.push(t[3 * e + 2]) } function ke(e) { a.push(e.x), a.push(e.y) } Re(), Pe() } return ( r.setAttribute('position', new Wi(o, 3)), r.setAttribute('uv', new Wi(a, 2)), r.computeVertexNormals(), r ) } return ( Gn(t, e), (t.prototype.toJSON = function () { var e = ro.prototype.toJSON.call(this) return vu(this.parameters.shapes, this.parameters.options, e) }), t ) })(ro), mu = { generateTopUV: function (e, t, n, r, i) { var o = t[3 * n], a = t[3 * n + 1], s = t[3 * r], l = t[3 * r + 1], c = t[3 * i], u = t[3 * i + 1] return [new Jn(o, a), new Jn(s, l), new Jn(c, u)] }, generateSideWallUV: function (e, t, n, r, i, o) { var a = t[3 * n], s = t[3 * n + 1], l = t[3 * n + 2], c = t[3 * r], u = t[3 * r + 1], h = t[3 * r + 2], d = t[3 * i], p = t[3 * i + 1], f = t[3 * i + 2], m = t[3 * o], v = t[3 * o + 1], g = t[3 * o + 2] return Math.abs(s - u) < 0.01 ? [ new Jn(a, 1 - l), new Jn(c, 1 - h), new Jn(d, 1 - f), new Jn(m, 1 - g), ] : [ new Jn(s, 1 - l), new Jn(u, 1 - h), new Jn(p, 1 - f), new Jn(v, 1 - g), ] }, } function vu(e, t, n) { if (((n.shapes = []), Array.isArray(e))) for (var r = 0, i = e.length; r < i; r++) { var o = e[r] n.shapes.push(o.uuid) } else n.shapes.push(e.uuid) return ( void 0 !== t.extrudePath && (n.options.extrudePath = t.extrudePath.toJSON()), n ) } var gu = (function (e) { function t(t, n) { var r void 0 === t && (t = 1), void 0 === n && (n = 0) var i = (1 + Math.sqrt(5)) / 2, o = [ -1, i, 0, 1, i, 0, -1, -i, 0, 1, -i, 0, 0, -1, i, 0, 1, i, 0, -1, -i, 0, 1, -i, i, 0, -1, i, 0, 1, -i, 0, -1, -i, 0, 1, ], a = [ 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, ] return ( ((r = e.call(this, o, a, t, n) || this).type = 'IcosahedronGeometry'), (r.parameters = { radius: t, detail: n }), r ) } return Gn(t, e), t })(Tc), yu = (function (e) { function t(t, n, r, i) { var o void 0 === n && (n = 12), void 0 === r && (r = 0), void 0 === i && (i = 2 * Math.PI), ((o = e.call(this) || this).type = 'LatheGeometry'), (o.parameters = { points: t, segments: n, phiStart: r, phiLength: i }), (n = Math.floor(n)), (i = Kn.clamp(i, 0, 2 * Math.PI)) for ( var a = [], s = [], l = [], c = 1 / n, u = new lr(), h = new Jn(), d = 0; d <= n; d++ ) for ( var p = r + d * c * i, f = Math.sin(p), m = Math.cos(p), v = 0; v <= t.length - 1; v++ ) (u.x = t[v].x * f), (u.y = t[v].y), (u.z = t[v].x * m), s.push(u.x, u.y, u.z), (h.x = d / n), (h.y = v / (t.length - 1)), l.push(h.x, h.y) for (var g = 0; g < n; g++) for (var y = 0; y < t.length - 1; y++) { var b = y + g * t.length, A = b, w = b + t.length, x = b + t.length + 1, E = b + 1 a.push(A, w, E), a.push(w, x, E) } if ( (o.setIndex(a), o.setAttribute('position', new Wi(s, 3)), o.setAttribute('uv', new Wi(l, 2)), o.computeVertexNormals(), i === 2 * Math.PI) ) for ( var M = o.attributes.normal.array, _ = new lr(), T = new lr(), S = new lr(), C = n * t.length * 3, L = 0, R = 0; L < t.length; L++, R += 3 ) (_.x = M[R + 0]), (_.y = M[R + 1]), (_.z = M[R + 2]), (T.x = M[C + R + 0]), (T.y = M[C + R + 1]), (T.z = M[C + R + 2]), S.addVectors(_, T).normalize(), (M[R + 0] = M[C + R + 0] = S.x), (M[R + 1] = M[C + R + 1] = S.y), (M[R + 2] = M[C + R + 2] = S.z) return o } return Gn(t, e), t })(ro), bu = (function (e) { function t(t, n) { var r void 0 === t && (t = 1), void 0 === n && (n = 0) var i = [1, 0, 0, -1, 0, 0, 0, 1, 0, 0, -1, 0, 0, 0, 1, 0, 0, -1], o = [ 0, 2, 4, 0, 4, 3, 0, 3, 5, 0, 5, 2, 1, 2, 5, 1, 5, 3, 1, 3, 4, 1, 4, 2, ] return ( ((r = e.call(this, i, o, t, n) || this).type = 'OctahedronGeometry'), (r.parameters = { radius: t, detail: n }), r ) } return Gn(t, e), t })(Tc) function Au(e, t, n) { ro.call(this), (this.type = 'ParametricGeometry'), (this.parameters = { func: e, slices: t, stacks: n }) var r = [], i = [], o = [], a = [], s = 1e-5, l = new lr(), c = new lr(), u = new lr(), h = new lr(), d = new lr() e.length < 3 && console.error( 'THREE.ParametricGeometry: Function must now modify a Vector3 as third parameter.', ) for (var p = t + 1, f = 0; f <= n; f++) for (var m = f / n, v = 0; v <= t; v++) { var g = v / t e(g, m, c), i.push(c.x, c.y, c.z), g - s >= 0 ? (e(g - s, m, u), h.subVectors(c, u)) : (e(g + s, m, u), h.subVectors(u, c)), m - s >= 0 ? (e(g, m - s, u), d.subVectors(c, u)) : (e(g, m + s, u), d.subVectors(u, c)), l.crossVectors(h, d).normalize(), o.push(l.x, l.y, l.z), a.push(g, m) } for (var y = 0; y < n; y++) for (var b = 0; b < t; b++) { var A = y * p + b, w = y * p + b + 1, x = (y + 1) * p + b + 1, E = (y + 1) * p + b r.push(A, w, E), r.push(w, x, E) } this.setIndex(r), this.setAttribute('position', new Wi(i, 3)), this.setAttribute('normal', new Wi(o, 3)), this.setAttribute('uv', new Wi(a, 2)) } ;(Au.prototype = Object.create(ro.prototype)), (Au.prototype.constructor = Au) var wu = (function (e) { function t(t, n, r, i, o, a) { var s void 0 === t && (t = 0.5), void 0 === n && (n = 1), void 0 === r && (r = 8), void 0 === i && (i = 1), void 0 === o && (o = 0), void 0 === a && (a = 2 * Math.PI), ((s = e.call(this) || this).type = 'RingGeometry'), (s.parameters = { innerRadius: t, outerRadius: n, thetaSegments: r, phiSegments: i, thetaStart: o, thetaLength: a, }), (r = Math.max(3, r)) for ( var l = [], c = [], u = [], h = [], d = t, p = (n - t) / (i = Math.max(1, i)), f = new lr(), m = new Jn(), v = 0; v <= i; v++ ) { for (var g = 0; g <= r; g++) { var y = o + (g / r) * a ;(f.x = d * Math.cos(y)), (f.y = d * Math.sin(y)), c.push(f.x, f.y, f.z), u.push(0, 0, 1), (m.x = (f.x / n + 1) / 2), (m.y = (f.y / n + 1) / 2), h.push(m.x, m.y) } d += p } for (var b = 0; b < i; b++) for (var A = b * (r + 1), w = 0; w < r; w++) { var x = w + A, E = x, M = x + r + 1, _ = x + r + 2, T = x + 1 l.push(E, M, T), l.push(M, _, T) } return ( s.setIndex(l), s.setAttribute('position', new Wi(c, 3)), s.setAttribute('normal', new Wi(u, 3)), s.setAttribute('uv', new Wi(h, 2)), s ) } return Gn(t, e), t })(ro), xu = (function (e) { function t(t, n) { var r void 0 === n && (n = 12), ((r = e.call(this) || this).type = 'ShapeGeometry'), (r.parameters = { shapes: t, curveSegments: n }) var i = [], o = [], a = [], s = [], l = 0, c = 0 if (!1 === Array.isArray(t)) h(t) else for (var u = 0; u < t.length; u++) h(t[u]), r.addGroup(l, c, u), (l += c), (c = 0) function h(e) { var t = o.length / 3, r = e.extractPoints(n), l = r.shape, u = r.holes !1 === hu.isClockWise(l) && (l = l.reverse()) for (var h = 0, d = u.length; h < d; h++) { var p = u[h] !0 === hu.isClockWise(p) && (u[h] = p.reverse()) } for ( var f = hu.triangulateShape(l, u), m = 0, v = u.length; m < v; m++ ) { var g = u[m] l = l.concat(g) } for (var y = 0, b = l.length; y < b; y++) { var A = l[y] o.push(A.x, A.y, 0), a.push(0, 0, 1), s.push(A.x, A.y) } for (var w = 0, x = f.length; w < x; w++) { var E = f[w], M = E[0] + t, _ = E[1] + t, T = E[2] + t i.push(M, _, T), (c += 3) } } return ( r.setIndex(i), r.setAttribute('position', new Wi(o, 3)), r.setAttribute('normal', new Wi(a, 3)), r.setAttribute('uv', new Wi(s, 2)), r ) } return ( Gn(t, e), (t.prototype.toJSON = function () { var e = ro.prototype.toJSON.call(this) return Eu(this.parameters.shapes, e) }), t ) })(ro) function Eu(e, t) { if (((t.shapes = []), Array.isArray(e))) for (var n = 0, r = e.length; n < r; n++) { var i = e[n] t.shapes.push(i.uuid) } else t.shapes.push(e.uuid) return t } var Mu = (function (e) { function t(t, n, r, i, o, a, s) { var l void 0 === t && (t = 1), void 0 === n && (n = 8), void 0 === r && (r = 6), void 0 === i && (i = 0), void 0 === o && (o = 2 * Math.PI), void 0 === a && (a = 0), void 0 === s && (s = Math.PI), ((l = e.call(this) || this).type = 'SphereGeometry'), (l.parameters = { radius: t, widthSegments: n, heightSegments: r, phiStart: i, phiLength: o, thetaStart: a, thetaLength: s, }), (n = Math.max(3, Math.floor(n))), (r = Math.max(2, Math.floor(r))) for ( var c = Math.min(a + s, Math.PI), u = 0, h = [], d = new lr(), p = new lr(), f = [], m = [], v = [], g = [], y = 0; y <= r; y++ ) { var b = [], A = y / r, w = 0 0 == y && 0 == a ? (w = 0.5 / n) : y == r && c == Math.PI && (w = -0.5 / n) for (var x = 0; x <= n; x++) { var E = x / n ;(d.x = -t * Math.cos(i + E * o) * Math.sin(a + A * s)), (d.y = t * Math.cos(a + A * s)), (d.z = t * Math.sin(i + E * o) * Math.sin(a + A * s)), m.push(d.x, d.y, d.z), p.copy(d).normalize(), v.push(p.x, p.y, p.z), g.push(E + w, 1 - A), b.push(u++) } h.push(b) } for (var M = 0; M < r; M++) for (var _ = 0; _ < n; _++) { var T = h[M][_ + 1], S = h[M][_], C = h[M + 1][_], L = h[M + 1][_ + 1] ;(0 !== M || a > 0) && f.push(T, S, L), (M !== r - 1 || c < Math.PI) && f.push(S, C, L) } return ( l.setIndex(f), l.setAttribute('position', new Wi(m, 3)), l.setAttribute('normal', new Wi(v, 3)), l.setAttribute('uv', new Wi(g, 2)), l ) } return Gn(t, e), t })(ro), _u = (function (e) { function t(t, n) { var r void 0 === t && (t = 1), void 0 === n && (n = 0) var i = [1, 1, 1, -1, -1, 1, -1, 1, -1, 1, -1, -1], o = [2, 1, 0, 0, 3, 2, 1, 3, 0, 2, 3, 1] return ( ((r = e.call(this, i, o, t, n) || this).type = 'TetrahedronGeometry'), (r.parameters = { radius: t, detail: n }), r ) } return Gn(t, e), t })(Tc), Tu = (function (e) { function t(t, n) { var r void 0 === n && (n = {}) var i = n.font if (!i || !i.isFont) return ( console.error( 'THREE.TextGeometry: font parameter is not an instance of THREE.Font.', ), new ro() || zn(r) ) var o = i.generateShapes(t, n.size) return ( (n.depth = void 0 !== n.height ? n.height : 50), void 0 === n.bevelThickness && (n.bevelThickness = 10), void 0 === n.bevelSize && (n.bevelSize = 8), void 0 === n.bevelEnabled && (n.bevelEnabled = !1), ((r = e.call(this, o, n) || this).type = 'TextGeometry'), r ) } return Gn(t, e), t })(fu), Su = (function (e) { function t(t, n, r, i, o) { var a void 0 === t && (t = 1), void 0 === n && (n = 0.4), void 0 === r && (r = 8), void 0 === i && (i = 6), void 0 === o && (o = 2 * Math.PI), ((a = e.call(this) || this).type = 'TorusGeometry'), (a.parameters = { radius: t, tube: n, radialSegments: r, tubularSegments: i, arc: o, }), (r = Math.floor(r)), (i = Math.floor(i)) for ( var s = [], l = [], c = [], u = [], h = new lr(), d = new lr(), p = new lr(), f = 0; f <= r; f++ ) for (var m = 0; m <= i; m++) { var v = (m / i) * o, g = (f / r) * Math.PI * 2 ;(d.x = (t + n * Math.cos(g)) * Math.cos(v)), (d.y = (t + n * Math.cos(g)) * Math.sin(v)), (d.z = n * Math.sin(g)), l.push(d.x, d.y, d.z), (h.x = t * Math.cos(v)), (h.y = t * Math.sin(v)), p.subVectors(d, h).normalize(), c.push(p.x, p.y, p.z), u.push(m / i), u.push(f / r) } for (var y = 1; y <= r; y++) for (var b = 1; b <= i; b++) { var A = (i + 1) * y + b - 1, w = (i + 1) * (y - 1) + b - 1, x = (i + 1) * (y - 1) + b, E = (i + 1) * y + b s.push(A, w, E), s.push(w, x, E) } return ( a.setIndex(s), a.setAttribute('position', new Wi(l, 3)), a.setAttribute('normal', new Wi(c, 3)), a.setAttribute('uv', new Wi(u, 2)), a ) } return Gn(t, e), t })(ro), Cu = (function (e) { function t(t, n, r, i, o, a) { var s void 0 === t && (t = 1), void 0 === n && (n = 0.4), void 0 === r && (r = 64), void 0 === i && (i = 8), void 0 === o && (o = 2), void 0 === a && (a = 3), ((s = e.call(this) || this).type = 'TorusKnotGeometry'), (s.parameters = { radius: t, tube: n, tubularSegments: r, radialSegments: i, p: o, q: a, }), (r = Math.floor(r)), (i = Math.floor(i)) for ( var l = [], c = [], u = [], h = [], d = new lr(), p = new lr(), f = new lr(), m = new lr(), v = new lr(), g = new lr(), y = new lr(), b = 0; b <= r; ++b ) { var A = (b / r) * o * Math.PI * 2 P(A, o, a, t, f), P(A + 0.01, o, a, t, m), g.subVectors(m, f), y.addVectors(m, f), v.crossVectors(g, y), y.crossVectors(v, g), v.normalize(), y.normalize() for (var w = 0; w <= i; ++w) { var x = (w / i) * Math.PI * 2, E = -n * Math.cos(x), M = n * Math.sin(x) ;(d.x = f.x + (E * y.x + M * v.x)), (d.y = f.y + (E * y.y + M * v.y)), (d.z = f.z + (E * y.z + M * v.z)), c.push(d.x, d.y, d.z), p.subVectors(d, f).normalize(), u.push(p.x, p.y, p.z), h.push(b / r), h.push(w / i) } } for (var _ = 1; _ <= r; _++) for (var T = 1; T <= i; T++) { var S = (i + 1) * (_ - 1) + (T - 1), C = (i + 1) * _ + (T - 1), L = (i + 1) * _ + T, R = (i + 1) * (_ - 1) + T l.push(S, C, R), l.push(C, L, R) } function P(e, t, n, r, i) { var o = Math.cos(e), a = Math.sin(e), s = (n / t) * e, l = Math.cos(s) ;(i.x = r * (2 + l) * 0.5 * o), (i.y = r * (2 + l) * a * 0.5), (i.z = r * Math.sin(s) * 0.5) } return ( s.setIndex(l), s.setAttribute('position', new Wi(c, 3)), s.setAttribute('normal', new Wi(u, 3)), s.setAttribute('uv', new Wi(h, 2)), s ) } return Gn(t, e), t })(ro), Lu = (function (e) { function t(t, n, r, i, o) { var a void 0 === n && (n = 64), void 0 === r && (r = 1), void 0 === i && (i = 8), void 0 === o && (o = !1), ((a = e.call(this) || this).type = 'TubeGeometry'), (a.parameters = { path: t, tubularSegments: n, radius: r, radialSegments: i, closed: o, }) var s = t.computeFrenetFrames(n, o) ;(a.tangents = s.tangents), (a.normals = s.normals), (a.binormals = s.binormals) var l = new lr(), c = new lr(), u = new Jn(), h = new lr(), d = [], p = [], f = [], m = [] function v() { for (var e = 0; e < n; e++) g(e) g(!1 === o ? n : 0), b(), y() } function g(e) { h = t.getPointAt(e / n, h) for (var o = s.normals[e], a = s.binormals[e], u = 0; u <= i; u++) { var f = (u / i) * Math.PI * 2, m = Math.sin(f), v = -Math.cos(f) ;(c.x = v * o.x + m * a.x), (c.y = v * o.y + m * a.y), (c.z = v * o.z + m * a.z), c.normalize(), p.push(c.x, c.y, c.z), (l.x = h.x + r * c.x), (l.y = h.y + r * c.y), (l.z = h.z + r * c.z), d.push(l.x, l.y, l.z) } } function y() { for (var e = 1; e <= n; e++) for (var t = 1; t <= i; t++) { var r = (i + 1) * (e - 1) + (t - 1), o = (i + 1) * e + (t - 1), a = (i + 1) * e + t, s = (i + 1) * (e - 1) + t m.push(r, o, s), m.push(o, a, s) } } function b() { for (var e = 0; e <= n; e++) for (var t = 0; t <= i; t++) (u.x = e / n), (u.y = t / i), f.push(u.x, u.y) } return ( v(), a.setIndex(m), a.setAttribute('position', new Wi(d, 3)), a.setAttribute('normal', new Wi(p, 3)), a.setAttribute('uv', new Wi(f, 2)), a ) } return ( Gn(t, e), (t.prototype.toJSON = function () { var e = ro.prototype.toJSON.call(this) return (e.path = this.parameters.path.toJSON()), e }), t ) })(ro), Ru = (function (e) { function t(t) { var n if ( (((n = e.call(this) || this).type = 'WireframeGeometry'), !0 === t.isGeometry) ) return ( console.error( 'THREE.WireframeGeometry no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.', ), zn(n) ) var r = [], i = [0, 0], o = {}, a = new lr() if (null !== t.index) { var s = t.attributes.position, l = t.index, c = t.groups 0 === c.length && (c = [{ start: 0, count: l.count, materialIndex: 0 }]) for (var u = 0, h = c.length; u < h; ++u) for (var d = c[u], p = d.start, f = p, m = p + d.count; f < m; f += 3) for (var v = 0; v < 3; v++) { var g = l.getX(f + v), y = l.getX(f + ((v + 1) % 3)) ;(i[0] = Math.min(g, y)), (i[1] = Math.max(g, y)) var b = i[0] + ',' + i[1] void 0 === o[b] && (o[b] = { index1: i[0], index2: i[1] }) } for (var A in o) { var w = o[A] a.fromBufferAttribute(s, w.index1), r.push(a.x, a.y, a.z), a.fromBufferAttribute(s, w.index2), r.push(a.x, a.y, a.z) } } else for (var x = t.attributes.position, E = 0, M = x.count / 3; E < M; E++) for (var _ = 0; _ < 3; _++) { var T = 3 * E + _ a.fromBufferAttribute(x, T), r.push(a.x, a.y, a.z) var S = 3 * E + ((_ + 1) % 3) a.fromBufferAttribute(x, S), r.push(a.x, a.y, a.z) } return n.setAttribute('position', new Wi(r, 3)), n } return Gn(t, e), t })(ro), Pu = Object.freeze({ __proto__: null, BoxGeometry: _o, BoxBufferGeometry: _o, CircleGeometry: Ec, CircleBufferGeometry: Ec, ConeGeometry: _c, ConeBufferGeometry: _c, CylinderGeometry: Mc, CylinderBufferGeometry: Mc, DodecahedronGeometry: Sc, DodecahedronBufferGeometry: Sc, EdgesGeometry: Dc, ExtrudeGeometry: fu, ExtrudeBufferGeometry: fu, IcosahedronGeometry: gu, IcosahedronBufferGeometry: gu, LatheGeometry: yu, LatheBufferGeometry: yu, OctahedronGeometry: bu, OctahedronBufferGeometry: bu, ParametricGeometry: Au, ParametricBufferGeometry: Au, PlaneGeometry: Wo, PlaneBufferGeometry: Wo, PolyhedronGeometry: Tc, PolyhedronBufferGeometry: Tc, RingGeometry: wu, RingBufferGeometry: wu, ShapeGeometry: xu, ShapeBufferGeometry: xu, SphereGeometry: Mu, SphereBufferGeometry: Mu, TetrahedronGeometry: _u, TetrahedronBufferGeometry: _u, TextGeometry: Tu, TextBufferGeometry: Tu, TorusGeometry: Su, TorusBufferGeometry: Su, TorusKnotGeometry: Cu, TorusKnotBufferGeometry: Cu, TubeGeometry: Lu, TubeBufferGeometry: Lu, WireframeGeometry: Ru, }) function Du(e) { Di.call(this), (this.type = 'ShadowMaterial'), (this.color = new Li(0)), (this.transparent = !0), this.setValues(e) } function Ou(e) { Po.call(this, e), (this.type = 'RawShaderMaterial') } function Iu(e) { Di.call(this), (this.defines = { STANDARD: '' }), (this.type = 'MeshStandardMaterial'), (this.color = new Li(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 Li(0)), (this.emissiveIntensity = 1), (this.emissiveMap = null), (this.bumpMap = null), (this.bumpScale = 1), (this.normalMap = null), (this.normalMapType = ln), (this.normalScale = new Jn(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 = 0.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(e) } function Bu(e) { Iu.call(this), (this.defines = { STANDARD: '', PHYSICAL: '' }), (this.type = 'MeshPhysicalMaterial'), (this.clearcoat = 0), (this.clearcoatMap = null), (this.clearcoatRoughness = 0), (this.clearcoatRoughnessMap = null), (this.clearcoatNormalScale = new Jn(1, 1)), (this.clearcoatNormalMap = null), (this.reflectivity = 0.5), Object.defineProperty(this, 'ior', { get: function () { return (1 + 0.4 * this.reflectivity) / (1 - 0.4 * this.reflectivity) }, set: function (e) { this.reflectivity = Kn.clamp((2.5 * (e - 1)) / (e + 1), 0, 1) }, }), (this.sheen = null), (this.transmission = 0), (this.transmissionMap = null), this.setValues(e) } function Fu(e) { Di.call(this), (this.type = 'MeshPhongMaterial'), (this.color = new Li(16777215)), (this.specular = new Li(1118481)), (this.shininess = 30), (this.map = null), (this.lightMap = null), (this.lightMapIntensity = 1), (this.aoMap = null), (this.aoMapIntensity = 1), (this.emissive = new Li(0)), (this.emissiveIntensity = 1), (this.emissiveMap = null), (this.bumpMap = null), (this.bumpScale = 1), (this.normalMap = null), (this.normalMapType = ln), (this.normalScale = new Jn(1, 1)), (this.displacementMap = null), (this.displacementScale = 1), (this.displacementBias = 0), (this.specularMap = null), (this.alphaMap = null), (this.envMap = null), (this.combine = Z), (this.reflectivity = 1), (this.refractionRatio = 0.98), (this.wireframe = !1), (this.wireframeLinewidth = 1), (this.wireframeLinecap = 'round'), (this.wireframeLinejoin = 'round'), (this.skinning = !1), (this.morphTargets = !1), (this.morphNormals = !1), this.setValues(e) } function ku(e) { Di.call(this), (this.defines = { TOON: '' }), (this.type = 'MeshToonMaterial'), (this.color = new Li(16777215)), (this.map = null), (this.gradientMap = null), (this.lightMap = null), (this.lightMapIntensity = 1), (this.aoMap = null), (this.aoMapIntensity = 1), (this.emissive = new Li(0)), (this.emissiveIntensity = 1), (this.emissiveMap = null), (this.bumpMap = null), (this.bumpScale = 1), (this.normalMap = null), (this.normalMapType = ln), (this.normalScale = new Jn(1, 1)), (this.displacementMap = null), (this.displacementScale = 1), (this.displacementBias = 0), (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(e) } function Nu(e) { Di.call(this), (this.type = 'MeshNormalMaterial'), (this.bumpMap = null), (this.bumpScale = 1), (this.normalMap = null), (this.normalMapType = ln), (this.normalScale = new Jn(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(e) } function Uu(e) { Di.call(this), (this.type = 'MeshLambertMaterial'), (this.color = new Li(16777215)), (this.map = null), (this.lightMap = null), (this.lightMapIntensity = 1), (this.aoMap = null), (this.aoMapIntensity = 1), (this.emissive = new Li(0)), (this.emissiveIntensity = 1), (this.emissiveMap = null), (this.specularMap = null), (this.alphaMap = null), (this.envMap = null), (this.combine = Z), (this.reflectivity = 1), (this.refractionRatio = 0.98), (this.wireframe = !1), (this.wireframeLinewidth = 1), (this.wireframeLinecap = 'round'), (this.wireframeLinejoin = 'round'), (this.skinning = !1), (this.morphTargets = !1), (this.morphNormals = !1), this.setValues(e) } function Hu(e) { Di.call(this), (this.defines = { MATCAP: '' }), (this.type = 'MeshMatcapMaterial'), (this.color = new Li(16777215)), (this.matcap = null), (this.map = null), (this.bumpMap = null), (this.bumpScale = 1), (this.normalMap = null), (this.normalMapType = ln), (this.normalScale = new Jn(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(e) } function Gu(e) { tc.call(this), (this.type = 'LineDashedMaterial'), (this.scale = 1), (this.dashSize = 3), (this.gapSize = 1), this.setValues(e) } ;(Du.prototype = Object.create(Di.prototype)), (Du.prototype.constructor = Du), (Du.prototype.isShadowMaterial = !0), (Du.prototype.copy = function (e) { return Di.prototype.copy.call(this, e), this.color.copy(e.color), this }), (Ou.prototype = Object.create(Po.prototype)), (Ou.prototype.constructor = Ou), (Ou.prototype.isRawShaderMaterial = !0), (Iu.prototype = Object.create(Di.prototype)), (Iu.prototype.constructor = Iu), (Iu.prototype.isMeshStandardMaterial = !0), (Iu.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), (this.defines = { STANDARD: '' }), this.color.copy(e.color), (this.roughness = e.roughness), (this.metalness = e.metalness), (this.map = e.map), (this.lightMap = e.lightMap), (this.lightMapIntensity = e.lightMapIntensity), (this.aoMap = e.aoMap), (this.aoMapIntensity = e.aoMapIntensity), this.emissive.copy(e.emissive), (this.emissiveMap = e.emissiveMap), (this.emissiveIntensity = e.emissiveIntensity), (this.bumpMap = e.bumpMap), (this.bumpScale = e.bumpScale), (this.normalMap = e.normalMap), (this.normalMapType = e.normalMapType), this.normalScale.copy(e.normalScale), (this.displacementMap = e.displacementMap), (this.displacementScale = e.displacementScale), (this.displacementBias = e.displacementBias), (this.roughnessMap = e.roughnessMap), (this.metalnessMap = e.metalnessMap), (this.alphaMap = e.alphaMap), (this.envMap = e.envMap), (this.envMapIntensity = e.envMapIntensity), (this.refractionRatio = e.refractionRatio), (this.wireframe = e.wireframe), (this.wireframeLinewidth = e.wireframeLinewidth), (this.wireframeLinecap = e.wireframeLinecap), (this.wireframeLinejoin = e.wireframeLinejoin), (this.skinning = e.skinning), (this.morphTargets = e.morphTargets), (this.morphNormals = e.morphNormals), (this.vertexTangents = e.vertexTangents), this ) }), (Bu.prototype = Object.create(Iu.prototype)), (Bu.prototype.constructor = Bu), (Bu.prototype.isMeshPhysicalMaterial = !0), (Bu.prototype.copy = function (e) { return ( Iu.prototype.copy.call(this, e), (this.defines = { STANDARD: '', PHYSICAL: '' }), (this.clearcoat = e.clearcoat), (this.clearcoatMap = e.clearcoatMap), (this.clearcoatRoughness = e.clearcoatRoughness), (this.clearcoatRoughnessMap = e.clearcoatRoughnessMap), (this.clearcoatNormalMap = e.clearcoatNormalMap), this.clearcoatNormalScale.copy(e.clearcoatNormalScale), (this.reflectivity = e.reflectivity), e.sheen ? (this.sheen = (this.sheen || new Li()).copy(e.sheen)) : (this.sheen = null), (this.transmission = e.transmission), (this.transmissionMap = e.transmissionMap), this ) }), (Fu.prototype = Object.create(Di.prototype)), (Fu.prototype.constructor = Fu), (Fu.prototype.isMeshPhongMaterial = !0), (Fu.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), this.color.copy(e.color), this.specular.copy(e.specular), (this.shininess = e.shininess), (this.map = e.map), (this.lightMap = e.lightMap), (this.lightMapIntensity = e.lightMapIntensity), (this.aoMap = e.aoMap), (this.aoMapIntensity = e.aoMapIntensity), this.emissive.copy(e.emissive), (this.emissiveMap = e.emissiveMap), (this.emissiveIntensity = e.emissiveIntensity), (this.bumpMap = e.bumpMap), (this.bumpScale = e.bumpScale), (this.normalMap = e.normalMap), (this.normalMapType = e.normalMapType), this.normalScale.copy(e.normalScale), (this.displacementMap = e.displacementMap), (this.displacementScale = e.displacementScale), (this.displacementBias = e.displacementBias), (this.specularMap = e.specularMap), (this.alphaMap = e.alphaMap), (this.envMap = e.envMap), (this.combine = e.combine), (this.reflectivity = e.reflectivity), (this.refractionRatio = e.refractionRatio), (this.wireframe = e.wireframe), (this.wireframeLinewidth = e.wireframeLinewidth), (this.wireframeLinecap = e.wireframeLinecap), (this.wireframeLinejoin = e.wireframeLinejoin), (this.skinning = e.skinning), (this.morphTargets = e.morphTargets), (this.morphNormals = e.morphNormals), this ) }), (ku.prototype = Object.create(Di.prototype)), (ku.prototype.constructor = ku), (ku.prototype.isMeshToonMaterial = !0), (ku.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), this.color.copy(e.color), (this.map = e.map), (this.gradientMap = e.gradientMap), (this.lightMap = e.lightMap), (this.lightMapIntensity = e.lightMapIntensity), (this.aoMap = e.aoMap), (this.aoMapIntensity = e.aoMapIntensity), this.emissive.copy(e.emissive), (this.emissiveMap = e.emissiveMap), (this.emissiveIntensity = e.emissiveIntensity), (this.bumpMap = e.bumpMap), (this.bumpScale = e.bumpScale), (this.normalMap = e.normalMap), (this.normalMapType = e.normalMapType), this.normalScale.copy(e.normalScale), (this.displacementMap = e.displacementMap), (this.displacementScale = e.displacementScale), (this.displacementBias = e.displacementBias), (this.alphaMap = e.alphaMap), (this.wireframe = e.wireframe), (this.wireframeLinewidth = e.wireframeLinewidth), (this.wireframeLinecap = e.wireframeLinecap), (this.wireframeLinejoin = e.wireframeLinejoin), (this.skinning = e.skinning), (this.morphTargets = e.morphTargets), (this.morphNormals = e.morphNormals), this ) }), (Nu.prototype = Object.create(Di.prototype)), (Nu.prototype.constructor = Nu), (Nu.prototype.isMeshNormalMaterial = !0), (Nu.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), (this.bumpMap = e.bumpMap), (this.bumpScale = e.bumpScale), (this.normalMap = e.normalMap), (this.normalMapType = e.normalMapType), this.normalScale.copy(e.normalScale), (this.displacementMap = e.displacementMap), (this.displacementScale = e.displacementScale), (this.displacementBias = e.displacementBias), (this.wireframe = e.wireframe), (this.wireframeLinewidth = e.wireframeLinewidth), (this.skinning = e.skinning), (this.morphTargets = e.morphTargets), (this.morphNormals = e.morphNormals), this ) }), (Uu.prototype = Object.create(Di.prototype)), (Uu.prototype.constructor = Uu), (Uu.prototype.isMeshLambertMaterial = !0), (Uu.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), this.color.copy(e.color), (this.map = e.map), (this.lightMap = e.lightMap), (this.lightMapIntensity = e.lightMapIntensity), (this.aoMap = e.aoMap), (this.aoMapIntensity = e.aoMapIntensity), this.emissive.copy(e.emissive), (this.emissiveMap = e.emissiveMap), (this.emissiveIntensity = e.emissiveIntensity), (this.specularMap = e.specularMap), (this.alphaMap = e.alphaMap), (this.envMap = e.envMap), (this.combine = e.combine), (this.reflectivity = e.reflectivity), (this.refractionRatio = e.refractionRatio), (this.wireframe = e.wireframe), (this.wireframeLinewidth = e.wireframeLinewidth), (this.wireframeLinecap = e.wireframeLinecap), (this.wireframeLinejoin = e.wireframeLinejoin), (this.skinning = e.skinning), (this.morphTargets = e.morphTargets), (this.morphNormals = e.morphNormals), this ) }), (Hu.prototype = Object.create(Di.prototype)), (Hu.prototype.constructor = Hu), (Hu.prototype.isMeshMatcapMaterial = !0), (Hu.prototype.copy = function (e) { return ( Di.prototype.copy.call(this, e), (this.defines = { MATCAP: '' }), this.color.copy(e.color), (this.matcap = e.matcap), (this.map = e.map), (this.bumpMap = e.bumpMap), (this.bumpScale = e.bumpScale), (this.normalMap = e.normalMap), (this.normalMapType = e.normalMapType), this.normalScale.copy(e.normalScale), (this.displacementMap = e.displacementMap), (this.displacementScale = e.displacementScale), (this.displacementBias = e.displacementBias), (this.alphaMap = e.alphaMap), (this.skinning = e.skinning), (this.morphTargets = e.morphTargets), (this.morphNormals = e.morphNormals), this ) }), (Gu.prototype = Object.create(tc.prototype)), (Gu.prototype.constructor = Gu), (Gu.prototype.isLineDashedMaterial = !0), (Gu.prototype.copy = function (e) { return ( tc.prototype.copy.call(this, e), (this.scale = e.scale), (this.dashSize = e.dashSize), (this.gapSize = e.gapSize), this ) }) var zu = Object.freeze({ __proto__: null, ShadowMaterial: Du, SpriteMaterial: xl, RawShaderMaterial: Ou, ShaderMaterial: Po, PointsMaterial: dc, MeshPhysicalMaterial: Bu, MeshStandardMaterial: Iu, MeshPhongMaterial: Fu, MeshToonMaterial: ku, MeshNormalMaterial: Nu, MeshLambertMaterial: Uu, MeshDepthMaterial: Qs, MeshDistanceMaterial: Zs, MeshBasicMaterial: Oi, MeshMatcapMaterial: Hu, LineDashedMaterial: Gu, LineBasicMaterial: tc, Material: Di, }), ju = { arraySlice: function (e, t, n) { return ju.isTypedArray(e) ? new e.constructor(e.subarray(t, void 0 !== n ? n : e.length)) : e.slice(t, n) }, convertArray: function (e, t, n) { return !e || (!n && e.constructor === t) ? e : 'number' === typeof t.BYTES_PER_ELEMENT ? new t(e) : Array.prototype.slice.call(e) }, isTypedArray: function (e) { return ArrayBuffer.isView(e) && !(e instanceof DataView) }, getKeyframeOrder: function (e) { function t(t, n) { return e[t] - e[n] } for (var n = e.length, r = new Array(n), i = 0; i !== n; ++i) r[i] = i return r.sort(t), r }, sortedArray: function (e, t, n) { for ( var r = e.length, i = new e.constructor(r), o = 0, a = 0; a !== r; ++o ) for (var s = n[o] * t, l = 0; l !== t; ++l) i[a++] = e[s + l] return i }, flattenJSON: function (e, t, n, r) { for (var i = 1, o = e[0]; void 0 !== o && void 0 === o[r]; ) o = e[i++] if (void 0 !== o) { var a = o[r] if (void 0 !== a) if (Array.isArray(a)) do { void 0 !== (a = o[r]) && (t.push(o.time), n.push.apply(n, a)), (o = e[i++]) } while (void 0 !== o) else if (void 0 !== a.toArray) do { void 0 !== (a = o[r]) && (t.push(o.time), a.toArray(n, n.length)), (o = e[i++]) } while (void 0 !== o) else do { void 0 !== (a = o[r]) && (t.push(o.time), n.push(a)), (o = e[i++]) } while (void 0 !== o) } }, subclip: function (e, t, n, r, i) { void 0 === i && (i = 30) var o = e.clone() o.name = t for (var a = [], s = 0; s < o.tracks.length; ++s) { for ( var l = o.tracks[s], c = l.getValueSize(), u = [], h = [], d = 0; d < l.times.length; ++d ) { var p = l.times[d] * i if (!(p < n || p >= r)) { u.push(l.times[d]) for (var f = 0; f < c; ++f) h.push(l.values[d * c + f]) } } 0 !== u.length && ((l.times = ju.convertArray(u, l.times.constructor)), (l.values = ju.convertArray(h, l.values.constructor)), a.push(l)) } o.tracks = a for (var m = 1 / 0, v = 0; v < o.tracks.length; ++v) m > o.tracks[v].times[0] && (m = o.tracks[v].times[0]) for (var g = 0; g < o.tracks.length; ++g) o.tracks[g].shift(-1 * m) return o.resetDuration(), o }, makeClipAdditive: function (e, t, n, r) { void 0 === t && (t = 0), void 0 === n && (n = e), void 0 === r && (r = 30), r <= 0 && (r = 30) for ( var i = n.tracks.length, o = t / r, a = function (t) { var r = n.tracks[t], i = r.ValueTypeName if ('bool' === i || 'string' === i) return 'continue' var a = e.tracks.find(function (e) { return e.name === r.name && e.ValueTypeName === i }) if (void 0 === a) return 'continue' var s = 0, l = r.getValueSize() r.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline && (s = l / 3) var c = 0, u = a.getValueSize() a.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline && (c = u / 3) var h = r.times.length - 1, d = void 0 if (o <= r.times[0]) { var p = s, f = l - s d = ju.arraySlice(r.values, p, f) } else if (o >= r.times[h]) { var m = h * l + s, v = m + l - s d = ju.arraySlice(r.values, m, v) } else { var g = r.createInterpolant(), y = s, b = l - s g.evaluate(o), (d = ju.arraySlice(g.resultBuffer, y, b)) } 'quaternion' === i && new sr().fromArray(d).normalize().conjugate().toArray(d) for (var A = a.times.length, w = 0; w < A; ++w) { var x = w * u + c if ('quaternion' === i) sr.multiplyQuaternionsFlat(a.values, x, d, 0, a.values, x) else for (var E = u - 2 * c, M = 0; M < E; ++M) a.values[x + M] -= d[M] } }, s = 0; s < i; ++s ) a(s) return (e.blendMode = Xt), e }, } function Vu(e, t, n, r) { ;(this.parameterPositions = e), (this._cachedIndex = 0), (this.resultBuffer = void 0 !== r ? r : new t.constructor(n)), (this.sampleValues = t), (this.valueSize = n) } function Wu(e, t, n, r) { Vu.call(this, e, t, n, r), (this._weightPrev = -0), (this._offsetPrev = -0), (this._weightNext = -0), (this._offsetNext = -0) } function qu(e, t, n, r) { Vu.call(this, e, t, n, r) } function Xu(e, t, n, r) { Vu.call(this, e, t, n, r) } function Yu(e, t, n, r) { if (void 0 === e) throw new Error('THREE.KeyframeTrack: track name is undefined') if (void 0 === t || 0 === t.length) throw new Error('THREE.KeyframeTrack: no keyframes in track named ' + e) ;(this.name = e), (this.times = ju.convertArray(t, this.TimeBufferType)), (this.values = ju.convertArray(n, this.ValueBufferType)), this.setInterpolation(r || this.DefaultInterpolation) } function Qu(e, t, n) { Yu.call(this, e, t, n) } function Zu(e, t, n, r) { Yu.call(this, e, t, n, r) } function Ku(e, t, n, r) { Yu.call(this, e, t, n, r) } function Ju(e, t, n, r) { Vu.call(this, e, t, n, r) } function $u(e, t, n, r) { Yu.call(this, e, t, n, r) } function eh(e, t, n, r) { Yu.call(this, e, t, n, r) } function th(e, t, n, r) { Yu.call(this, e, t, n, r) } function nh(e, t, n, r) { void 0 === t && (t = -1), void 0 === r && (r = qt), (this.name = e), (this.tracks = n), (this.duration = t), (this.blendMode = r), (this.uuid = Kn.generateUUID()), this.duration < 0 && this.resetDuration() } function rh(e) { switch (e.toLowerCase()) { case 'scalar': case 'double': case 'float': case 'number': case 'integer': return Ku case 'vector': case 'vector2': case 'vector3': case 'vector4': return th case 'color': return Zu case 'quaternion': return $u case 'bool': case 'boolean': return Qu case 'string': return eh } throw new Error('THREE.KeyframeTrack: Unsupported typeName: ' + e) } function ih(e) { if (void 0 === e.type) throw new Error('THREE.KeyframeTrack: track type undefined, can not parse') var t = rh(e.type) if (void 0 === e.times) { var n = [], r = [] ju.flattenJSON(e.keys, n, r, 'value'), (e.times = n), (e.values = r) } return void 0 !== t.parse ? t.parse(e) : new t(e.name, e.times, e.values, e.interpolation) } Object.assign(Vu.prototype, { evaluate: function (e) { var t = this.parameterPositions, n = this._cachedIndex, r = t[n], i = t[n - 1] e: { t: { var o n: { r: if (!(e < r)) { for (var a = n + 2; ; ) { if (void 0 === r) { if (e < i) break r return ( (n = t.length), (this._cachedIndex = n), this.afterEnd_(n - 1, e, i) ) } if (n === a) break if (((i = r), e < (r = t[++n]))) break t } o = t.length break n } if (e >= i) break e var s = t[1] e < s && ((n = 2), (i = s)) for (var l = n - 2; ; ) { if (void 0 === i) return (this._cachedIndex = 0), this.beforeStart_(0, e, r) if (n === l) break if (((r = i), e >= (i = t[--n - 1]))) break t } ;(o = n), (n = 0) } for (; n < o; ) { var c = (n + o) >>> 1 e < t[c] ? (o = c) : (n = c + 1) } if (((r = t[n]), void 0 === (i = t[n - 1]))) return (this._cachedIndex = 0), this.beforeStart_(0, e, r) if (void 0 === r) return ( (n = t.length), (this._cachedIndex = n), this.afterEnd_(n - 1, i, e) ) } ;(this._cachedIndex = n), this.intervalChanged_(n, i, r) } return this.interpolate_(n, i, e, r) }, settings: null, DefaultSettings_: {}, getSettings_: function () { return this.settings || this.DefaultSettings_ }, copySampleValue_: function (e) { for ( var t = this.resultBuffer, n = this.sampleValues, r = this.valueSize, i = e * r, o = 0; o !== r; ++o ) t[o] = n[i + o] return t }, interpolate_: function () { throw new Error('call to abstract method') }, intervalChanged_: function () {}, }), Object.assign(Vu.prototype, { beforeStart_: Vu.prototype.copySampleValue_, afterEnd_: Vu.prototype.copySampleValue_, }), (Wu.prototype = Object.assign(Object.create(Vu.prototype), { constructor: Wu, DefaultSettings_: { endingStart: jt, endingEnd: jt }, intervalChanged_: function (e, t, n) { var r = this.parameterPositions, i = e - 2, o = e + 1, a = r[i], s = r[o] if (void 0 === a) switch (this.getSettings_().endingStart) { case Vt: ;(i = e), (a = 2 * t - n) break case Wt: a = t + r[(i = r.length - 2)] - r[i + 1] break default: ;(i = e), (a = n) } if (void 0 === s) switch (this.getSettings_().endingEnd) { case Vt: ;(o = e), (s = 2 * n - t) break case Wt: ;(o = 1), (s = n + r[1] - r[0]) break default: ;(o = e - 1), (s = t) } var l = 0.5 * (n - t), c = this.valueSize ;(this._weightPrev = l / (t - a)), (this._weightNext = l / (s - n)), (this._offsetPrev = i * c), (this._offsetNext = o * c) }, interpolate_: function (e, t, n, r) { for ( var i = this.resultBuffer, o = this.sampleValues, a = this.valueSize, s = e * a, l = s - a, c = this._offsetPrev, u = this._offsetNext, h = this._weightPrev, d = this._weightNext, p = (n - t) / (r - t), f = p * p, m = f * p, v = -h * m + 2 * h * f - h * p, g = (1 + h) * m + (-1.5 - 2 * h) * f + (-0.5 + h) * p + 1, y = (-1 - d) * m + (1.5 + d) * f + 0.5 * p, b = d * m - d * f, A = 0; A !== a; ++A ) i[A] = v * o[c + A] + g * o[l + A] + y * o[s + A] + b * o[u + A] return i }, })), (qu.prototype = Object.assign(Object.create(Vu.prototype), { constructor: qu, interpolate_: function (e, t, n, r) { for ( var i = this.resultBuffer, o = this.sampleValues, a = this.valueSize, s = e * a, l = s - a, c = (n - t) / (r - t), u = 1 - c, h = 0; h !== a; ++h ) i[h] = o[l + h] * u + o[s + h] * c return i }, })), (Xu.prototype = Object.assign(Object.create(Vu.prototype), { constructor: Xu, interpolate_: function (e) { return this.copySampleValue_(e - 1) }, })), Object.assign(Yu, { toJSON: function (e) { var t, n = e.constructor if (void 0 !== n.toJSON) t = n.toJSON(e) else { t = { name: e.name, times: ju.convertArray(e.times, Array), values: ju.convertArray(e.values, Array), } var r = e.getInterpolation() r !== e.DefaultInterpolation && (t.interpolation = r) } return (t.type = e.ValueTypeName), t }, }), Object.assign(Yu.prototype, { constructor: Yu, TimeBufferType: Float32Array, ValueBufferType: Float32Array, DefaultInterpolation: Gt, InterpolantFactoryMethodDiscrete: function (e) { return new Xu(this.times, this.values, this.getValueSize(), e) }, InterpolantFactoryMethodLinear: function (e) { return new qu(this.times, this.values, this.getValueSize(), e) }, InterpolantFactoryMethodSmooth: function (e) { return new Wu(this.times, this.values, this.getValueSize(), e) }, setInterpolation: function (e) { var t switch (e) { case Ht: t = this.InterpolantFactoryMethodDiscrete break case Gt: t = this.InterpolantFactoryMethodLinear break case zt: t = this.InterpolantFactoryMethodSmooth } if (void 0 === t) { var n = 'unsupported interpolation for ' + this.ValueTypeName + ' keyframe track named ' + this.name if (void 0 === this.createInterpolant) { if (e === this.DefaultInterpolation) throw new Error(n) this.setInterpolation(this.DefaultInterpolation) } return console.warn('THREE.KeyframeTrack:', n), this } return (this.createInterpolant = t), this }, getInterpolation: function () { switch (this.createInterpolant) { case this.InterpolantFactoryMethodDiscrete: return Ht case this.InterpolantFactoryMethodLinear: return Gt case this.InterpolantFactoryMethodSmooth: return zt } }, getValueSize: function () { return this.values.length / this.times.length }, shift: function (e) { if (0 !== e) for (var t = this.times, n = 0, r = t.length; n !== r; ++n) t[n] += e return this }, scale: function (e) { if (1 !== e) for (var t = this.times, n = 0, r = t.length; n !== r; ++n) t[n] *= e return this }, trim: function (e, t) { for ( var n = this.times, r = n.length, i = 0, o = r - 1; i !== r && n[i] < e; ) ++i for (; -1 !== o && n[o] > t; ) --o if ((++o, 0 !== i || o !== r)) { i >= o && (i = (o = Math.max(o, 1)) - 1) var a = this.getValueSize() ;(this.times = ju.arraySlice(n, i, o)), (this.values = ju.arraySlice(this.values, i * a, o * a)) } return this }, validate: function () { var e = !0, t = this.getValueSize() t - Math.floor(t) !== 0 && (console.error( 'THREE.KeyframeTrack: Invalid value size in track.', this, ), (e = !1)) var n = this.times, r = this.values, i = n.length 0 === i && (console.error('THREE.KeyframeTrack: Track is empty.', this), (e = !1)) for (var o = null, a = 0; a !== i; a++) { var s = n[a] if ('number' === typeof s && isNaN(s)) { console.error( 'THREE.KeyframeTrack: Time is not a valid number.', this, a, s, ), (e = !1) break } if (null !== o && o > s) { console.error( 'THREE.KeyframeTrack: Out of order keys.', this, a, s, o, ), (e = !1) break } o = s } if (void 0 !== r && ju.isTypedArray(r)) for (var l = 0, c = r.length; l !== c; ++l) { var u = r[l] if (isNaN(u)) { console.error( 'THREE.KeyframeTrack: Value is not a valid number.', this, l, u, ), (e = !1) break } } return e }, optimize: function () { for ( var e = ju.arraySlice(this.times), t = ju.arraySlice(this.values), n = this.getValueSize(), r = this.getInterpolation() === zt, i = e.length - 1, o = 1, a = 1; a < i; ++a ) { var s = !1, l = e[a] if (l !== e[a + 1] && (1 !== a || l !== e[0])) if (r) s = !0 else for (var c = a * n, u = c - n, h = c + n, d = 0; d !== n; ++d) { var p = t[c + d] if (p !== t[u + d] || p !== t[h + d]) { s = !0 break } } if (s) { if (a !== o) { e[o] = e[a] for (var f = a * n, m = o * n, v = 0; v !== n; ++v) t[m + v] = t[f + v] } ++o } } if (i > 0) { e[o] = e[i] for (var g = i * n, y = o * n, b = 0; b !== n; ++b) t[y + b] = t[g + b] ++o } return ( o !== e.length ? ((this.times = ju.arraySlice(e, 0, o)), (this.values = ju.arraySlice(t, 0, o * n))) : ((this.times = e), (this.values = t)), this ) }, clone: function () { var e = ju.arraySlice(this.times, 0), t = ju.arraySlice(this.values, 0), n = new (0, this.constructor)(this.name, e, t) return (n.createInterpolant = this.createInterpolant), n }, }), (Qu.prototype = Object.assign(Object.create(Yu.prototype), { constructor: Qu, ValueTypeName: 'bool', ValueBufferType: Array, DefaultInterpolation: Ht, InterpolantFactoryMethodLinear: void 0, InterpolantFactoryMethodSmooth: void 0, })), (Zu.prototype = Object.assign(Object.create(Yu.prototype), { constructor: Zu, ValueTypeName: 'color', })), (Ku.prototype = Object.assign(Object.create(Yu.prototype), { constructor: Ku, ValueTypeName: 'number', })), (Ju.prototype = Object.assign(Object.create(Vu.prototype), { constructor: Ju, interpolate_: function (e, t, n, r) { for ( var i = this.resultBuffer, o = this.sampleValues, a = this.valueSize, s = (n - t) / (r - t), l = e * a, c = l + a; l !== c; l += 4 ) sr.slerpFlat(i, 0, o, l - a, o, l, s) return i }, })), ($u.prototype = Object.assign(Object.create(Yu.prototype), { constructor: $u, ValueTypeName: 'quaternion', DefaultInterpolation: Gt, InterpolantFactoryMethodLinear: function (e) { return new Ju(this.times, this.values, this.getValueSize(), e) }, InterpolantFactoryMethodSmooth: void 0, })), (eh.prototype = Object.assign(Object.create(Yu.prototype), { constructor: eh, ValueTypeName: 'string', ValueBufferType: Array, DefaultInterpolation: Ht, InterpolantFactoryMethodLinear: void 0, InterpolantFactoryMethodSmooth: void 0, })), (th.prototype = Object.assign(Object.create(Yu.prototype), { constructor: th, ValueTypeName: 'vector', })), Object.assign(nh, { parse: function (e) { for ( var t = [], n = e.tracks, r = 1 / (e.fps || 1), i = 0, o = n.length; i !== o; ++i ) t.push(ih(n[i]).scale(r)) var a = new nh(e.name, e.duration, t, e.blendMode) return (a.uuid = e.uuid), a }, toJSON: function (e) { for ( var t = [], n = e.tracks, r = { name: e.name, duration: e.duration, tracks: t, uuid: e.uuid, blendMode: e.blendMode, }, i = 0, o = n.length; i !== o; ++i ) t.push(Yu.toJSON(n[i])) return r }, CreateFromMorphTargetSequence: function (e, t, n, r) { for (var i = t.length, o = [], a = 0; a < i; a++) { var s = [], l = [] s.push((a + i - 1) % i, a, (a + 1) % i), l.push(0, 1, 0) var c = ju.getKeyframeOrder(s) ;(s = ju.sortedArray(s, 1, c)), (l = ju.sortedArray(l, 1, c)), r || 0 !== s[0] || (s.push(i), l.push(l[0])), o.push( new Ku('.morphTargetInfluences[' + t[a].name + ']', s, l).scale( 1 / n, ), ) } return new nh(e, -1, o) }, findByName: function (e, t) { var n = e if (!Array.isArray(e)) { var r = e n = (r.geometry && r.geometry.animations) || r.animations } for (var i = 0; i < n.length; i++) if (n[i].name === t) return n[i] return null }, CreateClipsFromMorphTargetSequences: function (e, t, n) { for ( var r = {}, i = /^([\w-]*?)([\d]+)$/, o = 0, a = e.length; o < a; o++ ) { var s = e[o], l = s.name.match(i) if (l && l.length > 1) { var c = l[1], u = r[c] u || (r[c] = u = []), u.push(s) } } var h = [] for (var d in r) h.push(nh.CreateFromMorphTargetSequence(d, r[d], t, n)) return h }, parseAnimation: function (e, t) { if (!e) return ( console.error( 'THREE.AnimationClip: No animation in JSONLoader data.', ), null ) for ( var n = function (e, t, n, r, i) { if (0 !== n.length) { var o = [], a = [] ju.flattenJSON(n, o, a, r), 0 !== o.length && i.push(new e(t, o, a)) } }, r = [], i = e.name || 'default', o = e.fps || 30, a = e.blendMode, s = e.length || -1, l = e.hierarchy || [], c = 0; c < l.length; c++ ) { var u = l[c].keys if (u && 0 !== u.length) if (u[0].morphTargets) { var h = {}, d = void 0 for (d = 0; d < u.length; d++) if (u[d].morphTargets) for (var p = 0; p < u[d].morphTargets.length; p++) h[u[d].morphTargets[p]] = -1 for (var f in h) { for ( var m = [], v = [], g = 0; g !== u[d].morphTargets.length; ++g ) { var y = u[d] m.push(y.time), v.push(y.morphTarget === f ? 1 : 0) } r.push(new Ku('.morphTargetInfluence[' + f + ']', m, v)) } s = h.length * (o || 1) } else { var b = '.bones[' + t[c].name + ']' n(th, b + '.position', u, 'pos', r), n($u, b + '.quaternion', u, 'rot', r), n(th, b + '.scale', u, 'scl', r) } } return 0 === r.length ? null : new nh(i, s, r, a) }, }), Object.assign(nh.prototype, { resetDuration: function () { for (var e = 0, t = 0, n = this.tracks.length; t !== n; ++t) { var r = this.tracks[t] e = Math.max(e, r.times[r.times.length - 1]) } return (this.duration = e), this }, trim: function () { for (var e = 0; e < this.tracks.length; e++) this.tracks[e].trim(0, this.duration) return this }, validate: function () { for (var e = !0, t = 0; t < this.tracks.length; t++) e = e && this.tracks[t].validate() return e }, optimize: function () { for (var e = 0; e < this.tracks.length; e++) this.tracks[e].optimize() return this }, clone: function () { for (var e = [], t = 0; t < this.tracks.length; t++) e.push(this.tracks[t].clone()) return new nh(this.name, this.duration, e, this.blendMode) }, toJSON: function () { return nh.toJSON(this) }, }) var oh = { enabled: !1, files: {}, add: function (e, t) { !1 !== this.enabled && (this.files[e] = t) }, get: function (e) { if (!1 !== this.enabled) return this.files[e] }, remove: function (e) { delete this.files[e] }, clear: function () { this.files = {} }, } function ah(e, t, n) { var r = this, i = !1, o = 0, a = 0, s = void 0, l = [] ;(this.onStart = void 0), (this.onLoad = e), (this.onProgress = t), (this.onError = n), (this.itemStart = function (e) { a++, !1 === i && void 0 !== r.onStart && r.onStart(e, o, a), (i = !0) }), (this.itemEnd = function (e) { o++, void 0 !== r.onProgress && r.onProgress(e, o, a), o === a && ((i = !1), void 0 !== r.onLoad && r.onLoad()) }), (this.itemError = function (e) { void 0 !== r.onError && r.onError(e) }), (this.resolveURL = function (e) { return s ? s(e) : e }), (this.setURLModifier = function (e) { return (s = e), this }), (this.addHandler = function (e, t) { return l.push(e, t), this }), (this.removeHandler = function (e) { var t = l.indexOf(e) return -1 !== t && l.splice(t, 2), this }), (this.getHandler = function (e) { for (var t = 0, n = l.length; t < n; t += 2) { var r = l[t], i = l[t + 1] if ((r.global && (r.lastIndex = 0), r.test(e))) return i } return null }) } var sh = new ah() function lh(e) { ;(this.manager = void 0 !== e ? e : sh), (this.crossOrigin = 'anonymous'), (this.withCredentials = !1), (this.path = ''), (this.resourcePath = ''), (this.requestHeader = {}) } Object.assign(lh.prototype, { load: function () {}, loadAsync: function (e, t) { var n = this return new Promise(function (r, i) { n.load(e, r, t, i) }) }, parse: function () {}, setCrossOrigin: function (e) { return (this.crossOrigin = e), this }, setWithCredentials: function (e) { return (this.withCredentials = e), this }, setPath: function (e) { return (this.path = e), this }, setResourcePath: function (e) { return (this.resourcePath = e), this }, setRequestHeader: function (e) { return (this.requestHeader = e), this }, }) var ch = {} function uh(e) { lh.call(this, e) } function hh(e) { lh.call(this, e) } function dh(e) { lh.call(this, e) } function ph(e) { lh.call(this, e) } function fh(e) { lh.call(this, e) } function mh(e) { lh.call(this, e) } function vh(e) { lh.call(this, e) } function gh() { ;(this.type = 'Curve'), (this.arcLengthDivisions = 200) } function yh(e, t, n, r, i, o, a, s) { gh.call(this), (this.type = 'EllipseCurve'), (this.aX = e || 0), (this.aY = t || 0), (this.xRadius = n || 1), (this.yRadius = r || 1), (this.aStartAngle = i || 0), (this.aEndAngle = o || 2 * Math.PI), (this.aClockwise = a || !1), (this.aRotation = s || 0) } function bh(e, t, n, r, i, o) { yh.call(this, e, t, n, n, r, i, o), (this.type = 'ArcCurve') } function Ah() { var e = 0, t = 0, n = 0, r = 0 function i(i, o, a, s) { ;(e = i), (t = a), (n = -3 * i + 3 * o - 2 * a - s), (r = 2 * i - 2 * o + a + s) } return { initCatmullRom: function (e, t, n, r, o) { i(t, n, o * (n - e), o * (r - t)) }, initNonuniformCatmullRom: function (e, t, n, r, o, a, s) { var l = (t - e) / o - (n - e) / (o + a) + (n - t) / a, c = (n - t) / a - (r - t) / (a + s) + (r - n) / s i(t, n, (l *= a), (c *= a)) }, calc: function (i) { var o = i * i return e + t * i + n * o + r * (o * i) }, } } ;(uh.prototype = Object.assign(Object.create(lh.prototype), { constructor: uh, load: function (e, t, n, r) { void 0 === e && (e = ''), void 0 !== this.path && (e = this.path + e), (e = this.manager.resolveURL(e)) var i = this, o = oh.get(e) if (void 0 !== o) return ( i.manager.itemStart(e), setTimeout(function () { t && t(o), i.manager.itemEnd(e) }, 0), o ) if (void 0 === ch[e]) { var a, s = /^data:(.*?)(;base64)?,(.*)$/, l = e.match(s) if (l) { var c = l[1], u = !!l[2], h = l[3] ;(h = decodeURIComponent(h)), u && (h = atob(h)) try { var d, p = (this.responseType || '').toLowerCase() switch (p) { case 'arraybuffer': case 'blob': for (var f = new Uint8Array(h.length), m = 0; m < h.length; m++) f[m] = h.charCodeAt(m) d = 'blob' === p ? new Blob([f.buffer], { type: c }) : f.buffer break case 'document': var v = new DOMParser() d = v.parseFromString(h, c) break case 'json': d = JSON.parse(h) break default: d = h } setTimeout(function () { t && t(d), i.manager.itemEnd(e) }, 0) } catch (y) { setTimeout(function () { r && r(y), i.manager.itemError(e), i.manager.itemEnd(e) }, 0) } } else { for (var g in ((ch[e] = []), ch[e].push({ onLoad: t, onProgress: n, onError: r }), (a = new XMLHttpRequest()).open('GET', e, !0), a.addEventListener( 'load', function (t) { var n = this.response, r = ch[e] if ((delete ch[e], 200 === this.status || 0 === this.status)) { 0 === this.status && console.warn('THREE.FileLoader: HTTP Status 0 received.'), oh.add(e, n) for (var o = 0, a = r.length; o < a; o++) { var s = r[o] s.onLoad && s.onLoad(n) } i.manager.itemEnd(e) } else { for (var l = 0, c = r.length; l < c; l++) { var u = r[l] u.onError && u.onError(t) } i.manager.itemError(e), i.manager.itemEnd(e) } }, !1, ), a.addEventListener( 'progress', function (t) { for (var n = ch[e], r = 0, i = n.length; r < i; r++) { var o = n[r] o.onProgress && o.onProgress(t) } }, !1, ), a.addEventListener( 'error', function (t) { var n = ch[e] delete ch[e] for (var r = 0, o = n.length; r < o; r++) { var a = n[r] a.onError && a.onError(t) } i.manager.itemError(e), i.manager.itemEnd(e) }, !1, ), a.addEventListener( 'abort', function (t) { var n = ch[e] delete ch[e] for (var r = 0, o = n.length; r < o; r++) { var a = n[r] a.onError && a.onError(t) } i.manager.itemError(e), i.manager.itemEnd(e) }, !1, ), void 0 !== this.responseType && (a.responseType = this.responseType), void 0 !== this.withCredentials && (a.withCredentials = this.withCredentials), a.overrideMimeType && a.overrideMimeType( void 0 !== this.mimeType ? this.mimeType : 'text/plain', ), this.requestHeader)) a.setRequestHeader(g, this.requestHeader[g]) a.send(null) } return i.manager.itemStart(e), a } ch[e].push({ onLoad: t, onProgress: n, onError: r }) }, setResponseType: function (e) { return (this.responseType = e), this }, setMimeType: function (e) { return (this.mimeType = e), this }, })), (hh.prototype = Object.assign(Object.create(lh.prototype), { constructor: hh, load: function (t, n, r, i) { var o = this, a = new uh(o.manager) a.setPath(o.path), a.setRequestHeader(o.requestHeader), a.setWithCredentials(o.withCredentials), a.load( t, function (r) { try { n(o.parse(JSON.parse(r))) } catch (e) { i ? i(e) : console.error(e), o.manager.itemError(t) } }, r, i, ) }, parse: function (e) { for (var t = [], n = 0; n < e.length; n++) { var r = nh.parse(e[n]) t.push(r) } return t }, })), (dh.prototype = Object.assign(Object.create(lh.prototype), { constructor: dh, load: function (e, t, n, r) { var i = this, o = [], a = new Ac(), s = new uh(this.manager) s.setPath(this.path), s.setResponseType('arraybuffer'), s.setRequestHeader(this.requestHeader), s.setWithCredentials(i.withCredentials) var l = 0 function c(c) { s.load( e[c], function (e) { var n = i.parse(e, !0) ;(o[c] = { width: n.width, height: n.height, format: n.format, mipmaps: n.mipmaps, }), 6 === (l += 1) && (1 === n.mipmapCount && (a.minFilter = Ae), (a.image = o), (a.format = n.format), (a.needsUpdate = !0), t && t(a)) }, n, r, ) } if (Array.isArray(e)) for (var u = 0, h = e.length; u < h; ++u) c(u) else s.load( e, function (e) { var n = i.parse(e, !0) if (n.isCubemap) { for ( var r = n.mipmaps.length / n.mipmapCount, s = 0; s < r; s++ ) { o[s] = { mipmaps: [] } for (var l = 0; l < n.mipmapCount; l++) o[s].mipmaps.push(n.mipmaps[s * n.mipmapCount + l]), (o[s].format = n.format), (o[s].width = n.width), (o[s].height = n.height) } a.image = o } else (a.image.width = n.width), (a.image.height = n.height), (a.mipmaps = n.mipmaps) 1 === n.mipmapCount && (a.minFilter = Ae), (a.format = n.format), (a.needsUpdate = !0), t && t(a) }, n, r, ) return a }, })), (ph.prototype = Object.assign(Object.create(lh.prototype), { constructor: ph, load: function (e, t, n, r) { void 0 !== this.path && (e = this.path + e), (e = this.manager.resolveURL(e)) var i = this, o = oh.get(e) if (void 0 !== o) return ( i.manager.itemStart(e), setTimeout(function () { t && t(o), i.manager.itemEnd(e) }, 0), o ) var a = document.createElementNS('http://www.w3.org/1999/xhtml', 'img') function s() { a.removeEventListener('load', s, !1), a.removeEventListener('error', l, !1), oh.add(e, this), t && t(this), i.manager.itemEnd(e) } function l(t) { a.removeEventListener('load', s, !1), a.removeEventListener('error', l, !1), r && r(t), i.manager.itemError(e), i.manager.itemEnd(e) } return ( a.addEventListener('load', s, !1), a.addEventListener('error', l, !1), 'data:' !== e.substr(0, 5) && void 0 !== this.crossOrigin && (a.crossOrigin = this.crossOrigin), i.manager.itemStart(e), (a.src = e), a ) }, })), (fh.prototype = Object.assign(Object.create(lh.prototype), { constructor: fh, load: function (e, t, n, r) { var i = new ko(), o = new ph(this.manager) o.setCrossOrigin(this.crossOrigin), o.setPath(this.path) var a = 0 function s(n) { o.load( e[n], function (e) { ;(i.images[n] = e), 6 === ++a && ((i.needsUpdate = !0), t && t(i)) }, void 0, r, ) } for (var l = 0; l < e.length; ++l) s(l) return i }, })), (mh.prototype = Object.assign(Object.create(lh.prototype), { constructor: mh, load: function (e, t, n, r) { var i = this, o = new Uo(), a = new uh(this.manager) return ( a.setResponseType('arraybuffer'), a.setRequestHeader(this.requestHeader), a.setPath(this.path), a.setWithCredentials(i.withCredentials), a.load( e, function (e) { var n = i.parse(e) n && (void 0 !== n.image ? (o.image = n.image) : void 0 !== n.data && ((o.image.width = n.width), (o.image.height = n.height), (o.image.data = n.data)), (o.wrapS = void 0 !== n.wrapS ? n.wrapS : pe), (o.wrapT = void 0 !== n.wrapT ? n.wrapT : pe), (o.magFilter = void 0 !== n.magFilter ? n.magFilter : Ae), (o.minFilter = void 0 !== n.minFilter ? n.minFilter : Ae), (o.anisotropy = void 0 !== n.anisotropy ? n.anisotropy : 1), void 0 !== n.encoding && (o.encoding = n.encoding), void 0 !== n.flipY && (o.flipY = n.flipY), void 0 !== n.format && (o.format = n.format), void 0 !== n.type && (o.type = n.type), void 0 !== n.mipmaps && ((o.mipmaps = n.mipmaps), (o.minFilter = Ee)), 1 === n.mipmapCount && (o.minFilter = Ae), (o.needsUpdate = !0), t && t(o, n)) }, n, r, ), o ) }, })), (vh.prototype = Object.assign(Object.create(lh.prototype), { constructor: vh, load: function (e, t, n, r) { var i = new nr(), o = new ph(this.manager) return ( o.setCrossOrigin(this.crossOrigin), o.setPath(this.path), o.load( e, function (n) { i.image = n var r = e.search(/\.jpe?g($|\?)/i) > 0 || 0 === e.search(/^data\:image\/jpeg/) ;(i.format = r ? Ne : Ue), (i.needsUpdate = !0), void 0 !== t && t(i) }, n, r, ), i ) }, })), Object.assign(gh.prototype, { getPoint: function () { return console.warn('THREE.Curve: .getPoint() not implemented.'), null }, getPointAt: function (e, t) { var n = this.getUtoTmapping(e) return this.getPoint(n, t) }, getPoints: function (e) { void 0 === e && (e = 5) for (var t = [], n = 0; n <= e; n++) t.push(this.getPoint(n / e)) return t }, getSpacedPoints: function (e) { void 0 === e && (e = 5) for (var t = [], n = 0; n <= e; n++) t.push(this.getPointAt(n / e)) return t }, getLength: function () { var e = this.getLengths() return e[e.length - 1] }, getLengths: function (e) { if ( (void 0 === e && (e = this.arcLengthDivisions), this.cacheArcLengths && this.cacheArcLengths.length === e + 1 && !this.needsUpdate) ) return this.cacheArcLengths this.needsUpdate = !1 var t, n = [], r = this.getPoint(0), i = 0 n.push(0) for (var o = 1; o <= e; o++) (i += (t = this.getPoint(o / e)).distanceTo(r)), n.push(i), (r = t) return (this.cacheArcLengths = n), n }, updateArcLengths: function () { ;(this.needsUpdate = !0), this.getLengths() }, getUtoTmapping: function (e, t) { var n, r = this.getLengths(), i = 0, o = r.length n = t || e * r[o - 1] for (var a, s = 0, l = o - 1; s <= l; ) if ((a = r[(i = Math.floor(s + (l - s) / 2))] - n) < 0) s = i + 1 else { if (!(a > 0)) { l = i break } l = i - 1 } if (r[(i = l)] === n) return i / (o - 1) var c = r[i] return (i + (n - c) / (r[i + 1] - c)) / (o - 1) }, getTangent: function (e, t) { var n = 1e-4, r = e - n, i = e + n r < 0 && (r = 0), i > 1 && (i = 1) var o = this.getPoint(r), a = this.getPoint(i), s = t || (o.isVector2 ? new Jn() : new lr()) return s.copy(a).sub(o).normalize(), s }, getTangentAt: function (e, t) { var n = this.getUtoTmapping(e) return this.getTangent(n, t) }, computeFrenetFrames: function (e, t) { for ( var n = new lr(), r = [], i = [], o = [], a = new lr(), s = new Fr(), l = 0; l <= e; l++ ) { var c = l / e ;(r[l] = this.getTangentAt(c, new lr())), r[l].normalize() } ;(i[0] = new lr()), (o[0] = new lr()) var u = Number.MAX_VALUE, h = Math.abs(r[0].x), d = Math.abs(r[0].y), p = Math.abs(r[0].z) h <= u && ((u = h), n.set(1, 0, 0)), d <= u && ((u = d), n.set(0, 1, 0)), p <= u && n.set(0, 0, 1), a.crossVectors(r[0], n).normalize(), i[0].crossVectors(r[0], a), o[0].crossVectors(r[0], i[0]) for (var f = 1; f <= e; f++) { if ( ((i[f] = i[f - 1].clone()), (o[f] = o[f - 1].clone()), a.crossVectors(r[f - 1], r[f]), a.length() > Number.EPSILON) ) { a.normalize() var m = Math.acos(Kn.clamp(r[f - 1].dot(r[f]), -1, 1)) i[f].applyMatrix4(s.makeRotationAxis(a, m)) } o[f].crossVectors(r[f], i[f]) } if (!0 === t) { var v = Math.acos(Kn.clamp(i[0].dot(i[e]), -1, 1)) ;(v /= e), r[0].dot(a.crossVectors(i[0], i[e])) > 0 && (v = -v) for (var g = 1; g <= e; g++) i[g].applyMatrix4(s.makeRotationAxis(r[g], v * g)), o[g].crossVectors(r[g], i[g]) } return { tangents: r, normals: i, binormals: o } }, clone: function () { return new this.constructor().copy(this) }, copy: function (e) { return (this.arcLengthDivisions = e.arcLengthDivisions), this }, toJSON: function () { var e = { metadata: { version: 4.5, type: 'Curve', generator: 'Curve.toJSON' }, } return ( (e.arcLengthDivisions = this.arcLengthDivisions), (e.type = this.type), e ) }, fromJSON: function (e) { return (this.arcLengthDivisions = e.arcLengthDivisions), this }, }), (yh.prototype = Object.create(gh.prototype)), (yh.prototype.constructor = yh), (yh.prototype.isEllipseCurve = !0), (yh.prototype.getPoint = function (e, t) { for ( var n = t || new Jn(), r = 2 * Math.PI, i = this.aEndAngle - this.aStartAngle, o = Math.abs(i) < Number.EPSILON; i < 0; ) i += r for (; i > r; ) i -= r i < Number.EPSILON && (i = o ? 0 : r), !0 !== this.aClockwise || o || (i === r ? (i = -r) : (i -= r)) var a = this.aStartAngle + e * i, s = this.aX + this.xRadius * Math.cos(a), l = this.aY + this.yRadius * Math.sin(a) if (0 !== this.aRotation) { var c = Math.cos(this.aRotation), u = Math.sin(this.aRotation), h = s - this.aX, d = l - this.aY ;(s = h * c - d * u + this.aX), (l = h * u + d * c + this.aY) } return n.set(s, l) }), (yh.prototype.copy = function (e) { return ( gh.prototype.copy.call(this, e), (this.aX = e.aX), (this.aY = e.aY), (this.xRadius = e.xRadius), (this.yRadius = e.yRadius), (this.aStartAngle = e.aStartAngle), (this.aEndAngle = e.aEndAngle), (this.aClockwise = e.aClockwise), (this.aRotation = e.aRotation), this ) }), (yh.prototype.toJSON = function () { var e = gh.prototype.toJSON.call(this) return ( (e.aX = this.aX), (e.aY = this.aY), (e.xRadius = this.xRadius), (e.yRadius = this.yRadius), (e.aStartAngle = this.aStartAngle), (e.aEndAngle = this.aEndAngle), (e.aClockwise = this.aClockwise), (e.aRotation = this.aRotation), e ) }), (yh.prototype.fromJSON = function (e) { return ( gh.prototype.fromJSON.call(this, e), (this.aX = e.aX), (this.aY = e.aY), (this.xRadius = e.xRadius), (this.yRadius = e.yRadius), (this.aStartAngle = e.aStartAngle), (this.aEndAngle = e.aEndAngle), (this.aClockwise = e.aClockwise), (this.aRotation = e.aRotation), this ) }), (bh.prototype = Object.create(yh.prototype)), (bh.prototype.constructor = bh), (bh.prototype.isArcCurve = !0) var wh = new lr(), xh = new Ah(), Eh = new Ah(), Mh = new Ah() function _h(e, t, n, r) { void 0 === e && (e = []), void 0 === t && (t = !1), void 0 === n && (n = 'centripetal'), void 0 === r && (r = 0.5), gh.call(this), (this.type = 'CatmullRomCurve3'), (this.points = e), (this.closed = t), (this.curveType = n), (this.tension = r) } function Th(e, t, n, r, i) { var o = 0.5 * (r - t), a = 0.5 * (i - n), s = e * e return ( (2 * n - 2 * r + o + a) * (e * s) + (-3 * n + 3 * r - 2 * o - a) * s + o * e + n ) } function Sh(e, t) { var n = 1 - e return n * n * t } function Ch(e, t) { return 2 * (1 - e) * e * t } function Lh(e, t) { return e * e * t } function Rh(e, t, n, r) { return Sh(e, t) + Ch(e, n) + Lh(e, r) } function Ph(e, t) { var n = 1 - e return n * n * n * t } function Dh(e, t) { var n = 1 - e return 3 * n * n * e * t } function Oh(e, t) { return 3 * (1 - e) * e * e * t } function Ih(e, t) { return e * e * e * t } function Bh(e, t, n, r, i) { return Ph(e, t) + Dh(e, n) + Oh(e, r) + Ih(e, i) } function Fh(e, t, n, r) { void 0 === e && (e = new Jn()), void 0 === t && (t = new Jn()), void 0 === n && (n = new Jn()), void 0 === r && (r = new Jn()), gh.call(this), (this.type = 'CubicBezierCurve'), (this.v0 = e), (this.v1 = t), (this.v2 = n), (this.v3 = r) } function kh(e, t, n, r) { void 0 === e && (e = new lr()), void 0 === t && (t = new lr()), void 0 === n && (n = new lr()), void 0 === r && (r = new lr()), gh.call(this), (this.type = 'CubicBezierCurve3'), (this.v0 = e), (this.v1 = t), (this.v2 = n), (this.v3 = r) } function Nh(e, t) { void 0 === e && (e = new Jn()), void 0 === t && (t = new Jn()), gh.call(this), (this.type = 'LineCurve'), (this.v1 = e), (this.v2 = t) } function Uh(e, t) { void 0 === e && (e = new lr()), void 0 === t && (t = new lr()), gh.call(this), (this.type = 'LineCurve3'), (this.v1 = e), (this.v2 = t) } function Hh(e, t, n) { void 0 === e && (e = new Jn()), void 0 === t && (t = new Jn()), void 0 === n && (n = new Jn()), gh.call(this), (this.type = 'QuadraticBezierCurve'), (this.v0 = e), (this.v1 = t), (this.v2 = n) } function Gh(e, t, n) { void 0 === e && (e = new lr()), void 0 === t && (t = new lr()), void 0 === n && (n = new lr()), gh.call(this), (this.type = 'QuadraticBezierCurve3'), (this.v0 = e), (this.v1 = t), (this.v2 = n) } function zh(e) { void 0 === e && (e = []), gh.call(this), (this.type = 'SplineCurve'), (this.points = e) } ;(_h.prototype = Object.create(gh.prototype)), (_h.prototype.constructor = _h), (_h.prototype.isCatmullRomCurve3 = !0), (_h.prototype.getPoint = function (e, t) { void 0 === t && (t = new lr()) var n, r, i = t, o = this.points, a = o.length, s = (a - (this.closed ? 0 : 1)) * e, l = Math.floor(s), c = s - l this.closed ? (l += l > 0 ? 0 : (Math.floor(Math.abs(l) / a) + 1) * a) : 0 === c && l === a - 1 && ((l = a - 2), (c = 1)), this.closed || l > 0 ? (n = o[(l - 1) % a]) : (wh.subVectors(o[0], o[1]).add(o[0]), (n = wh)) var u = o[l % a], h = o[(l + 1) % a] if ( (this.closed || l + 2 < a ? (r = o[(l + 2) % a]) : (wh.subVectors(o[a - 1], o[a - 2]).add(o[a - 1]), (r = wh)), 'centripetal' === this.curveType || 'chordal' === this.curveType) ) { var d = 'chordal' === this.curveType ? 0.5 : 0.25, p = Math.pow(n.distanceToSquared(u), d), f = Math.pow(u.distanceToSquared(h), d), m = Math.pow(h.distanceToSquared(r), d) f < 1e-4 && (f = 1), p < 1e-4 && (p = f), m < 1e-4 && (m = f), xh.initNonuniformCatmullRom(n.x, u.x, h.x, r.x, p, f, m), Eh.initNonuniformCatmullRom(n.y, u.y, h.y, r.y, p, f, m), Mh.initNonuniformCatmullRom(n.z, u.z, h.z, r.z, p, f, m) } else 'catmullrom' === this.curveType && (xh.initCatmullRom(n.x, u.x, h.x, r.x, this.tension), Eh.initCatmullRom(n.y, u.y, h.y, r.y, this.tension), Mh.initCatmullRom(n.z, u.z, h.z, r.z, this.tension)) return i.set(xh.calc(c), Eh.calc(c), Mh.calc(c)), i }), (_h.prototype.copy = function (e) { gh.prototype.copy.call(this, e), (this.points = []) for (var t = 0, n = e.points.length; t < n; t++) { var r = e.points[t] this.points.push(r.clone()) } return ( (this.closed = e.closed), (this.curveType = e.curveType), (this.tension = e.tension), this ) }), (_h.prototype.toJSON = function () { var e = gh.prototype.toJSON.call(this) e.points = [] for (var t = 0, n = this.points.length; t < n; t++) { var r = this.points[t] e.points.push(r.toArray()) } return ( (e.closed = this.closed), (e.curveType = this.curveType), (e.tension = this.tension), e ) }), (_h.prototype.fromJSON = function (e) { gh.prototype.fromJSON.call(this, e), (this.points = []) for (var t = 0, n = e.points.length; t < n; t++) { var r = e.points[t] this.points.push(new lr().fromArray(r)) } return ( (this.closed = e.closed), (this.curveType = e.curveType), (this.tension = e.tension), this ) }), (Fh.prototype = Object.create(gh.prototype)), (Fh.prototype.constructor = Fh), (Fh.prototype.isCubicBezierCurve = !0), (Fh.prototype.getPoint = function (e, t) { void 0 === t && (t = new Jn()) var n = t, r = this.v0, i = this.v1, o = this.v2, a = this.v3 return n.set(Bh(e, r.x, i.x, o.x, a.x), Bh(e, r.y, i.y, o.y, a.y)), n }), (Fh.prototype.copy = function (e) { return ( gh.prototype.copy.call(this, e), this.v0.copy(e.v0), this.v1.copy(e.v1), this.v2.copy(e.v2), this.v3.copy(e.v3), this ) }), (Fh.prototype.toJSON = function () { var e = gh.prototype.toJSON.call(this) return ( (e.v0 = this.v0.toArray()), (e.v1 = this.v1.toArray()), (e.v2 = this.v2.toArray()), (e.v3 = this.v3.toArray()), e ) }), (Fh.prototype.fromJSON = function (e) { return ( gh.prototype.fromJSON.call(this, e), this.v0.fromArray(e.v0), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this.v3.fromArray(e.v3), this ) }), (kh.prototype = Object.create(gh.prototype)), (kh.prototype.constructor = kh), (kh.prototype.isCubicBezierCurve3 = !0), (kh.prototype.getPoint = function (e, t) { void 0 === t && (t = new lr()) var n = t, r = this.v0, i = this.v1, o = this.v2, a = this.v3 return ( n.set( Bh(e, r.x, i.x, o.x, a.x), Bh(e, r.y, i.y, o.y, a.y), Bh(e, r.z, i.z, o.z, a.z), ), n ) }), (kh.prototype.copy = function (e) { return ( gh.prototype.copy.call(this, e), this.v0.copy(e.v0), this.v1.copy(e.v1), this.v2.copy(e.v2), this.v3.copy(e.v3), this ) }), (kh.prototype.toJSON = function () { var e = gh.prototype.toJSON.call(this) return ( (e.v0 = this.v0.toArray()), (e.v1 = this.v1.toArray()), (e.v2 = this.v2.toArray()), (e.v3 = this.v3.toArray()), e ) }), (kh.prototype.fromJSON = function (e) { return ( gh.prototype.fromJSON.call(this, e), this.v0.fromArray(e.v0), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this.v3.fromArray(e.v3), this ) }), (Nh.prototype = Object.create(gh.prototype)), (Nh.prototype.constructor = Nh), (Nh.prototype.isLineCurve = !0), (Nh.prototype.getPoint = function (e, t) { void 0 === t && (t = new Jn()) var n = t return ( 1 === e ? n.copy(this.v2) : (n.copy(this.v2).sub(this.v1), n.multiplyScalar(e).add(this.v1)), n ) }), (Nh.prototype.getPointAt = function (e, t) { return this.getPoint(e, t) }), (Nh.prototype.getTangent = function (e, t) { var n = t || new Jn() return n.copy(this.v2).sub(this.v1).normalize(), n }), (Nh.prototype.copy = function (e) { return ( gh.prototype.copy.call(this, e), this.v1.copy(e.v1), this.v2.copy(e.v2), this ) }), (Nh.prototype.toJSON = function () { var e = gh.prototype.toJSON.call(this) return (e.v1 = this.v1.toArray()), (e.v2 = this.v2.toArray()), e }), (Nh.prototype.fromJSON = function (e) { return ( gh.prototype.fromJSON.call(this, e), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this ) }), (Uh.prototype = Object.create(gh.prototype)), (Uh.prototype.constructor = Uh), (Uh.prototype.isLineCurve3 = !0), (Uh.prototype.getPoint = function (e, t) { void 0 === t && (t = new lr()) var n = t return ( 1 === e ? n.copy(this.v2) : (n.copy(this.v2).sub(this.v1), n.multiplyScalar(e).add(this.v1)), n ) }), (Uh.prototype.getPointAt = function (e, t) { return this.getPoint(e, t) }), (Uh.prototype.copy = function (e) { return ( gh.prototype.copy.call(this, e), this.v1.copy(e.v1), this.v2.copy(e.v2), this ) }), (Uh.prototype.toJSON = function () { var e = gh.prototype.toJSON.call(this) return (e.v1 = this.v1.toArray()), (e.v2 = this.v2.toArray()), e }), (Uh.prototype.fromJSON = function (e) { return ( gh.prototype.fromJSON.call(this, e), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this ) }), (Hh.prototype = Object.create(gh.prototype)), (Hh.prototype.constructor = Hh), (Hh.prototype.isQuadraticBezierCurve = !0), (Hh.prototype.getPoint = function (e, t) { void 0 === t && (t = new Jn()) var n = t, r = this.v0, i = this.v1, o = this.v2 return n.set(Rh(e, r.x, i.x, o.x), Rh(e, r.y, i.y, o.y)), n }), (Hh.prototype.copy = function (e) { return ( gh.prototype.copy.call(this, e), this.v0.copy(e.v0), this.v1.copy(e.v1), this.v2.copy(e.v2), this ) }), (Hh.prototype.toJSON = function () { var e = gh.prototype.toJSON.call(this) return ( (e.v0 = this.v0.toArray()), (e.v1 = this.v1.toArray()), (e.v2 = this.v2.toArray()), e ) }), (Hh.prototype.fromJSON = function (e) { return ( gh.prototype.fromJSON.call(this, e), this.v0.fromArray(e.v0), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this ) }), (Gh.prototype = Object.create(gh.prototype)), (Gh.prototype.constructor = Gh), (Gh.prototype.isQuadraticBezierCurve3 = !0), (Gh.prototype.getPoint = function (e, t) { void 0 === t && (t = new lr()) var n = t, r = this.v0, i = this.v1, o = this.v2 return ( n.set(Rh(e, r.x, i.x, o.x), Rh(e, r.y, i.y, o.y), Rh(e, r.z, i.z, o.z)), n ) }), (Gh.prototype.copy = function (e) { return ( gh.prototype.copy.call(this, e), this.v0.copy(e.v0), this.v1.copy(e.v1), this.v2.copy(e.v2), this ) }), (Gh.prototype.toJSON = function () { var e = gh.prototype.toJSON.call(this) return ( (e.v0 = this.v0.toArray()), (e.v1 = this.v1.toArray()), (e.v2 = this.v2.toArray()), e ) }), (Gh.prototype.fromJSON = function (e) { return ( gh.prototype.fromJSON.call(this, e), this.v0.fromArray(e.v0), this.v1.fromArray(e.v1), this.v2.fromArray(e.v2), this ) }), (zh.prototype = Object.create(gh.prototype)), (zh.prototype.constructor = zh), (zh.prototype.isSplineCurve = !0), (zh.prototype.getPoint = function (e, t) { void 0 === t && (t = new Jn()) var n = t, r = this.points, i = (r.length - 1) * e, o = Math.floor(i), a = i - o, s = r[0 === o ? o : o - 1], l = r[o], c = r[o > r.length - 2 ? r.length - 1 : o + 1], u = r[o > r.length - 3 ? r.length - 1 : o + 2] return n.set(Th(a, s.x, l.x, c.x, u.x), Th(a, s.y, l.y, c.y, u.y)), n }), (zh.prototype.copy = function (e) { gh.prototype.copy.call(this, e), (this.points = []) for (var t = 0, n = e.points.length; t < n; t++) { var r = e.points[t] this.points.push(r.clone()) } return this }), (zh.prototype.toJSON = function () { var e = gh.prototype.toJSON.call(this) e.points = [] for (var t = 0, n = this.points.length; t < n; t++) { var r = this.points[t] e.points.push(r.toArray()) } return e }), (zh.prototype.fromJSON = function (e) { gh.prototype.fromJSON.call(this, e), (this.points = []) for (var t = 0, n = e.points.length; t < n; t++) { var r = e.points[t] this.points.push(new Jn().fromArray(r)) } return this }) var jh = Object.freeze({ __proto__: null, ArcCurve: bh, CatmullRomCurve3: _h, CubicBezierCurve: Fh, CubicBezierCurve3: kh, EllipseCurve: yh, LineCurve: Nh, LineCurve3: Uh, QuadraticBezierCurve: Hh, QuadraticBezierCurve3: Gh, SplineCurve: zh, }) function Vh() { gh.call(this), (this.type = 'CurvePath'), (this.curves = []), (this.autoClose = !1) } function Wh(e) { Vh.call(this), (this.type = 'Path'), (this.currentPoint = new Jn()), e && this.setFromPoints(e) } function qh(e) { Wh.call(this, e), (this.uuid = Kn.generateUUID()), (this.type = 'Shape'), (this.holes = []) } function Xh(e, t) { void 0 === t && (t = 1), si.call(this), (this.type = 'Light'), (this.color = new Li(e)), (this.intensity = t) } function Yh(e, t, n) { Xh.call(this, e, n), (this.type = 'HemisphereLight'), this.position.copy(si.DefaultUp), this.updateMatrix(), (this.groundColor = new Li(t)) } function Qh(e) { ;(this.camera = e), (this.bias = 0), (this.normalBias = 0), (this.radius = 1), (this.mapSize = new Jn(512, 512)), (this.map = null), (this.mapPass = null), (this.matrix = new Fr()), (this.autoUpdate = !0), (this.needsUpdate = !1), (this._frustum = new zo()), (this._frameExtents = new Jn(1, 1)), (this._viewportCount = 1), (this._viewports = [new ir(0, 0, 1, 1)]) } function Zh() { Qh.call(this, new Oo(50, 1, 0.5, 500)), (this.focus = 1) } function Kh(e, t, n, r, i, o) { Xh.call(this, e, t), (this.type = 'SpotLight'), this.position.copy(si.DefaultUp), this.updateMatrix(), (this.target = new si()), Object.defineProperty(this, 'power', { get: function () { return this.intensity * Math.PI }, set: function (e) { this.intensity = e / Math.PI }, }), (this.distance = void 0 !== n ? n : 0), (this.angle = void 0 !== r ? r : Math.PI / 3), (this.penumbra = void 0 !== i ? i : 0), (this.decay = void 0 !== o ? o : 1), (this.shadow = new Zh()) } function Jh() { Qh.call(this, new Oo(90, 1, 0.5, 500)), (this._frameExtents = new Jn(4, 2)), (this._viewportCount = 6), (this._viewports = [ new ir(2, 1, 1, 1), new ir(0, 1, 1, 1), new ir(3, 1, 1, 1), new ir(1, 1, 1, 1), new ir(3, 0, 1, 1), new ir(1, 0, 1, 1), ]), (this._cubeDirections = [ new lr(1, 0, 0), new lr(-1, 0, 0), new lr(0, 0, 1), new lr(0, 0, -1), new lr(0, 1, 0), new lr(0, -1, 0), ]), (this._cubeUps = [ new lr(0, 1, 0), new lr(0, 1, 0), new lr(0, 1, 0), new lr(0, 1, 0), new lr(0, 0, 1), new lr(0, 0, -1), ]) } function $h(e, t, n, r) { Xh.call(this, e, t), (this.type = 'PointLight'), Object.defineProperty(this, 'power', { get: function () { return 4 * this.intensity * Math.PI }, set: function (e) { this.intensity = e / (4 * Math.PI) }, }), (this.distance = void 0 !== n ? n : 0), (this.decay = void 0 !== r ? r : 1), (this.shadow = new Jh()) } function ed(e, t, n, r, i, o) { void 0 === e && (e = -1), void 0 === t && (t = 1), void 0 === n && (n = 1), void 0 === r && (r = -1), void 0 === i && (i = 0.1), void 0 === o && (o = 2e3), Do.call(this), (this.type = 'OrthographicCamera'), (this.zoom = 1), (this.view = null), (this.left = e), (this.right = t), (this.top = n), (this.bottom = r), (this.near = i), (this.far = o), this.updateProjectionMatrix() } function td() { Qh.call(this, new ed(-5, 5, 5, -5, 0.5, 500)) } function nd(e, t) { Xh.call(this, e, t), (this.type = 'DirectionalLight'), this.position.copy(si.DefaultUp), this.updateMatrix(), (this.target = new si()), (this.shadow = new td()) } function rd(e, t) { Xh.call(this, e, t), (this.type = 'AmbientLight') } function id(e, t, n, r) { Xh.call(this, e, t), (this.type = 'RectAreaLight'), (this.width = void 0 !== n ? n : 10), (this.height = void 0 !== r ? r : 10) } ;(Vh.prototype = Object.assign(Object.create(gh.prototype), { constructor: Vh, add: function (e) { this.curves.push(e) }, closePath: function () { var e = this.curves[0].getPoint(0), t = this.curves[this.curves.length - 1].getPoint(1) e.equals(t) || this.curves.push(new Nh(t, e)) }, getPoint: function (e) { for ( var t = e * this.getLength(), n = this.getCurveLengths(), r = 0; r < n.length; ) { if (n[r] >= t) { var i = n[r] - t, o = this.curves[r], a = o.getLength(), s = 0 === a ? 0 : 1 - i / a return o.getPointAt(s) } r++ } return null }, getLength: function () { var e = this.getCurveLengths() return e[e.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 e = [], t = 0, n = 0, r = this.curves.length; n < r; n++) (t += this.curves[n].getLength()), e.push(t) return (this.cacheLengths = e), e }, getSpacedPoints: function (e) { void 0 === e && (e = 40) for (var t = [], n = 0; n <= e; n++) t.push(this.getPoint(n / e)) return this.autoClose && t.push(t[0]), t }, getPoints: function (e) { void 0 === e && (e = 12) for (var t, n = [], r = 0, i = this.curves; r < i.length; r++) for ( var o = i[r], a = o && o.isEllipseCurve ? 2 * e : o && (o.isLineCurve || o.isLineCurve3) ? 1 : o && o.isSplineCurve ? e * o.points.length : e, s = o.getPoints(a), l = 0; l < s.length; l++ ) { var c = s[l] ;(t && t.equals(c)) || (n.push(c), (t = c)) } return ( this.autoClose && n.length > 1 && !n[n.length - 1].equals(n[0]) && n.push(n[0]), n ) }, copy: function (e) { gh.prototype.copy.call(this, e), (this.curves = []) for (var t = 0, n = e.curves.length; t < n; t++) { var r = e.curves[t] this.curves.push(r.clone()) } return (this.autoClose = e.autoClose), this }, toJSON: function () { var e = gh.prototype.toJSON.call(this) ;(e.autoClose = this.autoClose), (e.curves = []) for (var t = 0, n = this.curves.length; t < n; t++) { var r = this.curves[t] e.curves.push(r.toJSON()) } return e }, fromJSON: function (e) { gh.prototype.fromJSON.call(this, e), (this.autoClose = e.autoClose), (this.curves = []) for (var t = 0, n = e.curves.length; t < n; t++) { var r = e.curves[t] this.curves.push(new jh[r.type]().fromJSON(r)) } return this }, })), (Wh.prototype = Object.assign(Object.create(Vh.prototype), { constructor: Wh, setFromPoints: function (e) { this.moveTo(e[0].x, e[0].y) for (var t = 1, n = e.length; t < n; t++) this.lineTo(e[t].x, e[t].y) return this }, moveTo: function (e, t) { return this.currentPoint.set(e, t), this }, lineTo: function (e, t) { var n = new Nh(this.currentPoint.clone(), new Jn(e, t)) return this.curves.push(n), this.currentPoint.set(e, t), this }, quadraticCurveTo: function (e, t, n, r) { var i = new Hh(this.currentPoint.clone(), new Jn(e, t), new Jn(n, r)) return this.curves.push(i), this.currentPoint.set(n, r), this }, bezierCurveTo: function (e, t, n, r, i, o) { var a = new Fh( this.currentPoint.clone(), new Jn(e, t), new Jn(n, r), new Jn(i, o), ) return this.curves.push(a), this.currentPoint.set(i, o), this }, splineThru: function (e) { var t = new zh([this.currentPoint.clone()].concat(e)) return this.curves.push(t), this.currentPoint.copy(e[e.length - 1]), this }, arc: function (e, t, n, r, i, o) { var a = this.currentPoint.x, s = this.currentPoint.y return this.absarc(e + a, t + s, n, r, i, o), this }, absarc: function (e, t, n, r, i, o) { return this.absellipse(e, t, n, n, r, i, o), this }, ellipse: function (e, t, n, r, i, o, a, s) { var l = this.currentPoint.x, c = this.currentPoint.y return this.absellipse(e + l, t + c, n, r, i, o, a, s), this }, absellipse: function (e, t, n, r, i, o, a, s) { var l = new yh(e, t, n, r, i, o, a, s) if (this.curves.length > 0) { var c = l.getPoint(0) c.equals(this.currentPoint) || this.lineTo(c.x, c.y) } this.curves.push(l) var u = l.getPoint(1) return this.currentPoint.copy(u), this }, copy: function (e) { return ( Vh.prototype.copy.call(this, e), this.currentPoint.copy(e.currentPoint), this ) }, toJSON: function () { var e = Vh.prototype.toJSON.call(this) return (e.currentPoint = this.currentPoint.toArray()), e }, fromJSON: function (e) { return ( Vh.prototype.fromJSON.call(this, e), this.currentPoint.fromArray(e.currentPoint), this ) }, })), (qh.prototype = Object.assign(Object.create(Wh.prototype), { constructor: qh, getPointsHoles: function (e) { for (var t = [], n = 0, r = this.holes.length; n < r; n++) t[n] = this.holes[n].getPoints(e) return t }, extractPoints: function (e) { return { shape: this.getPoints(e), holes: this.getPointsHoles(e) } }, copy: function (e) { Wh.prototype.copy.call(this, e), (this.holes = []) for (var t = 0, n = e.holes.length; t < n; t++) { var r = e.holes[t] this.holes.push(r.clone()) } return this }, toJSON: function () { var e = Wh.prototype.toJSON.call(this) ;(e.uuid = this.uuid), (e.holes = []) for (var t = 0, n = this.holes.length; t < n; t++) { var r = this.holes[t] e.holes.push(r.toJSON()) } return e }, fromJSON: function (e) { Wh.prototype.fromJSON.call(this, e), (this.uuid = e.uuid), (this.holes = []) for (var t = 0, n = e.holes.length; t < n; t++) { var r = e.holes[t] this.holes.push(new Wh().fromJSON(r)) } return this }, })), (Xh.prototype = Object.assign(Object.create(si.prototype), { constructor: Xh, isLight: !0, copy: function (e) { return ( si.prototype.copy.call(this, e), this.color.copy(e.color), (this.intensity = e.intensity), this ) }, toJSON: function (e) { var t = si.prototype.toJSON.call(this, e) return ( (t.object.color = this.color.getHex()), (t.object.intensity = this.intensity), void 0 !== this.groundColor && (t.object.groundColor = this.groundColor.getHex()), void 0 !== this.distance && (t.object.distance = this.distance), void 0 !== this.angle && (t.object.angle = this.angle), void 0 !== this.decay && (t.object.decay = this.decay), void 0 !== this.penumbra && (t.object.penumbra = this.penumbra), void 0 !== this.shadow && (t.object.shadow = this.shadow.toJSON()), t ) }, })), (Yh.prototype = Object.assign(Object.create(Xh.prototype), { constructor: Yh, isHemisphereLight: !0, copy: function (e) { return ( Xh.prototype.copy.call(this, e), this.groundColor.copy(e.groundColor), this ) }, })), Object.assign(Qh.prototype, { _projScreenMatrix: new Fr(), _lightPositionWorld: new lr(), _lookTarget: new lr(), getViewportCount: function () { return this._viewportCount }, getFrustum: function () { return this._frustum }, updateMatrices: function (e) { var t = this.camera, n = this.matrix, r = this._projScreenMatrix, i = this._lookTarget, o = this._lightPositionWorld o.setFromMatrixPosition(e.matrixWorld), t.position.copy(o), i.setFromMatrixPosition(e.target.matrixWorld), t.lookAt(i), t.updateMatrixWorld(), r.multiplyMatrices(t.projectionMatrix, t.matrixWorldInverse), this._frustum.setFromProjectionMatrix(r), n.set(0.5, 0, 0, 0.5, 0, 0.5, 0, 0.5, 0, 0, 0.5, 0.5, 0, 0, 0, 1), n.multiply(t.projectionMatrix), n.multiply(t.matrixWorldInverse) }, getViewport: function (e) { return this._viewports[e] }, getFrameExtents: function () { return this._frameExtents }, copy: function (e) { return ( (this.camera = e.camera.clone()), (this.bias = e.bias), (this.radius = e.radius), this.mapSize.copy(e.mapSize), this ) }, clone: function () { return new this.constructor().copy(this) }, toJSON: function () { var e = {} return ( 0 !== this.bias && (e.bias = this.bias), 0 !== this.normalBias && (e.normalBias = this.normalBias), 1 !== this.radius && (e.radius = this.radius), (512 === this.mapSize.x && 512 === this.mapSize.y) || (e.mapSize = this.mapSize.toArray()), (e.camera = this.camera.toJSON(!1).object), delete e.camera.matrix, e ) }, }), (Zh.prototype = Object.assign(Object.create(Qh.prototype), { constructor: Zh, isSpotLightShadow: !0, updateMatrices: function (e) { var t = this.camera, n = 2 * Kn.RAD2DEG * e.angle * this.focus, r = this.mapSize.width / this.mapSize.height, i = e.distance || t.far ;(n === t.fov && r === t.aspect && i === t.far) || ((t.fov = n), (t.aspect = r), (t.far = i), t.updateProjectionMatrix()), Qh.prototype.updateMatrices.call(this, e) }, })), (Kh.prototype = Object.assign(Object.create(Xh.prototype), { constructor: Kh, isSpotLight: !0, copy: function (e) { return ( Xh.prototype.copy.call(this, e), (this.distance = e.distance), (this.angle = e.angle), (this.penumbra = e.penumbra), (this.decay = e.decay), (this.target = e.target.clone()), (this.shadow = e.shadow.clone()), this ) }, })), (Jh.prototype = Object.assign(Object.create(Qh.prototype), { constructor: Jh, isPointLightShadow: !0, updateMatrices: function (e, t) { void 0 === t && (t = 0) var n = this.camera, r = this.matrix, i = this._lightPositionWorld, o = this._lookTarget, a = this._projScreenMatrix i.setFromMatrixPosition(e.matrixWorld), n.position.copy(i), o.copy(n.position), o.add(this._cubeDirections[t]), n.up.copy(this._cubeUps[t]), n.lookAt(o), n.updateMatrixWorld(), r.makeTranslation(-i.x, -i.y, -i.z), a.multiplyMatrices(n.projectionMatrix, n.matrixWorldInverse), this._frustum.setFromProjectionMatrix(a) }, })), ($h.prototype = Object.assign(Object.create(Xh.prototype), { constructor: $h, isPointLight: !0, copy: function (e) { return ( Xh.prototype.copy.call(this, e), (this.distance = e.distance), (this.decay = e.decay), (this.shadow = e.shadow.clone()), this ) }, })), (ed.prototype = Object.assign(Object.create(Do.prototype), { constructor: ed, isOrthographicCamera: !0, copy: function (e, t) { return ( Do.prototype.copy.call(this, e, t), (this.left = e.left), (this.right = e.right), (this.top = e.top), (this.bottom = e.bottom), (this.near = e.near), (this.far = e.far), (this.zoom = e.zoom), (this.view = null === e.view ? null : Object.assign({}, e.view)), this ) }, setViewOffset: function (e, t, n, r, i, o) { 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 = e), (this.view.fullHeight = t), (this.view.offsetX = n), (this.view.offsetY = r), (this.view.width = i), (this.view.height = o), this.updateProjectionMatrix() }, clearViewOffset: function () { null !== this.view && (this.view.enabled = !1), this.updateProjectionMatrix() }, updateProjectionMatrix: function () { var e = (this.right - this.left) / (2 * this.zoom), t = (this.top - this.bottom) / (2 * this.zoom), n = (this.right + this.left) / 2, r = (this.top + this.bottom) / 2, i = n - e, o = n + e, a = r + t, s = r - t if (null !== this.view && this.view.enabled) { var l = (this.right - this.left) / this.view.fullWidth / this.zoom, c = (this.top - this.bottom) / this.view.fullHeight / this.zoom ;(o = (i += l * this.view.offsetX) + l * this.view.width), (s = (a -= c * this.view.offsetY) - c * this.view.height) } this.projectionMatrix.makeOrthographic(i, o, a, s, this.near, this.far), this.projectionMatrixInverse.copy(this.projectionMatrix).invert() }, toJSON: function (e) { var t = si.prototype.toJSON.call(this, e) return ( (t.object.zoom = this.zoom), (t.object.left = this.left), (t.object.right = this.right), (t.object.top = this.top), (t.object.bottom = this.bottom), (t.object.near = this.near), (t.object.far = this.far), null !== this.view && (t.object.view = Object.assign({}, this.view)), t ) }, })), (td.prototype = Object.assign(Object.create(Qh.prototype), { constructor: td, isDirectionalLightShadow: !0, updateMatrices: function (e) { Qh.prototype.updateMatrices.call(this, e) }, })), (nd.prototype = Object.assign(Object.create(Xh.prototype), { constructor: nd, isDirectionalLight: !0, copy: function (e) { return ( Xh.prototype.copy.call(this, e), (this.target = e.target.clone()), (this.shadow = e.shadow.clone()), this ) }, })), (rd.prototype = Object.assign(Object.create(Xh.prototype), { constructor: rd, isAmbientLight: !0, })), (id.prototype = Object.assign(Object.create(Xh.prototype), { constructor: id, isRectAreaLight: !0, copy: function (e) { return ( Xh.prototype.copy.call(this, e), (this.width = e.width), (this.height = e.height), this ) }, toJSON: function (e) { var t = Xh.prototype.toJSON.call(this, e) return (t.object.width = this.width), (t.object.height = this.height), t }, })) var od = (function () { function e() { Object.defineProperty(this, 'isSphericalHarmonics3', { value: !0 }), (this.coefficients = []) for (var e = 0; e < 9; e++) this.coefficients.push(new lr()) } var t = e.prototype return ( (t.set = function (e) { for (var t = 0; t < 9; t++) this.coefficients[t].copy(e[t]) return this }), (t.zero = function () { for (var e = 0; e < 9; e++) this.coefficients[e].set(0, 0, 0) return this }), (t.getAt = function (e, t) { var n = e.x, r = e.y, i = e.z, o = this.coefficients return ( t.copy(o[0]).multiplyScalar(0.282095), t.addScaledVector(o[1], 0.488603 * r), t.addScaledVector(o[2], 0.488603 * i), t.addScaledVector(o[3], 0.488603 * n), t.addScaledVector(o[4], n * r * 1.092548), t.addScaledVector(o[5], r * i * 1.092548), t.addScaledVector(o[6], 0.315392 * (3 * i * i - 1)), t.addScaledVector(o[7], n * i * 1.092548), t.addScaledVector(o[8], 0.546274 * (n * n - r * r)), t ) }), (t.getIrradianceAt = function (e, t) { var n = e.x, r = e.y, i = e.z, o = this.coefficients return ( t.copy(o[0]).multiplyScalar(0.886227), t.addScaledVector(o[1], 1.023328 * r), t.addScaledVector(o[2], 1.023328 * i), t.addScaledVector(o[3], 1.023328 * n), t.addScaledVector(o[4], 0.858086 * n * r), t.addScaledVector(o[5], 0.858086 * r * i), t.addScaledVector(o[6], 0.743125 * i * i - 0.247708), t.addScaledVector(o[7], 0.858086 * n * i), t.addScaledVector(o[8], 0.429043 * (n * n - r * r)), t ) }), (t.add = function (e) { for (var t = 0; t < 9; t++) this.coefficients[t].add(e.coefficients[t]) return this }), (t.addScaledSH = function (e, t) { for (var n = 0; n < 9; n++) this.coefficients[n].addScaledVector(e.coefficients[n], t) return this }), (t.scale = function (e) { for (var t = 0; t < 9; t++) this.coefficients[t].multiplyScalar(e) return this }), (t.lerp = function (e, t) { for (var n = 0; n < 9; n++) this.coefficients[n].lerp(e.coefficients[n], t) return this }), (t.equals = function (e) { for (var t = 0; t < 9; t++) if (!this.coefficients[t].equals(e.coefficients[t])) return !1 return !0 }), (t.copy = function (e) { return this.set(e.coefficients) }), (t.clone = function () { return new this.constructor().copy(this) }), (t.fromArray = function (e, t) { void 0 === t && (t = 0) for (var n = this.coefficients, r = 0; r < 9; r++) n[r].fromArray(e, t + 3 * r) return this }), (t.toArray = function (e, t) { void 0 === e && (e = []), void 0 === t && (t = 0) for (var n = this.coefficients, r = 0; r < 9; r++) n[r].toArray(e, t + 3 * r) return e }), (e.getBasisAt = function (e, t) { var n = e.x, r = e.y, i = e.z ;(t[0] = 0.282095), (t[1] = 0.488603 * r), (t[2] = 0.488603 * i), (t[3] = 0.488603 * n), (t[4] = 1.092548 * n * r), (t[5] = 1.092548 * r * i), (t[6] = 0.315392 * (3 * i * i - 1)), (t[7] = 1.092548 * n * i), (t[8] = 0.546274 * (n * n - r * r)) }), e ) })() function ad(e, t) { Xh.call(this, void 0, t), (this.type = 'LightProbe'), (this.sh = void 0 !== e ? e : new od()) } function sd(e) { lh.call(this, e), (this.textures = {}) } ;(ad.prototype = Object.assign(Object.create(Xh.prototype), { constructor: ad, isLightProbe: !0, copy: function (e) { return Xh.prototype.copy.call(this, e), this.sh.copy(e.sh), this }, fromJSON: function (e) { return (this.intensity = e.intensity), this.sh.fromArray(e.sh), this }, toJSON: function (e) { var t = Xh.prototype.toJSON.call(this, e) return (t.object.sh = this.sh.toArray()), t }, })), (sd.prototype = Object.assign(Object.create(lh.prototype), { constructor: sd, load: function (t, n, r, i) { var o = this, a = new uh(o.manager) a.setPath(o.path), a.setRequestHeader(o.requestHeader), a.setWithCredentials(o.withCredentials), a.load( t, function (r) { try { n(o.parse(JSON.parse(r))) } catch (e) { i ? i(e) : console.error(e), o.manager.itemError(t) } }, r, i, ) }, parse: function (e) { var t = this.textures function n(e) { return ( void 0 === t[e] && console.warn('THREE.MaterialLoader: Undefined texture', e), t[e] ) } var r = new zu[e.type]() if ( (void 0 !== e.uuid && (r.uuid = e.uuid), void 0 !== e.name && (r.name = e.name), void 0 !== e.color && void 0 !== r.color && r.color.setHex(e.color), void 0 !== e.roughness && (r.roughness = e.roughness), void 0 !== e.metalness && (r.metalness = e.metalness), void 0 !== e.sheen && (r.sheen = new Li().setHex(e.sheen)), void 0 !== e.emissive && void 0 !== r.emissive && r.emissive.setHex(e.emissive), void 0 !== e.specular && void 0 !== r.specular && r.specular.setHex(e.specular), void 0 !== e.shininess && (r.shininess = e.shininess), void 0 !== e.clearcoat && (r.clearcoat = e.clearcoat), void 0 !== e.clearcoatRoughness && (r.clearcoatRoughness = e.clearcoatRoughness), void 0 !== e.fog && (r.fog = e.fog), void 0 !== e.flatShading && (r.flatShading = e.flatShading), void 0 !== e.blending && (r.blending = e.blending), void 0 !== e.combine && (r.combine = e.combine), void 0 !== e.side && (r.side = e.side), void 0 !== e.opacity && (r.opacity = e.opacity), void 0 !== e.transparent && (r.transparent = e.transparent), void 0 !== e.alphaTest && (r.alphaTest = e.alphaTest), void 0 !== e.depthTest && (r.depthTest = e.depthTest), void 0 !== e.depthWrite && (r.depthWrite = e.depthWrite), void 0 !== e.colorWrite && (r.colorWrite = e.colorWrite), void 0 !== e.stencilWrite && (r.stencilWrite = e.stencilWrite), void 0 !== e.stencilWriteMask && (r.stencilWriteMask = e.stencilWriteMask), void 0 !== e.stencilFunc && (r.stencilFunc = e.stencilFunc), void 0 !== e.stencilRef && (r.stencilRef = e.stencilRef), void 0 !== e.stencilFuncMask && (r.stencilFuncMask = e.stencilFuncMask), void 0 !== e.stencilFail && (r.stencilFail = e.stencilFail), void 0 !== e.stencilZFail && (r.stencilZFail = e.stencilZFail), void 0 !== e.stencilZPass && (r.stencilZPass = e.stencilZPass), void 0 !== e.wireframe && (r.wireframe = e.wireframe), void 0 !== e.wireframeLinewidth && (r.wireframeLinewidth = e.wireframeLinewidth), void 0 !== e.wireframeLinecap && (r.wireframeLinecap = e.wireframeLinecap), void 0 !== e.wireframeLinejoin && (r.wireframeLinejoin = e.wireframeLinejoin), void 0 !== e.rotation && (r.rotation = e.rotation), 1 !== e.linewidth && (r.linewidth = e.linewidth), void 0 !== e.dashSize && (r.dashSize = e.dashSize), void 0 !== e.gapSize && (r.gapSize = e.gapSize), void 0 !== e.scale && (r.scale = e.scale), void 0 !== e.polygonOffset && (r.polygonOffset = e.polygonOffset), void 0 !== e.polygonOffsetFactor && (r.polygonOffsetFactor = e.polygonOffsetFactor), void 0 !== e.polygonOffsetUnits && (r.polygonOffsetUnits = e.polygonOffsetUnits), void 0 !== e.skinning && (r.skinning = e.skinning), void 0 !== e.morphTargets && (r.morphTargets = e.morphTargets), void 0 !== e.morphNormals && (r.morphNormals = e.morphNormals), void 0 !== e.dithering && (r.dithering = e.dithering), void 0 !== e.vertexTangents && (r.vertexTangents = e.vertexTangents), void 0 !== e.visible && (r.visible = e.visible), void 0 !== e.toneMapped && (r.toneMapped = e.toneMapped), void 0 !== e.userData && (r.userData = e.userData), void 0 !== e.vertexColors && ('number' === typeof e.vertexColors ? (r.vertexColors = e.vertexColors > 0) : (r.vertexColors = e.vertexColors)), void 0 !== e.uniforms) ) for (var i in e.uniforms) { var o = e.uniforms[i] switch (((r.uniforms[i] = {}), o.type)) { case 't': r.uniforms[i].value = n(o.value) break case 'c': r.uniforms[i].value = new Li().setHex(o.value) break case 'v2': r.uniforms[i].value = new Jn().fromArray(o.value) break case 'v3': r.uniforms[i].value = new lr().fromArray(o.value) break case 'v4': r.uniforms[i].value = new ir().fromArray(o.value) break case 'm3': r.uniforms[i].value = new $n().fromArray(o.value) break case 'm4': r.uniforms[i].value = new Fr().fromArray(o.value) break default: r.uniforms[i].value = o.value } } if ( (void 0 !== e.defines && (r.defines = e.defines), void 0 !== e.vertexShader && (r.vertexShader = e.vertexShader), void 0 !== e.fragmentShader && (r.fragmentShader = e.fragmentShader), void 0 !== e.extensions) ) for (var a in e.extensions) r.extensions[a] = e.extensions[a] if ( (void 0 !== e.shading && (r.flatShading = 1 === e.shading), void 0 !== e.size && (r.size = e.size), void 0 !== e.sizeAttenuation && (r.sizeAttenuation = e.sizeAttenuation), void 0 !== e.map && (r.map = n(e.map)), void 0 !== e.matcap && (r.matcap = n(e.matcap)), void 0 !== e.alphaMap && (r.alphaMap = n(e.alphaMap)), void 0 !== e.bumpMap && (r.bumpMap = n(e.bumpMap)), void 0 !== e.bumpScale && (r.bumpScale = e.bumpScale), void 0 !== e.normalMap && (r.normalMap = n(e.normalMap)), void 0 !== e.normalMapType && (r.normalMapType = e.normalMapType), void 0 !== e.normalScale) ) { var s = e.normalScale !1 === Array.isArray(s) && (s = [s, s]), (r.normalScale = new Jn().fromArray(s)) } return ( void 0 !== e.displacementMap && (r.displacementMap = n(e.displacementMap)), void 0 !== e.displacementScale && (r.displacementScale = e.displacementScale), void 0 !== e.displacementBias && (r.displacementBias = e.displacementBias), void 0 !== e.roughnessMap && (r.roughnessMap = n(e.roughnessMap)), void 0 !== e.metalnessMap && (r.metalnessMap = n(e.metalnessMap)), void 0 !== e.emissiveMap && (r.emissiveMap = n(e.emissiveMap)), void 0 !== e.emissiveIntensity && (r.emissiveIntensity = e.emissiveIntensity), void 0 !== e.specularMap && (r.specularMap = n(e.specularMap)), void 0 !== e.envMap && (r.envMap = n(e.envMap)), void 0 !== e.envMapIntensity && (r.envMapIntensity = e.envMapIntensity), void 0 !== e.reflectivity && (r.reflectivity = e.reflectivity), void 0 !== e.refractionRatio && (r.refractionRatio = e.refractionRatio), void 0 !== e.lightMap && (r.lightMap = n(e.lightMap)), void 0 !== e.lightMapIntensity && (r.lightMapIntensity = e.lightMapIntensity), void 0 !== e.aoMap && (r.aoMap = n(e.aoMap)), void 0 !== e.aoMapIntensity && (r.aoMapIntensity = e.aoMapIntensity), void 0 !== e.gradientMap && (r.gradientMap = n(e.gradientMap)), void 0 !== e.clearcoatMap && (r.clearcoatMap = n(e.clearcoatMap)), void 0 !== e.clearcoatRoughnessMap && (r.clearcoatRoughnessMap = n(e.clearcoatRoughnessMap)), void 0 !== e.clearcoatNormalMap && (r.clearcoatNormalMap = n(e.clearcoatNormalMap)), void 0 !== e.clearcoatNormalScale && (r.clearcoatNormalScale = new Jn().fromArray(e.clearcoatNormalScale)), void 0 !== e.transmission && (r.transmission = e.transmission), void 0 !== e.transmissionMap && (r.transmissionMap = n(e.transmissionMap)), r ) }, setTextures: function (e) { return (this.textures = e), this }, })) var ld = { decodeText: function (t) { if ('undefined' !== typeof TextDecoder) return new TextDecoder().decode(t) for (var n = '', r = 0, i = t.length; r < i; r++) n += String.fromCharCode(t[r]) try { return decodeURIComponent(escape(n)) } catch (e) { return n } }, extractUrlBase: function (e) { var t = e.lastIndexOf('/') return -1 === t ? './' : e.substr(0, t + 1) }, } function cd() { ro.call(this), (this.type = 'InstancedBufferGeometry'), (this.instanceCount = 1 / 0) } function ud(e, t, n, r) { 'number' === typeof n && ((r = n), (n = !1), console.error( 'THREE.InstancedBufferAttribute: The constructor now expects normalized as the third argument.', )), Fi.call(this, e, t, n), (this.meshPerAttribute = r || 1) } function hd(e) { lh.call(this, e) } ;(cd.prototype = Object.assign(Object.create(ro.prototype), { constructor: cd, isInstancedBufferGeometry: !0, copy: function (e) { return ( ro.prototype.copy.call(this, e), (this.instanceCount = e.instanceCount), this ) }, clone: function () { return new this.constructor().copy(this) }, toJSON: function () { var e = ro.prototype.toJSON.call(this) return ( (e.instanceCount = this.instanceCount), (e.isInstancedBufferGeometry = !0), e ) }, })), (ud.prototype = Object.assign(Object.create(Fi.prototype), { constructor: ud, isInstancedBufferAttribute: !0, copy: function (e) { return ( Fi.prototype.copy.call(this, e), (this.meshPerAttribute = e.meshPerAttribute), this ) }, toJSON: function () { var e = Fi.prototype.toJSON.call(this) return ( (e.meshPerAttribute = this.meshPerAttribute), (e.isInstancedBufferAttribute = !0), e ) }, })), (hd.prototype = Object.assign(Object.create(lh.prototype), { constructor: hd, load: function (t, n, r, i) { var o = this, a = new uh(o.manager) a.setPath(o.path), a.setRequestHeader(o.requestHeader), a.setWithCredentials(o.withCredentials), a.load( t, function (r) { try { n(o.parse(JSON.parse(r))) } catch (e) { i ? i(e) : console.error(e), o.manager.itemError(t) } }, r, i, ) }, parse: function (e) { var t = {}, n = {} function r(e, n) { if (void 0 !== t[n]) return t[n] var r = e.interleavedBuffers[n], o = i(e, r.buffer), a = new yl(Qi(r.type, o), r.stride) return (a.uuid = r.uuid), (t[n] = a), a } function i(e, t) { if (void 0 !== n[t]) return n[t] var r = e.arrayBuffers[t], i = new Uint32Array(r).buffer return (n[t] = i), i } var o = e.isInstancedBufferGeometry ? new cd() : new ro(), a = e.data.index if (void 0 !== a) { var s = Qi(a.type, a.array) o.setIndex(new Fi(s, 1)) } var l = e.data.attributes for (var c in l) { var u = l[c], h = void 0 if (u.isInterleavedBufferAttribute) h = new wl(r(e.data, u.data), u.itemSize, u.offset, u.normalized) else { var d = Qi(u.type, u.array) h = new (u.isInstancedBufferAttribute ? ud : Fi)( d, u.itemSize, u.normalized, ) } void 0 !== u.name && (h.name = u.name), o.setAttribute(c, h) } var p = e.data.morphAttributes if (p) for (var f in p) { for (var m = p[f], v = [], g = 0, y = m.length; g < y; g++) { var b = m[g], A = void 0 ;(A = b.isInterleavedBufferAttribute ? new wl(r(e.data, b.data), b.itemSize, b.offset, b.normalized) : new Fi(Qi(b.type, b.array), b.itemSize, b.normalized)), void 0 !== b.name && (A.name = b.name), v.push(A) } o.morphAttributes[f] = v } e.data.morphTargetsRelative && (o.morphTargetsRelative = !0) var w = e.data.groups || e.data.drawcalls || e.data.offsets if (void 0 !== w) for (var x = 0, E = w.length; x !== E; ++x) { var M = w[x] o.addGroup(M.start, M.count, M.materialIndex) } var _ = e.data.boundingSphere if (void 0 !== _) { var T = new lr() void 0 !== _.center && T.fromArray(_.center), (o.boundingSphere = new Sr(T, _.radius)) } return ( e.name && (o.name = e.name), e.userData && (o.userData = e.userData), o ) }, })) var dd = (function (e) { function t(t) { return e.call(this, t) || this } Gn(t, e) var n = t.prototype return ( (n.load = function (e, t, n, r) { var i = this, o = '' === this.path ? ld.extractUrlBase(e) : this.path this.resourcePath = this.resourcePath || o var a = new uh(this.manager) a.setPath(this.path), a.setRequestHeader(this.requestHeader), a.setWithCredentials(this.withCredentials), a.load( e, function (n) { var o = null try { o = JSON.parse(n) } catch (s) { return ( void 0 !== r && r(s), void console.error( "THREE:ObjectLoader: Can't parse " + e + '.', s.message, ) ) } var a = o.metadata void 0 !== a && void 0 !== a.type && 'geometry' !== a.type.toLowerCase() ? i.parse(o, t) : console.error("THREE.ObjectLoader: Can't load " + e) }, n, r, ) }), (n.parse = function (e, t) { var n = this.parseAnimations(e.animations), r = this.parseShapes(e.shapes), i = this.parseGeometries(e.geometries, r), o = this.parseImages(e.images, function () { void 0 !== t && t(l) }), a = this.parseTextures(e.textures, o), s = this.parseMaterials(e.materials, a), l = this.parseObject(e.object, i, s, n), c = this.parseSkeletons(e.skeletons, l) if ((this.bindSkeletons(l, c), void 0 !== t)) { var u = !1 for (var h in o) if (o[h] instanceof HTMLImageElement) { u = !0 break } !1 === u && t(l) } return l }), (n.parseShapes = function (e) { var t = {} if (void 0 !== e) for (var n = 0, r = e.length; n < r; n++) { var i = new qh().fromJSON(e[n]) t[i.uuid] = i } return t }), (n.parseSkeletons = function (e, t) { var n = {}, r = {} if ( (t.traverse(function (e) { e.isBone && (r[e.uuid] = e) }), void 0 !== e) ) for (var i = 0, o = e.length; i < o; i++) { var a = new Ql().fromJSON(e[i], r) n[a.uuid] = a } return n }), (n.parseGeometries = function (e, t) { var n, r = {} if (void 0 !== e) for (var i = new hd(), o = 0, a = e.length; o < a; o++) { var s = void 0, l = e[o] switch (l.type) { case 'PlaneGeometry': case 'PlaneBufferGeometry': s = new Pu[l.type]( l.width, l.height, l.widthSegments, l.heightSegments, ) break case 'BoxGeometry': case 'BoxBufferGeometry': s = new Pu[l.type]( l.width, l.height, l.depth, l.widthSegments, l.heightSegments, l.depthSegments, ) break case 'CircleGeometry': case 'CircleBufferGeometry': s = new Pu[l.type]( l.radius, l.segments, l.thetaStart, l.thetaLength, ) break case 'CylinderGeometry': case 'CylinderBufferGeometry': s = new Pu[l.type]( l.radiusTop, l.radiusBottom, l.height, l.radialSegments, l.heightSegments, l.openEnded, l.thetaStart, l.thetaLength, ) break case 'ConeGeometry': case 'ConeBufferGeometry': s = new Pu[l.type]( l.radius, l.height, l.radialSegments, l.heightSegments, l.openEnded, l.thetaStart, l.thetaLength, ) break case 'SphereGeometry': case 'SphereBufferGeometry': s = new Pu[l.type]( l.radius, l.widthSegments, l.heightSegments, l.phiStart, l.phiLength, l.thetaStart, l.thetaLength, ) break case 'DodecahedronGeometry': case 'DodecahedronBufferGeometry': case 'IcosahedronGeometry': case 'IcosahedronBufferGeometry': case 'OctahedronGeometry': case 'OctahedronBufferGeometry': case 'TetrahedronGeometry': case 'TetrahedronBufferGeometry': s = new Pu[l.type](l.radius, l.detail) break case 'RingGeometry': case 'RingBufferGeometry': s = new Pu[l.type]( l.innerRadius, l.outerRadius, l.thetaSegments, l.phiSegments, l.thetaStart, l.thetaLength, ) break case 'TorusGeometry': case 'TorusBufferGeometry': s = new Pu[l.type]( l.radius, l.tube, l.radialSegments, l.tubularSegments, l.arc, ) break case 'TorusKnotGeometry': case 'TorusKnotBufferGeometry': s = new Pu[l.type]( l.radius, l.tube, l.tubularSegments, l.radialSegments, l.p, l.q, ) break case 'TubeGeometry': case 'TubeBufferGeometry': s = new Pu[l.type]( new jh[l.path.type]().fromJSON(l.path), l.tubularSegments, l.radius, l.radialSegments, l.closed, ) break case 'LatheGeometry': case 'LatheBufferGeometry': s = new Pu[l.type]( l.points, l.segments, l.phiStart, l.phiLength, ) break case 'PolyhedronGeometry': case 'PolyhedronBufferGeometry': s = new Pu[l.type](l.vertices, l.indices, l.radius, l.details) break case 'ShapeGeometry': case 'ShapeBufferGeometry': n = [] for (var c = 0, u = l.shapes.length; c < u; c++) { var h = t[l.shapes[c]] n.push(h) } s = new Pu[l.type](n, l.curveSegments) break case 'ExtrudeGeometry': case 'ExtrudeBufferGeometry': n = [] for (var d = 0, p = l.shapes.length; d < p; d++) { var f = t[l.shapes[d]] n.push(f) } var m = l.options.extrudePath void 0 !== m && (l.options.extrudePath = new jh[m.type]().fromJSON(m)), (s = new Pu[l.type](n, l.options)) break case 'BufferGeometry': case 'InstancedBufferGeometry': s = i.parse(l) break case 'Geometry': 'THREE' in window && 'LegacyJSONLoader' in THREE ? (s = new THREE.LegacyJSONLoader().parse( l, this.resourcePath, ).geometry) : console.error( 'THREE.ObjectLoader: You have to import LegacyJSONLoader in order load geometry data of type "Geometry".', ) break default: console.warn( 'THREE.ObjectLoader: Unsupported geometry type "' + l.type + '"', ) continue } ;(s.uuid = l.uuid), void 0 !== l.name && (s.name = l.name), !0 === s.isBufferGeometry && void 0 !== l.userData && (s.userData = l.userData), (r[l.uuid] = s) } return r }), (n.parseMaterials = function (e, t) { var n = {}, r = {} if (void 0 !== e) { var i = new sd() i.setTextures(t) for (var o = 0, a = e.length; o < a; o++) { var s = e[o] if ('MultiMaterial' === s.type) { for (var l = [], c = 0; c < s.materials.length; c++) { var u = s.materials[c] void 0 === n[u.uuid] && (n[u.uuid] = i.parse(u)), l.push(n[u.uuid]) } r[s.uuid] = l } else void 0 === n[s.uuid] && (n[s.uuid] = i.parse(s)), (r[s.uuid] = n[s.uuid]) } } return r }), (n.parseAnimations = function (e) { var t = {} if (void 0 !== e) for (var n = 0; n < e.length; n++) { var r = e[n], i = nh.parse(r) t[i.uuid] = i } return t }), (n.parseImages = function (e, t) { var n, r = this, i = {} function o(e) { return ( r.manager.itemStart(e), n.load( e, function () { r.manager.itemEnd(e) }, void 0, function () { r.manager.itemError(e), r.manager.itemEnd(e) }, ) ) } function a(e) { if ('string' === typeof e) { var t = e return o( /^(\/\/)|([a-z]+:(\/\/)?)/i.test(t) ? t : r.resourcePath + t, ) } return e.data ? { data: Qi(e.type, e.data), width: e.width, height: e.height } : null } if (void 0 !== e && e.length > 0) { var s = new ah(t) ;(n = new ph(s)).setCrossOrigin(this.crossOrigin) for (var l = 0, c = e.length; l < c; l++) { var u = e[l], h = u.url if (Array.isArray(h)) { i[u.uuid] = [] for (var d = 0, p = h.length; d < p; d++) { var f = a(h[d]) null !== f && (f instanceof HTMLImageElement ? i[u.uuid].push(f) : i[u.uuid].push(new Uo(f.data, f.width, f.height))) } } else { var m = a(u.url) null !== m && (i[u.uuid] = m) } } } return i }), (n.parseTextures = function (e, t) { function n(e, t) { return 'number' === typeof e ? e : (console.warn( 'THREE.ObjectLoader.parseTexture: Constant should be in numeric form.', e, ), t[e]) } var r = {} if (void 0 !== e) for (var i = 0, o = e.length; i < o; i++) { var a = e[i] void 0 === a.image && console.warn( 'THREE.ObjectLoader: No "image" specified for', a.uuid, ), void 0 === t[a.image] && console.warn('THREE.ObjectLoader: Undefined image', a.image) var s = void 0, l = t[a.image] Array.isArray(l) ? ((s = new ko(l)), 6 === l.length && (s.needsUpdate = !0)) : ((s = l && l.data ? new Uo(l.data, l.width, l.height) : new nr(l)), l && (s.needsUpdate = !0)), (s.uuid = a.uuid), void 0 !== a.name && (s.name = a.name), void 0 !== a.mapping && (s.mapping = n(a.mapping, pd)), void 0 !== a.offset && s.offset.fromArray(a.offset), void 0 !== a.repeat && s.repeat.fromArray(a.repeat), void 0 !== a.center && s.center.fromArray(a.center), void 0 !== a.rotation && (s.rotation = a.rotation), void 0 !== a.wrap && ((s.wrapS = n(a.wrap[0], fd)), (s.wrapT = n(a.wrap[1], fd))), void 0 !== a.format && (s.format = a.format), void 0 !== a.type && (s.type = a.type), void 0 !== a.encoding && (s.encoding = a.encoding), void 0 !== a.minFilter && (s.minFilter = n(a.minFilter, md)), void 0 !== a.magFilter && (s.magFilter = n(a.magFilter, md)), void 0 !== a.anisotropy && (s.anisotropy = a.anisotropy), void 0 !== a.flipY && (s.flipY = a.flipY), void 0 !== a.premultiplyAlpha && (s.premultiplyAlpha = a.premultiplyAlpha), void 0 !== a.unpackAlignment && (s.unpackAlignment = a.unpackAlignment), (r[a.uuid] = s) } return r }), (n.parseObject = function (e, t, n, r) { var i, o, a function s(e) { return ( void 0 === t[e] && console.warn('THREE.ObjectLoader: Undefined geometry', e), t[e] ) } function l(e) { if (void 0 !== e) { if (Array.isArray(e)) { for (var t = [], r = 0, i = e.length; r < i; r++) { var o = e[r] void 0 === n[o] && console.warn('THREE.ObjectLoader: Undefined material', o), t.push(n[o]) } return t } return ( void 0 === n[e] && console.warn('THREE.ObjectLoader: Undefined material', e), n[e] ) } } switch (e.type) { case 'Scene': ;(i = new gl()), void 0 !== e.background && Number.isInteger(e.background) && (i.background = new Li(e.background)), void 0 !== e.fog && ('Fog' === e.fog.type ? (i.fog = new vl(e.fog.color, e.fog.near, e.fog.far)) : 'FogExp2' === e.fog.type && (i.fog = new ml(e.fog.color, e.fog.density))) break case 'PerspectiveCamera': ;(i = new Oo(e.fov, e.aspect, e.near, e.far)), void 0 !== e.focus && (i.focus = e.focus), void 0 !== e.zoom && (i.zoom = e.zoom), void 0 !== e.filmGauge && (i.filmGauge = e.filmGauge), void 0 !== e.filmOffset && (i.filmOffset = e.filmOffset), void 0 !== e.view && (i.view = Object.assign({}, e.view)) break case 'OrthographicCamera': ;(i = new ed(e.left, e.right, e.top, e.bottom, e.near, e.far)), void 0 !== e.zoom && (i.zoom = e.zoom), void 0 !== e.view && (i.view = Object.assign({}, e.view)) break case 'AmbientLight': i = new rd(e.color, e.intensity) break case 'DirectionalLight': i = new nd(e.color, e.intensity) break case 'PointLight': i = new $h(e.color, e.intensity, e.distance, e.decay) break case 'RectAreaLight': i = new id(e.color, e.intensity, e.width, e.height) break case 'SpotLight': i = new Kh( e.color, e.intensity, e.distance, e.angle, e.penumbra, e.decay, ) break case 'HemisphereLight': i = new Yh(e.color, e.groundColor, e.intensity) break case 'LightProbe': i = new ad().fromJSON(e) break case 'SkinnedMesh': ;(i = new Wl((o = s(e.geometry)), (a = l(e.material)))), void 0 !== e.bindMode && (i.bindMode = e.bindMode), void 0 !== e.bindMatrix && i.bindMatrix.fromArray(e.bindMatrix), void 0 !== e.skeleton && (i.skeleton = e.skeleton) break case 'Mesh': i = new xo((o = s(e.geometry)), (a = l(e.material))) break case 'InstancedMesh': ;(o = s(e.geometry)), (a = l(e.material)) var c = e.count, u = e.instanceMatrix ;(i = new ec(o, a, c)).instanceMatrix = new Fi( new Float32Array(u.array), 16, ) break case 'LOD': i = new Ul() break case 'Line': i = new sc(s(e.geometry), l(e.material)) break case 'LineLoop': i = new hc(s(e.geometry), l(e.material)) break case 'LineSegments': i = new uc(s(e.geometry), l(e.material)) break case 'PointCloud': case 'Points': i = new gc(s(e.geometry), l(e.material)) break case 'Sprite': i = new Bl(l(e.material)) break case 'Group': i = new rl() break case 'Bone': i = new ql() break default: i = new si() } if ( ((i.uuid = e.uuid), void 0 !== e.name && (i.name = e.name), void 0 !== e.matrix ? (i.matrix.fromArray(e.matrix), void 0 !== e.matrixAutoUpdate && (i.matrixAutoUpdate = e.matrixAutoUpdate), i.matrixAutoUpdate && i.matrix.decompose(i.position, i.quaternion, i.scale)) : (void 0 !== e.position && i.position.fromArray(e.position), void 0 !== e.rotation && i.rotation.fromArray(e.rotation), void 0 !== e.quaternion && i.quaternion.fromArray(e.quaternion), void 0 !== e.scale && i.scale.fromArray(e.scale)), void 0 !== e.castShadow && (i.castShadow = e.castShadow), void 0 !== e.receiveShadow && (i.receiveShadow = e.receiveShadow), e.shadow && (void 0 !== e.shadow.bias && (i.shadow.bias = e.shadow.bias), void 0 !== e.shadow.normalBias && (i.shadow.normalBias = e.shadow.normalBias), void 0 !== e.shadow.radius && (i.shadow.radius = e.shadow.radius), void 0 !== e.shadow.mapSize && i.shadow.mapSize.fromArray(e.shadow.mapSize), void 0 !== e.shadow.camera && (i.shadow.camera = this.parseObject(e.shadow.camera))), void 0 !== e.visible && (i.visible = e.visible), void 0 !== e.frustumCulled && (i.frustumCulled = e.frustumCulled), void 0 !== e.renderOrder && (i.renderOrder = e.renderOrder), void 0 !== e.userData && (i.userData = e.userData), void 0 !== e.layers && (i.layers.mask = e.layers), void 0 !== e.children) ) for (var h = e.children, d = 0; d < h.length; d++) i.add(this.parseObject(h[d], t, n, r)) if (void 0 !== e.animations) for (var p = e.animations, f = 0; f < p.length; f++) { var m = p[f] i.animations.push(r[m]) } if ('LOD' === e.type) { void 0 !== e.autoUpdate && (i.autoUpdate = e.autoUpdate) for (var v = e.levels, g = 0; g < v.length; g++) { var y = v[g], b = i.getObjectByProperty('uuid', y.object) void 0 !== b && i.addLevel(b, y.distance) } } return i }), (n.bindSkeletons = function (e, t) { 0 !== Object.keys(t).length && e.traverse(function (e) { if (!0 === e.isSkinnedMesh && void 0 !== e.skeleton) { var n = t[e.skeleton] void 0 === n ? console.warn( 'THREE.ObjectLoader: No skeleton found with UUID:', e.skeleton, ) : e.bind(n, e.bindMatrix) } }) }), (n.setTexturePath = function (e) { return ( console.warn( 'THREE.ObjectLoader: .setTexturePath() has been renamed to .setResourcePath().', ), this.setResourcePath(e) ) }), t ) })(lh), pd = { UVMapping: oe, CubeReflectionMapping: ae, CubeRefractionMapping: se, EquirectangularReflectionMapping: le, EquirectangularRefractionMapping: ce, CubeUVReflectionMapping: ue, CubeUVRefractionMapping: he, }, fd = { RepeatWrapping: de, ClampToEdgeWrapping: pe, MirroredRepeatWrapping: fe, }, md = { NearestFilter: me, NearestMipmapNearestFilter: ve, NearestMipmapLinearFilter: ye, LinearFilter: Ae, LinearMipmapNearestFilter: we, LinearMipmapLinearFilter: Ee, } function vd(e) { 'undefined' === typeof createImageBitmap && console.warn('THREE.ImageBitmapLoader: createImageBitmap() not supported.'), 'undefined' === typeof fetch && console.warn('THREE.ImageBitmapLoader: fetch() not supported.'), lh.call(this, e), (this.options = { premultiplyAlpha: 'none' }) } function gd() { ;(this.type = 'ShapePath'), (this.color = new Li()), (this.subPaths = []), (this.currentPath = null) } ;(vd.prototype = Object.assign(Object.create(lh.prototype), { constructor: vd, isImageBitmapLoader: !0, setOptions: function (e) { return (this.options = e), this }, load: function (e, t, n, r) { void 0 === e && (e = ''), void 0 !== this.path && (e = this.path + e), (e = this.manager.resolveURL(e)) var i = this, o = oh.get(e) if (void 0 !== o) return ( i.manager.itemStart(e), setTimeout(function () { t && t(o), i.manager.itemEnd(e) }, 0), o ) var a = {} ;(a.credentials = 'anonymous' === this.crossOrigin ? 'same-origin' : 'include'), fetch(e, a) .then(function (e) { return e.blob() }) .then(function (e) { return createImageBitmap(e, i.options) }) .then(function (n) { oh.add(e, n), t && t(n), i.manager.itemEnd(e) }) .catch(function (t) { r && r(t), i.manager.itemError(e), i.manager.itemEnd(e) }), i.manager.itemStart(e) }, })), Object.assign(gd.prototype, { moveTo: function (e, t) { return ( (this.currentPath = new Wh()), this.subPaths.push(this.currentPath), this.currentPath.moveTo(e, t), this ) }, lineTo: function (e, t) { return this.currentPath.lineTo(e, t), this }, quadraticCurveTo: function (e, t, n, r) { return this.currentPath.quadraticCurveTo(e, t, n, r), this }, bezierCurveTo: function (e, t, n, r, i, o) { return this.currentPath.bezierCurveTo(e, t, n, r, i, o), this }, splineThru: function (e) { return this.currentPath.splineThru(e), this }, toShapes: function (e, t) { function n(e) { for (var t = [], n = 0, r = e.length; n < r; n++) { var i = e[n], o = new qh() ;(o.curves = i.curves), t.push(o) } return t } function r(e, t) { for (var n = t.length, r = !1, i = n - 1, o = 0; o < n; i = o++) { var a = t[i], s = t[o], l = s.x - a.x, c = s.y - a.y if (Math.abs(c) > Number.EPSILON) { if ( (c < 0 && ((a = t[o]), (l = -l), (s = t[i]), (c = -c)), e.y < a.y || e.y > s.y) ) continue if (e.y === a.y) { if (e.x === a.x) return !0 } else { var u = c * (e.x - a.x) - l * (e.y - a.y) if (0 === u) return !0 if (u < 0) continue r = !r } } else { if (e.y !== a.y) continue if ((s.x <= e.x && e.x <= a.x) || (a.x <= e.x && e.x <= s.x)) return !0 } } return r } var i, o, a, s = hu.isClockWise, l = this.subPaths if (0 === l.length) return [] if (!0 === t) return n(l) var c = [] if (1 === l.length) return (o = l[0]), ((a = new qh()).curves = o.curves), c.push(a), c var u = !s(l[0].getPoints()) u = e ? !u : u var h, d, p = [], f = [], m = [], v = 0 ;(f[v] = void 0), (m[v] = []) for (var g = 0, y = l.length; g < y; g++) (i = s((h = (o = l[g]).getPoints()))), (i = e ? !i : i) ? (!u && f[v] && v++, (f[v] = { s: new qh(), p: h }), (f[v].s.curves = o.curves), u && v++, (m[v] = [])) : m[v].push({ h: o, p: h[0] }) if (!f[0]) return n(l) if (f.length > 1) { for (var b = !1, A = [], w = 0, x = f.length; w < x; w++) p[w] = [] for (var E = 0, M = f.length; E < M; E++) for (var _ = m[E], T = 0; T < _.length; T++) { for (var S = _[T], C = !0, L = 0; L < f.length; L++) r(S.p, f[L].p) && (E !== L && A.push({ froms: E, tos: L, hole: T }), C ? ((C = !1), p[L].push(S)) : (b = !0)) C && p[E].push(S) } A.length > 0 && (b || (m = p)) } for (var R = 0, P = f.length; R < P; R++) { ;(a = f[R].s), c.push(a) for (var D = 0, O = (d = m[R]).length; D < O; D++) a.holes.push(d[D].h) } return c }, }) var yd, bd = (function () { function e(e) { Object.defineProperty(this, 'isFont', { value: !0 }), (this.type = 'Font'), (this.data = e) } return ( (e.prototype.generateShapes = function (e, t) { void 0 === t && (t = 100) for ( var n = [], r = Ad(e, t, this.data), i = 0, o = r.length; i < o; i++ ) Array.prototype.push.apply(n, r[i].toShapes()) return n }), e ) })() function Ad(e, t, n) { for ( var r = Array.from ? Array.from(e) : String(e).split(''), i = t / n.resolution, o = (n.boundingBox.yMax - n.boundingBox.yMin + n.underlineThickness) * i, a = [], s = 0, l = 0, c = 0; c < r.length; c++ ) { var u = r[c] if ('\n' === u) (s = 0), (l -= o) else { var h = wd(u, i, s, l, n) ;(s += h.offsetX), a.push(h.path) } } return a } function wd(e, t, n, r, i) { var o = i.glyphs[e] || i.glyphs['?'] if (o) { var a, s, l, c, u, h, d, p, f = new gd() if (o.o) for ( var m = o._cachedOutline || (o._cachedOutline = o.o.split(' ')), v = 0, g = m.length; v < g; ) switch (m[v++]) { case 'm': ;(a = m[v++] * t + n), (s = m[v++] * t + r), f.moveTo(a, s) break case 'l': ;(a = m[v++] * t + n), (s = m[v++] * t + r), f.lineTo(a, s) break case 'q': ;(l = m[v++] * t + n), (c = m[v++] * t + r), (u = m[v++] * t + n), (h = m[v++] * t + r), f.quadraticCurveTo(u, h, l, c) break case 'b': ;(l = m[v++] * t + n), (c = m[v++] * t + r), (u = m[v++] * t + n), (h = m[v++] * t + r), (d = m[v++] * t + n), (p = m[v++] * t + r), f.bezierCurveTo(u, h, d, p, l, c) } return { offsetX: o.ha * t, path: f } } console.error( 'THREE.Font: character "' + e + '" does not exists in font family ' + i.familyName + '.', ) } function xd(e) { lh.call(this, e) } xd.prototype = Object.assign(Object.create(lh.prototype), { constructor: xd, load: function (t, n, r, i) { var o = this, a = new uh(this.manager) a.setPath(this.path), a.setRequestHeader(this.requestHeader), a.setWithCredentials(o.withCredentials), a.load( t, function (t) { var r try { r = JSON.parse(t) } catch (e) { console.warn( 'THREE.FontLoader: typeface.js support is being deprecated. Use typeface.json instead.', ), (r = JSON.parse(t.substring(65, t.length - 2))) } var i = o.parse(r) n && n(i) }, r, i, ) }, parse: function (e) { return new bd(e) }, }) var Ed = { getContext: function () { return ( void 0 === yd && (yd = new (window.AudioContext || window.webkitAudioContext)()), yd ) }, setContext: function (e) { yd = e }, } function Md(e) { lh.call(this, e) } function _d(e, t, n) { ad.call(this, void 0, n) var r = new Li().set(e), i = new Li().set(t), o = new lr(r.r, r.g, r.b), a = new lr(i.r, i.g, i.b), s = Math.sqrt(Math.PI), l = s * Math.sqrt(0.75) this.sh.coefficients[0].copy(o).add(a).multiplyScalar(s), this.sh.coefficients[1].copy(o).sub(a).multiplyScalar(l) } function Td(e, t) { ad.call(this, void 0, t) var n = new Li().set(e) this.sh.coefficients[0] .set(n.r, n.g, n.b) .multiplyScalar(2 * Math.sqrt(Math.PI)) } ;(Md.prototype = Object.assign(Object.create(lh.prototype), { constructor: Md, load: function (t, n, r, i) { var o = this, a = new uh(o.manager) a.setResponseType('arraybuffer'), a.setPath(o.path), a.setRequestHeader(o.requestHeader), a.setWithCredentials(o.withCredentials), a.load( t, function (r) { try { var a = r.slice(0) Ed.getContext().decodeAudioData(a, function (e) { n(e) }) } catch (e) { i ? i(e) : console.error(e), o.manager.itemError(t) } }, r, i, ) }, })), (_d.prototype = Object.assign(Object.create(ad.prototype), { constructor: _d, isHemisphereLightProbe: !0, copy: function (e) { return ad.prototype.copy.call(this, e), this }, toJSON: function (e) { return ad.prototype.toJSON.call(this, e) }, })), (Td.prototype = Object.assign(Object.create(ad.prototype), { constructor: Td, isAmbientLightProbe: !0, copy: function (e) { return ad.prototype.copy.call(this, e), this }, toJSON: function (e) { return ad.prototype.toJSON.call(this, e) }, })) var Sd = new Fr(), Cd = new Fr() function Ld() { ;(this.type = 'StereoCamera'), (this.aspect = 1), (this.eyeSep = 0.064), (this.cameraL = new Oo()), this.cameraL.layers.enable(1), (this.cameraL.matrixAutoUpdate = !1), (this.cameraR = new Oo()), 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, }) } Object.assign(Ld.prototype, { update: function (e) { var t = this._cache if ( t.focus !== e.focus || t.fov !== e.fov || t.aspect !== e.aspect * this.aspect || t.near !== e.near || t.far !== e.far || t.zoom !== e.zoom || t.eyeSep !== this.eyeSep ) { ;(t.focus = e.focus), (t.fov = e.fov), (t.aspect = e.aspect * this.aspect), (t.near = e.near), (t.far = e.far), (t.zoom = e.zoom), (t.eyeSep = this.eyeSep) var n, r, i = e.projectionMatrix.clone(), o = t.eyeSep / 2, a = (o * t.near) / t.focus, s = (t.near * Math.tan(Kn.DEG2RAD * t.fov * 0.5)) / t.zoom ;(Cd.elements[12] = -o), (Sd.elements[12] = o), (n = -s * t.aspect + a), (r = s * t.aspect + a), (i.elements[0] = (2 * t.near) / (r - n)), (i.elements[8] = (r + n) / (r - n)), this.cameraL.projectionMatrix.copy(i), (n = -s * t.aspect - a), (r = s * t.aspect - a), (i.elements[0] = (2 * t.near) / (r - n)), (i.elements[8] = (r + n) / (r - n)), this.cameraR.projectionMatrix.copy(i) } this.cameraL.matrixWorld.copy(e.matrixWorld).multiply(Cd), this.cameraR.matrixWorld.copy(e.matrixWorld).multiply(Sd) }, }) var Rd = (function () { function e(e) { ;(this.autoStart = void 0 === e || e), (this.startTime = 0), (this.oldTime = 0), (this.elapsedTime = 0), (this.running = !1) } var t = e.prototype return ( (t.start = function () { ;(this.startTime = Pd()), (this.oldTime = this.startTime), (this.elapsedTime = 0), (this.running = !0) }), (t.stop = function () { this.getElapsedTime(), (this.running = !1), (this.autoStart = !1) }), (t.getElapsedTime = function () { return this.getDelta(), this.elapsedTime }), (t.getDelta = function () { var e = 0 if (this.autoStart && !this.running) return this.start(), 0 if (this.running) { var t = Pd() ;(e = (t - this.oldTime) / 1e3), (this.oldTime = t), (this.elapsedTime += e) } return e }), e ) })() function Pd() { return ('undefined' === typeof performance ? Date : performance).now() } var Dd = new lr(), Od = new sr(), Id = new lr(), Bd = new lr(), Fd = (function (e) { function t() { var t return ( ((t = e.call(this) || this).type = 'AudioListener'), (t.context = Ed.getContext()), (t.gain = t.context.createGain()), t.gain.connect(t.context.destination), (t.filter = null), (t.timeDelta = 0), (t._clock = new Rd()), t ) } Gn(t, e) var n = t.prototype return ( (n.getInput = function () { return this.gain }), (n.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 ) }), (n.getFilter = function () { return this.filter }), (n.setFilter = function (e) { return ( null !== this.filter ? (this.gain.disconnect(this.filter), this.filter.disconnect(this.context.destination)) : this.gain.disconnect(this.context.destination), (this.filter = e), this.gain.connect(this.filter), this.filter.connect(this.context.destination), this ) }), (n.getMasterVolume = function () { return this.gain.gain.value }), (n.setMasterVolume = function (e) { return ( this.gain.gain.setTargetAtTime(e, this.context.currentTime, 0.01), this ) }), (n.updateMatrixWorld = function (t) { e.prototype.updateMatrixWorld.call(this, t) var n = this.context.listener, r = this.up if ( ((this.timeDelta = this._clock.getDelta()), this.matrixWorld.decompose(Dd, Od, Id), Bd.set(0, 0, -1).applyQuaternion(Od), n.positionX) ) { var i = this.context.currentTime + this.timeDelta n.positionX.linearRampToValueAtTime(Dd.x, i), n.positionY.linearRampToValueAtTime(Dd.y, i), n.positionZ.linearRampToValueAtTime(Dd.z, i), n.forwardX.linearRampToValueAtTime(Bd.x, i), n.forwardY.linearRampToValueAtTime(Bd.y, i), n.forwardZ.linearRampToValueAtTime(Bd.z, i), n.upX.linearRampToValueAtTime(r.x, i), n.upY.linearRampToValueAtTime(r.y, i), n.upZ.linearRampToValueAtTime(r.z, i) } else n.setPosition(Dd.x, Dd.y, Dd.z), n.setOrientation(Bd.x, Bd.y, Bd.z, r.x, r.y, r.z) }), t ) })(si), kd = (function (e) { function t(t) { var n return ( ((n = e.call(this) || this).type = 'Audio'), (n.listener = t), (n.context = t.context), (n.gain = n.context.createGain()), n.gain.connect(t.getInput()), (n.autoplay = !1), (n.buffer = null), (n.detune = 0), (n.loop = !1), (n.loopStart = 0), (n.loopEnd = 0), (n.offset = 0), (n.duration = void 0), (n.playbackRate = 1), (n.isPlaying = !1), (n.hasPlaybackControl = !0), (n.source = null), (n.sourceType = 'empty'), (n._startedAt = 0), (n._progress = 0), (n._connected = !1), (n.filters = []), n ) } Gn(t, e) var n = t.prototype return ( (n.getOutput = function () { return this.gain }), (n.setNodeSource = function (e) { return ( (this.hasPlaybackControl = !1), (this.sourceType = 'audioNode'), (this.source = e), this.connect(), this ) }), (n.setMediaElementSource = function (e) { return ( (this.hasPlaybackControl = !1), (this.sourceType = 'mediaNode'), (this.source = this.context.createMediaElementSource(e)), this.connect(), this ) }), (n.setMediaStreamSource = function (e) { return ( (this.hasPlaybackControl = !1), (this.sourceType = 'mediaStreamNode'), (this.source = this.context.createMediaStreamSource(e)), this.connect(), this ) }), (n.setBuffer = function (e) { return ( (this.buffer = e), (this.sourceType = 'buffer'), this.autoplay && this.play(), this ) }), (n.play = function (e) { if ((void 0 === e && (e = 0), !0 !== this.isPlaying)) { if (!1 !== this.hasPlaybackControl) { this._startedAt = this.context.currentTime + e var t = this.context.createBufferSource() return ( (t.buffer = this.buffer), (t.loop = this.loop), (t.loopStart = this.loopStart), (t.loopEnd = this.loopEnd), (t.onended = this.onEnded.bind(this)), t.start( this._startedAt, this._progress + this.offset, this.duration, ), (this.isPlaying = !0), (this.source = t), 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.') }), (n.pause = function () { if (!1 !== this.hasPlaybackControl) return ( !0 === this.isPlaying && ((this._progress += Math.max(this.context.currentTime - this._startedAt, 0) * this.playbackRate), !0 === this.loop && (this._progress = this._progress % (this.duration || this.buffer.duration)), this.source.stop(), (this.source.onended = null), (this.isPlaying = !1)), this ) console.warn('THREE.Audio: this Audio has no playback control.') }), (n.stop = function () { if (!1 !== this.hasPlaybackControl) return ( (this._progress = 0), this.source.stop(), (this.source.onended = null), (this.isPlaying = !1), this ) console.warn('THREE.Audio: this Audio has no playback control.') }), (n.connect = function () { if (this.filters.length > 0) { this.source.connect(this.filters[0]) for (var e = 1, t = this.filters.length; e < t; e++) this.filters[e - 1].connect(this.filters[e]) this.filters[this.filters.length - 1].connect(this.getOutput()) } else this.source.connect(this.getOutput()) return (this._connected = !0), this }), (n.disconnect = function () { if (this.filters.length > 0) { this.source.disconnect(this.filters[0]) for (var e = 1, t = this.filters.length; e < t; e++) this.filters[e - 1].disconnect(this.filters[e]) this.filters[this.filters.length - 1].disconnect(this.getOutput()) } else this.source.disconnect(this.getOutput()) return (this._connected = !1), this }), (n.getFilters = function () { return this.filters }), (n.setFilters = function (e) { return ( e || (e = []), !0 === this._connected ? (this.disconnect(), (this.filters = e.slice()), this.connect()) : (this.filters = e.slice()), this ) }), (n.setDetune = function (e) { if (((this.detune = e), void 0 !== this.source.detune)) return ( !0 === this.isPlaying && this.source.detune.setTargetAtTime( this.detune, this.context.currentTime, 0.01, ), this ) }), (n.getDetune = function () { return this.detune }), (n.getFilter = function () { return this.getFilters()[0] }), (n.setFilter = function (e) { return this.setFilters(e ? [e] : []) }), (n.setPlaybackRate = function (e) { if (!1 !== this.hasPlaybackControl) return ( (this.playbackRate = e), !0 === this.isPlaying && this.source.playbackRate.setTargetAtTime( this.playbackRate, this.context.currentTime, 0.01, ), this ) console.warn('THREE.Audio: this Audio has no playback control.') }), (n.getPlaybackRate = function () { return this.playbackRate }), (n.onEnded = function () { this.isPlaying = !1 }), (n.getLoop = function () { return !1 === this.hasPlaybackControl ? (console.warn('THREE.Audio: this Audio has no playback control.'), !1) : this.loop }), (n.setLoop = function (e) { if (!1 !== this.hasPlaybackControl) return ( (this.loop = e), !0 === this.isPlaying && (this.source.loop = this.loop), this ) console.warn('THREE.Audio: this Audio has no playback control.') }), (n.setLoopStart = function (e) { return (this.loopStart = e), this }), (n.setLoopEnd = function (e) { return (this.loopEnd = e), this }), (n.getVolume = function () { return this.gain.gain.value }), (n.setVolume = function (e) { return ( this.gain.gain.setTargetAtTime(e, this.context.currentTime, 0.01), this ) }), t ) })(si), Nd = new lr(), Ud = new sr(), Hd = new lr(), Gd = new lr(), zd = (function (e) { function t(t) { var n return ( ((n = e.call(this, t) || this).panner = n.context.createPanner()), (n.panner.panningModel = 'HRTF'), n.panner.connect(n.gain), n ) } Gn(t, e) var n = t.prototype return ( (n.getOutput = function () { return this.panner }), (n.getRefDistance = function () { return this.panner.refDistance }), (n.setRefDistance = function (e) { return (this.panner.refDistance = e), this }), (n.getRolloffFactor = function () { return this.panner.rolloffFactor }), (n.setRolloffFactor = function (e) { return (this.panner.rolloffFactor = e), this }), (n.getDistanceModel = function () { return this.panner.distanceModel }), (n.setDistanceModel = function (e) { return (this.panner.distanceModel = e), this }), (n.getMaxDistance = function () { return this.panner.maxDistance }), (n.setMaxDistance = function (e) { return (this.panner.maxDistance = e), this }), (n.setDirectionalCone = function (e, t, n) { return ( (this.panner.coneInnerAngle = e), (this.panner.coneOuterAngle = t), (this.panner.coneOuterGain = n), this ) }), (n.updateMatrixWorld = function (t) { if ( (e.prototype.updateMatrixWorld.call(this, t), !0 !== this.hasPlaybackControl || !1 !== this.isPlaying) ) { this.matrixWorld.decompose(Nd, Ud, Hd), Gd.set(0, 0, 1).applyQuaternion(Ud) var n = this.panner if (n.positionX) { var r = this.context.currentTime + this.listener.timeDelta n.positionX.linearRampToValueAtTime(Nd.x, r), n.positionY.linearRampToValueAtTime(Nd.y, r), n.positionZ.linearRampToValueAtTime(Nd.z, r), n.orientationX.linearRampToValueAtTime(Gd.x, r), n.orientationY.linearRampToValueAtTime(Gd.y, r), n.orientationZ.linearRampToValueAtTime(Gd.z, r) } else n.setPosition(Nd.x, Nd.y, Nd.z), n.setOrientation(Gd.x, Gd.y, Gd.z) } }), t ) })(kd), jd = (function () { function e(e, t) { void 0 === t && (t = 2048), (this.analyser = e.context.createAnalyser()), (this.analyser.fftSize = t), (this.data = new Uint8Array(this.analyser.frequencyBinCount)), e.getOutput().connect(this.analyser) } var t = e.prototype return ( (t.getFrequencyData = function () { return this.analyser.getByteFrequencyData(this.data), this.data }), (t.getAverageFrequency = function () { for (var e = 0, t = this.getFrequencyData(), n = 0; n < t.length; n++) e += t[n] return e / t.length }), e ) })() function Vd(e, t, n) { var r, i, o switch (((this.binding = e), (this.valueSize = n), t)) { case 'quaternion': ;(r = this._slerp), (i = this._slerpAdditive), (o = this._setAdditiveIdentityQuaternion), (this.buffer = new Float64Array(6 * n)), (this._workIndex = 5) break case 'string': case 'bool': ;(r = this._select), (i = this._select), (o = this._setAdditiveIdentityOther), (this.buffer = new Array(5 * n)) break default: ;(r = this._lerp), (i = this._lerpAdditive), (o = this._setAdditiveIdentityNumeric), (this.buffer = new Float64Array(5 * n)) } ;(this._mixBufferRegion = r), (this._mixBufferRegionAdditive = i), (this._setIdentity = o), (this._origIndex = 3), (this._addIndex = 4), (this.cumulativeWeight = 0), (this.cumulativeWeightAdditive = 0), (this.useCount = 0), (this.referenceCount = 0) } Object.assign(Vd.prototype, { accumulate: function (e, t) { var n = this.buffer, r = this.valueSize, i = e * r + r, o = this.cumulativeWeight if (0 === o) { for (var a = 0; a !== r; ++a) n[i + a] = n[a] o = t } else { var s = t / (o += t) this._mixBufferRegion(n, i, 0, s, r) } this.cumulativeWeight = o }, accumulateAdditive: function (e) { var t = this.buffer, n = this.valueSize, r = n * this._addIndex 0 === this.cumulativeWeightAdditive && this._setIdentity(), this._mixBufferRegionAdditive(t, r, 0, e, n), (this.cumulativeWeightAdditive += e) }, apply: function (e) { var t = this.valueSize, n = this.buffer, r = e * t + t, i = this.cumulativeWeight, o = this.cumulativeWeightAdditive, a = this.binding if ( ((this.cumulativeWeight = 0), (this.cumulativeWeightAdditive = 0), i < 1) ) { var s = t * this._origIndex this._mixBufferRegion(n, r, s, 1 - i, t) } o > 0 && this._mixBufferRegionAdditive(n, r, this._addIndex * t, 1, t) for (var l = t, c = t + t; l !== c; ++l) if (n[l] !== n[l + t]) { a.setValue(n, r) break } }, saveOriginalState: function () { var e = this.binding, t = this.buffer, n = this.valueSize, r = n * this._origIndex e.getValue(t, r) for (var i = n, o = r; i !== o; ++i) t[i] = t[r + (i % n)] this._setIdentity(), (this.cumulativeWeight = 0), (this.cumulativeWeightAdditive = 0) }, restoreOriginalState: function () { var e = 3 * this.valueSize this.binding.setValue(this.buffer, e) }, _setAdditiveIdentityNumeric: function () { for ( var e = this._addIndex * this.valueSize, t = e + this.valueSize, n = e; n < t; n++ ) this.buffer[n] = 0 }, _setAdditiveIdentityQuaternion: function () { this._setAdditiveIdentityNumeric(), (this.buffer[this._addIndex * this.valueSize + 3] = 1) }, _setAdditiveIdentityOther: function () { for ( var e = this._origIndex * this.valueSize, t = this._addIndex * this.valueSize, n = 0; n < this.valueSize; n++ ) this.buffer[t + n] = this.buffer[e + n] }, _select: function (e, t, n, r, i) { if (r >= 0.5) for (var o = 0; o !== i; ++o) e[t + o] = e[n + o] }, _slerp: function (e, t, n, r) { sr.slerpFlat(e, t, e, t, e, n, r) }, _slerpAdditive: function (e, t, n, r, i) { var o = this._workIndex * i sr.multiplyQuaternionsFlat(e, o, e, t, e, n), sr.slerpFlat(e, t, e, t, e, o, r) }, _lerp: function (e, t, n, r, i) { for (var o = 1 - r, a = 0; a !== i; ++a) { var s = t + a e[s] = e[s] * o + e[n + a] * r } }, _lerpAdditive: function (e, t, n, r, i) { for (var o = 0; o !== i; ++o) { var a = t + o e[a] = e[a] + e[n + o] * r } }, }) var Wd = '\\[\\]\\.:\\/', qd = new RegExp('[' + Wd + ']', 'g'), Xd = '[^' + Wd + ']', Yd = '[^' + Wd.replace('\\.', '') + ']', Qd = /((?:WC+[\/:])*)/.source.replace('WC', Xd), Zd = /(WCOD+)?/.source.replace('WCOD', Yd), Kd = /(?:\.(WC+)(?:\[(.+)\])?)?/.source.replace('WC', Xd), Jd = /\.(WC+)(?:\[(.+)\])?/.source.replace('WC', Xd), $d = new RegExp('^' + Qd + Zd + Kd + Jd + '$'), ep = ['material', 'materials', 'bones'] function tp(e, t, n) { var r = n || np.parseTrackName(t) ;(this._targetGroup = e), (this._bindings = e.subscribe_(t, r)) } function np(e, t, n) { ;(this.path = t), (this.parsedPath = n || np.parseTrackName(t)), (this.node = np.findNode(e, this.parsedPath.nodeName) || e), (this.rootNode = e) } function rp() { ;(this.uuid = Kn.generateUUID()), (this._objects = Array.prototype.slice.call(arguments)), (this.nCachedObjects_ = 0) var e = {} this._indicesByUUID = e for (var t = 0, n = arguments.length; t !== n; ++t) e[arguments[t].uuid] = t ;(this._paths = []), (this._parsedPaths = []), (this._bindings = []), (this._bindingsIndicesByPath = {}) var r = this this.stats = { objects: { get total() { return r._objects.length }, get inUse() { return this.total - r.nCachedObjects_ }, }, get bindingsPerObject() { return r._bindings.length }, } } Object.assign(tp.prototype, { getValue: function (e, t) { this.bind() var n = this._targetGroup.nCachedObjects_, r = this._bindings[n] void 0 !== r && r.getValue(e, t) }, setValue: function (e, t) { for ( var n = this._bindings, r = this._targetGroup.nCachedObjects_, i = n.length; r !== i; ++r ) n[r].setValue(e, t) }, bind: function () { for ( var e = this._bindings, t = this._targetGroup.nCachedObjects_, n = e.length; t !== n; ++t ) e[t].bind() }, unbind: function () { for ( var e = this._bindings, t = this._targetGroup.nCachedObjects_, n = e.length; t !== n; ++t ) e[t].unbind() }, }), Object.assign(np, { Composite: tp, create: function (e, t, n) { return e && e.isAnimationObjectGroup ? new np.Composite(e, t, n) : new np(e, t, n) }, sanitizeNodeName: function (e) { return e.replace(/\s/g, '_').replace(qd, '') }, parseTrackName: function (e) { var t = $d.exec(e) if (!t) throw new Error('PropertyBinding: Cannot parse trackName: ' + e) var n = { nodeName: t[2], objectName: t[3], objectIndex: t[4], propertyName: t[5], propertyIndex: t[6], }, r = n.nodeName && n.nodeName.lastIndexOf('.') if (void 0 !== r && -1 !== r) { var i = n.nodeName.substring(r + 1) ;-1 !== ep.indexOf(i) && ((n.nodeName = n.nodeName.substring(0, r)), (n.objectName = i)) } if (null === n.propertyName || 0 === n.propertyName.length) throw new Error( 'PropertyBinding: can not parse propertyName from trackName: ' + e, ) return n }, findNode: function (e, t) { if ( !t || '' === t || '.' === t || -1 === t || t === e.name || t === e.uuid ) return e if (e.skeleton) { var n = e.skeleton.getBoneByName(t) if (void 0 !== n) return n } if (e.children) { var r = (function e(n) { for (var r = 0; r < n.length; r++) { var i = n[r] if (i.name === t || i.uuid === t) return i var o = e(i.children) if (o) return o } return null })(e.children) if (r) return r } return null }, }), Object.assign(np.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 (e, t) { e[t] = this.node[this.propertyName] }, function (e, t) { for (var n = this.resolvedProperty, r = 0, i = n.length; r !== i; ++r) e[t++] = n[r] }, function (e, t) { e[t] = this.resolvedProperty[this.propertyIndex] }, function (e, t) { this.resolvedProperty.toArray(e, t) }, ], SetterByBindingTypeAndVersioning: [ [ function (e, t) { this.targetObject[this.propertyName] = e[t] }, function (e, t) { ;(this.targetObject[this.propertyName] = e[t]), (this.targetObject.needsUpdate = !0) }, function (e, t) { ;(this.targetObject[this.propertyName] = e[t]), (this.targetObject.matrixWorldNeedsUpdate = !0) }, ], [ function (e, t) { for (var n = this.resolvedProperty, r = 0, i = n.length; r !== i; ++r) n[r] = e[t++] }, function (e, t) { for (var n = this.resolvedProperty, r = 0, i = n.length; r !== i; ++r) n[r] = e[t++] this.targetObject.needsUpdate = !0 }, function (e, t) { for (var n = this.resolvedProperty, r = 0, i = n.length; r !== i; ++r) n[r] = e[t++] this.targetObject.matrixWorldNeedsUpdate = !0 }, ], [ function (e, t) { this.resolvedProperty[this.propertyIndex] = e[t] }, function (e, t) { ;(this.resolvedProperty[this.propertyIndex] = e[t]), (this.targetObject.needsUpdate = !0) }, function (e, t) { ;(this.resolvedProperty[this.propertyIndex] = e[t]), (this.targetObject.matrixWorldNeedsUpdate = !0) }, ], [ function (e, t) { this.resolvedProperty.fromArray(e, t) }, function (e, t) { this.resolvedProperty.fromArray(e, t), (this.targetObject.needsUpdate = !0) }, function (e, t) { this.resolvedProperty.fromArray(e, t), (this.targetObject.matrixWorldNeedsUpdate = !0) }, ], ], getValue: function (e, t) { this.bind(), this.getValue(e, t) }, setValue: function (e, t) { this.bind(), this.setValue(e, t) }, bind: function () { var e = this.node, t = this.parsedPath, n = t.objectName, r = t.propertyName, i = t.propertyIndex if ( (e || ((e = np.findNode(this.rootNode, t.nodeName) || this.rootNode), (this.node = e)), (this.getValue = this._getValue_unavailable), (this.setValue = this._setValue_unavailable), e) ) { if (n) { var o = t.objectIndex switch (n) { case 'materials': if (!e.material) return void console.error( 'THREE.PropertyBinding: Can not bind to material as node does not have a material.', this, ) if (!e.material.materials) return void console.error( 'THREE.PropertyBinding: Can not bind to material.materials as node.material does not have a materials array.', this, ) e = e.material.materials break case 'bones': if (!e.skeleton) return void console.error( 'THREE.PropertyBinding: Can not bind to bones as node does not have a skeleton.', this, ) e = e.skeleton.bones for (var a = 0; a < e.length; a++) if (e[a].name === o) { o = a break } break default: if (void 0 === e[n]) return void console.error( 'THREE.PropertyBinding: Can not bind to objectName of node undefined.', this, ) e = e[n] } if (void 0 !== o) { if (void 0 === e[o]) return void console.error( 'THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.', this, e, ) e = e[o] } } var s = e[r] if (void 0 !== s) { var l = this.Versioning.None ;(this.targetObject = e), void 0 !== e.needsUpdate ? (l = this.Versioning.NeedsUpdate) : void 0 !== e.matrixWorldNeedsUpdate && (l = this.Versioning.MatrixWorldNeedsUpdate) var c = this.BindingType.Direct if (void 0 !== i) { if ('morphTargetInfluences' === r) { if (!e.geometry) return void console.error( 'THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.', this, ) if (!e.geometry.isBufferGeometry) return void console.error( 'THREE.PropertyBinding: Can not bind to morphTargetInfluences on THREE.Geometry. Use THREE.BufferGeometry instead.', this, ) if (!e.geometry.morphAttributes) return void console.error( 'THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphAttributes.', this, ) void 0 !== e.morphTargetDictionary[i] && (i = e.morphTargetDictionary[i]) } ;(c = this.BindingType.ArrayElement), (this.resolvedProperty = s), (this.propertyIndex = i) } else void 0 !== s.fromArray && void 0 !== s.toArray ? ((c = this.BindingType.HasFromToArray), (this.resolvedProperty = s)) : Array.isArray(s) ? ((c = this.BindingType.EntireArray), (this.resolvedProperty = s)) : (this.propertyName = r) ;(this.getValue = this.GetterByBindingType[c]), (this.setValue = this.SetterByBindingTypeAndVersioning[c][l]) } else { var u = t.nodeName console.error( 'THREE.PropertyBinding: Trying to update property for track: ' + u + '.' + r + " but it wasn't found.", e, ) } } 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(np.prototype, { _getValue_unbound: np.prototype.getValue, _setValue_unbound: np.prototype.setValue, }), Object.assign(rp.prototype, { isAnimationObjectGroup: !0, add: function () { for ( var e = this._objects, t = this._indicesByUUID, n = this._paths, r = this._parsedPaths, i = this._bindings, o = i.length, a = void 0, s = e.length, l = this.nCachedObjects_, c = 0, u = arguments.length; c !== u; ++c ) { var h = arguments[c], d = h.uuid, p = t[d] if (void 0 === p) { ;(p = s++), (t[d] = p), e.push(h) for (var f = 0, m = o; f !== m; ++f) i[f].push(new np(h, n[f], r[f])) } else if (p < l) { a = e[p] var v = --l, g = e[v] ;(t[g.uuid] = p), (e[p] = g), (t[d] = v), (e[v] = h) for (var y = 0, b = o; y !== b; ++y) { var A = i[y], w = A[v], x = A[p] ;(A[p] = w), void 0 === x && (x = new np(h, n[y], r[y])), (A[v] = x) } } else e[p] !== a && console.error( 'THREE.AnimationObjectGroup: Different objects with the same UUID detected. Clean the caches or recreate your infrastructure when reloading scenes.', ) } this.nCachedObjects_ = l }, remove: function () { for ( var e = this._objects, t = this._indicesByUUID, n = this._bindings, r = n.length, i = this.nCachedObjects_, o = 0, a = arguments.length; o !== a; ++o ) { var s = arguments[o], l = s.uuid, c = t[l] if (void 0 !== c && c >= i) { var u = i++, h = e[u] ;(t[h.uuid] = c), (e[c] = h), (t[l] = u), (e[u] = s) for (var d = 0, p = r; d !== p; ++d) { var f = n[d], m = f[u], v = f[c] ;(f[c] = m), (f[u] = v) } } } this.nCachedObjects_ = i }, uncache: function () { for ( var e = this._objects, t = this._indicesByUUID, n = this._bindings, r = n.length, i = this.nCachedObjects_, o = e.length, a = 0, s = arguments.length; a !== s; ++a ) { var l = arguments[a].uuid, c = t[l] if (void 0 !== c) if ((delete t[l], c < i)) { var u = --i, h = e[u], d = --o, p = e[d] ;(t[h.uuid] = c), (e[c] = h), (t[p.uuid] = u), (e[u] = p), e.pop() for (var f = 0, m = r; f !== m; ++f) { var v = n[f], g = v[u], y = v[d] ;(v[c] = g), (v[u] = y), v.pop() } } else { var b = --o, A = e[b] b > 0 && (t[A.uuid] = c), (e[c] = A), e.pop() for (var w = 0, x = r; w !== x; ++w) { var E = n[w] ;(E[c] = E[b]), E.pop() } } } this.nCachedObjects_ = i }, subscribe_: function (e, t) { var n = this._bindingsIndicesByPath, r = n[e], i = this._bindings if (void 0 !== r) return i[r] var o = this._paths, a = this._parsedPaths, s = this._objects, l = s.length, c = this.nCachedObjects_, u = new Array(l) ;(r = i.length), (n[e] = r), o.push(e), a.push(t), i.push(u) for (var h = c, d = s.length; h !== d; ++h) { var p = s[h] u[h] = new np(p, e, t) } return u }, unsubscribe_: function (e) { var t = this._bindingsIndicesByPath, n = t[e] if (void 0 !== n) { var r = this._paths, i = this._parsedPaths, o = this._bindings, a = o.length - 1, s = o[a] ;(t[e[a]] = n), (o[n] = s), o.pop(), (i[n] = i[a]), i.pop(), (r[n] = r[a]), r.pop() } }, }) var ip = (function () { function e(e, t, n, r) { void 0 === n && (n = null), void 0 === r && (r = t.blendMode), (this._mixer = e), (this._clip = t), (this._localRoot = n), (this.blendMode = r) for ( var i = t.tracks, o = i.length, a = new Array(o), s = { endingStart: jt, endingEnd: jt }, l = 0; l !== o; ++l ) { var c = i[l].createInterpolant(null) ;(a[l] = c), (c.settings = s) } ;(this._interpolantSettings = s), (this._interpolants = a), (this._propertyBindings = new Array(o)), (this._cacheIndex = null), (this._byClipCacheIndex = null), (this._timeScaleInterpolant = null), (this._weightInterpolant = null), (this.loop = Nt), (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) } var t = e.prototype return ( (t.play = function () { return this._mixer._activateAction(this), this }), (t.stop = function () { return this._mixer._deactivateAction(this), this.reset() }), (t.reset = function () { return ( (this.paused = !1), (this.enabled = !0), (this.time = 0), (this._loopCount = -1), (this._startTime = null), this.stopFading().stopWarping() ) }), (t.isRunning = function () { return ( this.enabled && !this.paused && 0 !== this.timeScale && null === this._startTime && this._mixer._isActiveAction(this) ) }), (t.isScheduled = function () { return this._mixer._isActiveAction(this) }), (t.startAt = function (e) { return (this._startTime = e), this }), (t.setLoop = function (e, t) { return (this.loop = e), (this.repetitions = t), this }), (t.setEffectiveWeight = function (e) { return ( (this.weight = e), (this._effectiveWeight = this.enabled ? e : 0), this.stopFading() ) }), (t.getEffectiveWeight = function () { return this._effectiveWeight }), (t.fadeIn = function (e) { return this._scheduleFading(e, 0, 1) }), (t.fadeOut = function (e) { return this._scheduleFading(e, 1, 0) }), (t.crossFadeFrom = function (e, t, n) { if ((e.fadeOut(t), this.fadeIn(t), n)) { var r = this._clip.duration, i = e._clip.duration, o = i / r, a = r / i e.warp(1, o, t), this.warp(a, 1, t) } return this }), (t.crossFadeTo = function (e, t, n) { return e.crossFadeFrom(this, t, n) }), (t.stopFading = function () { var e = this._weightInterpolant return ( null !== e && ((this._weightInterpolant = null), this._mixer._takeBackControlInterpolant(e)), this ) }), (t.setEffectiveTimeScale = function (e) { return ( (this.timeScale = e), (this._effectiveTimeScale = this.paused ? 0 : e), this.stopWarping() ) }), (t.getEffectiveTimeScale = function () { return this._effectiveTimeScale }), (t.setDuration = function (e) { return (this.timeScale = this._clip.duration / e), this.stopWarping() }), (t.syncWith = function (e) { return ( (this.time = e.time), (this.timeScale = e.timeScale), this.stopWarping() ) }), (t.halt = function (e) { return this.warp(this._effectiveTimeScale, 0, e) }), (t.warp = function (e, t, n) { var r = this._mixer, i = r.time, o = this.timeScale, a = this._timeScaleInterpolant null === a && ((a = r._lendControlInterpolant()), (this._timeScaleInterpolant = a)) var s = a.parameterPositions, l = a.sampleValues return (s[0] = i), (s[1] = i + n), (l[0] = e / o), (l[1] = t / o), this }), (t.stopWarping = function () { var e = this._timeScaleInterpolant return ( null !== e && ((this._timeScaleInterpolant = null), this._mixer._takeBackControlInterpolant(e)), this ) }), (t.getMixer = function () { return this._mixer }), (t.getClip = function () { return this._clip }), (t.getRoot = function () { return this._localRoot || this._mixer._root }), (t._update = function (e, t, n, r) { if (this.enabled) { var i = this._startTime if (null !== i) { var o = (e - i) * n if (o < 0 || 0 === n) return ;(this._startTime = null), (t = n * o) } t *= this._updateTimeScale(e) var a = this._updateTime(t), s = this._updateWeight(e) if (s > 0) { var l = this._interpolants, c = this._propertyBindings switch (this.blendMode) { case Xt: for (var u = 0, h = l.length; u !== h; ++u) l[u].evaluate(a), c[u].accumulateAdditive(s) break case qt: default: for (var d = 0, p = l.length; d !== p; ++d) l[d].evaluate(a), c[d].accumulate(r, s) } } } else this._updateWeight(e) }), (t._updateWeight = function (e) { var t = 0 if (this.enabled) { t = this.weight var n = this._weightInterpolant if (null !== n) { var r = n.evaluate(e)[0] ;(t *= r), e > n.parameterPositions[1] && (this.stopFading(), 0 === r && (this.enabled = !1)) } } return (this._effectiveWeight = t), t }), (t._updateTimeScale = function (e) { var t = 0 if (!this.paused) { t = this.timeScale var n = this._timeScaleInterpolant null !== n && ((t *= n.evaluate(e)[0]), e > n.parameterPositions[1] && (this.stopWarping(), 0 === t ? (this.paused = !0) : (this.timeScale = t))) } return (this._effectiveTimeScale = t), t }), (t._updateTime = function (e) { var t = this._clip.duration, n = this.loop, r = this.time + e, i = this._loopCount, o = n === Ut if (0 === e) return -1 === i ? r : o && 1 === (1 & i) ? t - r : r if (n === kt) { ;-1 === i && ((this._loopCount = 0), this._setEndings(!0, !0, !1)) e: { if (r >= t) r = t else { if (!(r < 0)) { this.time = r break e } r = 0 } this.clampWhenFinished ? (this.paused = !0) : (this.enabled = !1), (this.time = r), this._mixer.dispatchEvent({ type: 'finished', action: this, direction: e < 0 ? -1 : 1, }) } } else { if ( (-1 === i && (e >= 0 ? ((i = 0), this._setEndings(!0, 0 === this.repetitions, o)) : this._setEndings(0 === this.repetitions, !0, o)), r >= t || r < 0) ) { var a = Math.floor(r / t) ;(r -= t * a), (i += Math.abs(a)) var s = this.repetitions - i if (s <= 0) this.clampWhenFinished ? (this.paused = !0) : (this.enabled = !1), (r = e > 0 ? t : 0), (this.time = r), this._mixer.dispatchEvent({ type: 'finished', action: this, direction: e > 0 ? 1 : -1, }) else { if (1 === s) { var l = e < 0 this._setEndings(l, !l, o) } else this._setEndings(!1, !1, o) ;(this._loopCount = i), (this.time = r), this._mixer.dispatchEvent({ type: 'loop', action: this, loopDelta: a, }) } } else this.time = r if (o && 1 === (1 & i)) return t - r } return r }), (t._setEndings = function (e, t, n) { var r = this._interpolantSettings n ? ((r.endingStart = Vt), (r.endingEnd = Vt)) : ((r.endingStart = e ? (this.zeroSlopeAtStart ? Vt : jt) : Wt), (r.endingEnd = t ? (this.zeroSlopeAtEnd ? Vt : jt) : Wt)) }), (t._scheduleFading = function (e, t, n) { var r = this._mixer, i = r.time, o = this._weightInterpolant null === o && ((o = r._lendControlInterpolant()), (this._weightInterpolant = o)) var a = o.parameterPositions, s = o.sampleValues return (a[0] = i), (s[0] = t), (a[1] = i + e), (s[1] = n), this }), e ) })() function op(e) { ;(this._root = e), this._initMemoryManager(), (this._accuIndex = 0), (this.time = 0), (this.timeScale = 1) } op.prototype = Object.assign(Object.create(qn.prototype), { constructor: op, _bindAction: function (e, t) { var n = e._localRoot || this._root, r = e._clip.tracks, i = r.length, o = e._propertyBindings, a = e._interpolants, s = n.uuid, l = this._bindingsByRootAndName, c = l[s] void 0 === c && ((c = {}), (l[s] = c)) for (var u = 0; u !== i; ++u) { var h = r[u], d = h.name, p = c[d] if (void 0 !== p) o[u] = p else { if (void 0 !== (p = o[u])) { null === p._cacheIndex && (++p.referenceCount, this._addInactiveBinding(p, s, d)) continue } var f = t && t._propertyBindings[u].binding.parsedPath ++(p = new Vd(np.create(n, d, f), h.ValueTypeName, h.getValueSize())) .referenceCount, this._addInactiveBinding(p, s, d), (o[u] = p) } a[u].resultBuffer = p.buffer } }, _activateAction: function (e) { if (!this._isActiveAction(e)) { if (null === e._cacheIndex) { var t = (e._localRoot || this._root).uuid, n = e._clip.uuid, r = this._actionsByClip[n] this._bindAction(e, r && r.knownActions[0]), this._addInactiveAction(e, n, t) } for (var i = e._propertyBindings, o = 0, a = i.length; o !== a; ++o) { var s = i[o] 0 === s.useCount++ && (this._lendBinding(s), s.saveOriginalState()) } this._lendAction(e) } }, _deactivateAction: function (e) { if (this._isActiveAction(e)) { for (var t = e._propertyBindings, n = 0, r = t.length; n !== r; ++n) { var i = t[n] 0 === --i.useCount && (i.restoreOriginalState(), this._takeBackBinding(i)) } this._takeBackAction(e) } }, _initMemoryManager: function () { ;(this._actions = []), (this._nActiveActions = 0), (this._actionsByClip = {}), (this._bindings = []), (this._nActiveBindings = 0), (this._bindingsByRootAndName = {}), (this._controlInterpolants = []), (this._nActiveControlInterpolants = 0) var e = this this.stats = { actions: { get total() { return e._actions.length }, get inUse() { return e._nActiveActions }, }, bindings: { get total() { return e._bindings.length }, get inUse() { return e._nActiveBindings }, }, controlInterpolants: { get total() { return e._controlInterpolants.length }, get inUse() { return e._nActiveControlInterpolants }, }, } }, _isActiveAction: function (e) { var t = e._cacheIndex return null !== t && t < this._nActiveActions }, _addInactiveAction: function (e, t, n) { var r = this._actions, i = this._actionsByClip, o = i[t] if (void 0 === o) (o = { knownActions: [e], actionByRoot: {} }), (e._byClipCacheIndex = 0), (i[t] = o) else { var a = o.knownActions ;(e._byClipCacheIndex = a.length), a.push(e) } ;(e._cacheIndex = r.length), r.push(e), (o.actionByRoot[n] = e) }, _removeInactiveAction: function (e) { var t = this._actions, n = t[t.length - 1], r = e._cacheIndex ;(n._cacheIndex = r), (t[r] = n), t.pop(), (e._cacheIndex = null) var i = e._clip.uuid, o = this._actionsByClip, a = o[i], s = a.knownActions, l = s[s.length - 1], c = e._byClipCacheIndex ;(l._byClipCacheIndex = c), (s[c] = l), s.pop(), (e._byClipCacheIndex = null), delete a.actionByRoot[(e._localRoot || this._root).uuid], 0 === s.length && delete o[i], this._removeInactiveBindingsForAction(e) }, _removeInactiveBindingsForAction: function (e) { for (var t = e._propertyBindings, n = 0, r = t.length; n !== r; ++n) { var i = t[n] 0 === --i.referenceCount && this._removeInactiveBinding(i) } }, _lendAction: function (e) { var t = this._actions, n = e._cacheIndex, r = this._nActiveActions++, i = t[r] ;(e._cacheIndex = r), (t[r] = e), (i._cacheIndex = n), (t[n] = i) }, _takeBackAction: function (e) { var t = this._actions, n = e._cacheIndex, r = --this._nActiveActions, i = t[r] ;(e._cacheIndex = r), (t[r] = e), (i._cacheIndex = n), (t[n] = i) }, _addInactiveBinding: function (e, t, n) { var r = this._bindingsByRootAndName, i = this._bindings, o = r[t] void 0 === o && ((o = {}), (r[t] = o)), (o[n] = e), (e._cacheIndex = i.length), i.push(e) }, _removeInactiveBinding: function (e) { var t = this._bindings, n = e.binding, r = n.rootNode.uuid, i = n.path, o = this._bindingsByRootAndName, a = o[r], s = t[t.length - 1], l = e._cacheIndex ;(s._cacheIndex = l), (t[l] = s), t.pop(), delete a[i], 0 === Object.keys(a).length && delete o[r] }, _lendBinding: function (e) { var t = this._bindings, n = e._cacheIndex, r = this._nActiveBindings++, i = t[r] ;(e._cacheIndex = r), (t[r] = e), (i._cacheIndex = n), (t[n] = i) }, _takeBackBinding: function (e) { var t = this._bindings, n = e._cacheIndex, r = --this._nActiveBindings, i = t[r] ;(e._cacheIndex = r), (t[r] = e), (i._cacheIndex = n), (t[n] = i) }, _lendControlInterpolant: function () { var e = this._controlInterpolants, t = this._nActiveControlInterpolants++, n = e[t] return ( void 0 === n && (((n = new qu( new Float32Array(2), new Float32Array(2), 1, this._controlInterpolantsResultBuffer, )).__cacheIndex = t), (e[t] = n)), n ) }, _takeBackControlInterpolant: function (e) { var t = this._controlInterpolants, n = e.__cacheIndex, r = --this._nActiveControlInterpolants, i = t[r] ;(e.__cacheIndex = r), (t[r] = e), (i.__cacheIndex = n), (t[n] = i) }, _controlInterpolantsResultBuffer: new Float32Array(1), clipAction: function (e, t, n) { var r = t || this._root, i = r.uuid, o = 'string' === typeof e ? nh.findByName(r, e) : e, a = null !== o ? o.uuid : e, s = this._actionsByClip[a], l = null if ((void 0 === n && (n = null !== o ? o.blendMode : qt), void 0 !== s)) { var c = s.actionByRoot[i] if (void 0 !== c && c.blendMode === n) return c ;(l = s.knownActions[0]), null === o && (o = l._clip) } if (null === o) return null var u = new ip(this, o, t, n) return this._bindAction(u, l), this._addInactiveAction(u, a, i), u }, existingAction: function (e, t) { var n = t || this._root, r = n.uuid, i = 'string' === typeof e ? nh.findByName(n, e) : e, o = i ? i.uuid : e, a = this._actionsByClip[o] return (void 0 !== a && a.actionByRoot[r]) || null }, stopAllAction: function () { for (var e = this._actions, t = this._nActiveActions - 1; t >= 0; --t) e[t].stop() return this }, update: function (e) { e *= this.timeScale for ( var t = this._actions, n = this._nActiveActions, r = (this.time += e), i = Math.sign(e), o = (this._accuIndex ^= 1), a = 0; a !== n; ++a ) t[a]._update(r, e, i, o) for (var s = this._bindings, l = this._nActiveBindings, c = 0; c !== l; ++c) s[c].apply(o) return this }, setTime: function (e) { this.time = 0 for (var t = 0; t < this._actions.length; t++) this._actions[t].time = 0 return this.update(e) }, getRoot: function () { return this._root }, uncacheClip: function (e) { var t = this._actions, n = e.uuid, r = this._actionsByClip, i = r[n] if (void 0 !== i) { for (var o = i.knownActions, a = 0, s = o.length; a !== s; ++a) { var l = o[a] this._deactivateAction(l) var c = l._cacheIndex, u = t[t.length - 1] ;(l._cacheIndex = null), (l._byClipCacheIndex = null), (u._cacheIndex = c), (t[c] = u), t.pop(), this._removeInactiveBindingsForAction(l) } delete r[n] } }, uncacheRoot: function (e) { var t = e.uuid, n = this._actionsByClip for (var r in n) { var i = n[r].actionByRoot[t] void 0 !== i && (this._deactivateAction(i), this._removeInactiveAction(i)) } var o = this._bindingsByRootAndName[t] if (void 0 !== o) for (var a in o) { var s = o[a] s.restoreOriginalState(), this._removeInactiveBinding(s) } }, uncacheAction: function (e, t) { var n = this.existingAction(e, t) null !== n && (this._deactivateAction(n), this._removeInactiveAction(n)) }, }) var ap = (function () { function e(e) { 'string' === typeof e && (console.warn('THREE.Uniform: Type parameter is no longer needed.'), (e = arguments[1])), (this.value = e) } return ( (e.prototype.clone = function () { return new e( void 0 === this.value.clone ? this.value : this.value.clone(), ) }), e ) })() function sp(e, t, n) { yl.call(this, e, t), (this.meshPerAttribute = n || 1) } function lp(e, t, n, r, i) { ;(this.buffer = e), (this.type = t), (this.itemSize = n), (this.elementSize = r), (this.count = i), (this.version = 0) } function cp(e, t, n, r) { ;(this.ray = new Br(e, t)), (this.near = n || 0), (this.far = r || 1 / 0), (this.camera = null), (this.layers = new Xr()), (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 up(e, t) { return e.distance - t.distance } function hp(e, t, n, r) { if ((e.layers.test(t.layers) && e.raycast(t, n), !0 === r)) for (var i = e.children, o = 0, a = i.length; o < a; o++) hp(i[o], t, n, !0) } ;(sp.prototype = Object.assign(Object.create(yl.prototype), { constructor: sp, isInstancedInterleavedBuffer: !0, copy: function (e) { return ( yl.prototype.copy.call(this, e), (this.meshPerAttribute = e.meshPerAttribute), this ) }, clone: function (e) { var t = yl.prototype.clone.call(this, e) return (t.meshPerAttribute = this.meshPerAttribute), t }, toJSON: function (e) { var t = yl.prototype.toJSON.call(this, e) return ( (t.isInstancedInterleavedBuffer = !0), (t.meshPerAttribute = this.meshPerAttribute), t ) }, })), Object.defineProperty(lp.prototype, 'needsUpdate', { set: function (e) { !0 === e && this.version++ }, }), Object.assign(lp.prototype, { isGLBufferAttribute: !0, setBuffer: function (e) { return (this.buffer = e), this }, setType: function (e, t) { return (this.type = e), (this.elementSize = t), this }, setItemSize: function (e) { return (this.itemSize = e), this }, setCount: function (e) { return (this.count = e), this }, }), Object.assign(cp.prototype, { set: function (e, t) { this.ray.set(e, t) }, setFromCamera: function (e, t) { t && t.isPerspectiveCamera ? (this.ray.origin.setFromMatrixPosition(t.matrixWorld), this.ray.direction .set(e.x, e.y, 0.5) .unproject(t) .sub(this.ray.origin) .normalize(), (this.camera = t)) : t && t.isOrthographicCamera ? (this.ray.origin .set(e.x, e.y, (t.near + t.far) / (t.near - t.far)) .unproject(t), this.ray.direction.set(0, 0, -1).transformDirection(t.matrixWorld), (this.camera = t)) : console.error('THREE.Raycaster: Unsupported camera type: ' + t.type) }, intersectObject: function (e, t, n) { var r = n || [] return hp(e, this, r, t), r.sort(up), r }, intersectObjects: function (e, t, n) { var r = n || [] if (!1 === Array.isArray(e)) return ( console.warn( 'THREE.Raycaster.intersectObjects: objects is not an Array.', ), r ) for (var i = 0, o = e.length; i < o; i++) hp(e[i], this, r, t) return r.sort(up), r }, }) var dp = (function () { function e(e, t, n) { return ( void 0 === e && (e = 1), void 0 === t && (t = 0), void 0 === n && (n = 0), (this.radius = e), (this.phi = t), (this.theta = n), this ) } var t = e.prototype return ( (t.set = function (e, t, n) { return (this.radius = e), (this.phi = t), (this.theta = n), this }), (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { return ( (this.radius = e.radius), (this.phi = e.phi), (this.theta = e.theta), this ) }), (t.makeSafe = function () { var e = 1e-6 return (this.phi = Math.max(e, Math.min(Math.PI - e, this.phi))), this }), (t.setFromVector3 = function (e) { return this.setFromCartesianCoords(e.x, e.y, e.z) }), (t.setFromCartesianCoords = function (e, t, n) { return ( (this.radius = Math.sqrt(e * e + t * t + n * n)), 0 === this.radius ? ((this.theta = 0), (this.phi = 0)) : ((this.theta = Math.atan2(e, n)), (this.phi = Math.acos(Kn.clamp(t / this.radius, -1, 1)))), this ) }), e ) })(), pp = (function () { function e(e, t, n) { return ( (this.radius = void 0 !== e ? e : 1), (this.theta = void 0 !== t ? t : 0), (this.y = void 0 !== n ? n : 0), this ) } var t = e.prototype return ( (t.set = function (e, t, n) { return (this.radius = e), (this.theta = t), (this.y = n), this }), (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { return ( (this.radius = e.radius), (this.theta = e.theta), (this.y = e.y), this ) }), (t.setFromVector3 = function (e) { return this.setFromCartesianCoords(e.x, e.y, e.z) }), (t.setFromCartesianCoords = function (e, t, n) { return ( (this.radius = Math.sqrt(e * e + n * n)), (this.theta = Math.atan2(e, n)), (this.y = t), this ) }), e ) })(), fp = new Jn(), mp = (function () { function e(e, t) { Object.defineProperty(this, 'isBox2', { value: !0 }), (this.min = void 0 !== e ? e : new Jn(1 / 0, 1 / 0)), (this.max = void 0 !== t ? t : new Jn(-1 / 0, -1 / 0)) } var t = e.prototype return ( (t.set = function (e, t) { return this.min.copy(e), this.max.copy(t), this }), (t.setFromPoints = function (e) { this.makeEmpty() for (var t = 0, n = e.length; t < n; t++) this.expandByPoint(e[t]) return this }), (t.setFromCenterAndSize = function (e, t) { var n = fp.copy(t).multiplyScalar(0.5) return this.min.copy(e).sub(n), this.max.copy(e).add(n), this }), (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { return this.min.copy(e.min), this.max.copy(e.max), this }), (t.makeEmpty = function () { return ( (this.min.x = this.min.y = 1 / 0), (this.max.x = this.max.y = -1 / 0), this ) }), (t.isEmpty = function () { return this.max.x < this.min.x || this.max.y < this.min.y }), (t.getCenter = function (e) { return ( void 0 === e && (console.warn('THREE.Box2: .getCenter() target is now required'), (e = new Jn())), this.isEmpty() ? e.set(0, 0) : e.addVectors(this.min, this.max).multiplyScalar(0.5) ) }), (t.getSize = function (e) { return ( void 0 === e && (console.warn('THREE.Box2: .getSize() target is now required'), (e = new Jn())), this.isEmpty() ? e.set(0, 0) : e.subVectors(this.max, this.min) ) }), (t.expandByPoint = function (e) { return this.min.min(e), this.max.max(e), this }), (t.expandByVector = function (e) { return this.min.sub(e), this.max.add(e), this }), (t.expandByScalar = function (e) { return this.min.addScalar(-e), this.max.addScalar(e), this }), (t.containsPoint = function (e) { return !( e.x < this.min.x || e.x > this.max.x || e.y < this.min.y || e.y > this.max.y ) }), (t.containsBox = function (e) { return ( this.min.x <= e.min.x && e.max.x <= this.max.x && this.min.y <= e.min.y && e.max.y <= this.max.y ) }), (t.getParameter = function (e, t) { return ( void 0 === t && (console.warn('THREE.Box2: .getParameter() target is now required'), (t = new Jn())), t.set( (e.x - this.min.x) / (this.max.x - this.min.x), (e.y - this.min.y) / (this.max.y - this.min.y), ) ) }), (t.intersectsBox = function (e) { return !( e.max.x < this.min.x || e.min.x > this.max.x || e.max.y < this.min.y || e.min.y > this.max.y ) }), (t.clampPoint = function (e, t) { return ( void 0 === t && (console.warn('THREE.Box2: .clampPoint() target is now required'), (t = new Jn())), t.copy(e).clamp(this.min, this.max) ) }), (t.distanceToPoint = function (e) { return fp.copy(e).clamp(this.min, this.max).sub(e).length() }), (t.intersect = function (e) { return this.min.max(e.min), this.max.min(e.max), this }), (t.union = function (e) { return this.min.min(e.min), this.max.max(e.max), this }), (t.translate = function (e) { return this.min.add(e), this.max.add(e), this }), (t.equals = function (e) { return e.min.equals(this.min) && e.max.equals(this.max) }), e ) })(), vp = new lr(), gp = new lr(), yp = (function () { function e(e, t) { ;(this.start = void 0 !== e ? e : new lr()), (this.end = void 0 !== t ? t : new lr()) } var t = e.prototype return ( (t.set = function (e, t) { return this.start.copy(e), this.end.copy(t), this }), (t.clone = function () { return new this.constructor().copy(this) }), (t.copy = function (e) { return this.start.copy(e.start), this.end.copy(e.end), this }), (t.getCenter = function (e) { return ( void 0 === e && (console.warn('THREE.Line3: .getCenter() target is now required'), (e = new lr())), e.addVectors(this.start, this.end).multiplyScalar(0.5) ) }), (t.delta = function (e) { return ( void 0 === e && (console.warn('THREE.Line3: .delta() target is now required'), (e = new lr())), e.subVectors(this.end, this.start) ) }), (t.distanceSq = function () { return this.start.distanceToSquared(this.end) }), (t.distance = function () { return this.start.distanceTo(this.end) }), (t.at = function (e, t) { return ( void 0 === t && (console.warn('THREE.Line3: .at() target is now required'), (t = new lr())), this.delta(t).multiplyScalar(e).add(this.start) ) }), (t.closestPointToPointParameter = function (e, t) { vp.subVectors(e, this.start), gp.subVectors(this.end, this.start) var n = gp.dot(gp), r = gp.dot(vp) / n return t && (r = Kn.clamp(r, 0, 1)), r }), (t.closestPointToPoint = function (e, t, n) { var r = this.closestPointToPointParameter(e, t) return ( void 0 === n && (console.warn( 'THREE.Line3: .closestPointToPoint() target is now required', ), (n = new lr())), this.delta(n).multiplyScalar(r).add(this.start) ) }), (t.applyMatrix4 = function (e) { return this.start.applyMatrix4(e), this.end.applyMatrix4(e), this }), (t.equals = function (e) { return e.start.equals(this.start) && e.end.equals(this.end) }), e ) })() function bp(e) { si.call(this), (this.material = e), (this.render = function () {}), (this.hasPositions = !1), (this.hasNormals = !1), (this.hasColors = !1), (this.hasUvs = !1), (this.positionArray = null), (this.normalArray = null), (this.colorArray = null), (this.uvArray = null), (this.count = 0) } ;(bp.prototype = Object.create(si.prototype)), (bp.prototype.constructor = bp), (bp.prototype.isImmediateRenderObject = !0) var Ap = new lr(), wp = (function (e) { function t(t, n) { var r ;((r = e.call(this) || this).light = t), r.light.updateMatrixWorld(), (r.matrix = t.matrixWorld), (r.matrixAutoUpdate = !1), (r.color = n) for ( var i = new ro(), o = [ 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, ], a = 0, s = 1, l = 32; a < l; a++, s++ ) { var c = (a / l) * Math.PI * 2, u = (s / l) * Math.PI * 2 o.push(Math.cos(c), Math.sin(c), 1, Math.cos(u), Math.sin(u), 1) } i.setAttribute('position', new Wi(o, 3)) var h = new tc({ fog: !1, toneMapped: !1 }) return (r.cone = new uc(i, h)), r.add(r.cone), r.update(), r } Gn(t, e) var n = t.prototype return ( (n.dispose = function () { this.cone.geometry.dispose(), this.cone.material.dispose() }), (n.update = function () { this.light.updateMatrixWorld() var e = this.light.distance ? this.light.distance : 1e3, t = e * Math.tan(this.light.angle) this.cone.scale.set(t, t, e), Ap.setFromMatrixPosition(this.light.target.matrixWorld), this.cone.lookAt(Ap), void 0 !== this.color ? this.cone.material.color.set(this.color) : this.cone.material.color.copy(this.light.color) }), t ) })(si), xp = new lr(), Ep = new Fr(), Mp = new Fr(), _p = (function (e) { function t(t) { for ( var n, r = Tp(t), i = new ro(), o = [], a = [], s = new Li(0, 0, 1), l = new Li(0, 1, 0), c = 0; c < r.length; c++ ) { var u = r[c] u.parent && u.parent.isBone && (o.push(0, 0, 0), o.push(0, 0, 0), a.push(s.r, s.g, s.b), a.push(l.r, l.g, l.b)) } i.setAttribute('position', new Wi(o, 3)), i.setAttribute('color', new Wi(a, 3)) var h = new tc({ vertexColors: !0, depthTest: !1, depthWrite: !1, toneMapped: !1, transparent: !0, }) return ( ((n = e.call(this, i, h) || this).type = 'SkeletonHelper'), (n.isSkeletonHelper = !0), (n.root = t), (n.bones = r), (n.matrix = t.matrixWorld), (n.matrixAutoUpdate = !1), n ) } return ( Gn(t, e), (t.prototype.updateMatrixWorld = function (t) { var n = this.bones, r = this.geometry, i = r.getAttribute('position') Mp.copy(this.root.matrixWorld).invert() for (var o = 0, a = 0; o < n.length; o++) { var s = n[o] s.parent && s.parent.isBone && (Ep.multiplyMatrices(Mp, s.matrixWorld), xp.setFromMatrixPosition(Ep), i.setXYZ(a, xp.x, xp.y, xp.z), Ep.multiplyMatrices(Mp, s.parent.matrixWorld), xp.setFromMatrixPosition(Ep), i.setXYZ(a + 1, xp.x, xp.y, xp.z), (a += 2)) } ;(r.getAttribute('position').needsUpdate = !0), e.prototype.updateMatrixWorld.call(this, t) }), t ) })(uc) function Tp(e) { var t = [] e && e.isBone && t.push(e) for (var n = 0; n < e.children.length; n++) t.push.apply(t, Tp(e.children[n])) return t } var Sp = (function (e) { function t(t, n, r) { var i, o = new Mu(n, 4, 2), a = new Oi({ wireframe: !0, fog: !1, toneMapped: !1 }) return ( ((i = e.call(this, o, a) || this).light = t), i.light.updateMatrixWorld(), (i.color = r), (i.type = 'PointLightHelper'), (i.matrix = i.light.matrixWorld), (i.matrixAutoUpdate = !1), i.update(), i ) } Gn(t, e) var n = t.prototype return ( (n.dispose = function () { this.geometry.dispose(), this.material.dispose() }), (n.update = function () { void 0 !== this.color ? this.material.color.set(this.color) : this.material.color.copy(this.light.color) }), t ) })(xo), Cp = new lr(), Lp = new Li(), Rp = new Li(), Pp = (function (e) { function t(t, n, r) { var i ;((i = e.call(this) || this).light = t), i.light.updateMatrixWorld(), (i.matrix = t.matrixWorld), (i.matrixAutoUpdate = !1), (i.color = r) var o = new bu(n) o.rotateY(0.5 * Math.PI), (i.material = new Oi({ wireframe: !0, fog: !1, toneMapped: !1 })), void 0 === i.color && (i.material.vertexColors = !0) var a = o.getAttribute('position'), s = new Float32Array(3 * a.count) return ( o.setAttribute('color', new Fi(s, 3)), i.add(new xo(o, i.material)), i.update(), i ) } Gn(t, e) var n = t.prototype return ( (n.dispose = function () { this.children[0].geometry.dispose(), this.children[0].material.dispose() }), (n.update = function () { var e = this.children[0] if (void 0 !== this.color) this.material.color.set(this.color) else { var t = e.geometry.getAttribute('color') Lp.copy(this.light.color), Rp.copy(this.light.groundColor) for (var n = 0, r = t.count; n < r; n++) { var i = n < r / 2 ? Lp : Rp t.setXYZ(n, i.r, i.g, i.b) } t.needsUpdate = !0 } e.lookAt(Cp.setFromMatrixPosition(this.light.matrixWorld).negate()) }), t ) })(si), Dp = (function (e) { function t(t, n, r, i) { var o void 0 === t && (t = 10), void 0 === n && (n = 10), void 0 === r && (r = 4473924), void 0 === i && (i = 8947848), (r = new Li(r)), (i = new Li(i)) for ( var a = n / 2, s = t / n, l = t / 2, c = [], u = [], h = 0, d = 0, p = -l; h <= n; h++, p += s ) { c.push(-l, 0, p, l, 0, p), c.push(p, 0, -l, p, 0, l) var f = h === a ? r : i f.toArray(u, d), (d += 3), f.toArray(u, d), (d += 3), f.toArray(u, d), (d += 3), f.toArray(u, d), (d += 3) } var m = new ro() m.setAttribute('position', new Wi(c, 3)), m.setAttribute('color', new Wi(u, 3)) var v = new tc({ vertexColors: !0, toneMapped: !1 }) return ((o = e.call(this, m, v) || this).type = 'GridHelper'), o } return Gn(t, e), t })(uc), Op = (function (e) { function t(t, n, r, i, o, a) { var s void 0 === t && (t = 10), void 0 === n && (n = 16), void 0 === r && (r = 8), void 0 === i && (i = 64), void 0 === o && (o = 4473924), void 0 === a && (a = 8947848), (o = new Li(o)), (a = new Li(a)) for (var l = [], c = [], u = 0; u <= n; u++) { var h = (u / n) * (2 * Math.PI), d = Math.sin(h) * t, p = Math.cos(h) * t l.push(0, 0, 0), l.push(d, 0, p) var f = 1 & u ? o : a c.push(f.r, f.g, f.b), c.push(f.r, f.g, f.b) } for (var m = 0; m <= r; m++) for (var v = 1 & m ? o : a, g = t - (t / r) * m, y = 0; y < i; y++) { var b = (y / i) * (2 * Math.PI), A = Math.sin(b) * g, w = Math.cos(b) * g l.push(A, 0, w), c.push(v.r, v.g, v.b), (b = ((y + 1) / i) * (2 * Math.PI)), (A = Math.sin(b) * g), (w = Math.cos(b) * g), l.push(A, 0, w), c.push(v.r, v.g, v.b) } var x = new ro() x.setAttribute('position', new Wi(l, 3)), x.setAttribute('color', new Wi(c, 3)) var E = new tc({ vertexColors: !0, toneMapped: !1 }) return ((s = e.call(this, x, E) || this).type = 'PolarGridHelper'), s } return Gn(t, e), t })(uc), Ip = new lr(), Bp = new lr(), Fp = new lr(), kp = (function (e) { function t(t, n, r) { var i ;((i = e.call(this) || this).light = t), i.light.updateMatrixWorld(), (i.matrix = t.matrixWorld), (i.matrixAutoUpdate = !1), (i.color = r), void 0 === n && (n = 1) var o = new ro() o.setAttribute( 'position', new Wi([-n, n, 0, n, n, 0, n, -n, 0, -n, -n, 0, -n, n, 0], 3), ) var a = new tc({ fog: !1, toneMapped: !1 }) return ( (i.lightPlane = new sc(o, a)), i.add(i.lightPlane), (o = new ro()).setAttribute('position', new Wi([0, 0, 0, 0, 0, 1], 3)), (i.targetLine = new sc(o, a)), i.add(i.targetLine), i.update(), i ) } Gn(t, e) var n = t.prototype return ( (n.dispose = function () { this.lightPlane.geometry.dispose(), this.lightPlane.material.dispose(), this.targetLine.geometry.dispose(), this.targetLine.material.dispose() }), (n.update = function () { Ip.setFromMatrixPosition(this.light.matrixWorld), Bp.setFromMatrixPosition(this.light.target.matrixWorld), Fp.subVectors(Bp, Ip), this.lightPlane.lookAt(Bp), 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(Bp), (this.targetLine.scale.z = Fp.length()) }), t ) })(si), Np = new lr(), Up = new Do(), Hp = (function (e) { function t(t) { var n, r = new ro(), i = new tc({ color: 16777215, vertexColors: !0, toneMapped: !1 }), o = [], a = [], s = {}, l = new Li(16755200), c = new Li(16711680), u = new Li(43775), h = new Li(16777215), d = new Li(3355443) function p(e, t, n) { f(e, n), f(t, n) } function f(e, t) { o.push(0, 0, 0), a.push(t.r, t.g, t.b), void 0 === s[e] && (s[e] = []), s[e].push(o.length / 3 - 1) } return ( p('n1', 'n2', l), p('n2', 'n4', l), p('n4', 'n3', l), p('n3', 'n1', l), p('f1', 'f2', l), p('f2', 'f4', l), p('f4', 'f3', l), p('f3', 'f1', l), p('n1', 'f1', l), p('n2', 'f2', l), p('n3', 'f3', l), p('n4', 'f4', l), p('p', 'n1', c), p('p', 'n2', c), p('p', 'n3', c), p('p', 'n4', c), p('u1', 'u2', u), p('u2', 'u3', u), p('u3', 'u1', u), p('c', 't', h), p('p', 'c', d), p('cn1', 'cn2', d), p('cn3', 'cn4', d), p('cf1', 'cf2', d), p('cf3', 'cf4', d), r.setAttribute('position', new Wi(o, 3)), r.setAttribute('color', new Wi(a, 3)), ((n = e.call(this, r, i) || this).type = 'CameraHelper'), (n.camera = t), n.camera.updateProjectionMatrix && n.camera.updateProjectionMatrix(), (n.matrix = t.matrixWorld), (n.matrixAutoUpdate = !1), (n.pointMap = s), n.update(), n ) } return ( Gn(t, e), (t.prototype.update = function () { var e = this.geometry, t = this.pointMap, n = 1, r = 1 Up.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse), Gp('c', t, e, Up, 0, 0, -1), Gp('t', t, e, Up, 0, 0, 1), Gp('n1', t, e, Up, -n, -r, -1), Gp('n2', t, e, Up, n, -r, -1), Gp('n3', t, e, Up, -n, r, -1), Gp('n4', t, e, Up, n, r, -1), Gp('f1', t, e, Up, -n, -r, 1), Gp('f2', t, e, Up, n, -r, 1), Gp('f3', t, e, Up, -n, r, 1), Gp('f4', t, e, Up, n, r, 1), Gp('u1', t, e, Up, 0.7 * n, 1.1 * r, -1), Gp('u2', t, e, Up, 0.7 * -n, 1.1 * r, -1), Gp('u3', t, e, Up, 0, 2 * r, -1), Gp('cf1', t, e, Up, -n, 0, 1), Gp('cf2', t, e, Up, n, 0, 1), Gp('cf3', t, e, Up, 0, -r, 1), Gp('cf4', t, e, Up, 0, r, 1), Gp('cn1', t, e, Up, -n, 0, -1), Gp('cn2', t, e, Up, n, 0, -1), Gp('cn3', t, e, Up, 0, -r, -1), Gp('cn4', t, e, Up, 0, r, -1), (e.getAttribute('position').needsUpdate = !0) }), t ) })(uc) function Gp(e, t, n, r, i, o, a) { Np.set(i, o, a).unproject(r) var s = t[e] if (void 0 !== s) for (var l = n.getAttribute('position'), c = 0, u = s.length; c < u; c++) l.setXYZ(s[c], Np.x, Np.y, Np.z) } var zp, jp, Vp, Wp = new hr(), qp = (function (e) { function t(t, n) { var r void 0 === n && (n = 16776960) var i = 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, ]), o = new Float32Array(24), a = new ro() return ( a.setIndex(new Fi(i, 1)), a.setAttribute('position', new Fi(o, 3)), ((r = e.call(this, a, new tc({ color: n, toneMapped: !1 })) || this).object = t), (r.type = 'BoxHelper'), (r.matrixAutoUpdate = !1), r.update(), r ) } Gn(t, e) var n = t.prototype return ( (n.update = function (e) { if ( (void 0 !== e && console.warn('THREE.BoxHelper: .update() has no longer arguments.'), void 0 !== this.object && Wp.setFromObject(this.object), !Wp.isEmpty()) ) { var t = Wp.min, n = Wp.max, r = this.geometry.attributes.position, i = r.array ;(i[0] = n.x), (i[1] = n.y), (i[2] = n.z), (i[3] = t.x), (i[4] = n.y), (i[5] = n.z), (i[6] = t.x), (i[7] = t.y), (i[8] = n.z), (i[9] = n.x), (i[10] = t.y), (i[11] = n.z), (i[12] = n.x), (i[13] = n.y), (i[14] = t.z), (i[15] = t.x), (i[16] = n.y), (i[17] = t.z), (i[18] = t.x), (i[19] = t.y), (i[20] = t.z), (i[21] = n.x), (i[22] = t.y), (i[23] = t.z), (r.needsUpdate = !0), this.geometry.computeBoundingSphere() } }), (n.setFromObject = function (e) { return (this.object = e), this.update(), this }), (n.copy = function (e) { return uc.prototype.copy.call(this, e), (this.object = e.object), this }), t ) })(uc), Xp = (function (e) { function t(t, n) { var r void 0 === n && (n = 16776960) var i = 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, ]), o = [ 1, 1, 1, -1, 1, 1, -1, -1, 1, 1, -1, 1, 1, 1, -1, -1, 1, -1, -1, -1, -1, 1, -1, -1, ], a = new ro() return ( a.setIndex(new Fi(i, 1)), a.setAttribute('position', new Wi(o, 3)), ((r = e.call(this, a, new tc({ color: n, toneMapped: !1 })) || this).box = t), (r.type = 'Box3Helper'), r.geometry.computeBoundingSphere(), r ) } return ( Gn(t, e), (t.prototype.updateMatrixWorld = function (t) { var n = this.box n.isEmpty() || (n.getCenter(this.position), n.getSize(this.scale), this.scale.multiplyScalar(0.5), e.prototype.updateMatrixWorld.call(this, t)) }), t ) })(uc), Yp = (function (e) { function t(t, n, r) { var i void 0 === n && (n = 1), void 0 === r && (r = 16776960) var o = r, a = [ 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, ], s = new ro() s.setAttribute('position', new Wi(a, 3)), s.computeBoundingSphere(), ((i = e.call(this, s, new tc({ color: o, toneMapped: !1 })) || this).type = 'PlaneHelper'), (i.plane = t), (i.size = n) var l = [1, 1, 1, -1, 1, 1, -1, -1, 1, 1, 1, 1, -1, -1, 1, 1, -1, 1], c = new ro() return ( c.setAttribute('position', new Wi(l, 3)), c.computeBoundingSphere(), i.add( new xo( c, new Oi({ color: o, opacity: 0.2, transparent: !0, depthWrite: !1, toneMapped: !1, }), ), ), i ) } return ( Gn(t, e), (t.prototype.updateMatrixWorld = function (t) { var n = -this.plane.constant Math.abs(n) < 1e-8 && (n = 1e-8), this.scale.set(0.5 * this.size, 0.5 * this.size, n), (this.children[0].material.side = n < 0 ? v : m), this.lookAt(this.plane.normal), e.prototype.updateMatrixWorld.call(this, t) }), t ) })(sc), Qp = new lr(), Zp = (function (e) { function t(t, n, r, i, o, a) { var s return ( ((s = e.call(this) || this).type = 'ArrowHelper'), void 0 === t && (t = new lr(0, 0, 1)), void 0 === n && (n = new lr(0, 0, 0)), void 0 === r && (r = 1), void 0 === i && (i = 16776960), void 0 === o && (o = 0.2 * r), void 0 === a && (a = 0.2 * o), void 0 === zp && ((zp = new ro()).setAttribute( 'position', new Wi([0, 0, 0, 0, 1, 0], 3), ), (jp = new Mc(0, 0.5, 1, 5, 1)).translate(0, -0.5, 0)), s.position.copy(n), (s.line = new sc(zp, new tc({ color: i, toneMapped: !1 }))), (s.line.matrixAutoUpdate = !1), s.add(s.line), (s.cone = new xo(jp, new Oi({ color: i, toneMapped: !1 }))), (s.cone.matrixAutoUpdate = !1), s.add(s.cone), s.setDirection(t), s.setLength(r, o, a), s ) } Gn(t, e) var n = t.prototype return ( (n.setDirection = function (e) { if (e.y > 0.99999) this.quaternion.set(0, 0, 0, 1) else if (e.y < -0.99999) this.quaternion.set(1, 0, 0, 0) else { Qp.set(e.z, 0, -e.x).normalize() var t = Math.acos(e.y) this.quaternion.setFromAxisAngle(Qp, t) } }), (n.setLength = function (e, t, n) { void 0 === t && (t = 0.2 * e), void 0 === n && (n = 0.2 * t), this.line.scale.set(1, Math.max(1e-4, e - t), 1), this.line.updateMatrix(), this.cone.scale.set(n, t, n), (this.cone.position.y = e), this.cone.updateMatrix() }), (n.setColor = function (e) { this.line.material.color.set(e), this.cone.material.color.set(e) }), (n.copy = function (t) { return ( e.prototype.copy.call(this, t, !1), this.line.copy(t.line), this.cone.copy(t.cone), this ) }), t ) })(si), Kp = (function (e) { function t(t) { var n void 0 === t && (t = 1) var r = [0, 0, 0, t, 0, 0, 0, 0, 0, 0, t, 0, 0, 0, 0, 0, 0, t], i = [1, 0, 0, 1, 0.6, 0, 0, 1, 0, 0.6, 1, 0, 0, 0, 1, 0, 0.6, 1], o = new ro() o.setAttribute('position', new Wi(r, 3)), o.setAttribute('color', new Wi(i, 3)) var a = new tc({ vertexColors: !0, toneMapped: !1 }) return ((n = e.call(this, o, a) || this).type = 'AxesHelper'), n } return Gn(t, e), t })(uc), Jp = new Float32Array(1), $p = new Int32Array(Jp.buffer), ef = { toHalfFloat: function (e) { Jp[0] = e var t = $p[0], n = (t >> 16) & 32768, r = (t >> 12) & 2047, i = (t >> 23) & 255 return i < 103 ? n : i > 142 ? ((n |= 31744), (n |= (255 == i ? 0 : 1) && 8388607 & t)) : i < 113 ? (n |= ((r |= 2048) >> (114 - i)) + ((r >> (113 - i)) & 1)) : ((n |= ((i - 112) << 10) | (r >> 1)), (n += 1 & r)) }, }, tf = 4, nf = 8, rf = Math.pow(2, nf), of = [0.125, 0.215, 0.35, 0.446, 0.526, 0.582], af = nf - tf + 1 + of.length, sf = 20, lf = (((Vp = {})[Kt] = 0), (Vp[Jt] = 1), (Vp[en] = 2), (Vp[nn] = 3), (Vp[rn] = 4), (Vp[on] = 5), (Vp[$t] = 6), Vp), cf = new Oi({ side: v, depthWrite: !1, depthTest: !1 }), uf = new xo(new _o(), cf), hf = new ed(), df = Mf(), pf = df._lodPlanes, ff = df._sizeLods, mf = df._sigmas, vf = new Li(), gf = null, yf = (1 + Math.sqrt(5)) / 2, bf = 1 / yf, Af = [ new lr(1, 1, 1), new lr(-1, 1, 1), new lr(1, 1, -1), new lr(-1, 1, -1), new lr(0, yf, bf), new lr(0, yf, -bf), new lr(bf, 0, yf), new lr(-bf, 0, yf), new lr(yf, bf, 0), new lr(-yf, bf, 0), ] function wf(e) { var t = Math.max(e.r, e.g, e.b), n = Math.min(Math.max(Math.ceil(Math.log2(t)), -128), 127) return e.multiplyScalar(Math.pow(2, -n)), (n + 128) / 255 } var xf = (function () { function e(e) { ;(this._renderer = e), (this._pingPongRenderTarget = null), (this._blurMaterial = Sf(sf)), (this._equirectShader = null), (this._cubemapShader = null), this._compileMaterial(this._blurMaterial) } var t = e.prototype return ( (t.fromScene = function (e, t, n, r) { void 0 === t && (t = 0), void 0 === n && (n = 0.1), void 0 === r && (r = 100), (gf = this._renderer.getRenderTarget()) var i = this._allocateTargets() return ( this._sceneToCubeUV(e, n, r, i), t > 0 && this._blur(i, 0, 0, t), this._applyPMREM(i), this._cleanup(i), i ) }), (t.fromEquirectangular = function (e) { return this._fromTexture(e) }), (t.fromCubemap = function (e) { return this._fromTexture(e) }), (t.compileCubemapShader = function () { null === this._cubemapShader && ((this._cubemapShader = Lf()), this._compileMaterial(this._cubemapShader)) }), (t.compileEquirectangularShader = function () { null === this._equirectShader && ((this._equirectShader = Cf()), this._compileMaterial(this._equirectShader)) }), (t.dispose = function () { this._blurMaterial.dispose(), null !== this._cubemapShader && this._cubemapShader.dispose(), null !== this._equirectShader && this._equirectShader.dispose() for (var e = 0; e < pf.length; e++) pf[e].dispose() }), (t._cleanup = function (e) { this._pingPongRenderTarget.dispose(), this._renderer.setRenderTarget(gf), (e.scissorTest = !1), Tf(e, 0, 0, e.width, e.height) }), (t._fromTexture = function (e) { gf = this._renderer.getRenderTarget() var t = this._allocateTargets(e) return ( this._textureToCubeUV(e, t), this._applyPMREM(t), this._cleanup(t), t ) }), (t._allocateTargets = function (e) { var t = { magFilter: me, minFilter: me, generateMipmaps: !1, type: _e, format: ze, encoding: Ef(e) ? e.encoding : en, depthBuffer: !1, }, n = _f(t) return (n.depthBuffer = !e), (this._pingPongRenderTarget = _f(t)), n }), (t._compileMaterial = function (e) { var t = new xo(pf[0], e) this._renderer.compile(t, hf) }), (t._sceneToCubeUV = function (e, t, n, r) { var i = new Oo(90, 1, t, n), o = [1, -1, 1, 1, 1, 1], a = [1, 1, 1, -1, -1, -1], s = this._renderer, l = s.autoClear, c = s.outputEncoding, u = s.toneMapping s.getClearColor(vf), (s.toneMapping = $), (s.outputEncoding = Kt), (s.autoClear = !1) var h = !1, d = e.background if (d) { if (d.isColor) { cf.color.copy(d).convertSRGBToLinear(), (e.background = null) var p = wf(cf.color) ;(cf.opacity = p), (h = !0) } } else { cf.color.copy(vf).convertSRGBToLinear() var f = wf(cf.color) ;(cf.opacity = f), (h = !0) } for (var m = 0; m < 6; m++) { var v = m % 3 0 == v ? (i.up.set(0, o[m], 0), i.lookAt(a[m], 0, 0)) : 1 == v ? (i.up.set(0, 0, o[m]), i.lookAt(0, a[m], 0)) : (i.up.set(0, o[m], 0), i.lookAt(0, 0, a[m])), Tf(r, v * rf, m > 2 ? rf : 0, rf, rf), s.setRenderTarget(r), h && s.render(uf, i), s.render(e, i) } ;(s.toneMapping = u), (s.outputEncoding = c), (s.autoClear = l) }), (t._textureToCubeUV = function (e, t) { var n = this._renderer e.isCubeTexture ? null == this._cubemapShader && (this._cubemapShader = Lf()) : null == this._equirectShader && (this._equirectShader = Cf()) var r = e.isCubeTexture ? this._cubemapShader : this._equirectShader, i = new xo(pf[0], r), o = r.uniforms ;(o.envMap.value = e), e.isCubeTexture || o.texelSize.value.set(1 / e.image.width, 1 / e.image.height), (o.inputEncoding.value = lf[e.encoding]), (o.outputEncoding.value = lf[t.texture.encoding]), Tf(t, 0, 0, 3 * rf, 2 * rf), n.setRenderTarget(t), n.render(i, hf) }), (t._applyPMREM = function (e) { var t = this._renderer, n = t.autoClear t.autoClear = !1 for (var r = 1; r < af; r++) { var i = Math.sqrt(mf[r] * mf[r] - mf[r - 1] * mf[r - 1]), o = Af[(r - 1) % Af.length] this._blur(e, r - 1, r, i, o) } t.autoClear = n }), (t._blur = function (e, t, n, r, i) { var o = this._pingPongRenderTarget this._halfBlur(e, o, t, n, r, 'latitudinal', i), this._halfBlur(o, e, n, n, r, 'longitudinal', i) }), (t._halfBlur = function (e, t, n, r, i, o, a) { var s = this._renderer, l = this._blurMaterial 'latitudinal' !== o && 'longitudinal' !== o && console.error( 'blur direction must be either latitudinal or longitudinal!', ) var c = 3, u = new xo(pf[r], l), h = l.uniforms, d = ff[n] - 1, p = isFinite(i) ? Math.PI / (2 * d) : (2 * Math.PI) / (2 * sf - 1), f = i / p, m = isFinite(i) ? 1 + Math.floor(c * f) : sf m > sf && console.warn( 'sigmaRadians, ' + i + ', is too large and will clip, as it requested ' + m + ' samples when the maximum is set to ' + sf, ) for (var v = [], g = 0, y = 0; y < sf; ++y) { var b = y / f, A = Math.exp((-b * b) / 2) v.push(A), 0 == y ? (g += A) : y < m && (g += 2 * A) } for (var w = 0; w < v.length; w++) v[w] = v[w] / g ;(h.envMap.value = e.texture), (h.samples.value = m), (h.weights.value = v), (h.latitudinal.value = 'latitudinal' === o), a && (h.poleAxis.value = a), (h.dTheta.value = p), (h.mipInt.value = nf - n), (h.inputEncoding.value = lf[e.texture.encoding]), (h.outputEncoding.value = lf[e.texture.encoding]) var x = ff[r] Tf( t, 3 * Math.max(0, rf - 2 * x), (0 === r ? 0 : 2 * rf) + 2 * x * (r > nf - tf ? r - nf + tf : 0), 3 * x, 2 * x, ), s.setRenderTarget(t), s.render(u, hf) }), e ) })() function Ef(e) { return ( void 0 !== e && e.type === _e && (e.encoding === Kt || e.encoding === Jt || e.encoding === $t) ) } function Mf() { for (var e = [], t = [], n = [], r = nf, i = 0; i < af; i++) { var o = Math.pow(2, r) t.push(o) var a = 1 / o i > nf - tf ? (a = of[i - nf + tf - 1]) : 0 == i && (a = 0), n.push(a) for ( var s = 1 / (o - 1), l = -s / 2, c = 1 + s / 2, u = [l, l, c, l, c, c, l, l, c, c, l, c], h = 6, d = 6, p = 3, f = 2, m = 1, v = new Float32Array(p * d * h), g = new Float32Array(f * d * h), y = new Float32Array(m * d * h), b = 0; b < h; b++ ) { var A = ((b % 3) * 2) / 3 - 1, w = b > 2 ? 0 : -1, x = [ A, w, 0, A + 2 / 3, w, 0, A + 2 / 3, w + 1, 0, A, w, 0, A + 2 / 3, w + 1, 0, A, w + 1, 0, ] v.set(x, p * d * b), g.set(u, f * d * b) var E = [b, b, b, b, b, b] y.set(E, m * d * b) } var M = new ro() M.setAttribute('position', new Fi(v, p)), M.setAttribute('uv', new Fi(g, f)), M.setAttribute('faceIndex', new Fi(y, m)), e.push(M), r > tf && r-- } return { _lodPlanes: e, _sizeLods: t, _sigmas: n } } function _f(e) { var t = new or(3 * rf, 3 * rf, e) return ( (t.texture.mapping = ue), (t.texture.name = 'PMREM.cubeUv'), (t.scissorTest = !0), t ) } function Tf(e, t, n, r, i) { e.viewport.set(t, n, r, i), e.scissor.set(t, n, r, i) } function Sf(e) { return new Ou({ name: 'SphericalGaussianBlur', defines: { n: e }, uniforms: { envMap: { value: null }, samples: { value: 1 }, weights: { value: new Float32Array(e) }, latitudinal: { value: !1 }, dTheta: { value: 0 }, mipInt: { value: 0 }, poleAxis: { value: new lr(0, 1, 0) }, inputEncoding: { value: lf[Kt] }, outputEncoding: { value: lf[Kt] }, }, vertexShader: Rf(), fragmentShader: '\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform sampler2D envMap;\n\t\t\tuniform int samples;\n\t\t\tuniform float weights[ n ];\n\t\t\tuniform bool latitudinal;\n\t\t\tuniform float dTheta;\n\t\t\tuniform float mipInt;\n\t\t\tuniform vec3 poleAxis;\n\n\t\t\t' + Pf() + "\n\n\t\t\t#define ENVMAP_TYPE_CUBE_UV\n\t\t\t#include \n\n\t\t\tvec3 getSample( float theta, vec3 axis ) {\n\n\t\t\t\tfloat cosTheta = cos( theta );\n\t\t\t\t// Rodrigues' axis-angle rotation\n\t\t\t\tvec3 sampleDirection = vOutputDirection * cosTheta\n\t\t\t\t\t+ cross( axis, vOutputDirection ) * sin( theta )\n\t\t\t\t\t+ axis * dot( axis, vOutputDirection ) * ( 1.0 - cosTheta );\n\n\t\t\t\treturn bilinearCubeUV( envMap, sampleDirection, mipInt );\n\n\t\t\t}\n\n\t\t\tvoid main() {\n\n\t\t\t\tvec3 axis = latitudinal ? poleAxis : cross( poleAxis, vOutputDirection );\n\n\t\t\t\tif ( all( equal( axis, vec3( 0.0 ) ) ) ) {\n\n\t\t\t\t\taxis = vec3( vOutputDirection.z, 0.0, - vOutputDirection.x );\n\n\t\t\t\t}\n\n\t\t\t\taxis = normalize( axis );\n\n\t\t\t\tgl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 );\n\t\t\t\tgl_FragColor.rgb += weights[ 0 ] * getSample( 0.0, axis );\n\n\t\t\t\tfor ( int i = 1; i < n; i++ ) {\n\n\t\t\t\t\tif ( i >= samples ) {\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tfloat theta = dTheta * float( i );\n\t\t\t\t\tgl_FragColor.rgb += weights[ i ] * getSample( -1.0 * theta, axis );\n\t\t\t\t\tgl_FragColor.rgb += weights[ i ] * getSample( theta, axis );\n\n\t\t\t\t}\n\n\t\t\t\tgl_FragColor = linearToOutputTexel( gl_FragColor );\n\n\t\t\t}\n\t\t", blending: A, depthTest: !1, depthWrite: !1, }) } function Cf() { return new Ou({ name: 'EquirectangularToCubeUV', uniforms: { envMap: { value: null }, texelSize: { value: new Jn(1, 1) }, inputEncoding: { value: lf[Kt] }, outputEncoding: { value: lf[Kt] }, }, vertexShader: Rf(), fragmentShader: '\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform sampler2D envMap;\n\t\t\tuniform vec2 texelSize;\n\n\t\t\t' + Pf() + '\n\n\t\t\t#include \n\n\t\t\tvoid main() {\n\n\t\t\t\tgl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 );\n\n\t\t\t\tvec3 outputDirection = normalize( vOutputDirection );\n\t\t\t\tvec2 uv = equirectUv( outputDirection );\n\n\t\t\t\tvec2 f = fract( uv / texelSize - 0.5 );\n\t\t\t\tuv -= f * texelSize;\n\t\t\t\tvec3 tl = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\t\t\t\tuv.x += texelSize.x;\n\t\t\t\tvec3 tr = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\t\t\t\tuv.y += texelSize.y;\n\t\t\t\tvec3 br = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\t\t\t\tuv.x -= texelSize.x;\n\t\t\t\tvec3 bl = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\n\t\t\t\tvec3 tm = mix( tl, tr, f.x );\n\t\t\t\tvec3 bm = mix( bl, br, f.x );\n\t\t\t\tgl_FragColor.rgb = mix( tm, bm, f.y );\n\n\t\t\t\tgl_FragColor = linearToOutputTexel( gl_FragColor );\n\n\t\t\t}\n\t\t', blending: A, depthTest: !1, depthWrite: !1, }) } function Lf() { return new Ou({ name: 'CubemapToCubeUV', uniforms: { envMap: { value: null }, inputEncoding: { value: lf[Kt] }, outputEncoding: { value: lf[Kt] }, }, vertexShader: Rf(), fragmentShader: '\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform samplerCube envMap;\n\n\t\t\t' + Pf() + '\n\n\t\t\tvoid main() {\n\n\t\t\t\tgl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 );\n\t\t\t\tgl_FragColor.rgb = envMapTexelToLinear( textureCube( envMap, vec3( - vOutputDirection.x, vOutputDirection.yz ) ) ).rgb;\n\t\t\t\tgl_FragColor = linearToOutputTexel( gl_FragColor );\n\n\t\t\t}\n\t\t', blending: A, depthTest: !1, depthWrite: !1, }) } function Rf() { return '\n\n\t\tprecision mediump float;\n\t\tprecision mediump int;\n\n\t\tattribute vec3 position;\n\t\tattribute vec2 uv;\n\t\tattribute float faceIndex;\n\n\t\tvarying vec3 vOutputDirection;\n\n\t\t// RH coordinate system; PMREM face-indexing convention\n\t\tvec3 getDirection( vec2 uv, float face ) {\n\n\t\t\tuv = 2.0 * uv - 1.0;\n\n\t\t\tvec3 direction = vec3( uv, 1.0 );\n\n\t\t\tif ( face == 0.0 ) {\n\n\t\t\t\tdirection = direction.zyx; // ( 1, v, u ) pos x\n\n\t\t\t} else if ( face == 1.0 ) {\n\n\t\t\t\tdirection = direction.xzy;\n\t\t\t\tdirection.xz *= -1.0; // ( -u, 1, -v ) pos y\n\n\t\t\t} else if ( face == 2.0 ) {\n\n\t\t\t\tdirection.x *= -1.0; // ( -u, v, 1 ) pos z\n\n\t\t\t} else if ( face == 3.0 ) {\n\n\t\t\t\tdirection = direction.zyx;\n\t\t\t\tdirection.xz *= -1.0; // ( -1, v, -u ) neg x\n\n\t\t\t} else if ( face == 4.0 ) {\n\n\t\t\t\tdirection = direction.xzy;\n\t\t\t\tdirection.xy *= -1.0; // ( -u, -1, v ) neg y\n\n\t\t\t} else if ( face == 5.0 ) {\n\n\t\t\t\tdirection.z *= -1.0; // ( u, v, -1 ) neg z\n\n\t\t\t}\n\n\t\t\treturn direction;\n\n\t\t}\n\n\t\tvoid main() {\n\n\t\t\tvOutputDirection = getDirection( uv, faceIndex );\n\t\t\tgl_Position = vec4( position, 1.0 );\n\n\t\t}\n\t' } function Pf() { return '\n\n\t\tuniform int inputEncoding;\n\t\tuniform int outputEncoding;\n\n\t\t#include \n\n\t\tvec4 inputTexelToLinear( vec4 value ) {\n\n\t\t\tif ( inputEncoding == 0 ) {\n\n\t\t\t\treturn value;\n\n\t\t\t} else if ( inputEncoding == 1 ) {\n\n\t\t\t\treturn sRGBToLinear( value );\n\n\t\t\t} else if ( inputEncoding == 2 ) {\n\n\t\t\t\treturn RGBEToLinear( value );\n\n\t\t\t} else if ( inputEncoding == 3 ) {\n\n\t\t\t\treturn RGBMToLinear( value, 7.0 );\n\n\t\t\t} else if ( inputEncoding == 4 ) {\n\n\t\t\t\treturn RGBMToLinear( value, 16.0 );\n\n\t\t\t} else if ( inputEncoding == 5 ) {\n\n\t\t\t\treturn RGBDToLinear( value, 256.0 );\n\n\t\t\t} else {\n\n\t\t\t\treturn GammaToLinear( value, 2.2 );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvec4 linearToOutputTexel( vec4 value ) {\n\n\t\t\tif ( outputEncoding == 0 ) {\n\n\t\t\t\treturn value;\n\n\t\t\t} else if ( outputEncoding == 1 ) {\n\n\t\t\t\treturn LinearTosRGB( value );\n\n\t\t\t} else if ( outputEncoding == 2 ) {\n\n\t\t\t\treturn LinearToRGBE( value );\n\n\t\t\t} else if ( outputEncoding == 3 ) {\n\n\t\t\t\treturn LinearToRGBM( value, 7.0 );\n\n\t\t\t} else if ( outputEncoding == 4 ) {\n\n\t\t\t\treturn LinearToRGBM( value, 16.0 );\n\n\t\t\t} else if ( outputEncoding == 5 ) {\n\n\t\t\t\treturn LinearToRGBD( value, 256.0 );\n\n\t\t\t} else {\n\n\t\t\t\treturn LinearToGamma( value, 2.2 );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvec4 envMapTexelToLinear( vec4 color ) {\n\n\t\t\treturn inputTexelToLinear( color );\n\n\t\t}\n\t' } function Df(e, t, n, r, i, o, a) { return ( console.warn( 'THREE.Face4 has been removed. A THREE.Face3 will be created instead.', ), new Ri(e, t, n, i, o, a) ) } var Of = 0, If = 1, Bf = 0, Ff = 1, kf = 2 function Nf(e) { return ( console.warn( 'THREE.MeshFaceMaterial has been removed. Use an Array instead.', ), e ) } function Uf(e) { return ( void 0 === e && (e = []), console.warn('THREE.MultiMaterial has been removed. Use an Array instead.'), (e.isMultiMaterial = !0), (e.materials = e), (e.clone = function () { return e.slice() }), e ) } function Hf(e, t) { return ( console.warn('THREE.PointCloud has been renamed to THREE.Points.'), new gc(e, t) ) } function Gf(e) { return ( console.warn('THREE.Particle has been renamed to THREE.Sprite.'), new Bl(e) ) } function zf(e, t) { return ( console.warn('THREE.ParticleSystem has been renamed to THREE.Points.'), new gc(e, t) ) } function jf(e) { return ( console.warn( 'THREE.PointCloudMaterial has been renamed to THREE.PointsMaterial.', ), new dc(e) ) } function Vf(e) { return ( console.warn( 'THREE.ParticleBasicMaterial has been renamed to THREE.PointsMaterial.', ), new dc(e) ) } function Wf(e) { return ( console.warn( 'THREE.ParticleSystemMaterial has been renamed to THREE.PointsMaterial.', ), new dc(e) ) } function qf(e, t, n) { return ( console.warn('THREE.Vertex has been removed. Use THREE.Vector3 instead.'), new lr(e, t, n) ) } function Xf(e, t) { return ( console.warn( 'THREE.DynamicBufferAttribute has been removed. Use new THREE.BufferAttribute().setUsage( THREE.DynamicDrawUsage ) instead.', ), new Fi(e, t).setUsage(Sn) ) } function Yf(e, t) { return ( console.warn( 'THREE.Int8Attribute has been removed. Use new THREE.Int8BufferAttribute() instead.', ), new ki(e, t) ) } function Qf(e, t) { return ( console.warn( 'THREE.Uint8Attribute has been removed. Use new THREE.Uint8BufferAttribute() instead.', ), new Ni(e, t) ) } function Zf(e, t) { return ( console.warn( 'THREE.Uint8ClampedAttribute has been removed. Use new THREE.Uint8ClampedBufferAttribute() instead.', ), new Ui(e, t) ) } function Kf(e, t) { return ( console.warn( 'THREE.Int16Attribute has been removed. Use new THREE.Int16BufferAttribute() instead.', ), new Hi(e, t) ) } function Jf(e, t) { return ( console.warn( 'THREE.Uint16Attribute has been removed. Use new THREE.Uint16BufferAttribute() instead.', ), new Gi(e, t) ) } function $f(e, t) { return ( console.warn( 'THREE.Int32Attribute has been removed. Use new THREE.Int32BufferAttribute() instead.', ), new zi(e, t) ) } function em(e, t) { return ( console.warn( 'THREE.Uint32Attribute has been removed. Use new THREE.Uint32BufferAttribute() instead.', ), new ji(e, t) ) } function tm(e, t) { return ( console.warn( 'THREE.Float32Attribute has been removed. Use new THREE.Float32BufferAttribute() instead.', ), new Wi(e, t) ) } function nm(e, t) { return ( console.warn( 'THREE.Float64Attribute has been removed. Use new THREE.Float64BufferAttribute() instead.', ), new qi(e, t) ) } function rm(e) { console.warn( 'THREE.ClosedSplineCurve3 has been deprecated. Use THREE.CatmullRomCurve3 instead.', ), _h.call(this, e), (this.type = 'catmullrom'), (this.closed = !0) } function im(e) { console.warn( 'THREE.SplineCurve3 has been deprecated. Use THREE.CatmullRomCurve3 instead.', ), _h.call(this, e), (this.type = 'catmullrom') } function om(e) { console.warn( 'THREE.Spline has been removed. Use THREE.CatmullRomCurve3 instead.', ), _h.call(this, e), (this.type = 'catmullrom') } function am(e) { return ( console.warn('THREE.AxisHelper has been renamed to THREE.AxesHelper.'), new Kp(e) ) } function sm(e, t) { return ( console.warn( 'THREE.BoundingBoxHelper has been deprecated. Creating a THREE.BoxHelper instead.', ), new qp(e, t) ) } function lm(e, t) { return ( console.warn( 'THREE.EdgesHelper has been removed. Use THREE.EdgesGeometry instead.', ), new uc(new Dc(e.geometry), new tc({ color: void 0 !== t ? t : 16777215 })) ) } function cm(e, t) { return ( console.warn( 'THREE.WireframeHelper has been removed. Use THREE.WireframeGeometry instead.', ), new uc(new Ru(e.geometry), new tc({ color: void 0 !== t ? t : 16777215 })) ) } function um(e) { return ( console.warn('THREE.XHRLoader has been renamed to THREE.FileLoader.'), new uh(e) ) } function hm(e) { return ( console.warn( 'THREE.BinaryTextureLoader has been renamed to THREE.DataTextureLoader.', ), new mh(e) ) } function dm(e, t, n) { return ( console.warn( 'THREE.WebGLRenderTargetCube( width, height, options ) is now WebGLCubeRenderTarget( size, options ).', ), new No(e, n) ) } ;(gh.create = function (e, t) { return ( console.log('THREE.Curve.create() has been deprecated'), (e.prototype = Object.create(gh.prototype)), (e.prototype.constructor = e), (e.prototype.getPoint = t), e ) }), Object.assign(Wh.prototype, { fromPoints: function (e) { return ( console.warn( 'THREE.Path: .fromPoints() has been renamed to .setFromPoints().', ), this.setFromPoints(e) ) }, }), (rm.prototype = Object.create(_h.prototype)), (im.prototype = Object.create(_h.prototype)), (om.prototype = Object.create(_h.prototype)), Object.assign(om.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.', ) }, }), (Dp.prototype.setColors = function () { console.error( 'THREE.GridHelper: setColors() has been deprecated, pass them in the constructor instead.', ) }), (_p.prototype.update = function () { console.error( 'THREE.SkeletonHelper: update() no longer needs to be called.', ) }), Object.assign(lh.prototype, { extractUrlBase: function (e) { return ( console.warn( 'THREE.Loader: .extractUrlBase() has been deprecated. Use THREE.LoaderUtils.extractUrlBase() instead.', ), ld.extractUrlBase(e) ) }, }), (lh.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(mp.prototype, { center: function (e) { return ( console.warn('THREE.Box2: .center() has been renamed to .getCenter().'), this.getCenter(e) ) }, empty: function () { return ( console.warn('THREE.Box2: .empty() has been renamed to .isEmpty().'), this.isEmpty() ) }, isIntersectionBox: function (e) { return ( console.warn( 'THREE.Box2: .isIntersectionBox() has been renamed to .intersectsBox().', ), this.intersectsBox(e) ) }, size: function (e) { return ( console.warn('THREE.Box2: .size() has been renamed to .getSize().'), this.getSize(e) ) }, }), Object.assign(hr.prototype, { center: function (e) { return ( console.warn('THREE.Box3: .center() has been renamed to .getCenter().'), this.getCenter(e) ) }, empty: function () { return ( console.warn('THREE.Box3: .empty() has been renamed to .isEmpty().'), this.isEmpty() ) }, isIntersectionBox: function (e) { return ( console.warn( 'THREE.Box3: .isIntersectionBox() has been renamed to .intersectsBox().', ), this.intersectsBox(e) ) }, isIntersectionSphere: function (e) { return ( console.warn( 'THREE.Box3: .isIntersectionSphere() has been renamed to .intersectsSphere().', ), this.intersectsSphere(e) ) }, size: function (e) { return ( console.warn('THREE.Box3: .size() has been renamed to .getSize().'), this.getSize(e) ) }, }), Object.assign(Sr.prototype, { empty: function () { return ( console.warn('THREE.Sphere: .empty() has been renamed to .isEmpty().'), this.isEmpty() ) }, }), (zo.prototype.setFromMatrix = function (e) { return ( console.warn( 'THREE.Frustum: .setFromMatrix() has been renamed to .setFromProjectionMatrix().', ), this.setFromProjectionMatrix(e) ) }), (yp.prototype.center = function (e) { return ( console.warn('THREE.Line3: .center() has been renamed to .getCenter().'), this.getCenter(e) ) }), Object.assign(Kn, { random16: function () { return ( console.warn( 'THREE.Math: .random16() has been deprecated. Use Math.random() instead.', ), Math.random() ) }, nearestPowerOfTwo: function (e) { return ( console.warn( 'THREE.Math: .nearestPowerOfTwo() has been renamed to .floorPowerOfTwo().', ), Kn.floorPowerOfTwo(e) ) }, nextPowerOfTwo: function (e) { return ( console.warn( 'THREE.Math: .nextPowerOfTwo() has been renamed to .ceilPowerOfTwo().', ), Kn.ceilPowerOfTwo(e) ) }, }), Object.assign($n.prototype, { flattenToArrayOffset: function (e, t) { return ( console.warn( 'THREE.Matrix3: .flattenToArrayOffset() has been deprecated. Use .toArray() instead.', ), this.toArray(e, t) ) }, multiplyVector3: function (e) { return ( console.warn( 'THREE.Matrix3: .multiplyVector3() has been removed. Use vector.applyMatrix3( matrix ) instead.', ), e.applyMatrix3(this) ) }, multiplyVector3Array: function () { console.error('THREE.Matrix3: .multiplyVector3Array() has been removed.') }, applyToBufferAttribute: function (e) { return ( console.warn( 'THREE.Matrix3: .applyToBufferAttribute() has been removed. Use attribute.applyMatrix3( matrix ) instead.', ), e.applyMatrix3(this) ) }, applyToVector3Array: function () { console.error('THREE.Matrix3: .applyToVector3Array() has been removed.') }, getInverse: function (e) { return ( console.warn( 'THREE.Matrix3: .getInverse() has been removed. Use matrixInv.copy( matrix ).invert(); instead.', ), this.copy(e).invert() ) }, }), Object.assign(Fr.prototype, { extractPosition: function (e) { return ( console.warn( 'THREE.Matrix4: .extractPosition() has been renamed to .copyPosition().', ), this.copyPosition(e) ) }, flattenToArrayOffset: function (e, t) { return ( console.warn( 'THREE.Matrix4: .flattenToArrayOffset() has been deprecated. Use .toArray() instead.', ), this.toArray(e, t) ) }, getPosition: function () { return ( console.warn( 'THREE.Matrix4: .getPosition() has been removed. Use Vector3.setFromMatrixPosition( matrix ) instead.', ), new lr().setFromMatrixColumn(this, 3) ) }, setRotationFromQuaternion: function (e) { return ( console.warn( 'THREE.Matrix4: .setRotationFromQuaternion() has been renamed to .makeRotationFromQuaternion().', ), this.makeRotationFromQuaternion(e) ) }, multiplyToArray: function () { console.warn('THREE.Matrix4: .multiplyToArray() has been removed.') }, multiplyVector3: function (e) { return ( console.warn( 'THREE.Matrix4: .multiplyVector3() has been removed. Use vector.applyMatrix4( matrix ) instead.', ), e.applyMatrix4(this) ) }, multiplyVector4: function (e) { return ( console.warn( 'THREE.Matrix4: .multiplyVector4() has been removed. Use vector.applyMatrix4( matrix ) instead.', ), e.applyMatrix4(this) ) }, multiplyVector3Array: function () { console.error('THREE.Matrix4: .multiplyVector3Array() has been removed.') }, rotateAxis: function (e) { console.warn( 'THREE.Matrix4: .rotateAxis() has been removed. Use Vector3.transformDirection( matrix ) instead.', ), e.transformDirection(this) }, crossVector: function (e) { return ( console.warn( 'THREE.Matrix4: .crossVector() has been removed. Use vector.applyMatrix4( matrix ) instead.', ), e.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 (e) { return ( console.warn( 'THREE.Matrix4: .applyToBufferAttribute() has been removed. Use attribute.applyMatrix4( matrix ) instead.', ), e.applyMatrix4(this) ) }, applyToVector3Array: function () { console.error('THREE.Matrix4: .applyToVector3Array() has been removed.') }, makeFrustum: function (e, t, n, r, i, o) { return ( console.warn( 'THREE.Matrix4: .makeFrustum() has been removed. Use .makePerspective( left, right, top, bottom, near, far ) instead.', ), this.makePerspective(e, t, r, n, i, o) ) }, getInverse: function (e) { return ( console.warn( 'THREE.Matrix4: .getInverse() has been removed. Use matrixInv.copy( matrix ).invert(); instead.', ), this.copy(e).invert() ) }, }), (hi.prototype.isIntersectionLine = function (e) { return ( console.warn( 'THREE.Plane: .isIntersectionLine() has been renamed to .intersectsLine().', ), this.intersectsLine(e) ) }), Object.assign(sr.prototype, { multiplyVector3: function (e) { return ( console.warn( 'THREE.Quaternion: .multiplyVector3() has been removed. Use is now vector.applyQuaternion( quaternion ) instead.', ), e.applyQuaternion(this) ) }, inverse: function () { return ( console.warn( 'THREE.Quaternion: .inverse() has been renamed to invert().', ), this.invert() ) }, }), Object.assign(Br.prototype, { isIntersectionBox: function (e) { return ( console.warn( 'THREE.Ray: .isIntersectionBox() has been renamed to .intersectsBox().', ), this.intersectsBox(e) ) }, isIntersectionPlane: function (e) { return ( console.warn( 'THREE.Ray: .isIntersectionPlane() has been renamed to .intersectsPlane().', ), this.intersectsPlane(e) ) }, isIntersectionSphere: function (e) { return ( console.warn( 'THREE.Ray: .isIntersectionSphere() has been renamed to .intersectsSphere().', ), this.intersectsSphere(e) ) }, }), Object.assign(xi.prototype, { area: function () { return ( console.warn('THREE.Triangle: .area() has been renamed to .getArea().'), this.getArea() ) }, barycoordFromPoint: function (e, t) { return ( console.warn( 'THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord().', ), this.getBarycoord(e, t) ) }, midpoint: function (e) { return ( console.warn( 'THREE.Triangle: .midpoint() has been renamed to .getMidpoint().', ), this.getMidpoint(e) ) }, normal: function (e) { return ( console.warn( 'THREE.Triangle: .normal() has been renamed to .getNormal().', ), this.getNormal(e) ) }, plane: function (e) { return ( console.warn( 'THREE.Triangle: .plane() has been renamed to .getPlane().', ), this.getPlane(e) ) }, }), Object.assign(xi, { barycoordFromPoint: function (e, t, n, r, i) { return ( console.warn( 'THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord().', ), xi.getBarycoord(e, t, n, r, i) ) }, normal: function (e, t, n, r) { return ( console.warn( 'THREE.Triangle: .normal() has been renamed to .getNormal().', ), xi.getNormal(e, t, n, r) ) }, }), Object.assign(qh.prototype, { extractAllPoints: function (e) { return ( console.warn( 'THREE.Shape: .extractAllPoints() has been removed. Use .extractPoints() instead.', ), this.extractPoints(e) ) }, extrude: function (e) { return ( console.warn( 'THREE.Shape: .extrude() has been removed. Use ExtrudeGeometry() instead.', ), new fu(this, e) ) }, makeGeometry: function (e) { return ( console.warn( 'THREE.Shape: .makeGeometry() has been removed. Use ShapeGeometry() instead.', ), new xu(this, e) ) }, }), Object.assign(Jn.prototype, { fromAttribute: function (e, t, n) { return ( console.warn( 'THREE.Vector2: .fromAttribute() has been renamed to .fromBufferAttribute().', ), this.fromBufferAttribute(e, t, n) ) }, distanceToManhattan: function (e) { return ( console.warn( 'THREE.Vector2: .distanceToManhattan() has been renamed to .manhattanDistanceTo().', ), this.manhattanDistanceTo(e) ) }, lengthManhattan: function () { return ( console.warn( 'THREE.Vector2: .lengthManhattan() has been renamed to .manhattanLength().', ), this.manhattanLength() ) }, }), Object.assign(lr.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 (e) { return ( console.warn( 'THREE.Vector3: .getPositionFromMatrix() has been renamed to .setFromMatrixPosition().', ), this.setFromMatrixPosition(e) ) }, getScaleFromMatrix: function (e) { return ( console.warn( 'THREE.Vector3: .getScaleFromMatrix() has been renamed to .setFromMatrixScale().', ), this.setFromMatrixScale(e) ) }, getColumnFromMatrix: function (e, t) { return ( console.warn( 'THREE.Vector3: .getColumnFromMatrix() has been renamed to .setFromMatrixColumn().', ), this.setFromMatrixColumn(t, e) ) }, applyProjection: function (e) { return ( console.warn( 'THREE.Vector3: .applyProjection() has been removed. Use .applyMatrix4( m ) instead.', ), this.applyMatrix4(e) ) }, fromAttribute: function (e, t, n) { return ( console.warn( 'THREE.Vector3: .fromAttribute() has been renamed to .fromBufferAttribute().', ), this.fromBufferAttribute(e, t, n) ) }, distanceToManhattan: function (e) { return ( console.warn( 'THREE.Vector3: .distanceToManhattan() has been renamed to .manhattanDistanceTo().', ), this.manhattanDistanceTo(e) ) }, lengthManhattan: function () { return ( console.warn( 'THREE.Vector3: .lengthManhattan() has been renamed to .manhattanLength().', ), this.manhattanLength() ) }, }), Object.assign(ir.prototype, { fromAttribute: function (e, t, n) { return ( console.warn( 'THREE.Vector4: .fromAttribute() has been renamed to .fromBufferAttribute().', ), this.fromBufferAttribute(e, t, n) ) }, lengthManhattan: function () { return ( console.warn( 'THREE.Vector4: .lengthManhattan() has been renamed to .manhattanLength().', ), this.manhattanLength() ) }, }), Object.assign(si.prototype, { getChildByName: function (e) { return ( console.warn( 'THREE.Object3D: .getChildByName() has been renamed to .getObjectByName().', ), this.getObjectByName(e) ) }, renderDepth: function () { console.warn( 'THREE.Object3D: .renderDepth has been removed. Use .renderOrder, instead.', ) }, translate: function (e, t) { return ( console.warn( 'THREE.Object3D: .translate() has been removed. Use .translateOnAxis( axis, distance ) instead.', ), this.translateOnAxis(t, e) ) }, getWorldRotation: function () { console.error( 'THREE.Object3D: .getWorldRotation() has been removed. Use THREE.Object3D.getWorldQuaternion( target ) instead.', ) }, applyMatrix: function (e) { return ( console.warn( 'THREE.Object3D: .applyMatrix() has been renamed to .applyMatrix4().', ), this.applyMatrix4(e) ) }, }), Object.defineProperties(si.prototype, { eulerOrder: { get: function () { return ( console.warn('THREE.Object3D: .eulerOrder is now .rotation.order.'), this.rotation.order ) }, set: function (e) { console.warn('THREE.Object3D: .eulerOrder is now .rotation.order.'), (this.rotation.order = e) }, }, 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(xo.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(xo.prototype, { drawMode: { get: function () { return ( console.error( 'THREE.Mesh: .drawMode has been removed. The renderer now always assumes THREE.TrianglesDrawMode.', ), Yt ) }, 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(Ul.prototype, { objects: { get: function () { return ( console.warn('THREE.LOD: .objects has been renamed to .levels.'), this.levels ) }, }, }), Object.defineProperty(Ql.prototype, 'useVertexTexture', { get: function () { console.warn('THREE.Skeleton: useVertexTexture has been removed.') }, set: function () { console.warn('THREE.Skeleton: useVertexTexture has been removed.') }, }), (Wl.prototype.initBones = function () { console.error('THREE.SkinnedMesh: initBones() has been removed.') }), Object.defineProperty(gh.prototype, '__arcLengthDivisions', { get: function () { return ( console.warn( 'THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions.', ), this.arcLengthDivisions ) }, set: function (e) { console.warn( 'THREE.Curve: .__arcLengthDivisions is now .arcLengthDivisions.', ), (this.arcLengthDivisions = e) }, }), (Oo.prototype.setLens = function (e, t) { console.warn( 'THREE.PerspectiveCamera.setLens is deprecated. Use .setFocalLength and .filmGauge for a photographic setup.', ), void 0 !== t && (this.filmGauge = t), this.setFocalLength(e) }), Object.defineProperties(Xh.prototype, { onlyShadow: { set: function () { console.warn('THREE.Light: .onlyShadow has been removed.') }, }, shadowCameraFov: { set: function (e) { console.warn( 'THREE.Light: .shadowCameraFov is now .shadow.camera.fov.', ), (this.shadow.camera.fov = e) }, }, shadowCameraLeft: { set: function (e) { console.warn( 'THREE.Light: .shadowCameraLeft is now .shadow.camera.left.', ), (this.shadow.camera.left = e) }, }, shadowCameraRight: { set: function (e) { console.warn( 'THREE.Light: .shadowCameraRight is now .shadow.camera.right.', ), (this.shadow.camera.right = e) }, }, shadowCameraTop: { set: function (e) { console.warn( 'THREE.Light: .shadowCameraTop is now .shadow.camera.top.', ), (this.shadow.camera.top = e) }, }, shadowCameraBottom: { set: function (e) { console.warn( 'THREE.Light: .shadowCameraBottom is now .shadow.camera.bottom.', ), (this.shadow.camera.bottom = e) }, }, shadowCameraNear: { set: function (e) { console.warn( 'THREE.Light: .shadowCameraNear is now .shadow.camera.near.', ), (this.shadow.camera.near = e) }, }, shadowCameraFar: { set: function (e) { console.warn( 'THREE.Light: .shadowCameraFar is now .shadow.camera.far.', ), (this.shadow.camera.far = e) }, }, shadowCameraVisible: { set: function () { console.warn( 'THREE.Light: .shadowCameraVisible has been removed. Use new THREE.CameraHelper( light.shadow.camera ) instead.', ) }, }, shadowBias: { set: function (e) { console.warn('THREE.Light: .shadowBias is now .shadow.bias.'), (this.shadow.bias = e) }, }, shadowDarkness: { set: function () { console.warn('THREE.Light: .shadowDarkness has been removed.') }, }, shadowMapWidth: { set: function (e) { console.warn( 'THREE.Light: .shadowMapWidth is now .shadow.mapSize.width.', ), (this.shadow.mapSize.width = e) }, }, shadowMapHeight: { set: function (e) { console.warn( 'THREE.Light: .shadowMapHeight is now .shadow.mapSize.height.', ), (this.shadow.mapSize.height = e) }, }, }), Object.defineProperties(Fi.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.', ), this.usage === Sn ) }, set: function () { console.warn( 'THREE.BufferAttribute: .dynamic has been deprecated. Use .usage instead.', ), this.setUsage(Sn) }, }, }), Object.assign(Fi.prototype, { setDynamic: function (e) { return ( console.warn( 'THREE.BufferAttribute: .setDynamic() has been deprecated. Use .setUsage() instead.', ), this.setUsage(!0 === e ? Sn : Tn), 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(ro.prototype, { addIndex: function (e) { console.warn( 'THREE.BufferGeometry: .addIndex() has been renamed to .setIndex().', ), this.setIndex(e) }, addAttribute: function (e, t) { return ( console.warn( 'THREE.BufferGeometry: .addAttribute() has been renamed to .setAttribute().', ), (t && t.isBufferAttribute) || (t && t.isInterleavedBufferAttribute) ? 'index' === e ? (console.warn( 'THREE.BufferGeometry.addAttribute: Use .setIndex() for index attribute.', ), this.setIndex(t), this) : this.setAttribute(e, t) : (console.warn( 'THREE.BufferGeometry: .addAttribute() now expects ( name, attribute ).', ), this.setAttribute(e, new Fi(arguments[1], arguments[2]))) ) }, addDrawCall: function (e, t, n) { void 0 !== n && console.warn( 'THREE.BufferGeometry: .addDrawCall() no longer supports indexOffset.', ), console.warn( 'THREE.BufferGeometry: .addDrawCall() is now .addGroup().', ), this.addGroup(e, t) }, clearDrawCalls: function () { console.warn( 'THREE.BufferGeometry: .clearDrawCalls() is now .clearGroups().', ), this.clearGroups() }, computeOffsets: function () { console.warn('THREE.BufferGeometry: .computeOffsets() has been removed.') }, removeAttribute: function (e) { return ( console.warn( 'THREE.BufferGeometry: .removeAttribute() has been renamed to .deleteAttribute().', ), this.deleteAttribute(e) ) }, applyMatrix: function (e) { return ( console.warn( 'THREE.BufferGeometry: .applyMatrix() has been renamed to .applyMatrix4().', ), this.applyMatrix4(e) ) }, }), Object.defineProperties(ro.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(cd.prototype, { maxInstancedCount: { get: function () { return ( console.warn( 'THREE.InstancedBufferGeometry: .maxInstancedCount has been renamed to .instanceCount.', ), this.instanceCount ) }, set: function (e) { console.warn( 'THREE.InstancedBufferGeometry: .maxInstancedCount has been renamed to .instanceCount.', ), (this.instanceCount = e) }, }, }), Object.defineProperties(cp.prototype, { linePrecision: { get: function () { return ( console.warn( 'THREE.Raycaster: .linePrecision has been deprecated. Use .params.Line.threshold instead.', ), this.params.Line.threshold ) }, set: function (e) { console.warn( 'THREE.Raycaster: .linePrecision has been deprecated. Use .params.Line.threshold instead.', ), (this.params.Line.threshold = e) }, }, }), Object.defineProperties(yl.prototype, { dynamic: { get: function () { return ( console.warn( 'THREE.InterleavedBuffer: .length has been deprecated. Use .usage instead.', ), this.usage === Sn ) }, set: function (e) { console.warn( 'THREE.InterleavedBuffer: .length has been deprecated. Use .usage instead.', ), this.setUsage(e) }, }, }), Object.assign(yl.prototype, { setDynamic: function (e) { return ( console.warn( 'THREE.InterleavedBuffer: .setDynamic() has been deprecated. Use .setUsage() instead.', ), this.setUsage(!0 === e ? Sn : Tn), this ) }, setArray: function () { console.error( 'THREE.InterleavedBuffer: .setArray has been removed. Use BufferGeometry .setAttribute to replace/resize attribute buffers', ) }, }), Object.assign(fu.prototype, { getArrays: function () { console.error('THREE.ExtrudeGeometry: .getArrays() has been removed.') }, addShapeList: function () { console.error('THREE.ExtrudeGeometry: .addShapeList() has been removed.') }, addShape: function () { console.error('THREE.ExtrudeGeometry: .addShape() has been removed.') }, }), Object.assign(gl.prototype, { dispose: function () { console.error('THREE.Scene: .dispose() has been removed.') }, }), Object.defineProperties(ap.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(Di.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 Li() ) }, }, shading: { get: function () { console.error( 'THREE.' + this.type + ': .shading has been removed. Use the boolean .flatShading instead.', ) }, set: function (e) { console.warn( 'THREE.' + this.type + ': .shading has been removed. Use the boolean .flatShading instead.', ), (this.flatShading = e === y) }, }, stencilMask: { get: function () { return ( console.warn( 'THREE.' + this.type + ': .stencilMask has been removed. Use .stencilFuncMask instead.', ), this.stencilFuncMask ) }, set: function (e) { console.warn( 'THREE.' + this.type + ': .stencilMask has been removed. Use .stencilFuncMask instead.', ), (this.stencilFuncMask = e) }, }, }), Object.defineProperties(Fu.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(Bu.prototype, { transparency: { get: function () { return ( console.warn( 'THREE.MeshPhysicalMaterial: .transparency has been renamed to .transmission.', ), this.transmission ) }, set: function (e) { console.warn( 'THREE.MeshPhysicalMaterial: .transparency has been renamed to .transmission.', ), (this.transmission = e) }, }, }), Object.defineProperties(Po.prototype, { derivatives: { get: function () { return ( console.warn( 'THREE.ShaderMaterial: .derivatives has been moved to .extensions.derivatives.', ), this.extensions.derivatives ) }, set: function (e) { console.warn( 'THREE. ShaderMaterial: .derivatives has been moved to .extensions.derivatives.', ), (this.extensions.derivatives = e) }, }, }), Object.assign(pl.prototype, { clearTarget: function (e, t, n, r) { console.warn( 'THREE.WebGLRenderer: .clearTarget() has been deprecated. Use .setRenderTarget() and .clear() instead.', ), this.setRenderTarget(e), this.clear(t, n, r) }, animate: function (e) { console.warn( 'THREE.WebGLRenderer: .animate() is now .setAnimationLoop().', ), this.setAnimationLoop(e) }, 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 (e) { console.warn( 'THREE.WebGLRenderer: .enableScissorTest() is now .setScissorTest().', ), this.setScissorTest(e) }, 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.') }, 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(pl.prototype, { shadowMapEnabled: { get: function () { return this.shadowMap.enabled }, set: function (e) { console.warn( 'THREE.WebGLRenderer: .shadowMapEnabled is now .shadowMap.enabled.', ), (this.shadowMap.enabled = e) }, }, shadowMapType: { get: function () { return this.shadowMap.type }, set: function (e) { console.warn( 'THREE.WebGLRenderer: .shadowMapType is now .shadowMap.type.', ), (this.shadowMap.type = e) }, }, 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 (e) { console.warn( 'THREE.WebGLRenderer: .gammaOutput has been removed. Set WebGLRenderer.outputEncoding instead.', ), (this.outputEncoding = !0 === e ? Jt : Kt) }, }, toneMappingWhitePoint: { get: function () { return ( console.warn( 'THREE.WebGLRenderer: .toneMappingWhitePoint has been removed.', ), 1 ) }, set: function () { console.warn( 'THREE.WebGLRenderer: .toneMappingWhitePoint has been removed.', ) }, }, }), Object.defineProperties($s.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(or.prototype, { wrapS: { get: function () { return ( console.warn( 'THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS.', ), this.texture.wrapS ) }, set: function (e) { console.warn('THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS.'), (this.texture.wrapS = e) }, }, wrapT: { get: function () { return ( console.warn( 'THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT.', ), this.texture.wrapT ) }, set: function (e) { console.warn('THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT.'), (this.texture.wrapT = e) }, }, magFilter: { get: function () { return ( console.warn( 'THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter.', ), this.texture.magFilter ) }, set: function (e) { console.warn( 'THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter.', ), (this.texture.magFilter = e) }, }, minFilter: { get: function () { return ( console.warn( 'THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter.', ), this.texture.minFilter ) }, set: function (e) { console.warn( 'THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter.', ), (this.texture.minFilter = e) }, }, anisotropy: { get: function () { return ( console.warn( 'THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy.', ), this.texture.anisotropy ) }, set: function (e) { console.warn( 'THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy.', ), (this.texture.anisotropy = e) }, }, offset: { get: function () { return ( console.warn( 'THREE.WebGLRenderTarget: .offset is now .texture.offset.', ), this.texture.offset ) }, set: function (e) { console.warn( 'THREE.WebGLRenderTarget: .offset is now .texture.offset.', ), (this.texture.offset = e) }, }, repeat: { get: function () { return ( console.warn( 'THREE.WebGLRenderTarget: .repeat is now .texture.repeat.', ), this.texture.repeat ) }, set: function (e) { console.warn( 'THREE.WebGLRenderTarget: .repeat is now .texture.repeat.', ), (this.texture.repeat = e) }, }, format: { get: function () { return ( console.warn( 'THREE.WebGLRenderTarget: .format is now .texture.format.', ), this.texture.format ) }, set: function (e) { console.warn( 'THREE.WebGLRenderTarget: .format is now .texture.format.', ), (this.texture.format = e) }, }, type: { get: function () { return ( console.warn('THREE.WebGLRenderTarget: .type is now .texture.type.'), this.texture.type ) }, set: function (e) { console.warn('THREE.WebGLRenderTarget: .type is now .texture.type.'), (this.texture.type = e) }, }, generateMipmaps: { get: function () { return ( console.warn( 'THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps.', ), this.texture.generateMipmaps ) }, set: function (e) { console.warn( 'THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps.', ), (this.texture.generateMipmaps = e) }, }, }), Object.defineProperties(kd.prototype, { load: { value: function (e) { console.warn( 'THREE.Audio: .load has been deprecated. Use THREE.AudioLoader instead.', ) var t = this return ( new Md().load(e, function (e) { t.setBuffer(e) }), this ) }, }, startTime: { set: function () { console.warn('THREE.Audio: .startTime is now .play( delay ).') }, }, }), (jd.prototype.getData = function () { return ( console.warn( 'THREE.AudioAnalyser: .getData() is now .getFrequencyData().', ), this.getFrequencyData() ) }), (Fo.prototype.updateCubeMap = function (e, t) { return ( console.warn('THREE.CubeCamera: .updateCubeMap() is now .update().'), this.update(e, t) ) }), (Fo.prototype.clear = function (e, t, n, r) { return ( console.warn('THREE.CubeCamera: .clear() is now .renderTarget.clear().'), this.renderTarget.clear(e, t, n, r) ) }) var pm = { merge: function (e, t, n) { var r console.warn( 'THREE.GeometryUtils: .merge() has been moved to Geometry. Use geometry.merge( geometry2, matrix, materialIndexOffset ) instead.', ), t.isMesh && (t.matrixAutoUpdate && t.updateMatrix(), (r = t.matrix), (t = t.geometry)), e.merge(t, r, n) }, center: function (e) { return ( console.warn( 'THREE.GeometryUtils: .center() has been moved to Geometry. Use geometry.center() instead.', ), e.center() ) }, } function fm() { console.error('THREE.CanvasRenderer has been removed') } function mm() { console.error('THREE.JSONLoader has been removed.') } ;(er.crossOrigin = void 0), (er.loadTexture = function (e, t, n, r) { console.warn( 'THREE.ImageUtils.loadTexture has been deprecated. Use THREE.TextureLoader() instead.', ) var i = new vh() i.setCrossOrigin(this.crossOrigin) var o = i.load(e, n, void 0, r) return t && (o.mapping = t), o }), (er.loadTextureCube = function (e, t, n, r) { console.warn( 'THREE.ImageUtils.loadTextureCube has been deprecated. Use THREE.CubeTextureLoader() instead.', ) var i = new fh() i.setCrossOrigin(this.crossOrigin) var o = i.load(e, n, void 0, r) return t && (o.mapping = t), o }), (er.loadCompressedTexture = function () { console.error( 'THREE.ImageUtils.loadCompressedTexture has been removed. Use THREE.DDSLoader instead.', ) }), (er.loadCompressedTextureCube = function () { console.error( 'THREE.ImageUtils.loadCompressedTextureCube has been removed. Use THREE.DDSLoader instead.', ) }) var vm = { 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', ) }, } function gm() { console.error( 'THREE.LensFlare has been moved to /examples/jsm/objects/Lensflare.js', ) } 'undefined' !== typeof __THREE_DEVTOOLS__ && __THREE_DEVTOOLS__.dispatchEvent( new CustomEvent('register', { detail: { revision: i } }), ), 'undefined' !== typeof window && (window.__THREE__ ? console.warn('WARNING: Multiple instances of Three.js being imported.') : (window.__THREE__ = i)), (t.ACESFilmicToneMapping = re), (t.AddEquation = T), (t.AddOperation = J), (t.AdditiveAnimationBlendMode = Xt), (t.AdditiveBlending = x), (t.AlphaFormat = ke), (t.AlwaysDepth = j), (t.AlwaysStencilFunc = _n), (t.AmbientLight = rd), (t.AmbientLightProbe = Td), (t.AnimationClip = nh), (t.AnimationLoader = hh), (t.AnimationMixer = op), (t.AnimationObjectGroup = rp), (t.AnimationUtils = ju), (t.ArcCurve = bh), (t.ArrayCamera = il), (t.ArrowHelper = Zp), (t.Audio = kd), (t.AudioAnalyser = jd), (t.AudioContext = Ed), (t.AudioListener = Fd), (t.AudioLoader = Md), (t.AxesHelper = Kp), (t.AxisHelper = am), (t.BackSide = v), (t.BasicDepthPacking = an), (t.BasicShadowMap = h), (t.BinaryTextureLoader = hm), (t.Bone = ql), (t.BooleanKeyframeTrack = Qu), (t.BoundingBoxHelper = sm), (t.Box2 = mp), (t.Box3 = hr), (t.Box3Helper = Xp), (t.BoxBufferGeometry = _o), (t.BoxGeometry = _o), (t.BoxHelper = qp), (t.BufferAttribute = Fi), (t.BufferGeometry = ro), (t.BufferGeometryLoader = hd), (t.ByteType = Te), (t.Cache = oh), (t.Camera = Do), (t.CameraHelper = Hp), (t.CanvasRenderer = fm), (t.CanvasTexture = wc), (t.CatmullRomCurve3 = _h), (t.CineonToneMapping = ne), (t.CircleBufferGeometry = Ec), (t.CircleGeometry = Ec), (t.ClampToEdgeWrapping = pe), (t.Clock = Rd), (t.ClosedSplineCurve3 = rm), (t.Color = Li), (t.ColorKeyframeTrack = Zu), (t.CompressedTexture = Ac), (t.CompressedTextureLoader = dh), (t.ConeBufferGeometry = _c), (t.ConeGeometry = _c), (t.CubeCamera = Fo), (t.CubeReflectionMapping = ae), (t.CubeRefractionMapping = se), (t.CubeTexture = ko), (t.CubeTextureLoader = fh), (t.CubeUVReflectionMapping = ue), (t.CubeUVRefractionMapping = he), (t.CubicBezierCurve = Fh), (t.CubicBezierCurve3 = kh), (t.CubicInterpolant = Wu), (t.CullFaceBack = l), (t.CullFaceFront = c), (t.CullFaceFrontBack = u), (t.CullFaceNone = s), (t.Curve = gh), (t.CurvePath = Vh), (t.CustomBlending = _), (t.CustomToneMapping = ie), (t.CylinderBufferGeometry = Mc), (t.CylinderGeometry = Mc), (t.Cylindrical = pp), (t.DataTexture = Uo), (t.DataTexture2DArray = ca), (t.DataTexture3D = ua), (t.DataTextureLoader = mh), (t.DataUtils = ef), (t.DecrementStencilOp = fn), (t.DecrementWrapStencilOp = vn), (t.DefaultLoadingManager = sh), (t.DepthFormat = je), (t.DepthStencilFormat = Ve), (t.DepthTexture = xc), (t.DirectionalLight = nd), (t.DirectionalLightHelper = kp), (t.DiscreteInterpolant = Xu), (t.DodecahedronBufferGeometry = Sc), (t.DodecahedronGeometry = Sc), (t.DoubleSide = g), (t.DstAlphaFactor = k), (t.DstColorFactor = U), (t.DynamicBufferAttribute = Xf), (t.DynamicCopyUsage = On), (t.DynamicDrawUsage = Sn), (t.DynamicReadUsage = Rn), (t.EdgesGeometry = Dc), (t.EdgesHelper = lm), (t.EllipseCurve = yh), (t.EqualDepth = q), (t.EqualStencilFunc = An), (t.EquirectangularReflectionMapping = le), (t.EquirectangularRefractionMapping = ce), (t.Euler = Vr), (t.EventDispatcher = qn), (t.ExtrudeBufferGeometry = fu), (t.ExtrudeGeometry = fu), (t.Face3 = Ri), (t.Face4 = Df), (t.FaceColors = Ff), (t.FileLoader = uh), (t.FlatShading = y), (t.Float16BufferAttribute = Vi), (t.Float32Attribute = tm), (t.Float32BufferAttribute = Wi), (t.Float64Attribute = nm), (t.Float64BufferAttribute = qi), (t.FloatType = Pe), (t.Fog = vl), (t.FogExp2 = ml), (t.Font = bd), (t.FontLoader = xd), (t.FrontSide = m), (t.Frustum = zo), (t.GLBufferAttribute = lp), (t.GLSL1 = Bn), (t.GLSL3 = Fn), (t.GammaEncoding = $t), (t.GeometryUtils = pm), (t.GreaterDepth = Y), (t.GreaterEqualDepth = X), (t.GreaterEqualStencilFunc = Mn), (t.GreaterStencilFunc = xn), (t.GridHelper = Dp), (t.Group = rl), (t.HalfFloatType = De), (t.HemisphereLight = Yh), (t.HemisphereLightHelper = Pp), (t.HemisphereLightProbe = _d), (t.IcosahedronBufferGeometry = gu), (t.IcosahedronGeometry = gu), (t.ImageBitmapLoader = vd), (t.ImageLoader = ph), (t.ImageUtils = er), (t.ImmediateRenderObject = bp), (t.IncrementStencilOp = pn), (t.IncrementWrapStencilOp = mn), (t.InstancedBufferAttribute = ud), (t.InstancedBufferGeometry = cd), (t.InstancedInterleavedBuffer = sp), (t.InstancedMesh = ec), (t.Int16Attribute = Kf), (t.Int16BufferAttribute = Hi), (t.Int32Attribute = $f), (t.Int32BufferAttribute = zi), (t.Int8Attribute = Yf), (t.Int8BufferAttribute = ki), (t.IntType = Le), (t.InterleavedBuffer = yl), (t.InterleavedBufferAttribute = wl), (t.Interpolant = Vu), (t.InterpolateDiscrete = Ht), (t.InterpolateLinear = Gt), (t.InterpolateSmooth = zt), (t.InvertStencilOp = gn), (t.JSONLoader = mm), (t.KeepStencilOp = hn), (t.KeyframeTrack = Yu), (t.LOD = Ul), (t.LatheBufferGeometry = yu), (t.LatheGeometry = yu), (t.Layers = Xr), (t.LensFlare = gm), (t.LessDepth = V), (t.LessEqualDepth = W), (t.LessEqualStencilFunc = wn), (t.LessStencilFunc = bn), (t.Light = Xh), (t.LightProbe = ad), (t.Line = sc), (t.Line3 = yp), (t.LineBasicMaterial = tc), (t.LineCurve = Nh), (t.LineCurve3 = Uh), (t.LineDashedMaterial = Gu), (t.LineLoop = hc), (t.LinePieces = If), (t.LineSegments = uc), (t.LineStrip = Of), (t.LinearEncoding = Kt), (t.LinearFilter = Ae), (t.LinearInterpolant = qu), (t.LinearMipMapLinearFilter = Me), (t.LinearMipMapNearestFilter = xe), (t.LinearMipmapLinearFilter = Ee), (t.LinearMipmapNearestFilter = we), (t.LinearToneMapping = ee), (t.Loader = lh), (t.LoaderUtils = ld), (t.LoadingManager = ah), (t.LogLuvEncoding = tn), (t.LoopOnce = kt), (t.LoopPingPong = Ut), (t.LoopRepeat = Nt), (t.LuminanceAlphaFormat = Ge), (t.LuminanceFormat = He), (t.MOUSE = o), (t.Material = Di), (t.MaterialLoader = sd), (t.Math = Kn), (t.MathUtils = Kn), (t.Matrix3 = $n), (t.Matrix4 = Fr), (t.MaxEquation = R), (t.Mesh = xo), (t.MeshBasicMaterial = Oi), (t.MeshDepthMaterial = Qs), (t.MeshDistanceMaterial = Zs), (t.MeshFaceMaterial = Nf), (t.MeshLambertMaterial = Uu), (t.MeshMatcapMaterial = Hu), (t.MeshNormalMaterial = Nu), (t.MeshPhongMaterial = Fu), (t.MeshPhysicalMaterial = Bu), (t.MeshStandardMaterial = Iu), (t.MeshToonMaterial = ku), (t.MinEquation = L), (t.MirroredRepeatWrapping = fe), (t.MixOperation = K), (t.MultiMaterial = Uf), (t.MultiplyBlending = M), (t.MultiplyOperation = Z), (t.NearestFilter = me), (t.NearestMipMapLinearFilter = be), (t.NearestMipMapNearestFilter = ge), (t.NearestMipmapLinearFilter = ye), (t.NearestMipmapNearestFilter = ve), (t.NeverDepth = z), (t.NeverStencilFunc = yn), (t.NoBlending = A), (t.NoColors = Bf), (t.NoToneMapping = $), (t.NormalAnimationBlendMode = qt), (t.NormalBlending = w), (t.NotEqualDepth = Q), (t.NotEqualStencilFunc = En), (t.NumberKeyframeTrack = Ku), (t.Object3D = si), (t.ObjectLoader = dd), (t.ObjectSpaceNormalMap = cn), (t.OctahedronBufferGeometry = bu), (t.OctahedronGeometry = bu), (t.OneFactor = D), (t.OneMinusDstAlphaFactor = N), (t.OneMinusDstColorFactor = H), (t.OneMinusSrcAlphaFactor = F), (t.OneMinusSrcColorFactor = I), (t.OrthographicCamera = ed), (t.PCFShadowMap = d), (t.PCFSoftShadowMap = p), (t.PMREMGenerator = xf), (t.ParametricBufferGeometry = Au), (t.ParametricGeometry = Au), (t.Particle = Gf), (t.ParticleBasicMaterial = Vf), (t.ParticleSystem = zf), (t.ParticleSystemMaterial = Wf), (t.Path = Wh), (t.PerspectiveCamera = Oo), (t.Plane = hi), (t.PlaneBufferGeometry = Wo), (t.PlaneGeometry = Wo), (t.PlaneHelper = Yp), (t.PointCloud = Hf), (t.PointCloudMaterial = jf), (t.PointLight = $h), (t.PointLightHelper = Sp), (t.Points = gc), (t.PointsMaterial = dc), (t.PolarGridHelper = Op), (t.PolyhedronBufferGeometry = Tc), (t.PolyhedronGeometry = Tc), (t.PositionalAudio = zd), (t.PropertyBinding = np), (t.PropertyMixer = Vd), (t.QuadraticBezierCurve = Hh), (t.QuadraticBezierCurve3 = Gh), (t.Quaternion = sr), (t.QuaternionKeyframeTrack = $u), (t.QuaternionLinearInterpolant = Ju), (t.REVISION = i), (t.RGBADepthPacking = sn), (t.RGBAFormat = Ue), (t.RGBAIntegerFormat = Ze), (t.RGBA_ASTC_10x10_Format = bt), (t.RGBA_ASTC_10x5_Format = vt), (t.RGBA_ASTC_10x6_Format = gt), (t.RGBA_ASTC_10x8_Format = yt), (t.RGBA_ASTC_12x10_Format = At), (t.RGBA_ASTC_12x12_Format = wt), (t.RGBA_ASTC_4x4_Format = lt), (t.RGBA_ASTC_5x4_Format = ct), (t.RGBA_ASTC_5x5_Format = ut), (t.RGBA_ASTC_6x5_Format = ht), (t.RGBA_ASTC_6x6_Format = dt), (t.RGBA_ASTC_8x5_Format = pt), (t.RGBA_ASTC_8x6_Format = ft), (t.RGBA_ASTC_8x8_Format = mt), (t.RGBA_BPTC_Format = xt), (t.RGBA_ETC2_EAC_Format = st), (t.RGBA_PVRTC_2BPPV1_Format = it), (t.RGBA_PVRTC_4BPPV1_Format = rt), (t.RGBA_S3TC_DXT1_Format = Je), (t.RGBA_S3TC_DXT3_Format = $e), (t.RGBA_S3TC_DXT5_Format = et), (t.RGBDEncoding = on), (t.RGBEEncoding = en), (t.RGBEFormat = ze), (t.RGBFormat = Ne), (t.RGBIntegerFormat = Qe), (t.RGBM16Encoding = rn), (t.RGBM7Encoding = nn), (t.RGB_ETC1_Format = ot), (t.RGB_ETC2_Format = at), (t.RGB_PVRTC_2BPPV1_Format = nt), (t.RGB_PVRTC_4BPPV1_Format = tt), (t.RGB_S3TC_DXT1_Format = Ke), (t.RGFormat = Xe), (t.RGIntegerFormat = Ye), (t.RawShaderMaterial = Ou), (t.Ray = Br), (t.Raycaster = cp), (t.RectAreaLight = id), (t.RedFormat = We), (t.RedIntegerFormat = qe), (t.ReinhardToneMapping = te), (t.RepeatWrapping = de), (t.ReplaceStencilOp = dn), (t.ReverseSubtractEquation = C), (t.RingBufferGeometry = wu), (t.RingGeometry = wu), (t.SRGB8_ALPHA8_ASTC_10x10_Format = It), (t.SRGB8_ALPHA8_ASTC_10x5_Format = Pt), (t.SRGB8_ALPHA8_ASTC_10x6_Format = Dt), (t.SRGB8_ALPHA8_ASTC_10x8_Format = Ot), (t.SRGB8_ALPHA8_ASTC_12x10_Format = Bt), (t.SRGB8_ALPHA8_ASTC_12x12_Format = Ft), (t.SRGB8_ALPHA8_ASTC_4x4_Format = Et), (t.SRGB8_ALPHA8_ASTC_5x4_Format = Mt), (t.SRGB8_ALPHA8_ASTC_5x5_Format = _t), (t.SRGB8_ALPHA8_ASTC_6x5_Format = Tt), (t.SRGB8_ALPHA8_ASTC_6x6_Format = St), (t.SRGB8_ALPHA8_ASTC_8x5_Format = Ct), (t.SRGB8_ALPHA8_ASTC_8x6_Format = Lt), (t.SRGB8_ALPHA8_ASTC_8x8_Format = Rt), (t.Scene = gl), (t.SceneUtils = vm), (t.ShaderChunk = qo), (t.ShaderLib = Yo), (t.ShaderMaterial = Po), (t.ShadowMaterial = Du), (t.Shape = qh), (t.ShapeBufferGeometry = xu), (t.ShapeGeometry = xu), (t.ShapePath = gd), (t.ShapeUtils = hu), (t.ShortType = Se), (t.Skeleton = Ql), (t.SkeletonHelper = _p), (t.SkinnedMesh = Wl), (t.SmoothShading = b), (t.Sphere = Sr), (t.SphereBufferGeometry = Mu), (t.SphereGeometry = Mu), (t.Spherical = dp), (t.SphericalHarmonics3 = od), (t.Spline = om), (t.SplineCurve = zh), (t.SplineCurve3 = im), (t.SpotLight = Kh), (t.SpotLightHelper = wp), (t.Sprite = Bl), (t.SpriteMaterial = xl), (t.SrcAlphaFactor = B), (t.SrcAlphaSaturateFactor = G), (t.SrcColorFactor = O), (t.StaticCopyUsage = Dn), (t.StaticDrawUsage = Tn), (t.StaticReadUsage = Ln), (t.StereoCamera = Ld), (t.StreamCopyUsage = In), (t.StreamDrawUsage = Cn), (t.StreamReadUsage = Pn), (t.StringKeyframeTrack = eh), (t.SubtractEquation = S), (t.SubtractiveBlending = E), (t.TOUCH = a), (t.TangentSpaceNormalMap = ln), (t.TetrahedronBufferGeometry = _u), (t.TetrahedronGeometry = _u), (t.TextBufferGeometry = Tu), (t.TextGeometry = Tu), (t.Texture = nr), (t.TextureLoader = vh), (t.TorusBufferGeometry = Su), (t.TorusGeometry = Su), (t.TorusKnotBufferGeometry = Cu), (t.TorusKnotGeometry = Cu), (t.Triangle = xi), (t.TriangleFanDrawMode = Zt), (t.TriangleStripDrawMode = Qt), (t.TrianglesDrawMode = Yt), (t.TubeBufferGeometry = Lu), (t.TubeGeometry = Lu), (t.UVMapping = oe), (t.Uint16Attribute = Jf), (t.Uint16BufferAttribute = Gi), (t.Uint32Attribute = em), (t.Uint32BufferAttribute = ji), (t.Uint8Attribute = Qf), (t.Uint8BufferAttribute = Ni), (t.Uint8ClampedAttribute = Zf), (t.Uint8ClampedBufferAttribute = Ui), (t.Uniform = ap), (t.UniformsLib = Xo), (t.UniformsUtils = Co), (t.UnsignedByteType = _e), (t.UnsignedInt248Type = Fe), (t.UnsignedIntType = Re), (t.UnsignedShort4444Type = Oe), (t.UnsignedShort5551Type = Ie), (t.UnsignedShort565Type = Be), (t.UnsignedShortType = Ce), (t.VSMShadowMap = f), (t.Vector2 = Jn), (t.Vector3 = lr), (t.Vector4 = ir), (t.VectorKeyframeTrack = th), (t.Vertex = qf), (t.VertexColors = kf), (t.VideoTexture = bc), (t.WebGL1Renderer = fl), (t.WebGLCubeRenderTarget = No), (t.WebGLMultisampleRenderTarget = ar), (t.WebGLRenderTarget = or), (t.WebGLRenderTargetCube = dm), (t.WebGLRenderer = pl), (t.WebGLUtils = nl), (t.WireframeGeometry = Ru), (t.WireframeHelper = cm), (t.WrapAroundEnding = Wt), (t.XHRLoader = um), (t.ZeroCurvatureEnding = jt), (t.ZeroFactor = P), (t.ZeroSlopeEnding = Vt), (t.ZeroStencilOp = un), (t.sRGBEncoding = Jt), Object.defineProperty(t, '__esModule', { value: !0 }) }), 'object' === typeof i && 'undefined' !== typeof r ? a(i) : 'function' === typeof t && t.amd ? t(['exports'], a) : a( ((o = 'undefined' !== typeof globalThis ? globalThis : o || self).THREE = {}), ) }, {}, ], 58: [ function (e, t, n) { ;(THREE.DRACOLoader = function (e) { THREE.Loader.call(this, e), (this.decoderPath = ''), (this.decoderConfig = {}), (this.decoderBinary = null), (this.decoderPending = null), (this.workerLimit = 4), (this.workerPool = []), (this.workerNextTaskID = 1), (this.workerSourceURL = ''), (this.defaultAttributeIDs = { position: 'POSITION', normal: 'NORMAL', color: 'COLOR', uv: 'TEX_COORD', }), (this.defaultAttributeTypes = { position: 'Float32Array', normal: 'Float32Array', color: 'Float32Array', uv: 'Float32Array', }) }), (THREE.DRACOLoader.prototype = Object.assign( Object.create(THREE.Loader.prototype), { constructor: THREE.DRACOLoader, setDecoderPath: function (e) { return (this.decoderPath = e), this }, setDecoderConfig: function (e) { return (this.decoderConfig = e), this }, setWorkerLimit: function (e) { return (this.workerLimit = e), this }, setVerbosity: function () { console.warn( 'THREE.DRACOLoader: The .setVerbosity() method has been removed.', ) }, setDrawMode: function () { console.warn( 'THREE.DRACOLoader: The .setDrawMode() method has been removed.', ) }, setSkipDequantization: function () { console.warn( 'THREE.DRACOLoader: The .setSkipDequantization() method has been removed.', ) }, load: function (e, t, n, r) { var i = new THREE.FileLoader(this.manager) i.setPath(this.path), i.setResponseType('arraybuffer'), i.setRequestHeader(this.requestHeader), i.setWithCredentials(this.withCredentials), i.load( e, (e) => { var n = { attributeIDs: this.defaultAttributeIDs, attributeTypes: this.defaultAttributeTypes, useUniqueIDs: !1, } this.decodeGeometry(e, n).then(t).catch(r) }, n, r, ) }, decodeDracoFile: function (e, t, n, r) { var i = { attributeIDs: n || this.defaultAttributeIDs, attributeTypes: r || this.defaultAttributeTypes, useUniqueIDs: !!n, } this.decodeGeometry(e, i).then(t) }, decodeGeometry: function (e, t) { for (var n in t.attributeTypes) { var r = t.attributeTypes[n] void 0 !== r.BYTES_PER_ELEMENT && (t.attributeTypes[n] = r.name) } var i, o = JSON.stringify(t) if (THREE.DRACOLoader.taskCache.has(e)) { var a = THREE.DRACOLoader.taskCache.get(e) if (a.key === o) return a.promise if (0 === e.byteLength) throw new Error( 'THREE.DRACOLoader: Unable to re-decode a buffer with different settings. Buffer has already been transferred.', ) } var s = this.workerNextTaskID++, l = e.byteLength, c = this._getWorker(s, l) .then( (n) => ( (i = n), new Promise((n, r) => { ;(i._callbacks[s] = { resolve: n, reject: r }), i.postMessage( { type: 'decode', id: s, taskConfig: t, buffer: e }, [e], ) }) ), ) .then((e) => this._createGeometry(e.geometry)) return ( c .catch(() => !0) .then(() => { i && s && this._releaseTask(i, s) }), THREE.DRACOLoader.taskCache.set(e, { key: o, promise: c }), c ) }, _createGeometry: function (e) { var t = new THREE.BufferGeometry() e.index && t.setIndex(new THREE.BufferAttribute(e.index.array, 1)) for (var n = 0; n < e.attributes.length; n++) { var r = e.attributes[n], i = r.name, o = r.array, a = r.itemSize t.setAttribute(i, new THREE.BufferAttribute(o, a)) } return t }, _loadLibrary: function (e, t) { var n = new THREE.FileLoader(this.manager) return ( n.setPath(this.decoderPath), n.setResponseType(t), n.setWithCredentials(this.withCredentials), new Promise((t, r) => { n.load(e, t, void 0, r) }) ) }, preload: function () { return this._initDecoder(), this }, _initDecoder: function () { if (this.decoderPending) return this.decoderPending var e = 'object' !== typeof WebAssembly || 'js' === this.decoderConfig.type, t = [] return ( e ? t.push(this._loadLibrary('draco_decoder.js', 'text')) : (t.push(this._loadLibrary('draco_wasm_wrapper.js', 'text')), t.push(this._loadLibrary('draco_decoder.wasm', 'arraybuffer'))), (this.decoderPending = Promise.all(t).then((t) => { var n = t[0] e || (this.decoderConfig.wasmBinary = t[1]) var r = THREE.DRACOLoader.DRACOWorker.toString(), i = [ '/* draco decoder */', n, '', '/* worker */', r.substring(r.indexOf('{') + 1, r.lastIndexOf('}')), ].join('\n') this.workerSourceURL = URL.createObjectURL(new Blob([i])) })), this.decoderPending ) }, _getWorker: function (e, t) { return this._initDecoder().then(() => { var n return ( this.workerPool.length < this.workerLimit ? (((n = new Worker(this.workerSourceURL))._callbacks = {}), (n._taskCosts = {}), (n._taskLoad = 0), n.postMessage({ type: 'init', decoderConfig: this.decoderConfig }), (n.onmessage = function (e) { var t = e.data switch (t.type) { case 'decode': n._callbacks[t.id].resolve(t) break case 'error': n._callbacks[t.id].reject(t) break default: console.error( 'THREE.DRACOLoader: Unexpected message, "' + t.type + '"', ) } }), this.workerPool.push(n)) : this.workerPool.sort(function (e, t) { return e._taskLoad > t._taskLoad ? -1 : 1 }), ((n = this.workerPool[this.workerPool.length - 1])._taskCosts[e] = t), (n._taskLoad += t), n ) }) }, _releaseTask: function (e, t) { ;(e._taskLoad -= e._taskCosts[t]), delete e._callbacks[t], delete e._taskCosts[t] }, debug: function () { console.log( 'Task load: ', this.workerPool.map((e) => e._taskLoad), ) }, dispose: function () { for (var e = 0; e < this.workerPool.length; ++e) this.workerPool[e].terminate() return (this.workerPool.length = 0), this }, }, )), (THREE.DRACOLoader.DRACOWorker = function () { var e, t function n(e, t, n, o) { var a, s, l = o.attributeIDs, c = o.attributeTypes, u = t.GetEncodedGeometryType(n) if (u === e.TRIANGULAR_MESH) (a = new e.Mesh()), (s = t.DecodeBufferToMesh(n, a)) else { if (u !== e.POINT_CLOUD) throw new Error('THREE.DRACOLoader: Unexpected geometry type.') ;(a = new e.PointCloud()), (s = t.DecodeBufferToPointCloud(n, a)) } if (!s.ok() || 0 === a.ptr) throw new Error('THREE.DRACOLoader: Decoding failed: ' + s.error_msg()) var h = { index: null, attributes: [] } for (var d in l) { var p, f, m = self[c[d]] if (o.useUniqueIDs) (f = l[d]), (p = t.GetAttributeByUniqueId(a, f)) else { if (-1 === (f = t.GetAttributeId(a, e[l[d]]))) continue p = t.GetAttribute(a, f) } h.attributes.push(i(e, t, a, d, m, p)) } return u === e.TRIANGULAR_MESH && (h.index = r(e, t, a)), e.destroy(a), h } function r(e, t, n) { var r = 3 * n.num_faces(), i = 4 * r, o = e._malloc(i) t.GetTrianglesUInt32Array(n, i, o) var a = new Uint32Array(e.HEAPF32.buffer, o, r).slice() return e._free(o), { array: a, itemSize: 1 } } function i(e, t, n, r, i, a) { var s = a.num_components(), l = n.num_points() * s, c = l * i.BYTES_PER_ELEMENT, u = o(e, i), h = e._malloc(c) t.GetAttributeDataArrayForAllPoints(n, a, u, c, h) var d = new i(e.HEAPF32.buffer, h, l).slice() return e._free(h), { name: r, array: d, itemSize: s } } function o(e, t) { switch (t) { case Float32Array: return e.DT_FLOAT32 case Int8Array: return e.DT_INT8 case Int16Array: return e.DT_INT16 case Int32Array: return e.DT_INT32 case Uint8Array: return e.DT_UINT8 case Uint16Array: return e.DT_UINT16 case Uint32Array: return e.DT_UINT32 } } onmessage = function (r) { var i = r.data switch (i.type) { case 'init': ;(e = i.decoderConfig), (t = new Promise(function (t) { ;(e.onModuleLoaded = function (e) { t({ draco: e }) }), DracoDecoderModule(e) })) break case 'decode': var o = i.buffer, a = i.taskConfig t.then((e) => { var t = e.draco, r = new t.Decoder(), s = new t.DecoderBuffer() s.Init(new Int8Array(o), o.byteLength) try { var l = n(t, r, s, a), c = l.attributes.map((e) => e.array.buffer) l.index && c.push(l.index.array.buffer), self.postMessage({ type: 'decode', id: i.id, geometry: l }, c) } catch (u) { console.error(u), self.postMessage({ type: 'error', id: i.id, error: u.message }) } finally { t.destroy(s), t.destroy(r) } }) } } }), (THREE.DRACOLoader.taskCache = new WeakMap()), (THREE.DRACOLoader.setDecoderPath = function () { console.warn( 'THREE.DRACOLoader: The .setDecoderPath() method has been removed. Use instance methods.', ) }), (THREE.DRACOLoader.setDecoderConfig = function () { console.warn( 'THREE.DRACOLoader: The .setDecoderConfig() method has been removed. Use instance methods.', ) }), (THREE.DRACOLoader.releaseDecoderModule = function () { console.warn( 'THREE.DRACOLoader: The .releaseDecoderModule() method has been removed. Use instance methods.', ) }), (THREE.DRACOLoader.getDecoderModule = function () { console.warn( 'THREE.DRACOLoader: The .getDecoderModule() method has been removed. Use instance methods.', ) }) }, {}, ], 59: [ function (t, n, r) { THREE.GLTFLoader = (function () { function t(e) { THREE.Loader.call(this, e), (this.dracoLoader = null), (this.ddsLoader = null), (this.ktx2Loader = null), (this.meshoptDecoder = null), (this.pluginCallbacks = []), this.register(function (e) { return new s(e) }), this.register(function (e) { return new c(e) }), this.register(function (e) { return new u(e) }), this.register(function (e) { return new l(e) }), this.register(function (e) { return new o(e) }), this.register(function (e) { return new h(e) }) } function n() { var e = {} return { get: function (t) { return e[t] }, add: function (t, n) { e[t] = n }, remove: function (t) { delete e[t] }, removeAll: function () { e = {} }, } } t.prototype = Object.assign(Object.create(THREE.Loader.prototype), { constructor: t, load: function (t, n, r, i) { var o, a = this ;(o = '' !== this.resourcePath ? this.resourcePath : '' !== this.path ? this.path : THREE.LoaderUtils.extractUrlBase(t)), this.manager.itemStart(t) var s = function (e) { i ? i(e) : console.error(e), a.manager.itemError(t), a.manager.itemEnd(t) }, l = new THREE.FileLoader(this.manager) l.setPath(this.path), l.setResponseType('arraybuffer'), l.setRequestHeader(this.requestHeader), l.setWithCredentials(this.withCredentials), l.load( t, function (r) { try { a.parse( r, o, function (e) { n(e), a.manager.itemEnd(t) }, s, ) } catch (e) { s(e) } }, r, s, ) }, setDRACOLoader: function (e) { return (this.dracoLoader = e), this }, setDDSLoader: function (e) { return (this.ddsLoader = e), this }, setKTX2Loader: function (e) { return (this.ktx2Loader = e), this }, setMeshoptDecoder: function (e) { return (this.meshoptDecoder = e), this }, register: function (e) { return ( -1 === this.pluginCallbacks.indexOf(e) && this.pluginCallbacks.push(e), this ) }, unregister: function (e) { return ( -1 !== this.pluginCallbacks.indexOf(e) && this.pluginCallbacks.splice(this.pluginCallbacks.indexOf(e), 1), this ) }, parse: function (e, t, n, o) { var s, l = {}, c = {} if ('string' === typeof e) s = e else if (THREE.LoaderUtils.decodeText(new Uint8Array(e, 0, 4)) === d) { try { l[r.KHR_BINARY_GLTF] = new m(e) } catch (x) { return void (o && o(x)) } s = l[r.KHR_BINARY_GLTF].content } else s = THREE.LoaderUtils.decodeText(new Uint8Array(e)) var u = JSON.parse(s) if (void 0 === u.asset || u.asset.version[0] < 2) o && o( new Error( 'THREE.GLTFLoader: Unsupported asset. glTF versions >=2.0 are supported.', ), ) else { var h = new U(u, { path: t || this.resourcePath || '', crossOrigin: this.crossOrigin, manager: this.manager, ktx2Loader: this.ktx2Loader, meshoptDecoder: this.meshoptDecoder, }) h.fileLoader.setRequestHeader(this.requestHeader) for (var p = 0; p < this.pluginCallbacks.length; p++) { var f = this.pluginCallbacks[p](h) ;(c[f.name] = f), (l[f.name] = !0) } if (u.extensionsUsed) for (p = 0; p < u.extensionsUsed.length; ++p) { var y = u.extensionsUsed[p], w = u.extensionsRequired || [] switch (y) { case r.KHR_MATERIALS_UNLIT: l[y] = new a() break case r.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS: l[y] = new b() break case r.KHR_DRACO_MESH_COMPRESSION: l[y] = new v(u, this.dracoLoader) break case r.MSFT_TEXTURE_DDS: l[y] = new i(this.ddsLoader) break case r.KHR_TEXTURE_TRANSFORM: l[y] = new g() break case r.KHR_MESH_QUANTIZATION: l[y] = new A() break default: w.indexOf(y) >= 0 && void 0 === c[y] && console.warn('THREE.GLTFLoader: Unknown extension "' + y + '".') } } h.setExtensions(l), h.setPlugins(c), h.parse(n, o) } }, }) var r = { KHR_BINARY_GLTF: 'KHR_binary_glTF', KHR_DRACO_MESH_COMPRESSION: 'KHR_draco_mesh_compression', KHR_LIGHTS_PUNCTUAL: 'KHR_lights_punctual', KHR_MATERIALS_CLEARCOAT: 'KHR_materials_clearcoat', KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS: 'KHR_materials_pbrSpecularGlossiness', KHR_MATERIALS_TRANSMISSION: 'KHR_materials_transmission', KHR_MATERIALS_UNLIT: 'KHR_materials_unlit', KHR_TEXTURE_BASISU: 'KHR_texture_basisu', KHR_TEXTURE_TRANSFORM: 'KHR_texture_transform', KHR_MESH_QUANTIZATION: 'KHR_mesh_quantization', EXT_TEXTURE_WEBP: 'EXT_texture_webp', EXT_MESHOPT_COMPRESSION: 'EXT_meshopt_compression', MSFT_TEXTURE_DDS: 'MSFT_texture_dds', } function i(e) { if (!e) throw new Error( 'THREE.GLTFLoader: Attempting to load .dds texture without importing THREE.DDSLoader', ) ;(this.name = r.MSFT_TEXTURE_DDS), (this.ddsLoader = e) } function o(e) { ;(this.parser = e), (this.name = r.KHR_LIGHTS_PUNCTUAL), (this.cache = { refs: {}, uses: {} }) } function a() { this.name = r.KHR_MATERIALS_UNLIT } function s(e) { ;(this.parser = e), (this.name = r.KHR_MATERIALS_CLEARCOAT) } function l(e) { ;(this.parser = e), (this.name = r.KHR_MATERIALS_TRANSMISSION) } function c(e) { ;(this.parser = e), (this.name = r.KHR_TEXTURE_BASISU) } function u(e) { ;(this.parser = e), (this.name = r.EXT_TEXTURE_WEBP), (this.isSupported = null) } function h(e) { ;(this.name = r.EXT_MESHOPT_COMPRESSION), (this.parser = e) } ;(o.prototype._markDefs = function () { for ( var e = this.parser, t = this.parser.json.nodes || [], n = 0, r = t.length; n < r; n++ ) { var i = t[n] i.extensions && i.extensions[this.name] && void 0 !== i.extensions[this.name].light && e._addNodeRef(this.cache, i.extensions[this.name].light) } }), (o.prototype._loadLight = function (e) { var t = this.parser, n = 'light:' + e, r = t.cache.get(n) if (r) return r var i, o = t.json, a = (((o.extensions && o.extensions[this.name]) || {}).lights || [])[e], s = new THREE.Color(16777215) void 0 !== a.color && s.fromArray(a.color) var l = void 0 !== a.range ? a.range : 0 switch (a.type) { case 'directional': ;(i = new THREE.DirectionalLight(s)).target.position.set(0, 0, -1), i.add(i.target) break case 'point': ;(i = new THREE.PointLight(s)).distance = l break case 'spot': ;((i = new THREE.SpotLight(s)).distance = l), (a.spot = a.spot || {}), (a.spot.innerConeAngle = void 0 !== a.spot.innerConeAngle ? a.spot.innerConeAngle : 0), (a.spot.outerConeAngle = void 0 !== a.spot.outerConeAngle ? a.spot.outerConeAngle : Math.PI / 4), (i.angle = a.spot.outerConeAngle), (i.penumbra = 1 - a.spot.innerConeAngle / a.spot.outerConeAngle), i.target.position.set(0, 0, -1), i.add(i.target) break default: throw new Error('THREE.GLTFLoader: Unexpected light type: ' + a.type) } return ( i.position.set(0, 0, 0), (i.decay = 2), void 0 !== a.intensity && (i.intensity = a.intensity), (i.name = t.createUniqueName(a.name || 'light_' + e)), (r = Promise.resolve(i)), t.cache.add(n, r), r ) }), (o.prototype.createNodeAttachment = function (e) { var t = this, n = this.parser, r = n.json.nodes[e], i = ((r.extensions && r.extensions[this.name]) || {}).light return void 0 === i ? null : this._loadLight(i).then(function (e) { return n._getNodeRef(t.cache, i, e) }) }), (a.prototype.getMaterialType = function () { return THREE.MeshBasicMaterial }), (a.prototype.extendParams = function (e, t, n) { var r = [] ;(e.color = new THREE.Color(1, 1, 1)), (e.opacity = 1) var i = t.pbrMetallicRoughness if (i) { if (Array.isArray(i.baseColorFactor)) { var o = i.baseColorFactor e.color.fromArray(o), (e.opacity = o[3]) } void 0 !== i.baseColorTexture && r.push(n.assignTexture(e, 'map', i.baseColorTexture)) } return Promise.all(r) }), (s.prototype.getMaterialType = function (e) { var t = this.parser.json.materials[e] return t.extensions && t.extensions[this.name] ? THREE.MeshPhysicalMaterial : null }), (s.prototype.extendMaterialParams = function (e, t) { var n = this.parser, r = n.json.materials[e] if (!r.extensions || !r.extensions[this.name]) return Promise.resolve() var i = [], o = r.extensions[this.name] if ( (void 0 !== o.clearcoatFactor && (t.clearcoat = o.clearcoatFactor), void 0 !== o.clearcoatTexture && i.push(n.assignTexture(t, 'clearcoatMap', o.clearcoatTexture)), void 0 !== o.clearcoatRoughnessFactor && (t.clearcoatRoughness = o.clearcoatRoughnessFactor), void 0 !== o.clearcoatRoughnessTexture && i.push( n.assignTexture( t, 'clearcoatRoughnessMap', o.clearcoatRoughnessTexture, ), ), void 0 !== o.clearcoatNormalTexture && (i.push( n.assignTexture(t, 'clearcoatNormalMap', o.clearcoatNormalTexture), ), void 0 !== o.clearcoatNormalTexture.scale)) ) { var a = o.clearcoatNormalTexture.scale t.clearcoatNormalScale = new THREE.Vector2(a, -a) } return Promise.all(i) }), (l.prototype.getMaterialType = function (e) { var t = this.parser.json.materials[e] return t.extensions && t.extensions[this.name] ? THREE.MeshPhysicalMaterial : null }), (l.prototype.extendMaterialParams = function (e, t) { var n = this.parser, r = n.json.materials[e] if (!r.extensions || !r.extensions[this.name]) return Promise.resolve() var i = [], o = r.extensions[this.name] return ( void 0 !== o.transmissionFactor && (t.transmission = o.transmissionFactor), void 0 !== o.transmissionTexture && i.push(n.assignTexture(t, 'transmissionMap', o.transmissionTexture)), Promise.all(i) ) }), (c.prototype.loadTexture = function (e) { var t = this.parser, n = t.json, r = n.textures[e] if (!r.extensions || !r.extensions[this.name]) return null var i = r.extensions[this.name], o = n.images[i.source], a = t.options.ktx2Loader if (!a) { if (n.extensionsRequired && n.extensionsRequired.indexOf(this.name) >= 0) throw new Error( 'THREE.GLTFLoader: setKTX2Loader must be called before loading KTX2 textures', ) return null } return t.loadTextureImage(e, o, a) }), (u.prototype.loadTexture = function (e) { var t = this.name, n = this.parser, r = n.json, i = r.textures[e] if (!i.extensions || !i.extensions[t]) return null var o = i.extensions[t], a = r.images[o.source], s = a.uri ? n.options.manager.getHandler(a.uri) : n.textureLoader return this.detectSupport().then(function (i) { if (i) return n.loadTextureImage(e, a, s) if (r.extensionsRequired && r.extensionsRequired.indexOf(t) >= 0) throw new Error( 'THREE.GLTFLoader: WebP required by asset but unsupported.', ) return n.loadTexture(e) }) }), (u.prototype.detectSupport = function () { return ( this.isSupported || (this.isSupported = new Promise(function (e) { var t = new Image() ;(t.src = 'data:image/webp;base64,UklGRiIAAABXRUJQVlA4IBYAAAAwAQCdASoBAAEADsD+JaQAA3AAAAAA'), (t.onload = t.onerror = function () { e(1 === t.height) }) })), this.isSupported ) }), (h.prototype.loadBufferView = function (e) { var t = this.parser.json, n = t.bufferViews[e] if (n.extensions && n.extensions[this.name]) { var r = n.extensions[this.name], i = this.parser.getDependency('buffer', r.buffer), o = this.parser.options.meshoptDecoder if (!o || !o.supported) { if (t.extensionsRequired && t.extensionsRequired.indexOf(this.name) >= 0) throw new Error( 'THREE.GLTFLoader: setMeshoptDecoder must be called before loading compressed files', ) return null } return Promise.all([i, o.ready]).then(function (e) { var t = r.byteOffset || 0, n = r.byteLength || 0, i = r.count, a = r.byteStride, s = new ArrayBuffer(i * a), l = new Uint8Array(e[0], t, n) return o.decodeGltfBuffer(new Uint8Array(s), i, a, l, r.mode, r.filter), s }) } return null }) var d = 'glTF', p = 12, f = { JSON: 1313821514, BIN: 5130562 } function m(e) { ;(this.name = r.KHR_BINARY_GLTF), (this.content = null), (this.body = null) var t = new DataView(e, 0, p) if ( ((this.header = { magic: THREE.LoaderUtils.decodeText(new Uint8Array(e.slice(0, 4))), version: t.getUint32(4, !0), length: t.getUint32(8, !0), }), this.header.magic !== d) ) throw new Error('THREE.GLTFLoader: Unsupported glTF-Binary header.') if (this.header.version < 2) throw new Error('THREE.GLTFLoader: Legacy binary file detected.') for (var n = this.header.length - p, i = new DataView(e, p), o = 0; o < n; ) { var a = i.getUint32(o, !0) o += 4 var s = i.getUint32(o, !0) if (((o += 4), s === f.JSON)) { var l = new Uint8Array(e, p + o, a) this.content = THREE.LoaderUtils.decodeText(l) } else if (s === f.BIN) { var c = p + o this.body = e.slice(c, c + a) } o += a } if (null === this.content) throw new Error('THREE.GLTFLoader: JSON content not found.') } function v(e, t) { if (!t) throw new Error('THREE.GLTFLoader: No DRACOLoader instance provided.') ;(this.name = r.KHR_DRACO_MESH_COMPRESSION), (this.json = e), (this.dracoLoader = t), this.dracoLoader.preload() } function g() { this.name = r.KHR_TEXTURE_TRANSFORM } function y(e) { THREE.MeshStandardMaterial.call(this), (this.isGLTFSpecularGlossinessMaterial = !0) var t = [ '#ifdef USE_SPECULARMAP', '\tuniform sampler2D specularMap;', '#endif', ].join('\n'), n = [ '#ifdef USE_GLOSSINESSMAP', '\tuniform sampler2D glossinessMap;', '#endif', ].join('\n'), r = [ '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'), i = [ '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'), o = [ 'PhysicalMaterial material;', 'material.diffuseColor = diffuseColor.rgb * ( 1. - max( specularFactor.r, max( specularFactor.g, specularFactor.b ) ) );', '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;', ].join('\n'), a = { specular: { value: new THREE.Color().setHex(16777215) }, glossiness: { value: 1 }, specularMap: { value: null }, glossinessMap: { value: null }, } ;(this._extraUniforms = a), (this.onBeforeCompile = function (e) { for (var s in a) e.uniforms[s] = a[s] e.fragmentShader = e.fragmentShader .replace('uniform float roughness;', 'uniform vec3 specular;') .replace('uniform float metalness;', 'uniform float glossiness;') .replace('#include ', t) .replace('#include ', n) .replace('#include ', r) .replace('#include ', i) .replace('#include ', o) }), Object.defineProperties(this, { specular: { get: function () { return a.specular.value }, set: function (e) { a.specular.value = e }, }, specularMap: { get: function () { return a.specularMap.value }, set: function (e) { ;(a.specularMap.value = e), e ? (this.defines.USE_SPECULARMAP = '') : delete this.defines.USE_SPECULARMAP }, }, glossiness: { get: function () { return a.glossiness.value }, set: function (e) { a.glossiness.value = e }, }, glossinessMap: { get: function () { return a.glossinessMap.value }, set: function (e) { ;(a.glossinessMap.value = e), e ? ((this.defines.USE_GLOSSINESSMAP = ''), (this.defines.USE_UV = '')) : (delete this.defines.USE_GLOSSINESSMAP, delete this.defines.USE_UV) }, }, }), delete this.metalness, delete this.roughness, delete this.metalnessMap, delete this.roughnessMap, this.setValues(e) } function b() { return { name: r.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 y }, extendParams: function (e, t, n) { var r = t.extensions[this.name] ;(e.color = new THREE.Color(1, 1, 1)), (e.opacity = 1) var i = [] if (Array.isArray(r.diffuseFactor)) { var o = r.diffuseFactor e.color.fromArray(o), (e.opacity = o[3]) } if ( (void 0 !== r.diffuseTexture && i.push(n.assignTexture(e, 'map', r.diffuseTexture)), (e.emissive = new THREE.Color(0, 0, 0)), (e.glossiness = void 0 !== r.glossinessFactor ? r.glossinessFactor : 1), (e.specular = new THREE.Color(1, 1, 1)), Array.isArray(r.specularFactor) && e.specular.fromArray(r.specularFactor), void 0 !== r.specularGlossinessTexture) ) { var a = r.specularGlossinessTexture i.push(n.assignTexture(e, 'glossinessMap', a)), i.push(n.assignTexture(e, 'specularMap', a)) } return Promise.all(i) }, createMaterial: function (e) { var t = new y(e) return ( (t.fog = !0), (t.color = e.color), (t.map = void 0 === e.map ? null : e.map), (t.lightMap = null), (t.lightMapIntensity = 1), (t.aoMap = void 0 === e.aoMap ? null : e.aoMap), (t.aoMapIntensity = 1), (t.emissive = e.emissive), (t.emissiveIntensity = 1), (t.emissiveMap = void 0 === e.emissiveMap ? null : e.emissiveMap), (t.bumpMap = void 0 === e.bumpMap ? null : e.bumpMap), (t.bumpScale = 1), (t.normalMap = void 0 === e.normalMap ? null : e.normalMap), (t.normalMapType = THREE.TangentSpaceNormalMap), e.normalScale && (t.normalScale = e.normalScale), (t.displacementMap = null), (t.displacementScale = 1), (t.displacementBias = 0), (t.specularMap = void 0 === e.specularMap ? null : e.specularMap), (t.specular = e.specular), (t.glossinessMap = void 0 === e.glossinessMap ? null : e.glossinessMap), (t.glossiness = e.glossiness), (t.alphaMap = null), (t.envMap = void 0 === e.envMap ? null : e.envMap), (t.envMapIntensity = 1), (t.refractionRatio = 0.98), t ) }, } } function A() { this.name = r.KHR_MESH_QUANTIZATION } function w(e, t, n, r) { THREE.Interpolant.call(this, e, t, n, r) } ;(v.prototype.decodePrimitive = function (e, t) { var n = this.json, r = this.dracoLoader, i = e.extensions[this.name].bufferView, o = e.extensions[this.name].attributes, a = {}, s = {}, l = {} for (var c in o) { var u = S[c] || c.toLowerCase() a[u] = o[c] } for (c in e.attributes) if (((u = S[c] || c.toLowerCase()), void 0 !== o[c])) { var h = n.accessors[e.attributes[c]], d = E[h.componentType] ;(l[u] = d), (s[u] = !0 === h.normalized) } return t.getDependency('bufferView', i).then(function (e) { return new Promise(function (t) { r.decodeDracoFile( e, function (e) { for (var n in e.attributes) { var r = e.attributes[n], i = s[n] void 0 !== i && (r.normalized = i) } t(e) }, a, l, ) }) }) }), (g.prototype.extendTexture = function (e, t) { return ( (e = e.clone()), void 0 !== t.offset && e.offset.fromArray(t.offset), void 0 !== t.rotation && (e.rotation = t.rotation), void 0 !== t.scale && e.repeat.fromArray(t.scale), void 0 !== t.texCoord && console.warn( 'THREE.GLTFLoader: Custom UV sets in "' + this.name + '" extension not yet supported.', ), (e.needsUpdate = !0), e ) }), (y.prototype = Object.create(THREE.MeshStandardMaterial.prototype)), (y.prototype.constructor = y), (y.prototype.copy = function (e) { return ( THREE.MeshStandardMaterial.prototype.copy.call(this, e), (this.specularMap = e.specularMap), this.specular.copy(e.specular), (this.glossinessMap = e.glossinessMap), (this.glossiness = e.glossiness), delete this.metalness, delete this.roughness, delete this.metalnessMap, delete this.roughnessMap, this ) }), (w.prototype = Object.create(THREE.Interpolant.prototype)), (w.prototype.constructor = w), (w.prototype.copySampleValue_ = function (e) { for ( var t = this.resultBuffer, n = this.sampleValues, r = this.valueSize, i = e * r * 3 + r, o = 0; o !== r; o++ ) t[o] = n[i + o] return t }), (w.prototype.beforeStart_ = w.prototype.copySampleValue_), (w.prototype.afterEnd_ = w.prototype.copySampleValue_), (w.prototype.interpolate_ = function (e, t, n, r) { for ( var i = this.resultBuffer, o = this.sampleValues, a = this.valueSize, s = 2 * a, l = 3 * a, c = r - t, u = (n - t) / c, h = u * u, d = h * u, p = e * l, f = p - l, m = -2 * d + 3 * h, v = d - h, g = 1 - m, y = v - h + u, b = 0; b !== a; b++ ) { var A = o[f + b + a], w = o[f + b + s] * c, x = o[p + b + a], E = o[p + b] * c i[b] = g * A + y * w + m * x + v * E } return i }) var x = { FLOAT: 5126, FLOAT_MAT3: 35675, FLOAT_MAT4: 35676, FLOAT_VEC2: 35664, FLOAT_VEC3: 35665, FLOAT_VEC4: 35666, LINEAR: 9729, REPEAT: 10497, SAMPLER_2D: 35678, POINTS: 0, LINES: 1, LINE_LOOP: 2, LINE_STRIP: 3, TRIANGLES: 4, TRIANGLE_STRIP: 5, TRIANGLE_FAN: 6, UNSIGNED_BYTE: 5121, UNSIGNED_SHORT: 5123, }, E = { 5120: Int8Array, 5121: Uint8Array, 5122: Int16Array, 5123: Uint16Array, 5125: Uint32Array, 5126: Float32Array, }, M = { 9728: THREE.NearestFilter, 9729: THREE.LinearFilter, 9984: THREE.NearestMipmapNearestFilter, 9985: THREE.LinearMipmapNearestFilter, 9986: THREE.NearestMipmapLinearFilter, 9987: THREE.LinearMipmapLinearFilter, }, _ = { 33071: THREE.ClampToEdgeWrapping, 33648: THREE.MirroredRepeatWrapping, 10497: THREE.RepeatWrapping, }, T = { SCALAR: 1, VEC2: 2, VEC3: 3, VEC4: 4, MAT2: 4, MAT3: 9, MAT4: 16 }, S = { POSITION: 'position', NORMAL: 'normal', TANGENT: 'tangent', TEXCOORD_0: 'uv', TEXCOORD_1: 'uv2', COLOR_0: 'color', WEIGHTS_0: 'skinWeight', JOINTS_0: 'skinIndex', }, C = { scale: 'scale', translation: 'position', rotation: 'quaternion', weights: 'morphTargetInfluences', }, L = { CUBICSPLINE: void 0, LINEAR: THREE.InterpolateLinear, STEP: THREE.InterpolateDiscrete, }, R = { OPAQUE: 'OPAQUE', MASK: 'MASK', BLEND: 'BLEND' } function P(e, t) { return 'string' !== typeof e || '' === e ? '' : (/^https?:\/\//i.test(t) && /^\//.test(e) && (t = t.replace(/(^https?:\/\/[^\/]+).*/i, '$1')), /^(https?:)?\/\//i.test(e) || /^data:.*,.*$/i.test(e) || /^blob:.*$/i.test(e) ? e : t + e) } function D(e) { return ( void 0 === e.DefaultMaterial && (e.DefaultMaterial = new THREE.MeshStandardMaterial({ color: 16777215, emissive: 0, metalness: 1, roughness: 1, transparent: !1, depthTest: !0, side: THREE.FrontSide, })), e.DefaultMaterial ) } function O(e, t, n) { for (var r in n.extensions) void 0 === e[r] && ((t.userData.gltfExtensions = t.userData.gltfExtensions || {}), (t.userData.gltfExtensions[r] = n.extensions[r])) } function I(e, t) { void 0 !== t.extras && ('object' === typeof t.extras ? Object.assign(e.userData, t.extras) : console.warn( 'THREE.GLTFLoader: Ignoring primitive type .extras, ' + t.extras, )) } function B(e, t, n) { for ( var r = !1, i = !1, o = 0, a = t.length; o < a && (void 0 !== (c = t[o]).POSITION && (r = !0), void 0 !== c.NORMAL && (i = !0), !r || !i); o++ ); if (!r && !i) return Promise.resolve(e) var s = [], l = [] for (o = 0, a = t.length; o < a; o++) { var c = t[o] if (r) { var u = void 0 !== c.POSITION ? n.getDependency('accessor', c.POSITION) : e.attributes.position s.push(u) } i && ((u = void 0 !== c.NORMAL ? n.getDependency('accessor', c.NORMAL) : e.attributes.normal), l.push(u)) } return Promise.all([Promise.all(s), Promise.all(l)]).then(function (t) { var n = t[0], o = t[1] return ( r && (e.morphAttributes.position = n), i && (e.morphAttributes.normal = o), (e.morphTargetsRelative = !0), e ) }) } function F(e, t) { if ((e.updateMorphTargets(), void 0 !== t.weights)) for (var n = 0, r = t.weights.length; n < r; n++) e.morphTargetInfluences[n] = t.weights[n] if (t.extras && Array.isArray(t.extras.targetNames)) { var i = t.extras.targetNames if (e.morphTargetInfluences.length === i.length) for (e.morphTargetDictionary = {}, n = 0, r = i.length; n < r; n++) e.morphTargetDictionary[i[n]] = n else console.warn( 'THREE.GLTFLoader: Invalid extras.targetNames length. Ignoring names.', ) } } function k(e) { var t = e.extensions && e.extensions[r.KHR_DRACO_MESH_COMPRESSION] return t ? 'draco:' + t.bufferView + ':' + t.indices + ':' + N(t.attributes) : e.indices + ':' + N(e.attributes) + ':' + e.mode } function N(e) { for (var t = '', n = Object.keys(e).sort(), r = 0, i = n.length; r < i; r++) t += n[r] + ':' + e[n[r]] + ';' return t } function U(e, t) { ;(this.json = e || {}), (this.extensions = {}), (this.plugins = {}), (this.options = t || {}), (this.cache = new n()), (this.associations = new Map()), (this.primitiveCache = {}), (this.meshCache = { refs: {}, uses: {} }), (this.cameraCache = { refs: {}, uses: {} }), (this.lightCache = { refs: {}, uses: {} }), (this.nodeNamesUsed = {}), 'undefined' !== typeof createImageBitmap && !1 === /Firefox/.test(navigator.userAgent) ? (this.textureLoader = new THREE.ImageBitmapLoader(this.options.manager)) : (this.textureLoader = new THREE.TextureLoader(this.options.manager)), this.textureLoader.setCrossOrigin(this.options.crossOrigin), (this.fileLoader = new THREE.FileLoader(this.options.manager)), this.fileLoader.setResponseType('arraybuffer'), 'use-credentials' === this.options.crossOrigin && this.fileLoader.setWithCredentials(!0) } function H(e, t, n) { var r = t.attributes, i = new THREE.Box3() if (void 0 !== r.POSITION) { var o = (d = n.json.accessors[r.POSITION]).min, a = d.max if (void 0 !== o && void 0 !== a) { i.set( new THREE.Vector3(o[0], o[1], o[2]), new THREE.Vector3(a[0], a[1], a[2]), ) var s = t.targets if (void 0 !== s) { for ( var l = new THREE.Vector3(), c = new THREE.Vector3(), u = 0, h = s.length; u < h; u++ ) { var d, p = s[u] if (void 0 !== p.POSITION) (o = (d = n.json.accessors[p.POSITION]).min), (a = d.max), void 0 !== o && void 0 !== a ? (c.setX(Math.max(Math.abs(o[0]), Math.abs(a[0]))), c.setY(Math.max(Math.abs(o[1]), Math.abs(a[1]))), c.setZ(Math.max(Math.abs(o[2]), Math.abs(a[2]))), l.max(c)) : console.warn( 'THREE.GLTFLoader: Missing min/max properties for accessor POSITION.', ) } i.expandByVector(l) } e.boundingBox = i var f = new THREE.Sphere() i.getCenter(f.center), (f.radius = i.min.distanceTo(i.max) / 2), (e.boundingSphere = f) } else console.warn( 'THREE.GLTFLoader: Missing min/max properties for accessor POSITION.', ) } } function G(e, t, n) { var r = t.attributes, i = [] function o(t, r) { return n.getDependency('accessor', t).then(function (t) { e.setAttribute(r, t) }) } for (var a in r) { var s = S[a] || a.toLowerCase() s in e.attributes || i.push(o(r[a], s)) } if (void 0 !== t.indices && !e.index) { var l = n.getDependency('accessor', t.indices).then(function (t) { e.setIndex(t) }) i.push(l) } return ( I(e, t), H(e, t, n), Promise.all(i).then(function () { return void 0 !== t.targets ? B(e, t.targets, n) : e }) ) } function z(e, t) { var n = e.getIndex() if (null === n) { var r = [], i = e.getAttribute('position') if (void 0 === i) return ( console.error( 'THREE.GLTFLoader.toTrianglesDrawMode(): Undefined position attribute. Processing not possible.', ), e ) for (var o = 0; o < i.count; o++) r.push(o) e.setIndex(r), (n = e.getIndex()) } var a = n.count - 2, s = [] if (t === THREE.TriangleFanDrawMode) for (o = 1; o <= a; o++) s.push(n.getX(0)), s.push(n.getX(o)), s.push(n.getX(o + 1)) else for (o = 0; o < a; o++) o % 2 === 0 ? (s.push(n.getX(o)), s.push(n.getX(o + 1)), s.push(n.getX(o + 2))) : (s.push(n.getX(o + 2)), s.push(n.getX(o + 1)), s.push(n.getX(o))) s.length / 3 !== a && console.error( 'THREE.GLTFLoader.toTrianglesDrawMode(): Unable to generate correct amount of triangles.', ) var l = e.clone() return l.setIndex(s), l } return ( (U.prototype.setExtensions = function (e) { this.extensions = e }), (U.prototype.setPlugins = function (e) { this.plugins = e }), (U.prototype.parse = function (e, t) { var n = this, r = this.json, i = this.extensions this.cache.removeAll(), this._invokeAll(function (e) { return e._markDefs && e._markDefs() }), Promise.all([ this.getDependencies('scene'), this.getDependencies('animation'), this.getDependencies('camera'), ]) .then(function (t) { var o = { scene: t[0][r.scene || 0], scenes: t[0], animations: t[1], cameras: t[2], asset: r.asset, parser: n, userData: {}, } O(i, o, r), I(o, r), e(o) }) .catch(t) }), (U.prototype._markDefs = function () { for ( var e = this.json.nodes || [], t = this.json.skins || [], n = this.json.meshes || [], r = 0, i = t.length; r < i; r++ ) for (var o = t[r].joints, a = 0, s = o.length; a < s; a++) e[o[a]].isBone = !0 for (var l = 0, c = e.length; l < c; l++) { var u = e[l] void 0 !== u.mesh && (this._addNodeRef(this.meshCache, u.mesh), void 0 !== u.skin && (n[u.mesh].isSkinnedMesh = !0)), void 0 !== u.camera && this._addNodeRef(this.cameraCache, u.camera) } }), (U.prototype._addNodeRef = function (e, t) { void 0 !== t && (void 0 === e.refs[t] && (e.refs[t] = e.uses[t] = 0), e.refs[t]++) }), (U.prototype._getNodeRef = function (e, t, n) { if (e.refs[t] <= 1) return n var r = n.clone() return (r.name += '_instance_' + e.uses[t]++), r }), (U.prototype._invokeOne = function (e) { var t = Object.values(this.plugins) t.push(this) for (var n = 0; n < t.length; n++) { var r = e(t[n]) if (r) return r } }), (U.prototype._invokeAll = function (e) { var t = Object.values(this.plugins) t.unshift(this) for (var n = [], r = 0; r < t.length; r++) { var i = e(t[r]) i && n.push(i) } return n }), (U.prototype.getDependency = function (e, t) { var n = e + ':' + t, r = this.cache.get(n) if (!r) { switch (e) { case 'scene': r = this.loadScene(t) break case 'node': r = this.loadNode(t) break case 'mesh': r = this._invokeOne(function (e) { return e.loadMesh && e.loadMesh(t) }) break case 'accessor': r = this.loadAccessor(t) break case 'bufferView': r = this._invokeOne(function (e) { return e.loadBufferView && e.loadBufferView(t) }) break case 'buffer': r = this.loadBuffer(t) break case 'material': r = this._invokeOne(function (e) { return e.loadMaterial && e.loadMaterial(t) }) break case 'texture': r = this._invokeOne(function (e) { return e.loadTexture && e.loadTexture(t) }) break case 'skin': r = this.loadSkin(t) break case 'animation': r = this.loadAnimation(t) break case 'camera': r = this.loadCamera(t) break default: throw new Error('Unknown type: ' + e) } this.cache.add(n, r) } return r }), (U.prototype.getDependencies = function (e) { var t = this.cache.get(e) if (!t) { var n = this, r = this.json[e + ('mesh' === e ? 'es' : 's')] || [] ;(t = Promise.all( r.map(function (t, r) { return n.getDependency(e, r) }), )), this.cache.add(e, t) } return t }), (U.prototype.loadBuffer = function (e) { var t = this.json.buffers[e], n = this.fileLoader if (t.type && 'arraybuffer' !== t.type) throw new Error( 'THREE.GLTFLoader: ' + t.type + ' buffer type is not supported.', ) if (void 0 === t.uri && 0 === e) return Promise.resolve(this.extensions[r.KHR_BINARY_GLTF].body) var i = this.options return new Promise(function (e, r) { n.load(P(t.uri, i.path), e, void 0, function () { r(new Error('THREE.GLTFLoader: Failed to load buffer "' + t.uri + '".')) }) }) }), (U.prototype.loadBufferView = function (e) { var t = this.json.bufferViews[e] return this.getDependency('buffer', t.buffer).then(function (e) { var n = t.byteLength || 0, r = t.byteOffset || 0 return e.slice(r, r + n) }) }), (U.prototype.loadAccessor = function (e) { var t = this, n = this.json, r = this.json.accessors[e] if (void 0 === r.bufferView && void 0 === r.sparse) return Promise.resolve(null) var i = [] return ( void 0 !== r.bufferView ? i.push(this.getDependency('bufferView', r.bufferView)) : i.push(null), void 0 !== r.sparse && (i.push(this.getDependency('bufferView', r.sparse.indices.bufferView)), i.push(this.getDependency('bufferView', r.sparse.values.bufferView))), Promise.all(i).then(function (e) { var i, o, a = e[0], s = T[r.type], l = E[r.componentType], c = l.BYTES_PER_ELEMENT, u = c * s, h = r.byteOffset || 0, d = void 0 !== r.bufferView ? n.bufferViews[r.bufferView].byteStride : void 0, p = !0 === r.normalized if (d && d !== u) { var f = Math.floor(h / d), m = 'InterleavedBuffer:' + r.bufferView + ':' + r.componentType + ':' + f + ':' + r.count, v = t.cache.get(m) v || ((i = new l(a, f * d, (r.count * d) / c)), (v = new THREE.InterleavedBuffer(i, d / c)), t.cache.add(m, v)), (o = new THREE.InterleavedBufferAttribute(v, s, (h % d) / c, p)) } else (i = null === a ? new l(r.count * s) : new l(a, h, r.count * s)), (o = new THREE.BufferAttribute(i, s, p)) if (void 0 !== r.sparse) { var g = T.SCALAR, y = E[r.sparse.indices.componentType], b = r.sparse.indices.byteOffset || 0, A = r.sparse.values.byteOffset || 0, w = new y(e[1], b, r.sparse.count * g), x = new l(e[2], A, r.sparse.count * s) null !== a && (o = new THREE.BufferAttribute( o.array.slice(), o.itemSize, o.normalized, )) for (var M = 0, _ = w.length; M < _; M++) { var S = w[M] if ( (o.setX(S, x[M * s]), s >= 2 && o.setY(S, x[M * s + 1]), s >= 3 && o.setZ(S, x[M * s + 2]), s >= 4 && o.setW(S, x[M * s + 3]), s >= 5) ) throw new Error( 'THREE.GLTFLoader: Unsupported itemSize in sparse BufferAttribute.', ) } } return o }) ) }), (U.prototype.loadTexture = function (e) { var t, n, i = this, o = this.json, a = this.options, s = o.textures[e], l = s.extensions || {} return ( (t = l[r.MSFT_TEXTURE_DDS] ? o.images[l[r.MSFT_TEXTURE_DDS].source] : o.images[s.source]).uri && (n = a.manager.getHandler(t.uri)), n || (n = l[r.MSFT_TEXTURE_DDS] ? i.extensions[r.MSFT_TEXTURE_DDS].ddsLoader : this.textureLoader), this.loadTextureImage(e, t, n) ) }), (U.prototype.loadTextureImage = function (e, t, n) { var r = this, i = this.json, o = this.options, a = i.textures[e], s = self.URL || self.webkitURL, l = t.uri, c = !1, u = !0 return ( 'image/jpeg' === t.mimeType && (u = !1), void 0 !== t.bufferView && (l = r.getDependency('bufferView', t.bufferView).then(function (e) { if ('image/png' === t.mimeType) { var n = new DataView(e, 25, 1).getUint8(0, !1) u = 6 === n || 4 === n || 3 === n } c = !0 var r = new Blob([e], { type: t.mimeType }) return (l = s.createObjectURL(r)) })), Promise.resolve(l) .then(function (e) { return new Promise(function (t, r) { var i = t !0 === n.isImageBitmapLoader && (i = function (e) { t(new THREE.CanvasTexture(e)) }), n.load(P(e, o.path), i, void 0, r) }) }) .then(function (t) { !0 === c && s.revokeObjectURL(l), (t.flipY = !1), a.name && (t.name = a.name), u || (t.format = THREE.RGBFormat) var n = (i.samplers || {})[a.sampler] || {} return ( (t.magFilter = M[n.magFilter] || THREE.LinearFilter), (t.minFilter = M[n.minFilter] || THREE.LinearMipmapLinearFilter), (t.wrapS = _[n.wrapS] || THREE.RepeatWrapping), (t.wrapT = _[n.wrapT] || THREE.RepeatWrapping), r.associations.set(t, { type: 'textures', index: e }), t ) }) ) }), (U.prototype.assignTexture = function (e, t, n) { var i = this return this.getDependency('texture', n.index).then(function (o) { if ( (void 0 === n.texCoord || 0 == n.texCoord || ('aoMap' === t && 1 == n.texCoord) || console.warn( 'THREE.GLTFLoader: Custom UV set ' + n.texCoord + ' for texture ' + t + ' not yet supported.', ), i.extensions[r.KHR_TEXTURE_TRANSFORM]) ) { var a = void 0 !== n.extensions ? n.extensions[r.KHR_TEXTURE_TRANSFORM] : void 0 if (a) { var s = i.associations.get(o) ;(o = i.extensions[r.KHR_TEXTURE_TRANSFORM].extendTexture(o, a)), i.associations.set(o, s) } } e[t] = o }) }), (U.prototype.assignFinalMaterial = function (e) { var t = e.geometry, n = e.material, r = void 0 !== t.attributes.tangent, i = void 0 !== t.attributes.color, o = void 0 === t.attributes.normal, a = !0 === e.isSkinnedMesh, s = Object.keys(t.morphAttributes).length > 0, l = s && void 0 !== t.morphAttributes.normal if (e.isPoints) { var c = 'PointsMaterial:' + n.uuid, u = this.cache.get(c) u || ((u = new THREE.PointsMaterial()), THREE.Material.prototype.copy.call(u, n), u.color.copy(n.color), (u.map = n.map), (u.sizeAttenuation = !1), this.cache.add(c, u)), (n = u) } else if (e.isLine) { c = 'LineBasicMaterial:' + n.uuid var h = this.cache.get(c) h || ((h = new THREE.LineBasicMaterial()), THREE.Material.prototype.copy.call(h, n), h.color.copy(n.color), this.cache.add(c, h)), (n = h) } if (r || i || o || a || s) { ;(c = 'ClonedMaterial:' + n.uuid + ':'), n.isGLTFSpecularGlossinessMaterial && (c += 'specular-glossiness:'), a && (c += 'skinning:'), r && (c += 'vertex-tangents:'), i && (c += 'vertex-colors:'), o && (c += 'flat-shading:'), s && (c += 'morph-targets:'), l && (c += 'morph-normals:') var d = this.cache.get(c) d || ((d = n.clone()), a && (d.skinning = !0), i && (d.vertexColors = !0), o && (d.flatShading = !0), s && (d.morphTargets = !0), l && (d.morphNormals = !0), r && ((d.vertexTangents = !0), n.normalScale && (n.normalScale.y *= -1), n.clearcoatNormalScale && (n.clearcoatNormalScale.y *= -1)), this.cache.add(c, d), this.associations.set(d, this.associations.get(n))), (n = d) } n.aoMap && void 0 === t.attributes.uv2 && void 0 !== t.attributes.uv && t.setAttribute('uv2', t.attributes.uv), (e.material = n) }), (U.prototype.getMaterialType = function () { return THREE.MeshStandardMaterial }), (U.prototype.loadMaterial = function (e) { var t, n = this, i = this.json, o = this.extensions, a = i.materials[e], s = {}, l = a.extensions || {}, c = [] if (l[r.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS]) { var u = o[r.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS] ;(t = u.getMaterialType()), c.push(u.extendParams(s, a, n)) } else if (l[r.KHR_MATERIALS_UNLIT]) { var h = o[r.KHR_MATERIALS_UNLIT] ;(t = h.getMaterialType()), c.push(h.extendParams(s, a, n)) } else { var d = a.pbrMetallicRoughness || {} if ( ((s.color = new THREE.Color(1, 1, 1)), (s.opacity = 1), Array.isArray(d.baseColorFactor)) ) { var p = d.baseColorFactor s.color.fromArray(p), (s.opacity = p[3]) } void 0 !== d.baseColorTexture && c.push(n.assignTexture(s, 'map', d.baseColorTexture)), (s.metalness = void 0 !== d.metallicFactor ? d.metallicFactor : 1), (s.roughness = void 0 !== d.roughnessFactor ? d.roughnessFactor : 1), void 0 !== d.metallicRoughnessTexture && (c.push(n.assignTexture(s, 'metalnessMap', d.metallicRoughnessTexture)), c.push(n.assignTexture(s, 'roughnessMap', d.metallicRoughnessTexture))), (t = this._invokeOne(function (t) { return t.getMaterialType && t.getMaterialType(e) })), c.push( Promise.all( this._invokeAll(function (t) { return t.extendMaterialParams && t.extendMaterialParams(e, s) }), ), ) } !0 === a.doubleSided && (s.side = THREE.DoubleSide) var f = a.alphaMode || R.OPAQUE return ( f === R.BLEND ? ((s.transparent = !0), (s.depthWrite = !1)) : ((s.transparent = !1), f === R.MASK && (s.alphaTest = void 0 !== a.alphaCutoff ? a.alphaCutoff : 0.5)), void 0 !== a.normalTexture && t !== THREE.MeshBasicMaterial && (c.push(n.assignTexture(s, 'normalMap', a.normalTexture)), (s.normalScale = new THREE.Vector2(1, -1)), void 0 !== a.normalTexture.scale && s.normalScale.set(a.normalTexture.scale, -a.normalTexture.scale)), void 0 !== a.occlusionTexture && t !== THREE.MeshBasicMaterial && (c.push(n.assignTexture(s, 'aoMap', a.occlusionTexture)), void 0 !== a.occlusionTexture.strength && (s.aoMapIntensity = a.occlusionTexture.strength)), void 0 !== a.emissiveFactor && t !== THREE.MeshBasicMaterial && (s.emissive = new THREE.Color().fromArray(a.emissiveFactor)), void 0 !== a.emissiveTexture && t !== THREE.MeshBasicMaterial && c.push(n.assignTexture(s, 'emissiveMap', a.emissiveTexture)), Promise.all(c).then(function () { var i return ( (i = t === y ? o[r.KHR_MATERIALS_PBR_SPECULAR_GLOSSINESS].createMaterial(s) : new t(s)), a.name && (i.name = a.name), i.map && (i.map.encoding = THREE.sRGBEncoding), i.emissiveMap && (i.emissiveMap.encoding = THREE.sRGBEncoding), I(i, a), n.associations.set(i, { type: 'materials', index: e }), a.extensions && O(o, i, a), i ) }) ) }), (U.prototype.createUniqueName = function (e) { for ( var t = THREE.PropertyBinding.sanitizeNodeName(e || ''), n = t, r = 1; this.nodeNamesUsed[n]; ++r ) n = t + '_' + r return (this.nodeNamesUsed[n] = !0), n }), (U.prototype.loadGeometries = function (e) { var t = this, n = this.extensions, i = this.primitiveCache function o(e) { return n[r.KHR_DRACO_MESH_COMPRESSION] .decodePrimitive(e, t) .then(function (n) { return G(n, e, t) }) } for (var a = [], s = 0, l = e.length; s < l; s++) { var c, u = e[s], h = k(u), d = i[h] d ? a.push(d.promise) : ((c = u.extensions && u.extensions[r.KHR_DRACO_MESH_COMPRESSION] ? o(u) : G(new THREE.BufferGeometry(), u, t)), (i[h] = { primitive: u, promise: c }), a.push(c)) } return Promise.all(a) }), (U.prototype.loadMesh = function (e) { for ( var t = this, n = this.json, r = this.extensions, i = n.meshes[e], o = i.primitives, a = [], s = 0, l = o.length; s < l; s++ ) { var c = void 0 === o[s].material ? D(this.cache) : this.getDependency('material', o[s].material) a.push(c) } return ( a.push(t.loadGeometries(o)), Promise.all(a).then(function (n) { for ( var a = n.slice(0, n.length - 1), s = n[n.length - 1], l = [], c = 0, u = s.length; c < u; c++ ) { var h, d = s[c], p = o[c], f = a[c] if ( p.mode === x.TRIANGLES || p.mode === x.TRIANGLE_STRIP || p.mode === x.TRIANGLE_FAN || void 0 === p.mode ) (h = !0 === i.isSkinnedMesh ? new THREE.SkinnedMesh(d, f) : new THREE.Mesh(d, f)), !0 === f.isMeshStandardMaterial && f.side === THREE.DoubleSide && null !== d.getIndex() && !0 === d.hasAttribute('position') && !0 === d.hasAttribute('normal') && !0 === d.hasAttribute('uv') && !1 === d.hasAttribute('tangent') && (d.computeTangents(), (f.vertexTangents = !0)), !0 !== h.isSkinnedMesh || h.geometry.attributes.skinWeight.normalized || h.normalizeSkinWeights(), p.mode === x.TRIANGLE_STRIP ? (h.geometry = z(h.geometry, THREE.TriangleStripDrawMode)) : p.mode === x.TRIANGLE_FAN && (h.geometry = z(h.geometry, THREE.TriangleFanDrawMode)) else if (p.mode === x.LINES) h = new THREE.LineSegments(d, f) else if (p.mode === x.LINE_STRIP) h = new THREE.Line(d, f) else if (p.mode === x.LINE_LOOP) h = new THREE.LineLoop(d, f) else { if (p.mode !== x.POINTS) throw new Error( 'THREE.GLTFLoader: Primitive mode unsupported: ' + p.mode, ) h = new THREE.Points(d, f) } Object.keys(h.geometry.morphAttributes).length > 0 && F(h, i), (h.name = t.createUniqueName(i.name || 'mesh_' + e)), I(h, i), p.extensions && O(r, h, p), t.assignFinalMaterial(h), l.push(h) } if (1 === l.length) return l[0] var m = new THREE.Group() for (c = 0, u = l.length; c < u; c++) m.add(l[c]) return m }) ) }), (U.prototype.loadCamera = function (e) { var t, n = this.json.cameras[e], r = n[n.type] if (r) return ( 'perspective' === n.type ? (t = new THREE.PerspectiveCamera( THREE.MathUtils.radToDeg(r.yfov), r.aspectRatio || 1, r.znear || 1, r.zfar || 2e6, )) : 'orthographic' === n.type && (t = new THREE.OrthographicCamera( -r.xmag, r.xmag, r.ymag, -r.ymag, r.znear, r.zfar, )), n.name && (t.name = this.createUniqueName(n.name)), I(t, n), Promise.resolve(t) ) console.warn('THREE.GLTFLoader: Missing camera parameters.') }), (U.prototype.loadSkin = function (e) { var t = this.json.skins[e], n = { joints: t.joints } return void 0 === t.inverseBindMatrices ? Promise.resolve(n) : this.getDependency('accessor', t.inverseBindMatrices).then(function (e) { return (n.inverseBindMatrices = e), n }) }), (U.prototype.loadAnimation = function (e) { for ( var t = this.json.animations[e], n = [], r = [], i = [], o = [], a = [], s = 0, l = t.channels.length; s < l; s++ ) { var c = t.channels[s], u = t.samplers[c.sampler], h = c.target, d = void 0 !== h.node ? h.node : h.id, p = void 0 !== t.parameters ? t.parameters[u.input] : u.input, f = void 0 !== t.parameters ? t.parameters[u.output] : u.output n.push(this.getDependency('node', d)), r.push(this.getDependency('accessor', p)), i.push(this.getDependency('accessor', f)), o.push(u), a.push(h) } return Promise.all([ Promise.all(n), Promise.all(r), Promise.all(i), Promise.all(o), Promise.all(a), ]).then(function (n) { for ( var r = n[0], i = n[1], o = n[2], a = n[3], s = n[4], l = [], c = 0, u = r.length; c < u; c++ ) { var h = r[c], d = i[c], p = o[c], f = a[c], m = s[c] if (void 0 !== h) { var v switch ((h.updateMatrix(), (h.matrixAutoUpdate = !0), C[m.path])) { case C.weights: v = THREE.NumberKeyframeTrack break case C.rotation: v = THREE.QuaternionKeyframeTrack break case C.position: case C.scale: default: v = THREE.VectorKeyframeTrack } var g = h.name ? h.name : h.uuid, y = void 0 !== f.interpolation ? L[f.interpolation] : THREE.InterpolateLinear, b = [] C[m.path] === C.weights ? h.traverse(function (e) { !0 === e.isMesh && e.morphTargetInfluences && b.push(e.name ? e.name : e.uuid) }) : b.push(g) var A = p.array if (p.normalized) { var x if (A.constructor === Int8Array) x = 1 / 127 else if (A.constructor === Uint8Array) x = 1 / 255 else if (A.constructor == Int16Array) x = 1 / 32767 else { if (A.constructor !== Uint16Array) throw new Error( 'THREE.GLTFLoader: Unsupported output accessor component type.', ) x = 1 / 65535 } for ( var E = new Float32Array(A.length), M = 0, _ = A.length; M < _; M++ ) E[M] = A[M] * x A = E } for (M = 0, _ = b.length; M < _; M++) { var T = new v(b[M] + '.' + C[m.path], d.array, A, y) 'CUBICSPLINE' === f.interpolation && ((T.createInterpolant = function (e) { return new w(this.times, this.values, this.getValueSize() / 3, e) }), (T.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline = !0)), l.push(T) } } } var S = t.name ? t.name : 'animation_' + e return new THREE.AnimationClip(S, void 0, l) }) }), (U.prototype.loadNode = function (e) { var t = this.json, n = this.extensions, r = this, i = t.nodes[e], o = i.name ? r.createUniqueName(i.name) : '' return (function () { var t = [] return ( void 0 !== i.mesh && t.push( r.getDependency('mesh', i.mesh).then(function (e) { var t = r._getNodeRef(r.meshCache, i.mesh, e) return ( void 0 !== i.weights && t.traverse(function (e) { if (e.isMesh) for (var t = 0, n = i.weights.length; t < n; t++) e.morphTargetInfluences[t] = i.weights[t] }), t ) }), ), void 0 !== i.camera && t.push( r.getDependency('camera', i.camera).then(function (e) { return r._getNodeRef(r.cameraCache, i.camera, e) }), ), r ._invokeAll(function (t) { return t.createNodeAttachment && t.createNodeAttachment(e) }) .forEach(function (e) { t.push(e) }), Promise.all(t) ) })().then(function (t) { var a if ( (a = !0 === i.isBone ? new THREE.Bone() : t.length > 1 ? new THREE.Group() : 1 === t.length ? t[0] : new THREE.Object3D()) !== t[0] ) for (var s = 0, l = t.length; s < l; s++) a.add(t[s]) if ( (i.name && ((a.userData.name = i.name), (a.name = o)), I(a, i), i.extensions && O(n, a, i), void 0 !== i.matrix) ) { var c = new THREE.Matrix4() c.fromArray(i.matrix), a.applyMatrix4(c) } else void 0 !== i.translation && a.position.fromArray(i.translation), void 0 !== i.rotation && a.quaternion.fromArray(i.rotation), void 0 !== i.scale && a.scale.fromArray(i.scale) return r.associations.set(a, { type: 'nodes', index: e }), a }) }), (U.prototype.loadScene = (function () { function e(t, n, r, i) { var o = r.nodes[t] return i .getDependency('node', t) .then(function (e) { return void 0 === o.skin ? e : i .getDependency('skin', o.skin) .then(function (e) { for (var n = [], r = 0, o = (t = e).joints.length; r < o; r++) n.push(i.getDependency('node', t.joints[r])) return Promise.all(n) }) .then(function (n) { return ( e.traverse(function (e) { if (e.isMesh) { for ( var r = [], i = [], o = 0, a = n.length; o < a; o++ ) { var s = n[o] if (s) { r.push(s) var l = new THREE.Matrix4() void 0 !== t.inverseBindMatrices && l.fromArray(t.inverseBindMatrices.array, 16 * o), i.push(l) } else console.warn( 'THREE.GLTFLoader: Joint "%s" could not be found.', t.joints[o], ) } e.bind(new THREE.Skeleton(r, i), e.matrixWorld) } }), e ) }) var t }) .then(function (t) { n.add(t) var a = [] if (o.children) for (var s = o.children, l = 0, c = s.length; l < c; l++) { var u = s[l] a.push(e(u, t, r, i)) } return Promise.all(a) }) } return function (t) { var n = this.json, r = this.extensions, i = this.json.scenes[t], o = this, a = new THREE.Group() i.name && (a.name = o.createUniqueName(i.name)), I(a, i), i.extensions && O(r, a, i) for (var s = i.nodes || [], l = [], c = 0, u = s.length; c < u; c++) l.push(e(s[c], a, n, o)) return Promise.all(l).then(function () { return a }) } })()), t ) })() }, {}, ], 60: [ function (t, n, r) { ;(THREE.MTLLoader = function (e) { THREE.Loader.call(this, e) }), (THREE.MTLLoader.prototype = Object.assign( Object.create(THREE.Loader.prototype), { constructor: THREE.MTLLoader, load: function (t, n, r, i) { var o = this, a = '' === this.path ? THREE.LoaderUtils.extractUrlBase(t) : this.path, s = new THREE.FileLoader(this.manager) s.setPath(this.path), s.setRequestHeader(this.requestHeader), s.setWithCredentials(this.withCredentials), s.load( t, function (r) { try { n(o.parse(r, a)) } catch (e) { i ? i(e) : console.error(e), o.manager.itemError(t) } }, r, i, ) }, setMaterialOptions: function (e) { return (this.materialOptions = e), this }, parse: function (e, t) { for ( var n = e.split('\n'), r = {}, i = /\s+/, o = {}, a = 0; a < n.length; a++ ) { var s = n[a] if (0 !== (s = s.trim()).length && '#' !== s.charAt(0)) { var l = s.indexOf(' '), c = l >= 0 ? s.substring(0, l) : s c = c.toLowerCase() var u = l >= 0 ? s.substring(l + 1) : '' if (((u = u.trim()), 'newmtl' === c)) (r = { name: u }), (o[u] = r) else if ('ka' === c || 'kd' === c || 'ks' === c || 'ke' === c) { var h = u.split(i, 3) r[c] = [parseFloat(h[0]), parseFloat(h[1]), parseFloat(h[2])] } else r[c] = u } } var d = new THREE.MTLLoader.MaterialCreator( this.resourcePath || t, this.materialOptions, ) return ( d.setCrossOrigin(this.crossOrigin), d.setManager(this.manager), d.setMaterials(o), d ) }, }, )), (THREE.MTLLoader.MaterialCreator = function (e, t) { ;(this.baseUrl = e || ''), (this.options = t), (this.materialsInfo = {}), (this.materials = {}), (this.materialsArray = []), (this.nameLookup = {}), (this.side = this.options && this.options.side ? this.options.side : THREE.FrontSide), (this.wrap = this.options && this.options.wrap ? this.options.wrap : THREE.RepeatWrapping) }), (THREE.MTLLoader.MaterialCreator.prototype = { constructor: THREE.MTLLoader.MaterialCreator, crossOrigin: 'anonymous', setCrossOrigin: function (e) { return (this.crossOrigin = e), this }, setManager: function (e) { this.manager = e }, setMaterials: function (e) { ;(this.materialsInfo = this.convert(e)), (this.materials = {}), (this.materialsArray = []), (this.nameLookup = {}) }, convert: function (e) { if (!this.options) return e var t = {} for (var n in e) { var r = e[n], i = {} for (var o in ((t[n] = i), r)) { var a = !0, s = r[o], l = o.toLowerCase() switch (l) { case 'kd': case 'ka': case 'ks': this.options && this.options.normalizeRGB && (s = [s[0] / 255, s[1] / 255, s[2] / 255]), this.options && this.options.ignoreZeroRGBs && 0 === s[0] && 0 === s[1] && 0 === s[2] && (a = !1) } a && (i[l] = s) } } return t }, preload: function () { for (var e in this.materialsInfo) this.create(e) }, getIndex: function (e) { return this.nameLookup[e] }, getAsArray: function () { var e = 0 for (var t in this.materialsInfo) (this.materialsArray[e] = this.create(t)), (this.nameLookup[t] = e), e++ return this.materialsArray }, create: function (e) { return ( void 0 === this.materials[e] && this.createMaterial_(e), this.materials[e] ) }, createMaterial_: function (e) { var t = this, n = this.materialsInfo[e], r = { name: e, side: this.side } function i(e, t) { return 'string' !== typeof t || '' === t ? '' : /^https?:\/\//i.test(t) ? t : e + t } function o(e, n) { if (!r[e]) { var o = t.getTextureParams(n, r), a = t.loadTexture(i(t.baseUrl, o.url)) a.repeat.copy(o.scale), a.offset.copy(o.offset), (a.wrapS = t.wrap), (a.wrapT = t.wrap), (r[e] = a) } } for (var a in n) { var s, l = n[a] if ('' !== l) switch (a.toLowerCase()) { case 'kd': r.color = new THREE.Color().fromArray(l) break case 'ks': r.specular = new THREE.Color().fromArray(l) break case 'ke': r.emissive = new THREE.Color().fromArray(l) break case 'map_kd': o('map', l) break case 'map_ks': o('specularMap', l) break case 'map_ke': o('emissiveMap', l) break case 'norm': o('normalMap', l) break case 'map_bump': case 'bump': o('bumpMap', l) break case 'map_d': o('alphaMap', l), (r.transparent = !0) break case 'ns': r.shininess = parseFloat(l) break case 'd': ;(s = parseFloat(l)) < 1 && ((r.opacity = s), (r.transparent = !0)) break case 'tr': ;(s = parseFloat(l)), this.options && this.options.invertTrProperty && (s = 1 - s), s > 0 && ((r.opacity = 1 - s), (r.transparent = !0)) } } return (this.materials[e] = new THREE.MeshPhongMaterial(r)), this.materials[e] }, getTextureParams: function (e, t) { var n, r = { scale: new THREE.Vector2(1, 1), offset: new THREE.Vector2(0, 0) }, i = e.split(/\s+/) return ( (n = i.indexOf('-bm')) >= 0 && ((t.bumpScale = parseFloat(i[n + 1])), i.splice(n, 2)), (n = i.indexOf('-s')) >= 0 && (r.scale.set(parseFloat(i[n + 1]), parseFloat(i[n + 2])), i.splice(n, 4)), (n = i.indexOf('-o')) >= 0 && (r.offset.set(parseFloat(i[n + 1]), parseFloat(i[n + 2])), i.splice(n, 4)), (r.url = i.join(' ').trim()), r ) }, loadTexture: function (e, t, n, r, i) { var o, a = void 0 !== this.manager ? this.manager : THREE.DefaultLoadingManager, s = a.getHandler(e) return ( null === s && (s = new THREE.TextureLoader(a)), s.setCrossOrigin && s.setCrossOrigin(this.crossOrigin), (o = s.load(e, n, r, i)), void 0 !== t && (o.mapping = t), o ) }, }) }, {}, ], 61: [ function (t, n, r) { THREE.OBJLoader = (function () { var t = /^[og]\s*(.+)?/, n = /^mtllib /, r = /^usemtl /, i = /^usemap /, o = new THREE.Vector3(), a = new THREE.Vector3(), s = new THREE.Vector3(), l = new THREE.Vector3(), c = new THREE.Vector3() function u() { var e = { objects: [], object: {}, vertices: [], normals: [], colors: [], uvs: [], materials: {}, materialLibraries: [], startObject: function (e, t) { if (this.object && !1 === this.object.fromDeclaration) return ( (this.object.name = e), void (this.object.fromDeclaration = !1 !== t) ) var n = this.object && 'function' === typeof this.object.currentMaterial ? this.object.currentMaterial() : void 0 if ( (this.object && 'function' === typeof this.object._finalize && this.object._finalize(!0), (this.object = { name: e || '', fromDeclaration: !1 !== t, geometry: { vertices: [], normals: [], colors: [], uvs: [], hasUVIndices: !1, }, materials: [], smooth: !0, startMaterial: function (e, t) { var n = this._finalize(!1) n && (n.inherited || n.groupCount <= 0) && this.materials.splice(n.index, 1) var r = { index: this.materials.length, name: e || '', mtllib: Array.isArray(t) && t.length > 0 ? t[t.length - 1] : '', smooth: void 0 !== n ? n.smooth : this.smooth, groupStart: void 0 !== n ? n.groupEnd : 0, groupEnd: -1, groupCount: -1, inherited: !1, clone: function (e) { var t = { index: 'number' === typeof e ? e : this.index, name: this.name, mtllib: this.mtllib, smooth: this.smooth, groupStart: 0, groupEnd: -1, groupCount: -1, inherited: !1, } return (t.clone = this.clone.bind(t)), t }, } return this.materials.push(r), r }, currentMaterial: function () { if (this.materials.length > 0) return this.materials[this.materials.length - 1] }, _finalize: function (e) { var t = this.currentMaterial() if ( (t && -1 === t.groupEnd && ((t.groupEnd = this.geometry.vertices.length / 3), (t.groupCount = t.groupEnd - t.groupStart), (t.inherited = !1)), e && this.materials.length > 1) ) for (var n = this.materials.length - 1; n >= 0; n--) this.materials[n].groupCount <= 0 && this.materials.splice(n, 1) return ( e && 0 === this.materials.length && this.materials.push({ name: '', smooth: this.smooth }), t ) }, }), n && n.name && 'function' === typeof n.clone) ) { var r = n.clone(0) ;(r.inherited = !0), this.object.materials.push(r) } this.objects.push(this.object) }, finalize: function () { this.object && 'function' === typeof this.object._finalize && this.object._finalize(!0) }, parseVertexIndex: function (e, t) { var n = parseInt(e, 10) return 3 * (n >= 0 ? n - 1 : n + t / 3) }, parseNormalIndex: function (e, t) { var n = parseInt(e, 10) return 3 * (n >= 0 ? n - 1 : n + t / 3) }, parseUVIndex: function (e, t) { var n = parseInt(e, 10) return 2 * (n >= 0 ? n - 1 : n + t / 2) }, addVertex: function (e, t, n) { var r = this.vertices, i = this.object.geometry.vertices i.push(r[e + 0], r[e + 1], r[e + 2]), i.push(r[t + 0], r[t + 1], r[t + 2]), i.push(r[n + 0], r[n + 1], r[n + 2]) }, addVertexPoint: function (e) { var t = this.vertices this.object.geometry.vertices.push(t[e + 0], t[e + 1], t[e + 2]) }, addVertexLine: function (e) { var t = this.vertices this.object.geometry.vertices.push(t[e + 0], t[e + 1], t[e + 2]) }, addNormal: function (e, t, n) { var r = this.normals, i = this.object.geometry.normals i.push(r[e + 0], r[e + 1], r[e + 2]), i.push(r[t + 0], r[t + 1], r[t + 2]), i.push(r[n + 0], r[n + 1], r[n + 2]) }, addFaceNormal: function (e, t, n) { var r = this.vertices, i = this.object.geometry.normals o.fromArray(r, e), a.fromArray(r, t), s.fromArray(r, n), c.subVectors(s, a), l.subVectors(o, a), c.cross(l), c.normalize(), i.push(c.x, c.y, c.z), i.push(c.x, c.y, c.z), i.push(c.x, c.y, c.z) }, addColor: function (e, t, n) { var r = this.colors, i = this.object.geometry.colors void 0 !== r[e] && i.push(r[e + 0], r[e + 1], r[e + 2]), void 0 !== r[t] && i.push(r[t + 0], r[t + 1], r[t + 2]), void 0 !== r[n] && i.push(r[n + 0], r[n + 1], r[n + 2]) }, addUV: function (e, t, n) { var r = this.uvs, i = this.object.geometry.uvs i.push(r[e + 0], r[e + 1]), i.push(r[t + 0], r[t + 1]), i.push(r[n + 0], r[n + 1]) }, addDefaultUV: function () { var e = this.object.geometry.uvs e.push(0, 0), e.push(0, 0), e.push(0, 0) }, addUVLine: function (e) { var t = this.uvs this.object.geometry.uvs.push(t[e + 0], t[e + 1]) }, addFace: function (e, t, n, r, i, o, a, s, l) { var c = this.vertices.length, u = this.parseVertexIndex(e, c), h = this.parseVertexIndex(t, c), d = this.parseVertexIndex(n, c) if ( (this.addVertex(u, h, d), this.addColor(u, h, d), void 0 !== a && '' !== a) ) { var p = this.normals.length ;(u = this.parseNormalIndex(a, p)), (h = this.parseNormalIndex(s, p)), (d = this.parseNormalIndex(l, p)), this.addNormal(u, h, d) } else this.addFaceNormal(u, h, d) if (void 0 !== r && '' !== r) { var f = this.uvs.length ;(u = this.parseUVIndex(r, f)), (h = this.parseUVIndex(i, f)), (d = this.parseUVIndex(o, f)), this.addUV(u, h, d), (this.object.geometry.hasUVIndices = !0) } else this.addDefaultUV() }, addPointGeometry: function (e) { this.object.geometry.type = 'Points' for (var t = this.vertices.length, n = 0, r = e.length; n < r; n++) { var i = this.parseVertexIndex(e[n], t) this.addVertexPoint(i), this.addColor(i) } }, addLineGeometry: function (e, t) { this.object.geometry.type = 'Line' for ( var n = this.vertices.length, r = this.uvs.length, i = 0, o = e.length; i < o; i++ ) this.addVertexLine(this.parseVertexIndex(e[i], n)) var a = 0 for (o = t.length; a < o; a++) this.addUVLine(this.parseUVIndex(t[a], r)) }, } return e.startObject('', !1), e } function h(e) { THREE.Loader.call(this, e), (this.materials = null) } return ( (h.prototype = Object.assign(Object.create(THREE.Loader.prototype), { constructor: h, load: function (t, n, r, i) { var o = this, a = new THREE.FileLoader(this.manager) a.setPath(this.path), a.setRequestHeader(this.requestHeader), a.setWithCredentials(this.withCredentials), a.load( t, function (r) { try { n(o.parse(r)) } catch (e) { i ? i(e) : console.error(e), o.manager.itemError(t) } }, r, i, ) }, setMaterials: function (e) { return (this.materials = e), this }, parse: function (e) { var o = new u() ;-1 !== e.indexOf('\r\n') && (e = e.replace(/\r\n/g, '\n')), -1 !== e.indexOf('\\\n') && (e = e.replace(/\\\n/g, '')) for ( var a = e.split('\n'), s = '', l = '', c = [], h = 'function' === typeof ''.trimLeft, d = 0, p = a.length; d < p; d++ ) if ( ((s = a[d]), 0 !== (s = h ? s.trimLeft() : s.trim()).length && '#' !== (l = s.charAt(0))) ) if ('v' === l) { var f = s.split(/\s+/) switch (f[0]) { case 'v': o.vertices.push( parseFloat(f[1]), parseFloat(f[2]), parseFloat(f[3]), ), f.length >= 7 ? o.colors.push( parseFloat(f[4]), parseFloat(f[5]), parseFloat(f[6]), ) : o.colors.push(void 0, void 0, void 0) break case 'vn': o.normals.push( parseFloat(f[1]), parseFloat(f[2]), parseFloat(f[3]), ) break case 'vt': o.uvs.push(parseFloat(f[1]), parseFloat(f[2])) } } else if ('f' === l) { for ( var m = s.substr(1).trim().split(/\s+/), v = [], g = 0, y = m.length; g < y; g++ ) { var b = m[g] if (b.length > 0) { var A = b.split('/') v.push(A) } } var w = v[0] for (g = 1, y = v.length - 1; g < y; g++) { var x = v[g], E = v[g + 1] o.addFace(w[0], x[0], E[0], w[1], x[1], E[1], w[2], x[2], E[2]) } } else if ('l' === l) { var M = s.substring(1).trim().split(' '), _ = [], T = [] if (-1 === s.indexOf('/')) _ = M else for (var S = 0, C = M.length; S < C; S++) { var L = M[S].split('/') '' !== L[0] && _.push(L[0]), '' !== L[1] && T.push(L[1]) } o.addLineGeometry(_, T) } else if ('p' === l) { var R = s.substr(1).trim().split(' ') o.addPointGeometry(R) } else if (null !== (c = t.exec(s))) { var P = (' ' + c[0].substr(1).trim()).substr(1) o.startObject(P) } else if (r.test(s)) o.object.startMaterial(s.substring(7).trim(), o.materialLibraries) else if (n.test(s)) o.materialLibraries.push(s.substring(7).trim()) else if (i.test(s)) console.warn( 'THREE.OBJLoader: Rendering identifier "usemap" not supported. Textures must be defined in MTL files.', ) else if ('s' === l) { if ((c = s.split(' ')).length > 1) { var D = c[1].trim().toLowerCase() o.object.smooth = '0' !== D && 'off' !== D } else o.object.smooth = !0 ;(W = o.object.currentMaterial()) && (W.smooth = o.object.smooth) } else { if ('\0' === s) continue console.warn('THREE.OBJLoader: Unexpected line: "' + s + '"') } o.finalize() var O = new THREE.Group() if ( ((O.materialLibraries = [].concat(o.materialLibraries)), !0 === !( 1 === o.objects.length && 0 === o.objects[0].geometry.vertices.length )) ) for (d = 0, p = o.objects.length; d < p; d++) { var I = o.objects[d], B = I.geometry, F = I.materials, k = 'Line' === B.type, N = 'Points' === B.type, U = !1 if (0 !== B.vertices.length) { ;(Q = new THREE.BufferGeometry()).setAttribute( 'position', new THREE.Float32BufferAttribute(B.vertices, 3), ), B.normals.length > 0 && Q.setAttribute( 'normal', new THREE.Float32BufferAttribute(B.normals, 3), ), B.colors.length > 0 && ((U = !0), Q.setAttribute( 'color', new THREE.Float32BufferAttribute(B.colors, 3), )), !0 === B.hasUVIndices && Q.setAttribute('uv', new THREE.Float32BufferAttribute(B.uvs, 2)) for (var H, G = [], z = 0, j = F.length; z < j; z++) { var V = (Y = F[z]).name + '_' + Y.smooth + '_' + U, W = o.materials[V] if (null !== this.materials) if ( ((W = this.materials.create(Y.name)), !k || !W || W instanceof THREE.LineBasicMaterial) ) { if (N && W && !(W instanceof THREE.PointsMaterial)) { var q = new THREE.PointsMaterial({ size: 10, sizeAttenuation: !1, }) THREE.Material.prototype.copy.call(q, W), q.color.copy(W.color), (q.map = W.map), (W = q) } } else { var X = new THREE.LineBasicMaterial() THREE.Material.prototype.copy.call(X, W), X.color.copy(W.color), (W = X) } void 0 === W && (((W = k ? new THREE.LineBasicMaterial() : N ? new THREE.PointsMaterial({ size: 1, sizeAttenuation: !1 }) : new THREE.MeshPhongMaterial()).name = Y.name), (W.flatShading = !Y.smooth), (W.vertexColors = U), (o.materials[V] = W)), G.push(W) } if (G.length > 1) { for (z = 0, j = F.length; z < j; z++) { var Y = F[z] Q.addGroup(Y.groupStart, Y.groupCount, z) } H = k ? new THREE.LineSegments(Q, G) : N ? new THREE.Points(Q, G) : new THREE.Mesh(Q, G) } else H = k ? new THREE.LineSegments(Q, G[0]) : N ? new THREE.Points(Q, G[0]) : new THREE.Mesh(Q, G[0]) ;(H.name = I.name), O.add(H) } } else if (o.vertices.length > 0) { var Q ;(W = new THREE.PointsMaterial({ size: 1, sizeAttenuation: !1 })), (Q = new THREE.BufferGeometry()).setAttribute( 'position', new THREE.Float32BufferAttribute(o.vertices, 3), ), o.colors.length > 0 && void 0 !== o.colors[0] && (Q.setAttribute( 'color', new THREE.Float32BufferAttribute(o.colors, 3), ), (W.vertexColors = !0)) var Z = new THREE.Points(Q, W) O.add(Z) } return O }, })), h ) })() }, {}, ], 62: [ function (e, t, n) { THREE.BufferGeometryUtils = { computeTangents: function (e) { e.computeTangents(), console.warn( 'THREE.BufferGeometryUtils: .computeTangents() has been removed. Use BufferGeometry.computeTangents() instead.', ) }, mergeBufferGeometries: function (e, t) { for ( var n = null !== e[0].index, r = new Set(Object.keys(e[0].attributes)), i = new Set(Object.keys(e[0].morphAttributes)), o = {}, a = {}, s = e[0].morphTargetsRelative, l = new THREE.BufferGeometry(), c = 0, u = 0; u < e.length; ++u ) { var h = e[u], d = 0 if (n !== (null !== h.index)) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferGeometries() failed with geometry at index ' + u + '. All geometries must have compatible attributes; make sure index attribute exists among all geometries, or in none of them.', ), null ) for (var p in h.attributes) { if (!r.has(p)) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferGeometries() failed with geometry at index ' + u + '. All geometries must have compatible attributes; make sure "' + p + '" attribute exists among all geometries, or in none of them.', ), null ) void 0 === o[p] && (o[p] = []), o[p].push(h.attributes[p]), d++ } if (d !== r.size) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferGeometries() failed with geometry at index ' + u + '. Make sure all geometries have the same number of attributes.', ), null ) if (s !== h.morphTargetsRelative) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferGeometries() failed with geometry at index ' + u + '. .morphTargetsRelative must be consistent throughout all geometries.', ), null ) for (var p in h.morphAttributes) { if (!i.has(p)) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferGeometries() failed with geometry at index ' + u + '. .morphAttributes must be consistent throughout all geometries.', ), null ) void 0 === a[p] && (a[p] = []), a[p].push(h.morphAttributes[p]) } if ( ((l.userData.mergedUserData = l.userData.mergedUserData || []), l.userData.mergedUserData.push(h.userData), t) ) { var f if (n) f = h.index.count else { if (void 0 === h.attributes.position) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferGeometries() failed with geometry at index ' + u + '. The geometry must have either an index or a position attribute', ), null ) f = h.attributes.position.count } l.addGroup(c, f, u), (c += f) } } if (n) { var m = 0, v = [] for (u = 0; u < e.length; ++u) { for (var g = e[u].index, y = 0; y < g.count; ++y) v.push(g.getX(y) + m) m += e[u].attributes.position.count } l.setIndex(v) } for (var p in o) { var b = this.mergeBufferAttributes(o[p]) if (!b) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferGeometries() failed while trying to merge the ' + p + ' attribute.', ), null ) l.setAttribute(p, b) } for (var p in a) { var A = a[p][0].length if (0 === A) break for ( l.morphAttributes = l.morphAttributes || {}, l.morphAttributes[p] = [], u = 0; u < A; ++u ) { var w = [] for (y = 0; y < a[p].length; ++y) w.push(a[p][y][u]) var x = this.mergeBufferAttributes(w) if (!x) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferGeometries() failed while trying to merge the ' + p + ' morphAttribute.', ), null ) l.morphAttributes[p].push(x) } } return l }, mergeBufferAttributes: function (e) { for (var t, n, r, i = 0, o = 0; o < e.length; ++o) { var a = e[o] if (a.isInterleavedBufferAttribute) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferAttributes() failed. InterleavedBufferAttributes are not supported.', ), null ) if ((void 0 === t && (t = a.array.constructor), t !== a.array.constructor)) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferAttributes() failed. BufferAttribute.array must be of consistent array types across matching attributes.', ), null ) if ((void 0 === n && (n = a.itemSize), n !== a.itemSize)) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferAttributes() failed. BufferAttribute.itemSize must be consistent across matching attributes.', ), null ) if ((void 0 === r && (r = a.normalized), r !== a.normalized)) return ( console.error( 'THREE.BufferGeometryUtils: .mergeBufferAttributes() failed. BufferAttribute.normalized must be consistent across matching attributes.', ), null ) i += a.array.length } var s = new t(i), l = 0 for (o = 0; o < e.length; ++o) s.set(e[o].array, l), (l += e[o].array.length) return new THREE.BufferAttribute(s, n, r) }, interleaveAttributes: function (e) { for (var t, n = 0, r = 0, i = 0, o = e.length; i < o; ++i) { var a = e[i] if ((void 0 === t && (t = a.array.constructor), t !== a.array.constructor)) return ( console.error( 'AttributeBuffers of different types cannot be interleaved', ), null ) ;(n += a.array.length), (r += a.itemSize) } var s = new THREE.InterleavedBuffer(new t(n), r), l = 0, c = [], u = ['getX', 'getY', 'getZ', 'getW'], h = ['setX', 'setY', 'setZ', 'setW'], d = 0 for (o = e.length; d < o; d++) { var p = (a = e[d]).itemSize, f = a.count, m = new THREE.InterleavedBufferAttribute(s, p, l, a.normalized) c.push(m), (l += p) for (var v = 0; v < f; v++) for (var g = 0; g < p; g++) m[h[g]](v, a[u[g]](v)) } return c }, estimateBytesUsed: function (e) { var t = 0 for (var n in e.attributes) { var r = e.getAttribute(n) t += r.count * r.itemSize * r.array.BYTES_PER_ELEMENT } var i = e.getIndex() return (t += i ? i.count * i.itemSize * i.array.BYTES_PER_ELEMENT : 0) }, mergeVertices: function (e, t = 1e-4) { t = Math.max(t, Number.EPSILON) for ( var n = {}, r = e.getIndex(), i = e.getAttribute('position'), o = r ? r.count : i.count, a = 0, s = Object.keys(e.attributes), l = {}, c = {}, u = [], h = ['getX', 'getY', 'getZ', 'getW'], d = 0, p = s.length; d < p; d++ ) (l[(b = s[d])] = []), (E = e.morphAttributes[b]) && (c[b] = new Array(E.length).fill().map(() => [])) var f = Math.log10(1 / t), m = Math.pow(10, f) for (d = 0; d < o; d++) { var v = r ? r.getX(d) : d, g = '', y = 0 for (p = s.length; y < p; y++) for (var b = s[y], A = (x = e.getAttribute(b)).itemSize, w = 0; w < A; w++) g += ~~(x[h[w]](v) * m) + ',' if (g in n) u.push(n[g]) else { for (y = 0, p = s.length; y < p; y++) { b = s[y] var x = e.getAttribute(b), E = e.morphAttributes[b], M = ((A = x.itemSize), l[b]), _ = c[b] for (w = 0; w < A; w++) { var T = h[w] if ((M.push(x[T](v)), E)) for (var S = 0, C = E.length; S < C; S++) _[S].push(E[S][T](v)) } } ;(n[g] = a), u.push(a), a++ } } const L = e.clone() for (d = 0, p = s.length; d < p; d++) { b = s[d] var R = e.getAttribute(b), P = new R.array.constructor(l[b]) if ( ((x = new THREE.BufferAttribute(P, R.itemSize, R.normalized)), L.setAttribute(b, x), b in c) ) for (y = 0; y < c[b].length; y++) { var D = e.morphAttributes[b][y], O = ((P = new D.array.constructor(c[b][y])), new THREE.BufferAttribute(P, D.itemSize, D.normalized)) L.morphAttributes[b][y] = O } } return L.setIndex(u), L }, toTrianglesDrawMode: function (e, t) { if (t === THREE.TrianglesDrawMode) return ( console.warn( 'THREE.BufferGeometryUtils.toTrianglesDrawMode(): Geometry already defined as triangles.', ), e ) if (t === THREE.TriangleFanDrawMode || t === THREE.TriangleStripDrawMode) { var n = e.getIndex() if (null === n) { var r = [], i = e.getAttribute('position') if (void 0 === i) return ( console.error( 'THREE.BufferGeometryUtils.toTrianglesDrawMode(): Undefined position attribute. Processing not possible.', ), e ) for (var o = 0; o < i.count; o++) r.push(o) e.setIndex(r), (n = e.getIndex()) } var a = n.count - 2, s = [] if (t === THREE.TriangleFanDrawMode) for (o = 1; o <= a; o++) s.push(n.getX(0)), s.push(n.getX(o)), s.push(n.getX(o + 1)) else for (o = 0; o < a; o++) o % 2 === 0 ? (s.push(n.getX(o)), s.push(n.getX(o + 1)), s.push(n.getX(o + 2))) : (s.push(n.getX(o + 2)), s.push(n.getX(o + 1)), s.push(n.getX(o))) s.length / 3 !== a && console.error( 'THREE.BufferGeometryUtils.toTrianglesDrawMode(): Unable to generate correct amount of triangles.', ) var l = e.clone() return l.setIndex(s), l.clearGroups(), l } return ( console.error( 'THREE.BufferGeometryUtils.toTrianglesDrawMode(): Unknown draw mode:', t, ), e ) }, computeMorphedAttributes: function (e) { if (!0 !== e.geometry.isBufferGeometry) return ( console.error( 'THREE.BufferGeometryUtils: Geometry is not of type THREE.BufferGeometry.', ), null ) var t = new THREE.Vector3(), n = new THREE.Vector3(), r = new THREE.Vector3(), i = new THREE.Vector3(), o = new THREE.Vector3(), a = new THREE.Vector3(), s = new THREE.Vector3(), l = new THREE.Vector3(), c = new THREE.Vector3() function u(e, u, h, d, p, f, m, v, g) { t.fromBufferAttribute(h, f), n.fromBufferAttribute(h, m), r.fromBufferAttribute(h, v) var y = e.morphTargetInfluences if (u.morphTargets && d && y) { s.set(0, 0, 0), l.set(0, 0, 0), c.set(0, 0, 0) for (var b = 0, A = d.length; b < A; b++) { var w = y[b] ;(d = d[b]), 0 !== w && (i.fromBufferAttribute(d, f), o.fromBufferAttribute(d, m), a.fromBufferAttribute(d, v), p ? (s.addScaledVector(i, w), l.addScaledVector(o, w), c.addScaledVector(a, w)) : (s.addScaledVector(i.sub(t), w), l.addScaledVector(o.sub(n), w), c.addScaledVector(a.sub(r), w))) } t.add(s), n.add(l), r.add(c) } e.isSkinnedMesh && (e.boneTransform(f, t), e.boneTransform(m, n), e.boneTransform(v, r)), (g[3 * f + 0] = t.x), (g[3 * f + 1] = t.y), (g[3 * f + 2] = t.z), (g[3 * m + 0] = n.x), (g[3 * m + 1] = n.y), (g[3 * m + 2] = n.z), (g[3 * v + 0] = r.x), (g[3 * v + 1] = r.y), (g[3 * v + 2] = r.z) } var h, d, p, f, m, v, g, y, b, A = e.geometry, w = e.material, x = A.index, E = A.attributes.position, M = A.morphAttributes.position, _ = A.morphTargetsRelative, T = A.attributes.normal, S = A.morphAttributes.position, C = A.groups, L = A.drawRange, R = new Float32Array(E.count * E.itemSize), P = new Float32Array(T.count * T.itemSize) if (null !== x) if (Array.isArray(w)) for (f = 0, v = C.length; f < v; f++) for ( b = w[(y = C[f]).materialIndex], m = Math.max(y.start, L.start), g = Math.min(y.start + y.count, L.start + L.count); m < g; m += 3 ) u( e, b, E, M, _, (h = x.getX(m)), (d = x.getX(m + 1)), (p = x.getX(m + 2)), R, ), u(e, b, T, S, _, h, d, p, P) else for ( f = Math.max(0, L.start), v = Math.min(x.count, L.start + L.count); f < v; f += 3 ) u( e, w, E, M, _, (h = x.getX(f)), (d = x.getX(f + 1)), (p = x.getX(f + 2)), R, ), u(e, w, T, S, _, h, d, p, P) else if (void 0 !== E) if (Array.isArray(w)) for (f = 0, v = C.length; f < v; f++) for ( b = w[(y = C[f]).materialIndex], m = Math.max(y.start, L.start), g = Math.min(y.start + y.count, L.start + L.count); m < g; m += 3 ) u(e, b, E, M, _, (h = m), (d = m + 1), (p = m + 2), R), u(e, b, T, S, _, h, d, p, P) else for ( f = Math.max(0, L.start), v = Math.min(E.count, L.start + L.count); f < v; f += 3 ) u(e, w, E, M, _, (h = f), (d = f + 1), (p = f + 2), R), u(e, w, T, S, _, h, d, p, P) return { positionAttribute: E, normalAttribute: T, morphedPositionAttribute: new THREE.Float32BufferAttribute(R, 3), morphedNormalAttribute: new THREE.Float32BufferAttribute(P, 3), } }, } }, {}, ], 63: [ function (e, t, n) { var r = e('layout-bmfont-text'), i = e('inherits'), o = e('quad-indices'), a = e('three-buffer-vertex-data'), s = e('object-assign'), l = e('./lib/vertices'), c = e('./lib/utils'), u = THREE.BufferGeometry function h(e) { u.call(this), 'string' === typeof e && (e = { text: e }), (this._opt = s({}, e)), e && this.update(e) } ;(t.exports = function (e) { return new h(e) }), i(h, u), (h.prototype.update = function (e) { if ( ('string' === typeof e && (e = { text: e }), !(e = s({}, this._opt, e)).font) ) throw new TypeError('must specify a { font } in options') this.layout = r(e) var t = !1 !== e.flipY, n = e.font, i = n.common.scaleW, c = n.common.scaleH, u = this.layout.glyphs.filter(function (e) { var t = e.data return t.width * t.height > 0 }) this.visibleGlyphs = u var h = l.positions(u), d = l.uvs(u, i, c, t), p = o({ clockwise: !0, type: 'uint16', count: u.length }) if ( (a.index(this, p, 1, 'uint16'), a.attr(this, 'position', h, 2), a.attr(this, 'uv', d, 2), !e.multipage && 'page' in this.attributes) ) this.removeAttribute('page') else if (e.multipage) { var f = l.pages(u) a.attr(this, 'page', f, 1) } }), (h.prototype.computeBoundingSphere = function () { null === this.boundingSphere && (this.boundingSphere = new THREE.Sphere()) var e = this.attributes.position.array, t = this.attributes.position.itemSize if (!e || !t || e.length < 2) return ( (this.boundingSphere.radius = 0), void this.boundingSphere.center.set(0, 0, 0) ) c.computeSphere(e, this.boundingSphere), isNaN(this.boundingSphere.radius) && console.error( 'THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.', ) }), (h.prototype.computeBoundingBox = function () { null === this.boundingBox && (this.boundingBox = new THREE.Box3()) var e = this.boundingBox, t = this.attributes.position.array, n = this.attributes.position.itemSize !t || !n || t.length < 2 ? e.makeEmpty() : c.computeBox(t, e) }) }, { './lib/utils': 64, './lib/vertices': 65, inherits: 30, 'layout-bmfont-text': 36, 'object-assign': 39, 'quad-indices': 51, 'three-buffer-vertex-data': 66, }, ], 64: [ function (e, t, n) { var r = 2, i = { min: [0, 0], max: [0, 0] } function o(e) { var t = e.length / r ;(i.min[0] = e[0]), (i.min[1] = e[1]), (i.max[0] = e[0]), (i.max[1] = e[1]) for (var n = 0; n < t; n++) { var o = e[n * r + 0], a = e[n * r + 1] ;(i.min[0] = Math.min(o, i.min[0])), (i.min[1] = Math.min(a, i.min[1])), (i.max[0] = Math.max(o, i.max[0])), (i.max[1] = Math.max(a, i.max[1])) } } ;(t.exports.computeBox = function (e, t) { o(e), t.min.set(i.min[0], i.min[1], 0), t.max.set(i.max[0], i.max[1], 0) }), (t.exports.computeSphere = function (e, t) { o(e) var n = i.min[0], r = i.min[1], a = i.max[0] - n, s = i.max[1] - r, l = Math.sqrt(a * a + s * s) t.center.set(n + a / 2, r + s / 2, 0), (t.radius = l / 2) }) }, {}, ], 65: [ function (e, t, n) { ;(t.exports.pages = function (e) { var t = new Float32Array(4 * e.length * 1), n = 0 return ( e.forEach(function (e) { var r = e.data.page || 0 ;(t[n++] = r), (t[n++] = r), (t[n++] = r), (t[n++] = r) }), t ) }), (t.exports.uvs = function (e, t, n, r) { var i = new Float32Array(4 * e.length * 2), o = 0 return ( e.forEach(function (e) { var a = e.data, s = a.x + a.width, l = a.y + a.height, c = a.x / t, u = a.y / n, h = s / t, d = l / n r && ((u = (n - a.y) / n), (d = (n - l) / n)), (i[o++] = c), (i[o++] = u), (i[o++] = c), (i[o++] = d), (i[o++] = h), (i[o++] = d), (i[o++] = h), (i[o++] = u) }), i ) }), (t.exports.positions = function (e) { var t = new Float32Array(4 * e.length * 2), n = 0 return ( e.forEach(function (e) { var r = e.data, i = e.position[0] + r.xoffset, o = e.position[1] + r.yoffset, a = r.width, s = r.height ;(t[n++] = i), (t[n++] = o), (t[n++] = i), (t[n++] = o + s), (t[n++] = i + a), (t[n++] = o + s), (t[n++] = i + a), (t[n++] = o) }), t ) }) }, {}, ], 66: [ function (e, t, n) { var r = e('flatten-vertex-data') function i(e, t, n, r) { 'number' !== typeof n && (n = 1), 'string' !== typeof r && (r = 'uint16') var i = !e.index && 'function' !== typeof e.setIndex, o = a(i ? e.getAttribute('index') : e.index, t, n, r) o && (i ? e.addAttribute('index', o) : (e.index = o)) } function o(e, t, n, r, i) { if ( ('number' !== typeof r && (r = 3), 'string' !== typeof i && (i = 'float32'), Array.isArray(n) && Array.isArray(n[0]) && n[0].length !== r) ) throw new Error( 'Nested vertex array has unexpected size; expected ' + r + ' but found ' + n[0].length, ) var o = a(e.getAttribute(t), n, r, i) e.setAttribute(t, o) } function a(e, t, n, i) { return ( (t = r((t = t || []), i)), ((e = new THREE.BufferAttribute(t, n)).itemSize = n), (e.needsUpdate = !0), e ) } ;(t.exports.attr = o), (t.exports.index = i) }, { 'flatten-vertex-data': 23 }, ], 67: [ function (e, t, n) { ;(function (t, r) { var i = e('process/browser.js').nextTick, o = Function.prototype.apply, a = Array.prototype.slice, s = {}, l = 0 function c(e, t) { ;(this._id = e), (this._clearFn = t) } ;(n.setTimeout = function () { return new c(o.call(setTimeout, window, arguments), clearTimeout) }), (n.setInterval = function () { return new c(o.call(setInterval, window, arguments), clearInterval) }), (n.clearTimeout = n.clearInterval = function (e) { e.close() }), (c.prototype.unref = c.prototype.ref = function () {}), (c.prototype.close = function () { this._clearFn.call(window, this._id) }), (n.enroll = function (e, t) { clearTimeout(e._idleTimeoutId), (e._idleTimeout = t) }), (n.unenroll = function (e) { clearTimeout(e._idleTimeoutId), (e._idleTimeout = -1) }), (n._unrefActive = n.active = function (e) { clearTimeout(e._idleTimeoutId) var t = e._idleTimeout t >= 0 && (e._idleTimeoutId = setTimeout(function () { e._onTimeout && e._onTimeout() }, t)) }), (n.setImmediate = 'function' === typeof t ? t : function (e) { var t = l++, r = !(arguments.length < 2) && a.call(arguments, 1) return ( (s[t] = !0), i(function () { s[t] && (r ? e.apply(null, r) : e.call(null), n.clearImmediate(t)) }), t ) }), (n.clearImmediate = 'function' === typeof r ? r : function (e) { delete s[e] }) }.call(this, e('timers').setImmediate, e('timers').clearImmediate)) }, { 'process/browser.js': 49, timers: 67 }, ], 68: [ function (e, n, i) { ;(function (e) { !(function (e, r) { 'object' === typeof i && 'undefined' !== typeof n ? (n.exports = r()) : 'function' === typeof t && t.amd ? t(r) : (e.WebVRPolyfill = r()) })(this, function () { 'use strict' var t = 'undefined' !== typeof window ? window : 'undefined' !== typeof e ? e : 'undefined' !== typeof self ? self : {} function n(e) { return e && e.__esModule && Object.prototype.hasOwnProperty.call(e, 'default') ? e.default : e } function r(e, t) { return e((t = { exports: {} }), t.exports), t.exports } var i = function () { return ( /Android/i.test(navigator.userAgent) || /iPhone|iPad|iPod/i.test(navigator.userAgent) ) }, o = function (e, t) { for (var n = 0, r = e.length; n < r; n++) t[n] = e[n] }, a = function (e, t) { for (var n in t) t.hasOwnProperty(n) && (e[n] = t[n]) return e }, s = n( r(function (e, n) { var r ;(r = function () { var e = function (e, t) { if (!(e instanceof t)) throw new TypeError('Cannot call a class as a function') }, n = (function () { function e(e, t) { for (var n = 0; n < t.length; n++) { var r = t[n] ;(r.enumerable = r.enumerable || !1), (r.configurable = !0), 'value' in r && (r.writable = !0), Object.defineProperty(e, r.key, r) } } return function (t, n, r) { return n && e(t.prototype, n), r && e(t, r), t } })(), r = (function () { function e(e, t) { var n = [], r = !0, i = !1, o = void 0 try { for ( var a, s = e[Symbol.iterator](); !(r = (a = s.next()).done) && (n.push(a.value), !t || n.length !== t); r = !0 ); } catch (l) { ;(i = !0), (o = l) } finally { try { !r && s.return && s.return() } finally { if (i) throw o } } return n } return function (t, n) { if (Array.isArray(t)) return t if (Symbol.iterator in Object(t)) return e(t, n) throw new TypeError( 'Invalid attempt to destructure non-iterable instance', ) } })(), i = 0.001, o = 1, a = function (e, t) { return 'data:' + e + ',' + encodeURIComponent(t) }, s = function (e, t, n) { return e + (t - e) * n }, l = (function () { var e = /iPad|iPhone|iPod/.test(navigator.platform) return function () { return e } })(), c = (function () { var e = -1 !== navigator.userAgent.indexOf('Version') && -1 !== navigator.userAgent.indexOf('Android') && -1 !== navigator.userAgent.indexOf('Chrome') return function () { return e } })(), u = (function () { var e = /^((?!chrome|android).)*safari/i.test(navigator.userAgent) return function () { return e } })(), h = (function () { var e = -1 !== navigator.userAgent.indexOf('Firefox') && -1 !== navigator.userAgent.indexOf('Android') return function () { return e } })(), d = (function () { var e = navigator.userAgent.match(/.*Chrome\/([0-9]+)/), t = e ? parseInt(e[1], 10) : null return function () { return t } })(), p = (function () { var e = !1 return ( (e = l() && u() && -1 !== navigator.userAgent.indexOf('13_4')), function () { return e } ) })(), f = (function () { var e = !1 if (65 === d()) { var t = navigator.userAgent.match(/.*Chrome\/([0-9\.]*)/) if (t) { var n = t[1].split('.'), i = r(n, 4), o = (i[0], i[1], i[2]), a = i[3] e = 3325 === parseInt(o, 10) && parseInt(a, 10) < 148 } } return function () { return e } })(), m = (function () { var e = -1 !== navigator.userAgent.indexOf('R7 Build') return function () { return e } })(), v = function () { var e = 90 == window.orientation || -90 == window.orientation return m() ? !e : e }, g = function (e) { return !isNaN(e) && !(e <= i) && !(e > o) }, y = function () { return ( Math.max(window.screen.width, window.screen.height) * window.devicePixelRatio ) }, b = function () { return ( Math.min(window.screen.width, window.screen.height) * window.devicePixelRatio ) }, A = function (e) { if (c()) return !1 if (e.requestFullscreen) e.requestFullscreen() else if (e.webkitRequestFullscreen) e.webkitRequestFullscreen() else if (e.mozRequestFullScreen) e.mozRequestFullScreen() else { if (!e.msRequestFullscreen) return !1 e.msRequestFullscreen() } return !0 }, w = function () { if (document.exitFullscreen) document.exitFullscreen() else if (document.webkitExitFullscreen) document.webkitExitFullscreen() else if (document.mozCancelFullScreen) document.mozCancelFullScreen() else { if (!document.msExitFullscreen) return !1 document.msExitFullscreen() } return !0 }, x = function () { return ( document.fullscreenElement || document.webkitFullscreenElement || document.mozFullScreenElement || document.msFullscreenElement ) }, E = function (e, t, n, r) { var i = e.createShader(e.VERTEX_SHADER) e.shaderSource(i, t), e.compileShader(i) var o = e.createShader(e.FRAGMENT_SHADER) e.shaderSource(o, n), e.compileShader(o) var a = e.createProgram() for (var s in (e.attachShader(a, i), e.attachShader(a, o), r)) e.bindAttribLocation(a, r[s], s) return e.linkProgram(a), e.deleteShader(i), e.deleteShader(o), a }, M = function (e, t) { for ( var n = {}, r = e.getProgramParameter(t, e.ACTIVE_UNIFORMS), i = '', o = 0; o < r; o++ ) n[(i = e.getActiveUniform(t, o).name.replace('[0]', ''))] = e.getUniformLocation(t, i) return n }, _ = function (e, t, n, r, i, o, a) { var s = 1 / (t - n), l = 1 / (r - i), c = 1 / (o - a) return ( (e[0] = -2 * s), (e[1] = 0), (e[2] = 0), (e[3] = 0), (e[4] = 0), (e[5] = -2 * l), (e[6] = 0), (e[7] = 0), (e[8] = 0), (e[9] = 0), (e[10] = 2 * c), (e[11] = 0), (e[12] = (t + n) * s), (e[13] = (i + r) * l), (e[14] = (a + o) * c), (e[15] = 1), e ) }, T = function () { var e, t = !1 return ( (e = navigator.userAgent || navigator.vendor || window.opera), (/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test( e, ) || /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test( e.substr(0, 4), )) && (t = !0), t ) }, S = function (e, t) { for (var n in t) t.hasOwnProperty(n) && (e[n] = t[n]) return e }, C = function (e) { if (l()) { var t = e.style.width, n = e.style.height ;(e.style.width = parseInt(t) + 1 + 'px'), (e.style.height = parseInt(n) + 'px'), setTimeout(function () { ;(e.style.width = t), (e.style.height = n) }, 100) } window.canvas = e }, L = (function () { var e = Math.PI / 180, t = 0.25 * Math.PI function n(n, r, i, o) { var a = Math.tan(r ? r.upDegrees * e : t), s = Math.tan(r ? r.downDegrees * e : t), l = Math.tan(r ? r.leftDegrees * e : t), c = Math.tan(r ? r.rightDegrees * e : t), u = 2 / (l + c), h = 2 / (a + s) return ( (n[0] = u), (n[1] = 0), (n[2] = 0), (n[3] = 0), (n[4] = 0), (n[5] = h), (n[6] = 0), (n[7] = 0), (n[8] = -(l - c) * u * 0.5), (n[9] = (a - s) * h * 0.5), (n[10] = o / (i - o)), (n[11] = -1), (n[12] = 0), (n[13] = 0), (n[14] = (o * i) / (i - o)), (n[15] = 0), n ) } function r(e, t, n) { var r = t[0], i = t[1], o = t[2], a = t[3], s = r + r, l = i + i, c = o + o, u = r * s, h = r * l, d = r * c, p = i * l, f = i * c, m = o * c, v = a * s, g = a * l, y = a * c return ( (e[0] = 1 - (p + m)), (e[1] = h + y), (e[2] = d - g), (e[3] = 0), (e[4] = h - y), (e[5] = 1 - (u + m)), (e[6] = f + v), (e[7] = 0), (e[8] = d + g), (e[9] = f - v), (e[10] = 1 - (u + p)), (e[11] = 0), (e[12] = n[0]), (e[13] = n[1]), (e[14] = n[2]), (e[15] = 1), e ) } function i(e, t, n) { var r, i, o, a, s, l, c, u, h, d, p, f, m = n[0], v = n[1], g = n[2] return ( t === e ? ((e[12] = t[0] * m + t[4] * v + t[8] * g + t[12]), (e[13] = t[1] * m + t[5] * v + t[9] * g + t[13]), (e[14] = t[2] * m + t[6] * v + t[10] * g + t[14]), (e[15] = t[3] * m + t[7] * v + t[11] * g + t[15])) : ((r = t[0]), (i = t[1]), (o = t[2]), (a = t[3]), (s = t[4]), (l = t[5]), (c = t[6]), (u = t[7]), (h = t[8]), (d = t[9]), (p = t[10]), (f = t[11]), (e[0] = r), (e[1] = i), (e[2] = o), (e[3] = a), (e[4] = s), (e[5] = l), (e[6] = c), (e[7] = u), (e[8] = h), (e[9] = d), (e[10] = p), (e[11] = f), (e[12] = r * m + s * v + h * g + t[12]), (e[13] = i * m + l * v + d * g + t[13]), (e[14] = o * m + c * v + p * g + t[14]), (e[15] = a * m + u * v + f * g + t[15])), e ) } function o(e, t) { var n = t[0], r = t[1], i = t[2], o = t[3], a = t[4], s = t[5], l = t[6], c = t[7], u = t[8], h = t[9], d = t[10], p = t[11], f = t[12], m = t[13], v = t[14], g = t[15], y = n * s - r * a, b = n * l - i * a, A = n * c - o * a, w = r * l - i * s, x = r * c - o * s, E = i * c - o * l, M = u * m - h * f, _ = u * v - d * f, T = u * g - p * f, S = h * v - d * m, C = h * g - p * m, L = d * g - p * v, R = y * L - b * C + A * S + w * T - x * _ + E * M return R ? ((R = 1 / R), (e[0] = (s * L - l * C + c * S) * R), (e[1] = (i * C - r * L - o * S) * R), (e[2] = (m * E - v * x + g * w) * R), (e[3] = (d * x - h * E - p * w) * R), (e[4] = (l * T - a * L - c * _) * R), (e[5] = (n * L - i * T + o * _) * R), (e[6] = (v * A - f * E - g * b) * R), (e[7] = (u * E - d * A + p * b) * R), (e[8] = (a * C - s * T + c * M) * R), (e[9] = (r * T - n * C - o * M) * R), (e[10] = (f * x - m * A + g * y) * R), (e[11] = (h * A - u * x - p * y) * R), (e[12] = (s * _ - a * S - l * M) * R), (e[13] = (n * S - r * _ + i * M) * R), (e[14] = (m * b - f * w - v * y) * R), (e[15] = (u * w - h * b + d * y) * R), e) : null } var a = new Float32Array([0, 0, 0, 1]), s = new Float32Array([0, 0, 0]) function l(e, t, l, c, u, h) { n(e, c || null, h.depthNear, h.depthFar), r(t, l.orientation || a, l.position || s), u && i(t, t, u), o(t, t) } return function (e, t, n) { return ( !(!e || !t) && ((e.pose = t), (e.timestamp = t.timestamp), l( e.leftProjectionMatrix, e.leftViewMatrix, t, n._getFieldOfView('left'), n._getEyeOffset('left'), n, ), l( e.rightProjectionMatrix, e.rightViewMatrix, t, n._getFieldOfView('right'), n._getEyeOffset('right'), n, ), !0) ) } })(), R = function () { var e = window.self !== window.top, t = P(document.referrer), n = P(window.location.href) return e && t !== n }, P = function (e) { var t, n = e.indexOf('://') t = -1 !== n ? n + 3 : 0 var r = e.indexOf('/', t) return -1 === r && (r = e.length), e.substring(0, r) }, D = function (e) { return e.w > 1 ? (console.warn('getQuaternionAngle: w > 1'), 0) : 2 * Math.acos(e.w) }, O = (function () { var e = {} return function (t, n) { void 0 === e[t] && (console.warn('webvr-polyfill: ' + n), (e[t] = !0)) } })(), I = function (e, t) { O( e, e + ' has been deprecated. This may not work on native WebVR displays. ' + (t ? 'Please use ' + t + ' instead.' : ''), ) } function B(e, t, n) { if (t) { for (var r = [], i = null, o = 0; o < t.length; ++o) switch ((a = t[o])) { case e.TEXTURE_BINDING_2D: case e.TEXTURE_BINDING_CUBE_MAP: if ((l = t[++o]) < e.TEXTURE0 || l > e.TEXTURE31) { console.error( 'TEXTURE_BINDING_2D or TEXTURE_BINDING_CUBE_MAP must be followed by a valid texture unit', ), r.push(null, null) break } i || (i = e.getParameter(e.ACTIVE_TEXTURE)), e.activeTexture(l), r.push(e.getParameter(a), null) break case e.ACTIVE_TEXTURE: ;(i = e.getParameter(e.ACTIVE_TEXTURE)), r.push(null) break default: r.push(e.getParameter(a)) } for (n(e), o = 0; o < t.length; ++o) { var a = t[o], s = r[o] switch (a) { case e.ACTIVE_TEXTURE: break case e.ARRAY_BUFFER_BINDING: e.bindBuffer(e.ARRAY_BUFFER, s) break case e.COLOR_CLEAR_VALUE: e.clearColor(s[0], s[1], s[2], s[3]) break case e.COLOR_WRITEMASK: e.colorMask(s[0], s[1], s[2], s[3]) break case e.CURRENT_PROGRAM: e.useProgram(s) break case e.ELEMENT_ARRAY_BUFFER_BINDING: e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, s) break case e.FRAMEBUFFER_BINDING: e.bindFramebuffer(e.FRAMEBUFFER, s) break case e.RENDERBUFFER_BINDING: e.bindRenderbuffer(e.RENDERBUFFER, s) break case e.TEXTURE_BINDING_2D: if ((l = t[++o]) < e.TEXTURE0 || l > e.TEXTURE31) break e.activeTexture(l), e.bindTexture(e.TEXTURE_2D, s) break case e.TEXTURE_BINDING_CUBE_MAP: var l if ((l = t[++o]) < e.TEXTURE0 || l > e.TEXTURE31) break e.activeTexture(l), e.bindTexture(e.TEXTURE_CUBE_MAP, s) break case e.VIEWPORT: e.viewport(s[0], s[1], s[2], s[3]) break case e.BLEND: case e.CULL_FACE: case e.DEPTH_TEST: case e.SCISSOR_TEST: case e.STENCIL_TEST: s ? e.enable(a) : e.disable(a) break default: console.log('No GL restore behavior for 0x' + a.toString(16)) } i && e.activeTexture(i) } } else n(e) } var F = B, k = [ 'attribute vec2 position;', 'attribute vec3 texCoord;', 'varying vec2 vTexCoord;', 'uniform vec4 viewportOffsetScale[2];', 'void main() {', ' vec4 viewport = viewportOffsetScale[int(texCoord.z)];', ' vTexCoord = (texCoord.xy * viewport.zw) + viewport.xy;', ' gl_Position = vec4( position, 1.0, 1.0 );', '}', ].join('\n'), N = [ 'precision mediump float;', 'uniform sampler2D diffuse;', 'varying vec2 vTexCoord;', 'void main() {', ' gl_FragColor = texture2D(diffuse, vTexCoord);', '}', ].join('\n') function U(e, t, n, r) { ;(this.gl = e), (this.cardboardUI = t), (this.bufferScale = n), (this.dirtySubmitFrameBindings = r), (this.ctxAttribs = e.getContextAttributes()), (this.instanceExt = e.getExtension('ANGLE_instanced_arrays')), (this.meshWidth = 20), (this.meshHeight = 20), (this.bufferWidth = e.drawingBufferWidth), (this.bufferHeight = e.drawingBufferHeight), (this.realBindFramebuffer = e.bindFramebuffer), (this.realEnable = e.enable), (this.realDisable = e.disable), (this.realColorMask = e.colorMask), (this.realClearColor = e.clearColor), (this.realViewport = e.viewport), l() || ((this.realCanvasWidth = Object.getOwnPropertyDescriptor( e.canvas.__proto__, 'width', )), (this.realCanvasHeight = Object.getOwnPropertyDescriptor( e.canvas.__proto__, 'height', ))), (this.isPatched = !1), (this.lastBoundFramebuffer = null), (this.cullFace = !1), (this.depthTest = !1), (this.blend = !1), (this.scissorTest = !1), (this.stencilTest = !1), (this.viewport = [0, 0, 0, 0]), (this.colorMask = [!0, !0, !0, !0]), (this.clearColor = [0, 0, 0, 0]), (this.attribs = { position: 0, texCoord: 1 }), (this.program = E(e, k, N, this.attribs)), (this.uniforms = M(e, this.program)), (this.viewportOffsetScale = new Float32Array(8)), this.setTextureBounds(), (this.vertexBuffer = e.createBuffer()), (this.indexBuffer = e.createBuffer()), (this.indexCount = 0), (this.renderTarget = e.createTexture()), (this.framebuffer = e.createFramebuffer()), (this.depthStencilBuffer = null), (this.depthBuffer = null), (this.stencilBuffer = null), this.ctxAttribs.depth && this.ctxAttribs.stencil ? (this.depthStencilBuffer = e.createRenderbuffer()) : this.ctxAttribs.depth ? (this.depthBuffer = e.createRenderbuffer()) : this.ctxAttribs.stencil && (this.stencilBuffer = e.createRenderbuffer()), this.patch(), this.onResize() } ;(U.prototype.destroy = function () { var e = this.gl this.unpatch(), e.deleteProgram(this.program), e.deleteBuffer(this.vertexBuffer), e.deleteBuffer(this.indexBuffer), e.deleteTexture(this.renderTarget), e.deleteFramebuffer(this.framebuffer), this.depthStencilBuffer && e.deleteRenderbuffer(this.depthStencilBuffer), this.depthBuffer && e.deleteRenderbuffer(this.depthBuffer), this.stencilBuffer && e.deleteRenderbuffer(this.stencilBuffer), this.cardboardUI && this.cardboardUI.destroy() }), (U.prototype.onResize = function () { var e = this.gl, t = this, n = [e.RENDERBUFFER_BINDING, e.TEXTURE_BINDING_2D, e.TEXTURE0] F(e, n, function (e) { t.realBindFramebuffer.call(e, e.FRAMEBUFFER, null), t.scissorTest && t.realDisable.call(e, e.SCISSOR_TEST), t.realColorMask.call(e, !0, !0, !0, !0), t.realViewport.call( e, 0, 0, e.drawingBufferWidth, e.drawingBufferHeight, ), t.realClearColor.call(e, 0, 0, 0, 1), e.clear(e.COLOR_BUFFER_BIT), t.realBindFramebuffer.call(e, e.FRAMEBUFFER, t.framebuffer), e.bindTexture(e.TEXTURE_2D, t.renderTarget), e.texImage2D( e.TEXTURE_2D, 0, t.ctxAttribs.alpha ? e.RGBA : e.RGB, t.bufferWidth, t.bufferHeight, 0, t.ctxAttribs.alpha ? e.RGBA : e.RGB, e.UNSIGNED_BYTE, null, ), e.texParameteri(e.TEXTURE_2D, e.TEXTURE_MAG_FILTER, e.LINEAR), e.texParameteri(e.TEXTURE_2D, e.TEXTURE_MIN_FILTER, e.LINEAR), e.texParameteri( e.TEXTURE_2D, e.TEXTURE_WRAP_S, e.CLAMP_TO_EDGE, ), e.texParameteri( e.TEXTURE_2D, e.TEXTURE_WRAP_T, e.CLAMP_TO_EDGE, ), e.framebufferTexture2D( e.FRAMEBUFFER, e.COLOR_ATTACHMENT0, e.TEXTURE_2D, t.renderTarget, 0, ), t.ctxAttribs.depth && t.ctxAttribs.stencil ? (e.bindRenderbuffer(e.RENDERBUFFER, t.depthStencilBuffer), e.renderbufferStorage( e.RENDERBUFFER, e.DEPTH_STENCIL, t.bufferWidth, t.bufferHeight, ), e.framebufferRenderbuffer( e.FRAMEBUFFER, e.DEPTH_STENCIL_ATTACHMENT, e.RENDERBUFFER, t.depthStencilBuffer, )) : t.ctxAttribs.depth ? (e.bindRenderbuffer(e.RENDERBUFFER, t.depthBuffer), e.renderbufferStorage( e.RENDERBUFFER, e.DEPTH_COMPONENT16, t.bufferWidth, t.bufferHeight, ), e.framebufferRenderbuffer( e.FRAMEBUFFER, e.DEPTH_ATTACHMENT, e.RENDERBUFFER, t.depthBuffer, )) : t.ctxAttribs.stencil && (e.bindRenderbuffer(e.RENDERBUFFER, t.stencilBuffer), e.renderbufferStorage( e.RENDERBUFFER, e.STENCIL_INDEX8, t.bufferWidth, t.bufferHeight, ), e.framebufferRenderbuffer( e.FRAMEBUFFER, e.STENCIL_ATTACHMENT, e.RENDERBUFFER, t.stencilBuffer, )), !e.checkFramebufferStatus(e.FRAMEBUFFER) === e.FRAMEBUFFER_COMPLETE && console.error('Framebuffer incomplete!'), t.realBindFramebuffer.call( e, e.FRAMEBUFFER, t.lastBoundFramebuffer, ), t.scissorTest && t.realEnable.call(e, e.SCISSOR_TEST), t.realColorMask.apply(e, t.colorMask), t.realViewport.apply(e, t.viewport), t.realClearColor.apply(e, t.clearColor) }), this.cardboardUI && this.cardboardUI.onResize() }), (U.prototype.patch = function () { if (!this.isPatched) { var e = this, t = this.gl.canvas, n = this.gl l() || ((t.width = y() * this.bufferScale), (t.height = b() * this.bufferScale), Object.defineProperty(t, 'width', { configurable: !0, enumerable: !0, get: function () { return e.bufferWidth }, set: function (n) { ;(e.bufferWidth = n), e.realCanvasWidth.set.call(t, n), e.onResize() }, }), Object.defineProperty(t, 'height', { configurable: !0, enumerable: !0, get: function () { return e.bufferHeight }, set: function (n) { ;(e.bufferHeight = n), e.realCanvasHeight.set.call(t, n), e.onResize() }, })), (this.lastBoundFramebuffer = n.getParameter( n.FRAMEBUFFER_BINDING, )), null == this.lastBoundFramebuffer && ((this.lastBoundFramebuffer = this.framebuffer), this.gl.bindFramebuffer(n.FRAMEBUFFER, this.framebuffer)), (this.gl.bindFramebuffer = function (t, r) { ;(e.lastBoundFramebuffer = r || e.framebuffer), e.realBindFramebuffer.call(n, t, e.lastBoundFramebuffer) }), (this.cullFace = n.getParameter(n.CULL_FACE)), (this.depthTest = n.getParameter(n.DEPTH_TEST)), (this.blend = n.getParameter(n.BLEND)), (this.scissorTest = n.getParameter(n.SCISSOR_TEST)), (this.stencilTest = n.getParameter(n.STENCIL_TEST)), (n.enable = function (t) { switch (t) { case n.CULL_FACE: e.cullFace = !0 break case n.DEPTH_TEST: e.depthTest = !0 break case n.BLEND: e.blend = !0 break case n.SCISSOR_TEST: e.scissorTest = !0 break case n.STENCIL_TEST: e.stencilTest = !0 } e.realEnable.call(n, t) }), (n.disable = function (t) { switch (t) { case n.CULL_FACE: e.cullFace = !1 break case n.DEPTH_TEST: e.depthTest = !1 break case n.BLEND: e.blend = !1 break case n.SCISSOR_TEST: e.scissorTest = !1 break case n.STENCIL_TEST: e.stencilTest = !1 } e.realDisable.call(n, t) }), (this.colorMask = n.getParameter(n.COLOR_WRITEMASK)), (n.colorMask = function (t, r, i, o) { ;(e.colorMask[0] = t), (e.colorMask[1] = r), (e.colorMask[2] = i), (e.colorMask[3] = o), e.realColorMask.call(n, t, r, i, o) }), (this.clearColor = n.getParameter(n.COLOR_CLEAR_VALUE)), (n.clearColor = function (t, r, i, o) { ;(e.clearColor[0] = t), (e.clearColor[1] = r), (e.clearColor[2] = i), (e.clearColor[3] = o), e.realClearColor.call(n, t, r, i, o) }), (this.viewport = n.getParameter(n.VIEWPORT)), (n.viewport = function (t, r, i, o) { ;(e.viewport[0] = t), (e.viewport[1] = r), (e.viewport[2] = i), (e.viewport[3] = o), e.realViewport.call(n, t, r, i, o) }), (this.isPatched = !0), C(t) } }), (U.prototype.unpatch = function () { if (this.isPatched) { var e = this.gl, t = this.gl.canvas l() || (Object.defineProperty(t, 'width', this.realCanvasWidth), Object.defineProperty(t, 'height', this.realCanvasHeight)), (t.width = this.bufferWidth), (t.height = this.bufferHeight), (e.bindFramebuffer = this.realBindFramebuffer), (e.enable = this.realEnable), (e.disable = this.realDisable), (e.colorMask = this.realColorMask), (e.clearColor = this.realClearColor), (e.viewport = this.realViewport), this.lastBoundFramebuffer == this.framebuffer && e.bindFramebuffer(e.FRAMEBUFFER, null), (this.isPatched = !1), setTimeout(function () { C(t) }, 1) } }), (U.prototype.setTextureBounds = function (e, t) { e || (e = [0, 0, 0.5, 1]), t || (t = [0.5, 0, 0.5, 1]), (this.viewportOffsetScale[0] = e[0]), (this.viewportOffsetScale[1] = e[1]), (this.viewportOffsetScale[2] = e[2]), (this.viewportOffsetScale[3] = e[3]), (this.viewportOffsetScale[4] = t[0]), (this.viewportOffsetScale[5] = t[1]), (this.viewportOffsetScale[6] = t[2]), (this.viewportOffsetScale[7] = t[3]) }), (U.prototype.submitFrame = function () { var e = this.gl, t = this, n = [] if ( (this.dirtySubmitFrameBindings || n.push( e.CURRENT_PROGRAM, e.ARRAY_BUFFER_BINDING, e.ELEMENT_ARRAY_BUFFER_BINDING, e.TEXTURE_BINDING_2D, e.TEXTURE0, ), F(e, n, function (e) { t.realBindFramebuffer.call(e, e.FRAMEBUFFER, null) var n = 0, r = 0 t.instanceExt && ((n = e.getVertexAttrib( t.attribs.position, t.instanceExt.VERTEX_ATTRIB_ARRAY_DIVISOR_ANGLE, )), (r = e.getVertexAttrib( t.attribs.texCoord, t.instanceExt.VERTEX_ATTRIB_ARRAY_DIVISOR_ANGLE, ))), t.cullFace && t.realDisable.call(e, e.CULL_FACE), t.depthTest && t.realDisable.call(e, e.DEPTH_TEST), t.blend && t.realDisable.call(e, e.BLEND), t.scissorTest && t.realDisable.call(e, e.SCISSOR_TEST), t.stencilTest && t.realDisable.call(e, e.STENCIL_TEST), t.realColorMask.call(e, !0, !0, !0, !0), t.realViewport.call( e, 0, 0, e.drawingBufferWidth, e.drawingBufferHeight, ), (t.ctxAttribs.alpha || l()) && (t.realClearColor.call(e, 0, 0, 0, 1), e.clear(e.COLOR_BUFFER_BIT)), e.useProgram(t.program), e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, t.indexBuffer), e.bindBuffer(e.ARRAY_BUFFER, t.vertexBuffer), e.enableVertexAttribArray(t.attribs.position), e.enableVertexAttribArray(t.attribs.texCoord), e.vertexAttribPointer( t.attribs.position, 2, e.FLOAT, !1, 20, 0, ), e.vertexAttribPointer( t.attribs.texCoord, 3, e.FLOAT, !1, 20, 8, ), t.instanceExt && (0 != n && t.instanceExt.vertexAttribDivisorANGLE( t.attribs.position, 0, ), 0 != r && t.instanceExt.vertexAttribDivisorANGLE( t.attribs.texCoord, 0, )), e.activeTexture(e.TEXTURE0), e.uniform1i(t.uniforms.diffuse, 0), e.bindTexture(e.TEXTURE_2D, t.renderTarget), e.uniform4fv( t.uniforms.viewportOffsetScale, t.viewportOffsetScale, ), e.drawElements( e.TRIANGLES, t.indexCount, e.UNSIGNED_SHORT, 0, ), t.cardboardUI && t.cardboardUI.renderNoState(), t.realBindFramebuffer.call( t.gl, e.FRAMEBUFFER, t.framebuffer, ), t.ctxAttribs.preserveDrawingBuffer || (t.realClearColor.call(e, 0, 0, 0, 0), e.clear(e.COLOR_BUFFER_BIT)), t.dirtySubmitFrameBindings || t.realBindFramebuffer.call( e, e.FRAMEBUFFER, t.lastBoundFramebuffer, ), t.cullFace && t.realEnable.call(e, e.CULL_FACE), t.depthTest && t.realEnable.call(e, e.DEPTH_TEST), t.blend && t.realEnable.call(e, e.BLEND), t.scissorTest && t.realEnable.call(e, e.SCISSOR_TEST), t.stencilTest && t.realEnable.call(e, e.STENCIL_TEST), t.realColorMask.apply(e, t.colorMask), t.realViewport.apply(e, t.viewport), (!t.ctxAttribs.alpha && t.ctxAttribs.preserveDrawingBuffer) || t.realClearColor.apply(e, t.clearColor), t.instanceExt && (0 != n && t.instanceExt.vertexAttribDivisorANGLE( t.attribs.position, n, ), 0 != r && t.instanceExt.vertexAttribDivisorANGLE( t.attribs.texCoord, r, )) }), l()) ) { var r = e.canvas ;(r.width == t.bufferWidth && r.height == t.bufferHeight) || ((t.bufferWidth = r.width), (t.bufferHeight = r.height), t.onResize()) } }), (U.prototype.updateDeviceInfo = function (e) { var t = this.gl, n = this, r = [t.ARRAY_BUFFER_BINDING, t.ELEMENT_ARRAY_BUFFER_BINDING] F(t, r, function (t) { var r = n.computeMeshVertices_(n.meshWidth, n.meshHeight, e) if ( (t.bindBuffer(t.ARRAY_BUFFER, n.vertexBuffer), t.bufferData(t.ARRAY_BUFFER, r, t.STATIC_DRAW), !n.indexCount) ) { var i = n.computeMeshIndices_(n.meshWidth, n.meshHeight) t.bindBuffer(t.ELEMENT_ARRAY_BUFFER, n.indexBuffer), t.bufferData(t.ELEMENT_ARRAY_BUFFER, i, t.STATIC_DRAW), (n.indexCount = i.length) } }) }), (U.prototype.computeMeshVertices_ = function (e, t, n) { for ( var r = new Float32Array(2 * e * t * 5), i = n.getLeftEyeVisibleTanAngles(), o = n.getLeftEyeNoLensTanAngles(), a = n.getLeftEyeVisibleScreenRect(o), l = 0, c = 0; c < 2; c++ ) { for (var u = 0; u < t; u++) for (var h = 0; h < e; h++, l++) { var d = h / (e - 1), p = u / (t - 1), f = d, m = p, v = s(i[0], i[2], d), g = s(i[3], i[1], p), y = Math.sqrt(v * v + g * g), b = n.distortion.distortInverse(y), A = (g * b) / y ;(d = ((v * b) / y - o[0]) / (o[2] - o[0])), (p = (A - o[3]) / (o[1] - o[3])), (d = 2 * (a.x + d * a.width - 0.5)), (p = 2 * (a.y + p * a.height - 0.5)), (r[5 * l + 0] = d), (r[5 * l + 1] = p), (r[5 * l + 2] = f), (r[5 * l + 3] = m), (r[5 * l + 4] = c) } var w = i[2] - i[0] ;(i[0] = -(w + i[0])), (i[2] = w - i[2]), (w = o[2] - o[0]), (o[0] = -(w + o[0])), (o[2] = w - o[2]), (a.x = 1 - (a.x + a.width)) } return r }), (U.prototype.computeMeshIndices_ = function (e, t) { for ( var n = new Uint16Array(2 * (e - 1) * (t - 1) * 6), r = e / 2, i = t / 2, o = 0, a = 0, s = 0; s < 2; s++ ) for (var l = 0; l < t; l++) for (var c = 0; c < e; c++, o++) 0 != c && 0 != l && (c <= r == l <= i ? ((n[a++] = o), (n[a++] = o - e - 1), (n[a++] = o - e), (n[a++] = o - e - 1), (n[a++] = o), (n[a++] = o - 1)) : ((n[a++] = o - 1), (n[a++] = o - e), (n[a++] = o), (n[a++] = o - e), (n[a++] = o - 1), (n[a++] = o - e - 1))) return n }), (U.prototype.getOwnPropertyDescriptor_ = function (e, t) { var n = Object.getOwnPropertyDescriptor(e, t) return ( (void 0 !== n.get && void 0 !== n.set) || ((n.configurable = !0), (n.enumerable = !0), (n.get = function () { return this.getAttribute(t) }), (n.set = function (e) { this.setAttribute(t, e) })), n ) }) var H = [ 'attribute vec2 position;', 'uniform mat4 projectionMat;', 'void main() {', ' gl_Position = projectionMat * vec4( position, -1.0, 1.0 );', '}', ].join('\n'), G = [ 'precision mediump float;', 'uniform vec4 color;', 'void main() {', ' gl_FragColor = color;', '}', ].join('\n'), z = Math.PI / 180, j = 60, V = 12, W = 20, q = 1, X = 0.75, Y = 0.3125, Q = 4, Z = 28, K = 1.5 function J(e) { ;(this.gl = e), (this.attribs = { position: 0 }), (this.program = E(e, H, G, this.attribs)), (this.uniforms = M(e, this.program)), (this.vertexBuffer = e.createBuffer()), (this.gearOffset = 0), (this.gearVertexCount = 0), (this.arrowOffset = 0), (this.arrowVertexCount = 0), (this.projMat = new Float32Array(16)), (this.listener = null), this.onResize() } function $(e) { this.coefficients = e } ;(J.prototype.destroy = function () { var e = this.gl this.listener && e.canvas.removeEventListener('click', this.listener, !1), e.deleteProgram(this.program), e.deleteBuffer(this.vertexBuffer) }), (J.prototype.listen = function (e, t) { var n = this.gl.canvas ;(this.listener = function (r) { var i = n.clientWidth / 2, o = Z * K r.clientX > i - o && r.clientX < i + o && r.clientY > n.clientHeight - o ? e(r) : r.clientX < o && r.clientY < o && t(r) }), n.addEventListener('click', this.listener, !1) }), (J.prototype.onResize = function () { var e = this.gl, t = this, n = [e.ARRAY_BUFFER_BINDING] F(e, n, function (e) { var n = [], r = e.drawingBufferWidth / 2, i = Math.max(screen.width, screen.height) * window.devicePixelRatio, o = (e.drawingBufferWidth / i) * window.devicePixelRatio, a = (Q * o) / 2, s = Z * K * o, l = (Z * o) / 2, c = (Z * K - Z) * o function u(e, t) { var i = (90 - e) * z, o = Math.cos(i), a = Math.sin(i) n.push(Y * o * l + r, Y * a * l + l), n.push(t * o * l + r, t * a * l + l) } n.push(r - a, s), n.push(r - a, e.drawingBufferHeight), n.push(r + a, s), n.push(r + a, e.drawingBufferHeight), (t.gearOffset = n.length / 2) for (var h = 0; h <= 6; h++) { var d = h * j u(d, q), u(d + V, q), u(d + W, X), u(d + (j - W), X), u(d + (j - V), q) } function p(t, r) { n.push(c + t, e.drawingBufferHeight - c - r) } ;(t.gearVertexCount = n.length / 2 - t.gearOffset), (t.arrowOffset = n.length / 2) var f = a / Math.sin(45 * z) p(0, l), p(l, 0), p(l + f, f), p(f, l + f), p(f, l - f), p(0, l), p(l, 2 * l), p(l + f, 2 * l - f), p(f, l - f), p(0, l), p(f, l - a), p(Z * o, l - a), p(f, l + a), p(Z * o, l + a), (t.arrowVertexCount = n.length / 2 - t.arrowOffset), e.bindBuffer(e.ARRAY_BUFFER, t.vertexBuffer), e.bufferData(e.ARRAY_BUFFER, new Float32Array(n), e.STATIC_DRAW) }) }), (J.prototype.render = function () { var e = this.gl, t = this, n = [ e.CULL_FACE, e.DEPTH_TEST, e.BLEND, e.SCISSOR_TEST, e.STENCIL_TEST, e.COLOR_WRITEMASK, e.VIEWPORT, e.CURRENT_PROGRAM, e.ARRAY_BUFFER_BINDING, ] F(e, n, function (e) { e.disable(e.CULL_FACE), e.disable(e.DEPTH_TEST), e.disable(e.BLEND), e.disable(e.SCISSOR_TEST), e.disable(e.STENCIL_TEST), e.colorMask(!0, !0, !0, !0), e.viewport(0, 0, e.drawingBufferWidth, e.drawingBufferHeight), t.renderNoState() }) }), (J.prototype.renderNoState = function () { var e = this.gl e.useProgram(this.program), e.bindBuffer(e.ARRAY_BUFFER, this.vertexBuffer), e.enableVertexAttribArray(this.attribs.position), e.vertexAttribPointer( this.attribs.position, 2, e.FLOAT, !1, 8, 0, ), e.uniform4f(this.uniforms.color, 1, 1, 1, 1), _( this.projMat, 0, e.drawingBufferWidth, 0, e.drawingBufferHeight, 0.1, 1024, ), e.uniformMatrix4fv(this.uniforms.projectionMat, !1, this.projMat), e.drawArrays(e.TRIANGLE_STRIP, 0, 4), e.drawArrays( e.TRIANGLE_STRIP, this.gearOffset, this.gearVertexCount, ), e.drawArrays( e.TRIANGLE_STRIP, this.arrowOffset, this.arrowVertexCount, ) }), ($.prototype.distortInverse = function (e) { for ( var t = 0, n = 1, r = e - this.distort(t); Math.abs(n - t) > 1e-4; ) { var i = e - this.distort(n), o = n - i * ((n - t) / (i - r)) ;(t = n), (n = o), (r = i) } return n }), ($.prototype.distort = function (e) { for (var t = e * e, n = 0, r = 0; r < this.coefficients.length; r++) n = t * (n + this.coefficients[r]) return (n + 1) * e }) var ee = Math.PI / 180, te = 180 / Math.PI, ne = function (e, t, n) { ;(this.x = e || 0), (this.y = t || 0), (this.z = n || 0) } ne.prototype = { constructor: ne, set: function (e, t, n) { return (this.x = e), (this.y = t), (this.z = n), this }, copy: function (e) { return (this.x = e.x), (this.y = e.y), (this.z = e.z), this }, length: function () { return Math.sqrt( this.x * this.x + this.y * this.y + this.z * this.z, ) }, normalize: function () { var e = this.length() if (0 !== e) { var t = 1 / e this.multiplyScalar(t) } else (this.x = 0), (this.y = 0), (this.z = 0) return this }, multiplyScalar: function (e) { ;(this.x *= e), (this.y *= e), (this.z *= e) }, applyQuaternion: function (e) { var t = this.x, n = this.y, r = this.z, i = e.x, o = e.y, a = e.z, s = e.w, l = s * t + o * r - a * n, c = s * n + a * t - i * r, u = s * r + i * n - o * t, h = -i * t - o * n - a * r return ( (this.x = l * s + h * -i + c * -a - u * -o), (this.y = c * s + h * -o + u * -i - l * -a), (this.z = u * s + h * -a + l * -o - c * -i), this ) }, dot: function (e) { return this.x * e.x + this.y * e.y + this.z * e.z }, crossVectors: function (e, t) { var n = e.x, r = e.y, i = e.z, o = t.x, a = t.y, s = t.z return ( (this.x = r * s - i * a), (this.y = i * o - n * s), (this.z = n * a - r * o), this ) }, } var re = function (e, t, n, r) { ;(this.x = e || 0), (this.y = t || 0), (this.z = n || 0), (this.w = void 0 !== r ? r : 1) } function ie(e) { ;(this.width = e.width || y()), (this.height = e.height || b()), (this.widthMeters = e.widthMeters), (this.heightMeters = e.heightMeters), (this.bevelMeters = e.bevelMeters) } re.prototype = { constructor: re, set: function (e, t, n, r) { return (this.x = e), (this.y = t), (this.z = n), (this.w = r), this }, copy: function (e) { return ( (this.x = e.x), (this.y = e.y), (this.z = e.z), (this.w = e.w), this ) }, setFromEulerXYZ: function (e, t, n) { var r = Math.cos(e / 2), i = Math.cos(t / 2), o = Math.cos(n / 2), a = Math.sin(e / 2), s = Math.sin(t / 2), l = Math.sin(n / 2) return ( (this.x = a * i * o + r * s * l), (this.y = r * s * o - a * i * l), (this.z = r * i * l + a * s * o), (this.w = r * i * o - a * s * l), this ) }, setFromEulerYXZ: function (e, t, n) { var r = Math.cos(e / 2), i = Math.cos(t / 2), o = Math.cos(n / 2), a = Math.sin(e / 2), s = Math.sin(t / 2), l = Math.sin(n / 2) return ( (this.x = a * i * o + r * s * l), (this.y = r * s * o - a * i * l), (this.z = r * i * l - a * s * o), (this.w = r * i * o + a * s * l), this ) }, setFromAxisAngle: function (e, t) { var n = t / 2, r = Math.sin(n) return ( (this.x = e.x * r), (this.y = e.y * r), (this.z = e.z * r), (this.w = Math.cos(n)), this ) }, multiply: function (e) { return this.multiplyQuaternions(this, e) }, multiplyQuaternions: function (e, t) { var n = e.x, r = e.y, i = e.z, o = e.w, a = t.x, s = t.y, l = t.z, c = t.w return ( (this.x = n * c + o * a + r * l - i * s), (this.y = r * c + o * s + i * a - n * l), (this.z = i * c + o * l + n * s - r * a), (this.w = o * c - n * a - r * s - i * l), this ) }, inverse: function () { return ( (this.x *= -1), (this.y *= -1), (this.z *= -1), this.normalize(), this ) }, normalize: function () { var e = Math.sqrt( this.x * this.x + this.y * this.y + this.z * this.z + this.w * this.w, ) return ( 0 === e ? ((this.x = 0), (this.y = 0), (this.z = 0), (this.w = 1)) : ((e = 1 / e), (this.x = this.x * e), (this.y = this.y * e), (this.z = this.z * e), (this.w = this.w * e)), this ) }, slerp: function (e, t) { if (0 === t) return this if (1 === t) return this.copy(e) var n = this.x, r = this.y, i = this.z, o = this.w, a = o * e.w + n * e.x + r * e.y + i * e.z if ( (a < 0 ? ((this.w = -e.w), (this.x = -e.x), (this.y = -e.y), (this.z = -e.z), (a = -a)) : this.copy(e), a >= 1) ) return ( (this.w = o), (this.x = n), (this.y = r), (this.z = i), this ) var s = Math.acos(a), l = Math.sqrt(1 - a * a) if (Math.abs(l) < 0.001) return ( (this.w = 0.5 * (o + this.w)), (this.x = 0.5 * (n + this.x)), (this.y = 0.5 * (r + this.y)), (this.z = 0.5 * (i + this.z)), this ) var c = Math.sin((1 - t) * s) / l, u = Math.sin(t * s) / l return ( (this.w = o * c + this.w * u), (this.x = n * c + this.x * u), (this.y = r * c + this.y * u), (this.z = i * c + this.z * u), this ) }, setFromUnitVectors: (function () { var e, t, n = 1e-6 return function (r, i) { return ( void 0 === e && (e = new ne()), (t = r.dot(i) + 1) < n ? ((t = 0), Math.abs(r.x) > Math.abs(r.z) ? e.set(-r.y, r.x, 0) : e.set(0, -r.z, r.y)) : e.crossVectors(r, i), (this.x = e.x), (this.y = e.y), (this.z = e.z), (this.w = t), this.normalize(), this ) } })(), } var oe = new ie({ widthMeters: 0.11, heightMeters: 0.062, bevelMeters: 0.004, }), ae = new ie({ widthMeters: 0.1038, heightMeters: 0.0584, bevelMeters: 0.004, }), se = { CardboardV1: new ce({ id: 'CardboardV1', label: 'Cardboard I/O 2014', fov: 40, interLensDistance: 0.06, baselineLensDistance: 0.035, screenLensDistance: 0.042, distortionCoefficients: [0.441, 0.156], inverseCoefficients: [ -0.4410035, 0.42756155, -0.4804439, 0.5460139, -0.58821183, 0.5733938, -0.48303202, 0.33299083, -0.17573841, 0.0651772, -0.01488963, 0.001559834, ], }), CardboardV2: new ce({ id: 'CardboardV2', label: 'Cardboard I/O 2015', fov: 60, interLensDistance: 0.064, baselineLensDistance: 0.035, screenLensDistance: 0.039, distortionCoefficients: [0.34, 0.55], inverseCoefficients: [ -0.33836704, -0.18162185, 0.862655, -1.2462051, 1.0560602, -0.58208317, 0.21609078, -0.05444823, 0.009177956, -0.0009904169, 6183535e-11, -16981803e-13, ], }), } function le(e, t) { ;(this.viewer = se.CardboardV2), this.updateDeviceParams(e), (this.distortion = new $(this.viewer.distortionCoefficients)) for (var n = 0; n < t.length; n++) { var r = t[n] se[r.id] = new ce(r) } } function ce(e) { ;(this.id = e.id), (this.label = e.label), (this.fov = e.fov), (this.interLensDistance = e.interLensDistance), (this.baselineLensDistance = e.baselineLensDistance), (this.screenLensDistance = e.screenLensDistance), (this.distortionCoefficients = e.distortionCoefficients), (this.inverseCoefficients = e.inverseCoefficients) } ;(le.prototype.updateDeviceParams = function (e) { this.device = this.determineDevice_(e) || this.device }), (le.prototype.getDevice = function () { return this.device }), (le.prototype.setViewer = function (e) { ;(this.viewer = e), (this.distortion = new $(this.viewer.distortionCoefficients)) }), (le.prototype.determineDevice_ = function (e) { if (!e) return l() ? (console.warn('Using fallback iOS device measurements.'), ae) : (console.warn('Using fallback Android device measurements.'), oe) var t = 0.0254, n = t / e.xdpi, r = t / e.ydpi return new ie({ widthMeters: n * y(), heightMeters: r * b(), bevelMeters: 0.001 * e.bevelMm, }) }), (le.prototype.getDistortedFieldOfViewLeftEye = function () { var e = this.viewer, t = this.device, n = this.distortion, r = e.screenLensDistance, i = (t.widthMeters - e.interLensDistance) / 2, o = e.interLensDistance / 2, a = e.baselineLensDistance - t.bevelMeters, s = t.heightMeters - a, l = te * Math.atan(n.distort(i / r)), c = te * Math.atan(n.distort(o / r)), u = te * Math.atan(n.distort(a / r)), h = te * Math.atan(n.distort(s / r)) return { leftDegrees: Math.min(l, e.fov), rightDegrees: Math.min(c, e.fov), downDegrees: Math.min(u, e.fov), upDegrees: Math.min(h, e.fov), } }), (le.prototype.getLeftEyeVisibleTanAngles = function () { var e = this.viewer, t = this.device, n = this.distortion, r = Math.tan(-ee * e.fov), i = Math.tan(ee * e.fov), o = Math.tan(ee * e.fov), a = Math.tan(-ee * e.fov), s = t.widthMeters / 4, l = t.heightMeters / 2, c = e.baselineLensDistance - t.bevelMeters - l, u = e.interLensDistance / 2 - s, h = -c, d = e.screenLensDistance, p = n.distort((u - s) / d), f = n.distort((h + l) / d), m = n.distort((u + s) / d), v = n.distort((h - l) / d), g = new Float32Array(4) return ( (g[0] = Math.max(r, p)), (g[1] = Math.min(i, f)), (g[2] = Math.min(o, m)), (g[3] = Math.max(a, v)), g ) }), (le.prototype.getLeftEyeNoLensTanAngles = function () { var e = this.viewer, t = this.device, n = this.distortion, r = new Float32Array(4), i = n.distortInverse(Math.tan(-ee * e.fov)), o = n.distortInverse(Math.tan(ee * e.fov)), a = n.distortInverse(Math.tan(ee * e.fov)), s = n.distortInverse(Math.tan(-ee * e.fov)), l = t.widthMeters / 4, c = t.heightMeters / 2, u = e.baselineLensDistance - t.bevelMeters - c, h = e.interLensDistance / 2 - l, d = -u, p = e.screenLensDistance, f = (h - l) / p, m = (d + c) / p, v = (h + l) / p, g = (d - c) / p return ( (r[0] = Math.max(i, f)), (r[1] = Math.min(o, m)), (r[2] = Math.min(a, v)), (r[3] = Math.max(s, g)), r ) }), (le.prototype.getLeftEyeVisibleScreenRect = function (e) { var t = this.viewer, n = this.device, r = t.screenLensDistance, i = (n.widthMeters - t.interLensDistance) / 2, o = t.baselineLensDistance - n.bevelMeters, a = (e[0] * r + i) / n.widthMeters, s = (e[1] * r + o) / n.heightMeters, l = (e[2] * r + i) / n.widthMeters, c = (e[3] * r + o) / n.heightMeters return { x: a, y: c, width: l - a, height: s - c } }), (le.prototype.getFieldOfViewLeftEye = function (e) { return e ? this.getUndistortedFieldOfViewLeftEye() : this.getDistortedFieldOfViewLeftEye() }), (le.prototype.getFieldOfViewRightEye = function (e) { var t = this.getFieldOfViewLeftEye(e) return { leftDegrees: t.rightDegrees, rightDegrees: t.leftDegrees, upDegrees: t.upDegrees, downDegrees: t.downDegrees, } }), (le.prototype.getUndistortedFieldOfViewLeftEye = function () { var e = this.getUndistortedParams_() return { leftDegrees: te * Math.atan(e.outerDist), rightDegrees: te * Math.atan(e.innerDist), downDegrees: te * Math.atan(e.bottomDist), upDegrees: te * Math.atan(e.topDist), } }), (le.prototype.getUndistortedViewportLeftEye = function () { var e = this.getUndistortedParams_(), t = this.viewer, n = this.device, r = t.screenLensDistance, i = n.widthMeters / r, o = n.heightMeters / r, a = n.width / i, s = n.height / o, l = Math.round((e.eyePosX - e.outerDist) * a), c = Math.round((e.eyePosY - e.bottomDist) * s) return { x: l, y: c, width: Math.round((e.eyePosX + e.innerDist) * a) - l, height: Math.round((e.eyePosY + e.topDist) * s) - c, } }), (le.prototype.getUndistortedParams_ = function () { var e = this.viewer, t = this.device, n = this.distortion, r = e.screenLensDistance, i = e.interLensDistance / 2 / r, o = t.widthMeters / r, a = t.heightMeters / r, s = o / 2 - i, l = (e.baselineLensDistance - t.bevelMeters) / r, c = e.fov, u = n.distortInverse(Math.tan(ee * c)), h = Math.min(s, u), d = Math.min(i, u), p = Math.min(l, u) return { outerDist: h, innerDist: d, topDist: Math.min(a - l, u), bottomDist: p, eyePosX: s, eyePosY: l, } }), (le.Viewers = se) var ue = { format: 1, last_updated: '2019-11-09T17:36:14Z', devices: [ { type: 'android', rules: [{ mdmh: 'asus/*/Nexus 7/*' }, { ua: 'Nexus 7' }], dpi: [320.8, 323], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'asus/*/ASUS_X00PD/*' }, { ua: 'ASUS_X00PD' }], dpi: 245, bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'asus/*/ASUS_X008D/*' }, { ua: 'ASUS_X008D' }], dpi: 282, bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'asus/*/ASUS_Z00AD/*' }, { ua: 'ASUS_Z00AD' }], dpi: [403, 404.6], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Google/*/Pixel 2 XL/*' }, { ua: 'Pixel 2 XL' }], dpi: 537.9, bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Google/*/Pixel 3 XL/*' }, { ua: 'Pixel 3 XL' }], dpi: [558.5, 553.8], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Google/*/Pixel XL/*' }, { ua: 'Pixel XL' }], dpi: [537.9, 533], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Google/*/Pixel 3/*' }, { ua: 'Pixel 3' }], dpi: 442.4, bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Google/*/Pixel 2/*' }, { ua: 'Pixel 2' }], dpi: 441, bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'Google/*/Pixel/*' }, { ua: 'Pixel' }], dpi: [432.6, 436.7], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'HTC/*/HTC6435LVW/*' }, { ua: 'HTC6435LVW' }], dpi: [449.7, 443.3], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'HTC/*/HTC One XL/*' }, { ua: 'HTC One XL' }], dpi: [315.3, 314.6], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'htc/*/Nexus 9/*' }, { ua: 'Nexus 9' }], dpi: 289, bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'HTC/*/HTC One M9/*' }, { ua: 'HTC One M9' }], dpi: [442.5, 443.3], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'HTC/*/HTC One_M8/*' }, { ua: 'HTC One_M8' }], dpi: [449.7, 447.4], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'HTC/*/HTC One/*' }, { ua: 'HTC One' }], dpi: 472.8, bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Huawei/*/Nexus 6P/*' }, { ua: 'Nexus 6P' }], dpi: [515.1, 518], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Huawei/*/BLN-L24/*' }, { ua: 'HONORBLN-L24' }], dpi: 480, bw: 4, ac: 500, }, { type: 'android', rules: [{ mdmh: 'Huawei/*/BKL-L09/*' }, { ua: 'BKL-L09' }], dpi: 403, bw: 3.47, ac: 500, }, { type: 'android', rules: [ { mdmh: 'LENOVO/*/Lenovo PB2-690Y/*' }, { ua: 'Lenovo PB2-690Y' }, ], dpi: [457.2, 454.713], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'LGE/*/Nexus 5X/*' }, { ua: 'Nexus 5X' }], dpi: [422, 419.9], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'LGE/*/LGMS345/*' }, { ua: 'LGMS345' }], dpi: [221.7, 219.1], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'LGE/*/LG-D800/*' }, { ua: 'LG-D800' }], dpi: [422, 424.1], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'LGE/*/LG-D850/*' }, { ua: 'LG-D850' }], dpi: [537.9, 541.9], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'LGE/*/VS985 4G/*' }, { ua: 'VS985 4G' }], dpi: [537.9, 535.6], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'LGE/*/Nexus 5/*' }, { ua: 'Nexus 5 B' }], dpi: [442.4, 444.8], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'LGE/*/Nexus 4/*' }, { ua: 'Nexus 4' }], dpi: [319.8, 318.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'LGE/*/LG-P769/*' }, { ua: 'LG-P769' }], dpi: [240.6, 247.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'LGE/*/LGMS323/*' }, { ua: 'LGMS323' }], dpi: [206.6, 204.6], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'LGE/*/LGLS996/*' }, { ua: 'LGLS996' }], dpi: [403.4, 401.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Micromax/*/4560MMX/*' }, { ua: '4560MMX' }], dpi: [240, 219.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Micromax/*/A250/*' }, { ua: 'Micromax A250' }], dpi: [480, 446.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [ { mdmh: 'Micromax/*/Micromax AQ4501/*' }, { ua: 'Micromax AQ4501' }, ], dpi: 240, bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'motorola/*/G5/*' }, { ua: 'Moto G (5) Plus' }], dpi: [403.4, 403], bw: 3, ac: 1e3, }, { type: 'android', rules: [ { mdmh: 'motorola/*/DROID RAZR/*' }, { ua: 'DROID RAZR' }, ], dpi: [368.1, 256.7], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT830C/*' }, { ua: 'XT830C' }], dpi: [254, 255.9], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT1021/*' }, { ua: 'XT1021' }], dpi: [254, 256.7], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT1023/*' }, { ua: 'XT1023' }], dpi: [254, 256.7], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT1028/*' }, { ua: 'XT1028' }], dpi: [326.6, 327.6], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT1034/*' }, { ua: 'XT1034' }], dpi: [326.6, 328.4], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT1053/*' }, { ua: 'XT1053' }], dpi: [315.3, 316.1], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT1562/*' }, { ua: 'XT1562' }], dpi: [403.4, 402.7], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'motorola/*/Nexus 6/*' }, { ua: 'Nexus 6 B' }], dpi: [494.3, 489.7], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT1063/*' }, { ua: 'XT1063' }], dpi: [295, 296.6], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT1064/*' }, { ua: 'XT1064' }], dpi: [295, 295.6], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT1092/*' }, { ua: 'XT1092' }], dpi: [422, 424.1], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'motorola/*/XT1095/*' }, { ua: 'XT1095' }], dpi: [422, 423.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'motorola/*/G4/*' }, { ua: 'Moto G (4)' }], dpi: 401, bw: 4, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'OnePlus/*/A0001/*' }, { ua: 'A0001' }], dpi: [403.4, 401], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'OnePlus/*/ONE E1001/*' }, { ua: 'ONE E1001' }], dpi: [442.4, 441.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'OnePlus/*/ONE E1003/*' }, { ua: 'ONE E1003' }], dpi: [442.4, 441.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'OnePlus/*/ONE E1005/*' }, { ua: 'ONE E1005' }], dpi: [442.4, 441.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'OnePlus/*/ONE A2001/*' }, { ua: 'ONE A2001' }], dpi: [391.9, 405.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'OnePlus/*/ONE A2003/*' }, { ua: 'ONE A2003' }], dpi: [391.9, 405.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'OnePlus/*/ONE A2005/*' }, { ua: 'ONE A2005' }], dpi: [391.9, 405.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [ { mdmh: 'OnePlus/*/ONEPLUS A3000/*' }, { ua: 'ONEPLUS A3000' }, ], dpi: 401, bw: 3, ac: 500, }, { type: 'android', rules: [ { mdmh: 'OnePlus/*/ONEPLUS A3003/*' }, { ua: 'ONEPLUS A3003' }, ], dpi: 401, bw: 3, ac: 500, }, { type: 'android', rules: [ { mdmh: 'OnePlus/*/ONEPLUS A3010/*' }, { ua: 'ONEPLUS A3010' }, ], dpi: 401, bw: 3, ac: 500, }, { type: 'android', rules: [ { mdmh: 'OnePlus/*/ONEPLUS A5000/*' }, { ua: 'ONEPLUS A5000 ' }, ], dpi: [403.411, 399.737], bw: 3, ac: 1e3, }, { type: 'android', rules: [ { mdmh: 'OnePlus/*/ONE A5010/*' }, { ua: 'ONEPLUS A5010' }, ], dpi: [403, 400], bw: 2, ac: 1e3, }, { type: 'android', rules: [ { mdmh: 'OnePlus/*/ONEPLUS A6000/*' }, { ua: 'ONEPLUS A6000' }, ], dpi: 401, bw: 3, ac: 500, }, { type: 'android', rules: [ { mdmh: 'OnePlus/*/ONEPLUS A6003/*' }, { ua: 'ONEPLUS A6003' }, ], dpi: 401, bw: 3, ac: 500, }, { type: 'android', rules: [ { mdmh: 'OnePlus/*/ONEPLUS A6010/*' }, { ua: 'ONEPLUS A6010' }, ], dpi: 401, bw: 2, ac: 500, }, { type: 'android', rules: [ { mdmh: 'OnePlus/*/ONEPLUS A6013/*' }, { ua: 'ONEPLUS A6013' }, ], dpi: 401, bw: 2, ac: 500, }, { type: 'android', rules: [{ mdmh: 'OPPO/*/X909/*' }, { ua: 'X909' }], dpi: [442.4, 444.1], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/GT-I9082/*' }, { ua: 'GT-I9082' }], dpi: [184.7, 185.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G360P/*' }, { ua: 'SM-G360P' }], dpi: [196.7, 205.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/Nexus S/*' }, { ua: 'Nexus S' }], dpi: [234.5, 229.8], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/GT-I9300/*' }, { ua: 'GT-I9300' }], dpi: [304.8, 303.9], bw: 5, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-T230NU/*' }, { ua: 'SM-T230NU' }], dpi: 216, bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SGH-T399/*' }, { ua: 'SGH-T399' }], dpi: [217.7, 231.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SGH-M919/*' }, { ua: 'SGH-M919' }], dpi: [440.8, 437.7], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-N9005/*' }, { ua: 'SM-N9005' }], dpi: [386.4, 387], bw: 3, ac: 500, }, { type: 'android', rules: [ { mdmh: 'samsung/*/SAMSUNG-SM-N900A/*' }, { ua: 'SAMSUNG-SM-N900A' }, ], dpi: [386.4, 387.7], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/GT-I9500/*' }, { ua: 'GT-I9500' }], dpi: [442.5, 443.3], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/GT-I9505/*' }, { ua: 'GT-I9505' }], dpi: 439.4, bw: 4, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G900F/*' }, { ua: 'SM-G900F' }], dpi: [415.6, 431.6], bw: 5, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G900M/*' }, { ua: 'SM-G900M' }], dpi: [415.6, 431.6], bw: 5, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G800F/*' }, { ua: 'SM-G800F' }], dpi: 326.8, bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G906S/*' }, { ua: 'SM-G906S' }], dpi: [562.7, 572.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/GT-I9300/*' }, { ua: 'GT-I9300' }], dpi: [306.7, 304.8], bw: 5, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-T535/*' }, { ua: 'SM-T535' }], dpi: [142.6, 136.4], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-N920C/*' }, { ua: 'SM-N920C' }], dpi: [515.1, 518.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-N920P/*' }, { ua: 'SM-N920P' }], dpi: [386.3655, 390.144], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-N920W8/*' }, { ua: 'SM-N920W8' }], dpi: [515.1, 518.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/GT-I9300I/*' }, { ua: 'GT-I9300I' }], dpi: [304.8, 305.8], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/GT-I9195/*' }, { ua: 'GT-I9195' }], dpi: [249.4, 256.7], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SPH-L520/*' }, { ua: 'SPH-L520' }], dpi: [249.4, 255.9], bw: 3, ac: 1e3, }, { type: 'android', rules: [ { mdmh: 'samsung/*/SAMSUNG-SGH-I717/*' }, { ua: 'SAMSUNG-SGH-I717' }, ], dpi: 285.8, bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SPH-D710/*' }, { ua: 'SPH-D710' }], dpi: [217.7, 204.2], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/GT-N7100/*' }, { ua: 'GT-N7100' }], dpi: 265.1, bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SCH-I605/*' }, { ua: 'SCH-I605' }], dpi: 265.1, bw: 3, ac: 1e3, }, { type: 'android', rules: [ { mdmh: 'samsung/*/Galaxy Nexus/*' }, { ua: 'Galaxy Nexus' }, ], dpi: [315.3, 314.2], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-N910H/*' }, { ua: 'SM-N910H' }], dpi: [515.1, 518], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-N910C/*' }, { ua: 'SM-N910C' }], dpi: [515.2, 520.2], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G130M/*' }, { ua: 'SM-G130M' }], dpi: [165.9, 164.8], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G928I/*' }, { ua: 'SM-G928I' }], dpi: [515.1, 518.4], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G920F/*' }, { ua: 'SM-G920F' }], dpi: 580.6, bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G920P/*' }, { ua: 'SM-G920P' }], dpi: [522.5, 577], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G925F/*' }, { ua: 'SM-G925F' }], dpi: 580.6, bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G925V/*' }, { ua: 'SM-G925V' }], dpi: [522.5, 576.6], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G930F/*' }, { ua: 'SM-G930F' }], dpi: 576.6, bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G935F/*' }, { ua: 'SM-G935F' }], dpi: 533, bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G950F/*' }, { ua: 'SM-G950F' }], dpi: [562.707, 565.293], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G955U/*' }, { ua: 'SM-G955U' }], dpi: [522.514, 525.762], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G955F/*' }, { ua: 'SM-G955F' }], dpi: [522.514, 525.762], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G960F/*' }, { ua: 'SM-G960F' }], dpi: [569.575, 571.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G9600/*' }, { ua: 'SM-G9600' }], dpi: [569.575, 571.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G960T/*' }, { ua: 'SM-G960T' }], dpi: [569.575, 571.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G960N/*' }, { ua: 'SM-G960N' }], dpi: [569.575, 571.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G960U/*' }, { ua: 'SM-G960U' }], dpi: [569.575, 571.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G9608/*' }, { ua: 'SM-G9608' }], dpi: [569.575, 571.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G960FD/*' }, { ua: 'SM-G960FD' }], dpi: [569.575, 571.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G960W/*' }, { ua: 'SM-G960W' }], dpi: [569.575, 571.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G965F/*' }, { ua: 'SM-G965F' }], dpi: 529, bw: 2, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Sony/*/C6903/*' }, { ua: 'C6903' }], dpi: [442.5, 443.3], bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'Sony/*/D6653/*' }, { ua: 'D6653' }], dpi: [428.6, 427.6], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Sony/*/E6653/*' }, { ua: 'E6653' }], dpi: [428.6, 425.7], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Sony/*/E6853/*' }, { ua: 'E6853' }], dpi: [403.4, 401.9], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Sony/*/SGP321/*' }, { ua: 'SGP321' }], dpi: [224.7, 224.1], bw: 3, ac: 500, }, { type: 'android', rules: [ { mdmh: 'TCT/*/ALCATEL ONE TOUCH Fierce/*' }, { ua: 'ALCATEL ONE TOUCH Fierce' }, ], dpi: [240, 247.5], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'THL/*/thl 5000/*' }, { ua: 'thl 5000' }], dpi: [480, 443.3], bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Fly/*/IQ4412/*' }, { ua: 'IQ4412' }], dpi: 307.9, bw: 3, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'ZTE/*/ZTE Blade L2/*' }, { ua: 'ZTE Blade L2' }], dpi: 240, bw: 3, ac: 500, }, { type: 'android', rules: [{ mdmh: 'BENEVE/*/VR518/*' }, { ua: 'VR518' }], dpi: 480, bw: 3, ac: 500, }, { type: 'ios', rules: [{ res: [640, 960] }], dpi: [325.1, 328.4], bw: 4, ac: 1e3, }, { type: 'ios', rules: [{ res: [640, 1136] }], dpi: [317.1, 320.2], bw: 3, ac: 1e3, }, { type: 'ios', rules: [{ res: [750, 1334] }], dpi: 326.4, bw: 4, ac: 1e3, }, { type: 'ios', rules: [{ res: [1242, 2208] }], dpi: [453.6, 458.4], bw: 4, ac: 1e3, }, { type: 'ios', rules: [{ res: [1125, 2001] }], dpi: [410.9, 415.4], bw: 4, ac: 1e3, }, { type: 'ios', rules: [{ res: [1125, 2436] }], dpi: 458, bw: 4, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'Huawei/*/EML-L29/*' }, { ua: 'EML-L29' }], dpi: 428, bw: 3.45, ac: 500, }, { type: 'android', rules: [{ mdmh: 'Nokia/*/Nokia 7.1/*' }, { ua: 'Nokia 7.1' }], dpi: [432, 431.9], bw: 3, ac: 500, }, { type: 'ios', rules: [{ res: [1242, 2688] }], dpi: 458, bw: 4, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G570M/*' }, { ua: 'SM-G570M' }], dpi: 320, bw: 3.684, ac: 1e3, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G970F/*' }, { ua: 'SM-G970F' }], dpi: 438, bw: 2.281, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G973F/*' }, { ua: 'SM-G973F' }], dpi: 550, bw: 2.002, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G975F/*' }, { ua: 'SM-G975F' }], dpi: 522, bw: 2.054, ac: 500, }, { type: 'android', rules: [{ mdmh: 'samsung/*/SM-G977F/*' }, { ua: 'SM-G977F' }], dpi: 505, bw: 2.334, ac: 500, }, { type: 'ios', rules: [{ res: [828, 1792] }], dpi: 326, bw: 5, ac: 500, }, ], } function he(e, t) { if (((this.dpdb = ue), this.recalculateDeviceParams_(), e)) { this.onDeviceParamsUpdated = t var n = new XMLHttpRequest(), r = this n.open('GET', e, !0), n.addEventListener('load', function () { ;(r.loading = !1), n.status >= 200 && n.status <= 299 ? ((r.dpdb = JSON.parse(n.response)), r.recalculateDeviceParams_()) : console.error('Error loading online DPDB!') }), n.send() } } function de(e) { ;(this.xdpi = e.xdpi), (this.ydpi = e.ydpi), (this.bevelMm = e.bevelMm) } function pe(e, t) { this.set(e, t) } function fe(e, t) { ;(this.kFilter = e), (this.isDebug = t), (this.currentAccelMeasurement = new pe()), (this.currentGyroMeasurement = new pe()), (this.previousGyroMeasurement = new pe()), l() ? (this.filterQ = new re(-1, 0, 0, 1)) : (this.filterQ = new re(1, 0, 0, 1)), (this.previousFilterQ = new re()), this.previousFilterQ.copy(this.filterQ), (this.accelQ = new re()), (this.isOrientationInitialized = !1), (this.estimatedGravity = new ne()), (this.measuredGravity = new ne()), (this.gyroIntegralQ = new re()) } function me(e, t) { ;(this.predictionTimeS = e), (this.isDebug = t), (this.previousQ = new re()), (this.previousTimestampS = null), (this.deltaQ = new re()), (this.outQ = new re()) } function ve(e, t, n, r) { ;(this.yawOnly = n), (this.accelerometer = new ne()), (this.gyroscope = new ne()), (this.filter = new fe(e, r)), (this.posePredictor = new me(t, r)), (this.isFirefoxAndroid = h()), (this.isIOS = l()) var i = d() ;(this.isDeviceMotionInRadians = !this.isIOS && i && i < 66), (this.isWithoutDeviceMotion = f() || p()), (this.filterToWorldQ = new re()), l() ? this.filterToWorldQ.setFromAxisAngle( new ne(1, 0, 0), Math.PI / 2, ) : this.filterToWorldQ.setFromAxisAngle( new ne(1, 0, 0), -Math.PI / 2, ), (this.inverseWorldToScreenQ = new re()), (this.worldToScreenQ = new re()), (this.originalPoseAdjustQ = new re()), this.originalPoseAdjustQ.setFromAxisAngle( new ne(0, 0, 1), (-window.orientation * Math.PI) / 180, ), this.setScreenTransform_(), v() && this.filterToWorldQ.multiply(this.inverseWorldToScreenQ), (this.resetQ = new re()), (this.orientationOut_ = new Float32Array(4)), this.start() } ;(he.prototype.getDeviceParams = function () { return this.deviceParams }), (he.prototype.recalculateDeviceParams_ = function () { var e = this.calcDeviceParams_() e ? ((this.deviceParams = e), this.onDeviceParamsUpdated && this.onDeviceParamsUpdated(this.deviceParams)) : console.error('Failed to recalculate device parameters.') }), (he.prototype.calcDeviceParams_ = function () { var e = this.dpdb if (!e) return console.error('DPDB not available.'), null if (1 != e.format) return console.error('DPDB has unexpected format version.'), null if (!e.devices || !e.devices.length) return ( console.error('DPDB does not have a devices section.'), null ) var t = navigator.userAgent || navigator.vendor || window.opera, n = y(), r = b() if (!e.devices) return console.error('DPDB has no devices section.'), null for (var i = 0; i < e.devices.length; i++) { var o = e.devices[i] if (o.rules) if ('ios' == o.type || 'android' == o.type) { if (l() == ('ios' == o.type)) { for (var a = !1, s = 0; s < o.rules.length; s++) { var c = o.rules[s] if (this.ruleMatches_(c, t, n, r)) { a = !0 break } } if (a) return new de({ xdpi: o.dpi[0] || o.dpi, ydpi: o.dpi[1] || o.dpi, bevelMm: o.bw, }) } } else console.warn('Device[' + i + '] has invalid type.') else console.warn('Device[' + i + '] has no rules section.') } return console.warn('No DPDB device match.'), null }), (he.prototype.ruleMatches_ = function (e, t, n, r) { if (!e.ua && !e.res) return !1 if ( (e.ua && 'SM' === e.ua.substring(0, 2) && (e.ua = e.ua.substring(0, 7)), e.ua && t.indexOf(e.ua) < 0) ) return !1 if (e.res) { if (!e.res[0] || !e.res[1]) return !1 var i = e.res[0], o = e.res[1] if ( Math.min(n, r) != Math.min(i, o) || Math.max(n, r) != Math.max(i, o) ) return !1 } return !0 }), (pe.prototype.set = function (e, t) { ;(this.sample = e), (this.timestampS = t) }), (pe.prototype.copy = function (e) { this.set(e.sample, e.timestampS) }), (fe.prototype.addAccelMeasurement = function (e, t) { this.currentAccelMeasurement.set(e, t) }), (fe.prototype.addGyroMeasurement = function (e, t) { this.currentGyroMeasurement.set(e, t) var n = t - this.previousGyroMeasurement.timestampS g(n) && this.run_(), this.previousGyroMeasurement.copy(this.currentGyroMeasurement) }), (fe.prototype.run_ = function () { if (!this.isOrientationInitialized) return ( (this.accelQ = this.accelToQuaternion_( this.currentAccelMeasurement.sample, )), this.previousFilterQ.copy(this.accelQ), void (this.isOrientationInitialized = !0) ) var e = this.currentGyroMeasurement.timestampS - this.previousGyroMeasurement.timestampS, t = this.gyroToQuaternionDelta_( this.currentGyroMeasurement.sample, e, ) this.gyroIntegralQ.multiply(t), this.filterQ.copy(this.previousFilterQ), this.filterQ.multiply(t) var n = new re() n.copy(this.filterQ), n.inverse(), this.estimatedGravity.set(0, 0, -1), this.estimatedGravity.applyQuaternion(n), this.estimatedGravity.normalize(), this.measuredGravity.copy(this.currentAccelMeasurement.sample), this.measuredGravity.normalize() var r = new re() r.setFromUnitVectors(this.estimatedGravity, this.measuredGravity), r.inverse(), this.isDebug && console.log( 'Delta: %d deg, G_est: (%s, %s, %s), G_meas: (%s, %s, %s)', te * D(r), this.estimatedGravity.x.toFixed(1), this.estimatedGravity.y.toFixed(1), this.estimatedGravity.z.toFixed(1), this.measuredGravity.x.toFixed(1), this.measuredGravity.y.toFixed(1), this.measuredGravity.z.toFixed(1), ) var i = new re() i.copy(this.filterQ), i.multiply(r), this.filterQ.slerp(i, 1 - this.kFilter), this.previousFilterQ.copy(this.filterQ) }), (fe.prototype.getOrientation = function () { return this.filterQ }), (fe.prototype.accelToQuaternion_ = function (e) { var t = new ne() t.copy(e), t.normalize() var n = new re() return n.setFromUnitVectors(new ne(0, 0, -1), t), n.inverse(), n }), (fe.prototype.gyroToQuaternionDelta_ = function (e, t) { var n = new re(), r = new ne() return ( r.copy(e), r.normalize(), n.setFromAxisAngle(r, e.length() * t), n ) }), (me.prototype.getPrediction = function (e, t, n) { if (!this.previousTimestampS) return this.previousQ.copy(e), (this.previousTimestampS = n), e var r = new ne() r.copy(t), r.normalize() var i = t.length() if (i < 20 * ee) return ( this.isDebug && console.log( 'Moving slowly, at %s deg/s: no prediction', (te * i).toFixed(1), ), this.outQ.copy(e), this.previousQ.copy(e), this.outQ ) var o = i * this.predictionTimeS return ( this.deltaQ.setFromAxisAngle(r, o), this.outQ.copy(this.previousQ), this.outQ.multiply(this.deltaQ), this.previousQ.copy(e), (this.previousTimestampS = n), this.outQ ) }), (ve.prototype.getPosition = function () { return null }), (ve.prototype.getOrientation = function () { var e = void 0 if (this.isWithoutDeviceMotion && this._deviceOrientationQ) return ( (this.deviceOrientationFixQ = this.deviceOrientationFixQ || (function () { var e = new re().setFromAxisAngle(new ne(0, 0, -1), 0), t = new re() return ( -90 === window.orientation ? t.setFromAxisAngle(new ne(0, 1, 0), Math.PI / -2) : t.setFromAxisAngle(new ne(0, 1, 0), Math.PI / 2), e.multiply(t) ) })()), (this.deviceOrientationFilterToWorldQ = this.deviceOrientationFilterToWorldQ || (function () { var e = new re() return e.setFromAxisAngle(new ne(1, 0, 0), -Math.PI / 2), e })()), (e = this._deviceOrientationQ), (t = new re()).copy(e), t.multiply(this.deviceOrientationFilterToWorldQ), t.multiply(this.resetQ), t.multiply(this.worldToScreenQ), t.multiplyQuaternions(this.deviceOrientationFixQ, t), this.yawOnly && ((t.x = 0), (t.z = 0), t.normalize()), (this.orientationOut_[0] = t.x), (this.orientationOut_[1] = t.y), (this.orientationOut_[2] = t.z), (this.orientationOut_[3] = t.w), this.orientationOut_ ) var t, n = this.filter.getOrientation() return ( (e = this.posePredictor.getPrediction( n, this.gyroscope, this.previousTimestampS, )), (t = new re()).copy(this.filterToWorldQ), t.multiply(this.resetQ), t.multiply(e), t.multiply(this.worldToScreenQ), this.yawOnly && ((t.x = 0), (t.z = 0), t.normalize()), (this.orientationOut_[0] = t.x), (this.orientationOut_[1] = t.y), (this.orientationOut_[2] = t.z), (this.orientationOut_[3] = t.w), this.orientationOut_ ) }), (ve.prototype.resetPose = function () { this.resetQ.copy(this.filter.getOrientation()), (this.resetQ.x = 0), (this.resetQ.y = 0), (this.resetQ.z *= -1), this.resetQ.normalize(), v() && this.resetQ.multiply(this.inverseWorldToScreenQ), this.resetQ.multiply(this.originalPoseAdjustQ) }), (ve.prototype.onDeviceOrientation_ = function (e) { this._deviceOrientationQ = this._deviceOrientationQ || new re() var t = e.alpha, n = e.beta, r = e.gamma ;(t = ((t || 0) * Math.PI) / 180), (n = ((n || 0) * Math.PI) / 180), (r = ((r || 0) * Math.PI) / 180), this._deviceOrientationQ.setFromEulerYXZ(n, t, -r) }), (ve.prototype.onDeviceMotion_ = function (e) { this.updateDeviceMotion_(e) }), (ve.prototype.updateDeviceMotion_ = function (e) { var t = e.accelerationIncludingGravity, n = e.rotationRate, r = e.timeStamp / 1e3, a = r - this.previousTimestampS return a < 0 ? (O( 'fusion-pose-sensor:invalid:non-monotonic', 'Invalid timestamps detected: non-monotonic timestamp from devicemotion', ), void (this.previousTimestampS = r)) : a <= i || a > o ? (O( 'fusion-pose-sensor:invalid:outside-threshold', 'Invalid timestamps detected: Timestamp from devicemotion outside expected range.', ), void (this.previousTimestampS = r)) : (this.accelerometer.set(-t.x, -t.y, -t.z), n && (m() ? this.gyroscope.set(-n.beta, n.alpha, n.gamma) : this.gyroscope.set(n.alpha, n.beta, n.gamma), this.isDeviceMotionInRadians || this.gyroscope.multiplyScalar(Math.PI / 180), this.filter.addGyroMeasurement(this.gyroscope, r)), this.filter.addAccelMeasurement(this.accelerometer, r), void (this.previousTimestampS = r)) }), (ve.prototype.onOrientationChange_ = function (e) { this.setScreenTransform_() }), (ve.prototype.onMessage_ = function (e) { var t = e.data t && t.type && 'devicemotion' === t.type.toLowerCase() && this.updateDeviceMotion_(t.deviceMotionEvent) }), (ve.prototype.setScreenTransform_ = function () { switch ((this.worldToScreenQ.set(0, 0, 0, 1), window.orientation)) { case 0: break case 90: this.worldToScreenQ.setFromAxisAngle( new ne(0, 0, 1), -Math.PI / 2, ) break case -90: this.worldToScreenQ.setFromAxisAngle( new ne(0, 0, 1), Math.PI / 2, ) } this.inverseWorldToScreenQ.copy(this.worldToScreenQ), this.inverseWorldToScreenQ.inverse() }), (ve.prototype.start = function () { ;(this.onDeviceMotionCallback_ = this.onDeviceMotion_.bind(this)), (this.onOrientationChangeCallback_ = this.onOrientationChange_.bind(this)), (this.onMessageCallback_ = this.onMessage_.bind(this)), (this.onDeviceOrientationCallback_ = this.onDeviceOrientation_.bind(this)), l() && R() && window.addEventListener('message', this.onMessageCallback_), window.addEventListener( 'orientationchange', this.onOrientationChangeCallback_, ), this.isWithoutDeviceMotion ? window.addEventListener( 'deviceorientation', this.onDeviceOrientationCallback_, ) : window.addEventListener( 'devicemotion', this.onDeviceMotionCallback_, ) }), (ve.prototype.stop = function () { window.removeEventListener( 'devicemotion', this.onDeviceMotionCallback_, ), window.removeEventListener( 'deviceorientation', this.onDeviceOrientationCallback_, ), window.removeEventListener( 'orientationchange', this.onOrientationChangeCallback_, ), window.removeEventListener('message', this.onMessageCallback_) }) var ge = 60, ye = new ne(1, 0, 0), be = new ne(0, 0, 1), Ae = new re() Ae.setFromAxisAngle(ye, -Math.PI / 2), Ae.multiply(new re().setFromAxisAngle(be, Math.PI / 2)) var we = (function () { function t(n) { e(this, t), (this.config = n), (this.sensor = null), (this.fusionSensor = null), (this._out = new Float32Array(4)), (this.api = null), (this.errors = []), (this._sensorQ = new re()), (this._outQ = new re()), (this._onSensorRead = this._onSensorRead.bind(this)), (this._onSensorError = this._onSensorError.bind(this)), this.init() } return ( n(t, [ { key: 'init', value: function () { var e = null try { ;(e = new RelativeOrientationSensor({ frequency: ge, referenceFrame: 'screen', })).addEventListener('error', this._onSensorError) } catch (t) { this.errors.push(t), 'SecurityError' === t.name ? (console.error( 'Cannot construct sensors due to the Feature Policy', ), console.warn( 'Attempting to fall back using "devicemotion"; however this will fail in the future without correct permissions.', ), this.useDeviceMotion()) : 'ReferenceError' === t.name ? this.useDeviceMotion() : console.error(t) } e && ((this.api = 'sensor'), (this.sensor = e), this.sensor.addEventListener( 'reading', this._onSensorRead, ), this.sensor.start()) }, }, { key: 'useDeviceMotion', value: function () { ;(this.api = 'devicemotion'), (this.fusionSensor = new ve( this.config.K_FILTER, this.config.PREDICTION_TIME_S, this.config.YAW_ONLY, this.config.DEBUG, )), this.sensor && (this.sensor.removeEventListener( 'reading', this._onSensorRead, ), this.sensor.removeEventListener( 'error', this._onSensorError, ), (this.sensor = null)) }, }, { key: 'getOrientation', value: function () { if (this.fusionSensor) return this.fusionSensor.getOrientation() if (!this.sensor || !this.sensor.quaternion) return ( (this._out[0] = this._out[1] = this._out[2] = 0), (this._out[3] = 1), this._out ) var e = this.sensor.quaternion this._sensorQ.set(e[0], e[1], e[2], e[3]) var t = this._outQ return ( t.copy(Ae), t.multiply(this._sensorQ), this.config.YAW_ONLY && ((t.x = t.z = 0), t.normalize()), (this._out[0] = t.x), (this._out[1] = t.y), (this._out[2] = t.z), (this._out[3] = t.w), this._out ) }, }, { key: '_onSensorError', value: function (e) { this.errors.push(e.error), 'NotAllowedError' === e.error.name ? console.error( 'Permission to access sensor was denied', ) : 'NotReadableError' === e.error.name ? console.error('Sensor could not be read') : console.error(e.error), this.useDeviceMotion() }, }, { key: '_onSensorRead', value: function () {} }, ]), t ) })(), xe = "" function Ee() { this.loadIcon_() var e = document.createElement('div') ;((o = e.style).position = 'fixed'), (o.top = 0), (o.right = 0), (o.bottom = 0), (o.left = 0), (o.backgroundColor = 'gray'), (o.fontFamily = 'sans-serif'), (o.zIndex = 1e6) var t = document.createElement('img') ;(t.src = this.icon), ((o = t.style).marginLeft = '25%'), (o.marginTop = '25%'), (o.width = '50%'), e.appendChild(t) var n = document.createElement('div') ;((o = n.style).textAlign = 'center'), (o.fontSize = '16px'), (o.lineHeight = '24px'), (o.margin = '24px 25%'), (o.width = '50%'), (n.innerHTML = 'Place your phone into your Cardboard viewer.'), e.appendChild(n) var r = document.createElement('div') ;((o = r.style).backgroundColor = '#CFD8DC'), (o.position = 'fixed'), (o.bottom = 0), (o.width = '100%'), (o.height = '48px'), (o.padding = '14px 24px'), (o.boxSizing = 'border-box'), (o.color = '#656A6B'), e.appendChild(r) var i = document.createElement('div') ;(i.style.float = 'left'), (i.innerHTML = 'No Cardboard viewer?') var o, a = document.createElement('a') ;(a.href = 'https://www.google.com/get/cardboard/get-cardboard/'), (a.innerHTML = 'get one'), (a.target = '_blank'), ((o = a.style).float = 'right'), (o.fontWeight = 600), (o.textTransform = 'uppercase'), (o.borderLeft = '1px solid gray'), (o.paddingLeft = '24px'), (o.textDecoration = 'none'), (o.color = '#656A6B'), r.appendChild(i), r.appendChild(a), (this.overlay = e), (this.text = n), this.hide() } ;(Ee.prototype.show = function (e) { e || this.overlay.parentElement ? e && (this.overlay.parentElement && this.overlay.parentElement != e && this.overlay.parentElement.removeChild(this.overlay), e.appendChild(this.overlay)) : document.body.appendChild(this.overlay), (this.overlay.style.display = 'block') var t = this.overlay.querySelector('img').style v() ? ((t.width = '20%'), (t.marginLeft = '40%'), (t.marginTop = '3%')) : ((t.width = '50%'), (t.marginLeft = '25%'), (t.marginTop = '25%')) }), (Ee.prototype.hide = function () { this.overlay.style.display = 'none' }), (Ee.prototype.showTemporarily = function (e, t) { this.show(t), (this.timer = setTimeout(this.hide.bind(this), e)) }), (Ee.prototype.disableShowTemporarily = function () { clearTimeout(this.timer) }), (Ee.prototype.update = function () { this.disableShowTemporarily(), !v() && T() ? this.show() : this.hide() }), (Ee.prototype.loadIcon_ = function () { this.icon = a('image/svg+xml', xe) }) var Me = 'CardboardV1', _e = 'WEBVR_CARDBOARD_VIEWER', Te = 'webvr-polyfill-viewer-selector' function Se(e) { try { this.selectedKey = localStorage.getItem(_e) } catch (t) { console.error('Failed to load viewer profile: %s', t) } this.selectedKey || (this.selectedKey = e || Me), (this.dialog = this.createDialog_(le.Viewers)), (this.root = null), (this.onChangeCallbacks_ = []) } function Ce(e) { return e && e.__esModule && Object.prototype.hasOwnProperty.call(e, 'default') ? e.default : e } function Le(e, t) { return e((t = { exports: {} }), t.exports), t.exports } ;(Se.prototype.show = function (e) { ;(this.root = e), e.appendChild(this.dialog), (this.dialog.querySelector('#' + this.selectedKey).checked = !0), (this.dialog.style.display = 'block') }), (Se.prototype.hide = function () { this.root && this.root.contains(this.dialog) && this.root.removeChild(this.dialog), (this.dialog.style.display = 'none') }), (Se.prototype.getCurrentViewer = function () { return le.Viewers[this.selectedKey] }), (Se.prototype.getSelectedKey_ = function () { var e = this.dialog.querySelector('input[name=field]:checked') return e ? e.id : null }), (Se.prototype.onChange = function (e) { this.onChangeCallbacks_.push(e) }), (Se.prototype.fireOnChange_ = function (e) { for (var t = 0; t < this.onChangeCallbacks_.length; t++) this.onChangeCallbacks_[t](e) }), (Se.prototype.onSave_ = function () { if ( ((this.selectedKey = this.getSelectedKey_()), this.selectedKey && le.Viewers[this.selectedKey]) ) { this.fireOnChange_(le.Viewers[this.selectedKey]) try { localStorage.setItem(_e, this.selectedKey) } catch (e) { console.error('Failed to save viewer profile: %s', e) } this.hide() } else console.error('ViewerSelector.onSave_: this should never happen!') }), (Se.prototype.createDialog_ = function (e) { var t = document.createElement('div') t.classList.add(Te), (t.style.display = 'none') var n = document.createElement('div') ;((o = n.style).position = 'fixed'), (o.left = 0), (o.top = 0), (o.width = '100%'), (o.height = '100%'), (o.background = 'rgba(0, 0, 0, 0.3)'), n.addEventListener('click', this.hide.bind(this)) var r = 280, i = document.createElement('div'), o = i.style for (var a in ((o.boxSizing = 'border-box'), (o.position = 'fixed'), (o.top = '24px'), (o.left = '50%'), (o.marginLeft = -r / 2 + 'px'), (o.width = r + 'px'), (o.padding = '24px'), (o.overflow = 'hidden'), (o.background = '#fafafa'), (o.fontFamily = "'Roboto', sans-serif"), (o.boxShadow = '0px 5px 20px #666'), i.appendChild(this.createH1_('Select your viewer')), e)) i.appendChild(this.createChoice_(a, e[a].label)) return ( i.appendChild( this.createButton_('Save', this.onSave_.bind(this)), ), t.appendChild(n), t.appendChild(i), t ) }), (Se.prototype.createH1_ = function (e) { var t = document.createElement('h1'), n = t.style return ( (n.color = 'black'), (n.fontSize = '20px'), (n.fontWeight = 'bold'), (n.marginTop = 0), (n.marginBottom = '24px'), (t.innerHTML = e), t ) }), (Se.prototype.createChoice_ = function (e, t) { var n = document.createElement('div') ;(n.style.marginTop = '8px'), (n.style.color = 'black') var r = document.createElement('input') ;(r.style.fontSize = '30px'), r.setAttribute('id', e), r.setAttribute('type', 'radio'), r.setAttribute('value', e), r.setAttribute('name', 'field') var i = document.createElement('label') return ( (i.style.marginLeft = '4px'), i.setAttribute('for', e), (i.innerHTML = t), n.appendChild(r), n.appendChild(i), n ) }), (Se.prototype.createButton_ = function (e, t) { var n = document.createElement('button') n.innerHTML = e var r = n.style return ( (r.float = 'right'), (r.textTransform = 'uppercase'), (r.color = '#1094f7'), (r.fontSize = '14px'), (r.letterSpacing = 0), (r.border = 0), (r.background = 'none'), (r.marginTop = '16px'), n.addEventListener('click', t), n ) }), 'undefined' !== typeof window ? window : 'undefined' !== typeof t || ('undefined' !== typeof self && self) var Re = Ce( Le(function (e, t) { var n ;(n = function () { return (function (e) { var t = {} function n(r) { if (t[r]) return t[r].exports var i = (t[r] = { i: r, l: !1, exports: {} }) return ( e[r].call(i.exports, i, i.exports, n), (i.l = !0), i.exports ) } return ( (n.m = e), (n.c = t), (n.d = function (e, t, r) { n.o(e, t) || Object.defineProperty(e, t, { configurable: !1, enumerable: !0, get: r, }) }), (n.n = function (e) { var t = e && e.__esModule ? function () { return e.default } : function () { return e } return n.d(t, 'a', t), t }), (n.o = function (e, t) { return Object.prototype.hasOwnProperty.call(e, t) }), (n.p = ''), n((n.s = 0)) ) })([ function (e, t, n) { var r = (function () { function e(e, t) { for (var n = 0; n < t.length; n++) { var r = t[n] ;(r.enumerable = r.enumerable || !1), (r.configurable = !0), 'value' in r && (r.writable = !0), Object.defineProperty(e, r.key, r) } } return function (t, n, r) { return n && e(t.prototype, n), r && e(t, r), t } })() function i(e, t) { if (!(e instanceof t)) throw new TypeError('Cannot call a class as a function') } var o = n(1), a = 'undefined' !== typeof navigator && parseFloat( ( '' + (/CPU.*OS ([0-9_]{3,4})[0-9_]{0,1}|(CPU like).*AppleWebKit.*Mobile/i.exec( navigator.userAgent, ) || [0, ''])[1] ) .replace('undefined', '3_2') .replace('_', '.') .replace('_', ''), ) < 10 && !window.MSStream, s = (function () { function e() { i(this, e), a ? (this.noSleepTimer = null) : ((this.noSleepVideo = document.createElement('video')), this.noSleepVideo.setAttribute( 'playsinline', '', ), this.noSleepVideo.setAttribute('src', o), this.noSleepVideo.addEventListener( 'timeupdate', function (e) { this.noSleepVideo.currentTime > 0.5 && (this.noSleepVideo.currentTime = Math.random()) }.bind(this), )) } return ( r(e, [ { key: 'enable', value: function () { a ? (this.disable(), (this.noSleepTimer = window.setInterval( function () { ;(window.location.href = '/'), window.setTimeout(window.stop, 0) }, 15e3, ))) : this.noSleepVideo.play() }, }, { key: 'disable', value: function () { a ? this.noSleepTimer && (window.clearInterval(this.noSleepTimer), (this.noSleepTimer = null)) : this.noSleepVideo.pause() }, }, ]), e ) })() e.exports = s }, function (e, t, n) { e.exports = 'data:video/mp4;base64,AAAAIGZ0eXBtcDQyAAACAGlzb21pc28yYXZjMW1wNDEAAAAIZnJlZQAACKBtZGF0AAAC8wYF///v3EXpvebZSLeWLNgg2SPu73gyNjQgLSBjb3JlIDE0MiByMjQ3OSBkZDc5YTYxIC0gSC4yNjQvTVBFRy00IEFWQyBjb2RlYyAtIENvcHlsZWZ0IDIwMDMtMjAxNCAtIGh0dHA6Ly93d3cudmlkZW9sYW4ub3JnL3gyNjQuaHRtbCAtIG9wdGlvbnM6IGNhYmFjPTEgcmVmPTEgZGVibG9jaz0xOjA6MCBhbmFseXNlPTB4MToweDExMSBtZT1oZXggc3VibWU9MiBwc3k9MSBwc3lfcmQ9MS4wMDowLjAwIG1peGVkX3JlZj0wIG1lX3JhbmdlPTE2IGNocm9tYV9tZT0xIHRyZWxsaXM9MCA4eDhkY3Q9MCBjcW09MCBkZWFkem9uZT0yMSwxMSBmYXN0X3Bza2lwPTEgY2hyb21hX3FwX29mZnNldD0wIHRocmVhZHM9NiBsb29rYWhlYWRfdGhyZWFkcz0xIHNsaWNlZF90aHJlYWRzPTAgbnI9MCBkZWNpbWF0ZT0xIGludGVybGFjZWQ9MCBibHVyYXlfY29tcGF0PTAgY29uc3RyYWluZWRfaW50cmE9MCBiZnJhbWVzPTMgYl9weXJhbWlkPTIgYl9hZGFwdD0xIGJfYmlhcz0wIGRpcmVjdD0xIHdlaWdodGI9MSBvcGVuX2dvcD0wIHdlaWdodHA9MSBrZXlpbnQ9MzAwIGtleWludF9taW49MzAgc2NlbmVjdXQ9NDAgaW50cmFfcmVmcmVzaD0wIHJjX2xvb2thaGVhZD0xMCByYz1jcmYgbWJ0cmVlPTEgY3JmPTIwLjAgcWNvbXA9MC42MCBxcG1pbj0wIHFwbWF4PTY5IHFwc3RlcD00IHZidl9tYXhyYXRlPTIwMDAwIHZidl9idWZzaXplPTI1MDAwIGNyZl9tYXg9MC4wIG5hbF9ocmQ9bm9uZSBmaWxsZXI9MCBpcF9yYXRpbz0xLjQwIGFxPTE6MS4wMACAAAAAOWWIhAA3//p+C7v8tDDSTjf97w55i3SbRPO4ZY+hkjD5hbkAkL3zpJ6h/LR1CAABzgB1kqqzUorlhQAAAAxBmiQYhn/+qZYADLgAAAAJQZ5CQhX/AAj5IQADQGgcIQADQGgcAAAACQGeYUQn/wALKCEAA0BoHAAAAAkBnmNEJ/8ACykhAANAaBwhAANAaBwAAAANQZpoNExDP/6plgAMuSEAA0BoHAAAAAtBnoZFESwr/wAI+SEAA0BoHCEAA0BoHAAAAAkBnqVEJ/8ACykhAANAaBwAAAAJAZ6nRCf/AAsoIQADQGgcIQADQGgcAAAADUGarDRMQz/+qZYADLghAANAaBwAAAALQZ7KRRUsK/8ACPkhAANAaBwAAAAJAZ7pRCf/AAsoIQADQGgcIQADQGgcAAAACQGe60Qn/wALKCEAA0BoHAAAAA1BmvA0TEM//qmWAAy5IQADQGgcIQADQGgcAAAAC0GfDkUVLCv/AAj5IQADQGgcAAAACQGfLUQn/wALKSEAA0BoHCEAA0BoHAAAAAkBny9EJ/8ACyghAANAaBwAAAANQZs0NExDP/6plgAMuCEAA0BoHAAAAAtBn1JFFSwr/wAI+SEAA0BoHCEAA0BoHAAAAAkBn3FEJ/8ACyghAANAaBwAAAAJAZ9zRCf/AAsoIQADQGgcIQADQGgcAAAADUGbeDRMQz/+qZYADLkhAANAaBwAAAALQZ+WRRUsK/8ACPghAANAaBwhAANAaBwAAAAJAZ+1RCf/AAspIQADQGgcAAAACQGft0Qn/wALKSEAA0BoHCEAA0BoHAAAAA1Bm7w0TEM//qmWAAy4IQADQGgcAAAAC0Gf2kUVLCv/AAj5IQADQGgcAAAACQGf+UQn/wALKCEAA0BoHCEAA0BoHAAAAAkBn/tEJ/8ACykhAANAaBwAAAANQZvgNExDP/6plgAMuSEAA0BoHCEAA0BoHAAAAAtBnh5FFSwr/wAI+CEAA0BoHAAAAAkBnj1EJ/8ACyghAANAaBwhAANAaBwAAAAJAZ4/RCf/AAspIQADQGgcAAAADUGaJDRMQz/+qZYADLghAANAaBwAAAALQZ5CRRUsK/8ACPkhAANAaBwhAANAaBwAAAAJAZ5hRCf/AAsoIQADQGgcAAAACQGeY0Qn/wALKSEAA0BoHCEAA0BoHAAAAA1Bmmg0TEM//qmWAAy5IQADQGgcAAAAC0GehkUVLCv/AAj5IQADQGgcIQADQGgcAAAACQGepUQn/wALKSEAA0BoHAAAAAkBnqdEJ/8ACyghAANAaBwAAAANQZqsNExDP/6plgAMuCEAA0BoHCEAA0BoHAAAAAtBnspFFSwr/wAI+SEAA0BoHAAAAAkBnulEJ/8ACyghAANAaBwhAANAaBwAAAAJAZ7rRCf/AAsoIQADQGgcAAAADUGa8DRMQz/+qZYADLkhAANAaBwhAANAaBwAAAALQZ8ORRUsK/8ACPkhAANAaBwAAAAJAZ8tRCf/AAspIQADQGgcIQADQGgcAAAACQGfL0Qn/wALKCEAA0BoHAAAAA1BmzQ0TEM//qmWAAy4IQADQGgcAAAAC0GfUkUVLCv/AAj5IQADQGgcIQADQGgcAAAACQGfcUQn/wALKCEAA0BoHAAAAAkBn3NEJ/8ACyghAANAaBwhAANAaBwAAAANQZt4NExC//6plgAMuSEAA0BoHAAAAAtBn5ZFFSwr/wAI+CEAA0BoHCEAA0BoHAAAAAkBn7VEJ/8ACykhAANAaBwAAAAJAZ+3RCf/AAspIQADQGgcAAAADUGbuzRMQn/+nhAAYsAhAANAaBwhAANAaBwAAAAJQZ/aQhP/AAspIQADQGgcAAAACQGf+UQn/wALKCEAA0BoHCEAA0BoHCEAA0BoHCEAA0BoHCEAA0BoHCEAA0BoHAAACiFtb292AAAAbG12aGQAAAAA1YCCX9WAgl8AAAPoAAAH/AABAAABAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADAAAAGGlvZHMAAAAAEICAgAcAT////v7/AAAF+XRyYWsAAABcdGtoZAAAAAPVgIJf1YCCXwAAAAEAAAAAAAAH0AAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAEAAAAAAygAAAMoAAAAAACRlZHRzAAAAHGVsc3QAAAAAAAAAAQAAB9AAABdwAAEAAAAABXFtZGlhAAAAIG1kaGQAAAAA1YCCX9WAgl8AAV+QAAK/IFXEAAAAAAAtaGRscgAAAAAAAAAAdmlkZQAAAAAAAAAAAAAAAFZpZGVvSGFuZGxlcgAAAAUcbWluZgAAABR2bWhkAAAAAQAAAAAAAAAAAAAAJGRpbmYAAAAcZHJlZgAAAAAAAAABAAAADHVybCAAAAABAAAE3HN0YmwAAACYc3RzZAAAAAAAAAABAAAAiGF2YzEAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAygDKAEgAAABIAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAY//8AAAAyYXZjQwFNQCj/4QAbZ01AKOyho3ySTUBAQFAAAAMAEAAr8gDxgxlgAQAEaO+G8gAAABhzdHRzAAAAAAAAAAEAAAA8AAALuAAAABRzdHNzAAAAAAAAAAEAAAABAAAB8GN0dHMAAAAAAAAAPAAAAAEAABdwAAAAAQAAOpgAAAABAAAXcAAAAAEAAAAAAAAAAQAAC7gAAAABAAA6mAAAAAEAABdwAAAAAQAAAAAAAAABAAALuAAAAAEAADqYAAAAAQAAF3AAAAABAAAAAAAAAAEAAAu4AAAAAQAAOpgAAAABAAAXcAAAAAEAAAAAAAAAAQAAC7gAAAABAAA6mAAAAAEAABdwAAAAAQAAAAAAAAABAAALuAAAAAEAADqYAAAAAQAAF3AAAAABAAAAAAAAAAEAAAu4AAAAAQAAOpgAAAABAAAXcAAAAAEAAAAAAAAAAQAAC7gAAAABAAA6mAAAAAEAABdwAAAAAQAAAAAAAAABAAALuAAAAAEAADqYAAAAAQAAF3AAAAABAAAAAAAAAAEAAAu4AAAAAQAAOpgAAAABAAAXcAAAAAEAAAAAAAAAAQAAC7gAAAABAAA6mAAAAAEAABdwAAAAAQAAAAAAAAABAAALuAAAAAEAADqYAAAAAQAAF3AAAAABAAAAAAAAAAEAAAu4AAAAAQAAOpgAAAABAAAXcAAAAAEAAAAAAAAAAQAAC7gAAAABAAA6mAAAAAEAABdwAAAAAQAAAAAAAAABAAALuAAAAAEAAC7gAAAAAQAAF3AAAAABAAAAAAAAABxzdHNjAAAAAAAAAAEAAAABAAAAAQAAAAEAAAEEc3RzegAAAAAAAAAAAAAAPAAAAzQAAAAQAAAADQAAAA0AAAANAAAAEQAAAA8AAAANAAAADQAAABEAAAAPAAAADQAAAA0AAAARAAAADwAAAA0AAAANAAAAEQAAAA8AAAANAAAADQAAABEAAAAPAAAADQAAAA0AAAARAAAADwAAAA0AAAANAAAAEQAAAA8AAAANAAAADQAAABEAAAAPAAAADQAAAA0AAAARAAAADwAAAA0AAAANAAAAEQAAAA8AAAANAAAADQAAABEAAAAPAAAADQAAAA0AAAARAAAADwAAAA0AAAANAAAAEQAAAA8AAAANAAAADQAAABEAAAANAAAADQAAAQBzdGNvAAAAAAAAADwAAAAwAAADZAAAA3QAAAONAAADoAAAA7kAAAPQAAAD6wAAA/4AAAQXAAAELgAABEMAAARcAAAEbwAABIwAAAShAAAEugAABM0AAATkAAAE/wAABRIAAAUrAAAFQgAABV0AAAVwAAAFiQAABaAAAAW1AAAFzgAABeEAAAX+AAAGEwAABiwAAAY/AAAGVgAABnEAAAaEAAAGnQAABrQAAAbPAAAG4gAABvUAAAcSAAAHJwAAB0AAAAdTAAAHcAAAB4UAAAeeAAAHsQAAB8gAAAfjAAAH9gAACA8AAAgmAAAIQQAACFQAAAhnAAAIhAAACJcAAAMsdHJhawAAAFx0a2hkAAAAA9WAgl/VgIJfAAAAAgAAAAAAAAf8AAAAAAAAAAAAAAABAQAAAAABAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAACsm1kaWEAAAAgbWRoZAAAAADVgIJf1YCCXwAArEQAAWAAVcQAAAAAACdoZGxyAAAAAAAAAABzb3VuAAAAAAAAAAAAAAAAU3RlcmVvAAAAAmNtaW5mAAAAEHNtaGQAAAAAAAAAAAAAACRkaW5mAAAAHGRyZWYAAAAAAAAAAQAAAAx1cmwgAAAAAQAAAidzdGJsAAAAZ3N0c2QAAAAAAAAAAQAAAFdtcDRhAAAAAAAAAAEAAAAAAAAAAAACABAAAAAArEQAAAAAADNlc2RzAAAAAAOAgIAiAAIABICAgBRAFQAAAAADDUAAAAAABYCAgAISEAaAgIABAgAAABhzdHRzAAAAAAAAAAEAAABYAAAEAAAAABxzdHNjAAAAAAAAAAEAAAABAAAAAQAAAAEAAAAUc3RzegAAAAAAAAAGAAAAWAAAAXBzdGNvAAAAAAAAAFgAAAOBAAADhwAAA5oAAAOtAAADswAAA8oAAAPfAAAD5QAAA/gAAAQLAAAEEQAABCgAAAQ9AAAEUAAABFYAAARpAAAEgAAABIYAAASbAAAErgAABLQAAATHAAAE3gAABPMAAAT5AAAFDAAABR8AAAUlAAAFPAAABVEAAAVXAAAFagAABX0AAAWDAAAFmgAABa8AAAXCAAAFyAAABdsAAAXyAAAF+AAABg0AAAYgAAAGJgAABjkAAAZQAAAGZQAABmsAAAZ+AAAGkQAABpcAAAauAAAGwwAABskAAAbcAAAG7wAABwYAAAcMAAAHIQAABzQAAAc6AAAHTQAAB2QAAAdqAAAHfwAAB5IAAAeYAAAHqwAAB8IAAAfXAAAH3QAAB/AAAAgDAAAICQAACCAAAAg1AAAIOwAACE4AAAhhAAAIeAAACH4AAAiRAAAIpAAACKoAAAiwAAAItgAACLwAAAjCAAAAFnVkdGEAAAAObmFtZVN0ZXJlbwAAAHB1ZHRhAAAAaG1ldGEAAAAAAAAAIWhkbHIAAAAAAAAAAG1kaXJhcHBsAAAAAAAAAAAAAAAAO2lsc3QAAAAzqXRvbwAAACtkYXRhAAAAAQAAAABIYW5kQnJha2UgMC4xMC4yIDIwMTUwNjExMDA=' }, ]) }), (e.exports = n()) }), ), Pe = 1e3, De = [0, 0, 0.5, 1], Oe = [0.5, 0, 0.5, 1], Ie = window.requestAnimationFrame, Be = window.cancelAnimationFrame function Fe() { ;(this.leftProjectionMatrix = new Float32Array(16)), (this.leftViewMatrix = new Float32Array(16)), (this.rightProjectionMatrix = new Float32Array(16)), (this.rightViewMatrix = new Float32Array(16)), (this.pose = null) } function ke(e) { Object.defineProperties(this, { hasPosition: { writable: !1, enumerable: !0, value: e.hasPosition }, hasExternalDisplay: { writable: !1, enumerable: !0, value: e.hasExternalDisplay, }, canPresent: { writable: !1, enumerable: !0, value: e.canPresent }, maxLayers: { writable: !1, enumerable: !0, value: e.maxLayers }, hasOrientation: { enumerable: !0, get: function () { return ( I( 'VRDisplayCapabilities.prototype.hasOrientation', 'VRDisplay.prototype.getFrameData', ), e.hasOrientation ) }, }, }) } function Ne(e) { var t = !('wakelock' in (e = e || {})) || e.wakelock ;(this.isPolyfilled = !0), (this.displayId = Pe++), (this.displayName = ''), (this.depthNear = 0.01), (this.depthFar = 1e4), (this.isPresenting = !1), Object.defineProperty(this, 'isConnected', { get: function () { return ( I( 'VRDisplay.prototype.isConnected', 'VRDisplayCapabilities.prototype.hasExternalDisplay', ), !1 ) }, }), (this.capabilities = new ke({ hasPosition: !1, hasOrientation: !1, hasExternalDisplay: !1, canPresent: !1, maxLayers: 1, })), (this.stageParameters = null), (this.waitingForPresent_ = !1), (this.layer_ = null), (this.originalParent_ = null), (this.fullscreenElement_ = null), (this.fullscreenWrapper_ = null), (this.fullscreenElementCachedStyle_ = null), (this.fullscreenEventTarget_ = null), (this.fullscreenChangeHandler_ = null), (this.fullscreenErrorHandler_ = null), t && T() && (this.wakelock_ = new Re()) } ;(Ne.prototype.getFrameData = function (e) { return L(e, this._getPose(), this) }), (Ne.prototype.getPose = function () { return ( I( 'VRDisplay.prototype.getPose', 'VRDisplay.prototype.getFrameData', ), this._getPose() ) }), (Ne.prototype.resetPose = function () { return I('VRDisplay.prototype.resetPose'), this._resetPose() }), (Ne.prototype.getImmediatePose = function () { return ( I( 'VRDisplay.prototype.getImmediatePose', 'VRDisplay.prototype.getFrameData', ), this._getPose() ) }), (Ne.prototype.requestAnimationFrame = function (e) { return Ie(e) }), (Ne.prototype.cancelAnimationFrame = function (e) { return Be(e) }), (Ne.prototype.wrapForFullscreen = function (e) { if (l()) return e if (!this.fullscreenWrapper_) { this.fullscreenWrapper_ = document.createElement('div') var t = [ 'height: ' + Math.min(screen.height, screen.width) + 'px !important', 'top: 0 !important', 'left: 0 !important', 'right: 0 !important', 'border: 0', 'margin: 0', 'padding: 0', 'z-index: 999999 !important', 'position: fixed', ] this.fullscreenWrapper_.setAttribute('style', t.join('; ') + ';'), this.fullscreenWrapper_.classList.add( 'webvr-polyfill-fullscreen-wrapper', ) } if (this.fullscreenElement_ == e) return this.fullscreenWrapper_ if ( (this.fullscreenElement_ && (this.originalParent_ ? this.originalParent_.appendChild(this.fullscreenElement_) : this.fullscreenElement_.parentElement.removeChild( this.fullscreenElement_, )), (this.fullscreenElement_ = e), (this.originalParent_ = e.parentElement), this.originalParent_ || document.body.appendChild(e), !this.fullscreenWrapper_.parentElement) ) { var n = this.fullscreenElement_.parentElement n.insertBefore(this.fullscreenWrapper_, this.fullscreenElement_), n.removeChild(this.fullscreenElement_) } this.fullscreenWrapper_.insertBefore( this.fullscreenElement_, this.fullscreenWrapper_.firstChild, ), (this.fullscreenElementCachedStyle_ = this.fullscreenElement_.getAttribute('style')) var r = this function i() { if (r.fullscreenElement_) { var e = [ 'position: absolute', 'top: 0', 'left: 0', 'width: ' + Math.max(screen.width, screen.height) + 'px', 'height: ' + Math.min(screen.height, screen.width) + 'px', 'border: 0', 'margin: 0', 'padding: 0', ] r.fullscreenElement_.setAttribute('style', e.join('; ') + ';') } } return i(), this.fullscreenWrapper_ }), (Ne.prototype.removeFullscreenWrapper = function () { if (this.fullscreenElement_) { var e = this.fullscreenElement_ this.fullscreenElementCachedStyle_ ? e.setAttribute('style', this.fullscreenElementCachedStyle_) : e.removeAttribute('style'), (this.fullscreenElement_ = null), (this.fullscreenElementCachedStyle_ = null) var t = this.fullscreenWrapper_.parentElement return ( this.fullscreenWrapper_.removeChild(e), this.originalParent_ === t ? t.insertBefore(e, this.fullscreenWrapper_) : this.originalParent_ && this.originalParent_.appendChild(e), t.removeChild(this.fullscreenWrapper_), e ) } }), (Ne.prototype.requestPresent = function (e) { var t = this.isPresenting, n = this return ( e instanceof Array || (I( 'VRDisplay.prototype.requestPresent with non-array argument', 'an array of VRLayers as the first argument', ), (e = [e])), new Promise(function (r, i) { if (n.capabilities.canPresent) if (0 == e.length || e.length > n.capabilities.maxLayers) i(new Error('Invalid number of layers.')) else { var o = e[0] if (o.source) { var a = o.leftBounds || De, s = o.rightBounds || Oe if (t) { var u = n.layer_ u.source !== o.source && (u.source = o.source) for (var h = 0; h < 4; h++) (u.leftBounds[h] = a[h]), (u.rightBounds[h] = s[h]) return ( n.wrapForFullscreen(n.layer_.source), n.updatePresent_(), void r() ) } if ( ((n.layer_ = { predistorted: o.predistorted, source: o.source, leftBounds: a.slice(0), rightBounds: s.slice(0), }), (n.waitingForPresent_ = !1), n.layer_ && n.layer_.source) ) { var d = n.wrapForFullscreen(n.layer_.source), p = function () { var e = x() ;(n.isPresenting = d === e), n.isPresenting ? (screen.orientation && screen.orientation.lock && screen.orientation .lock('landscape-primary') .catch(function (e) { console.error( 'screen.orientation.lock() failed due to', e.message, ) }), (n.waitingForPresent_ = !1), n.beginPresent_(), r()) : (screen.orientation && screen.orientation.unlock && screen.orientation.unlock(), n.removeFullscreenWrapper(), n.disableWakeLock(), n.endPresent_(), n.removeFullscreenListeners_()), n.fireVRDisplayPresentChange_() }, f = function () { n.waitingForPresent_ && (n.removeFullscreenWrapper(), n.removeFullscreenListeners_(), n.disableWakeLock(), (n.waitingForPresent_ = !1), (n.isPresenting = !1), i(new Error('Unable to present.'))) } n.addFullscreenListeners_(d, p, f), A(d) ? (n.enableWakeLock(), (n.waitingForPresent_ = !0)) : (l() || c()) && (n.enableWakeLock(), (n.isPresenting = !0), n.beginPresent_(), n.fireVRDisplayPresentChange_(), r()) } n.waitingForPresent_ || l() || (w(), i(new Error('Unable to present.'))) } else r() } else i(new Error('VRDisplay is not capable of presenting.')) }) ) }), (Ne.prototype.exitPresent = function () { var e = this.isPresenting, t = this return ( (this.isPresenting = !1), (this.layer_ = null), this.disableWakeLock(), new Promise(function (n, r) { e ? (!w() && l() && (t.endPresent_(), t.fireVRDisplayPresentChange_()), c() && (t.removeFullscreenWrapper(), t.removeFullscreenListeners_(), t.endPresent_(), t.fireVRDisplayPresentChange_()), n()) : r(new Error('Was not presenting to VRDisplay.')) }) ) }), (Ne.prototype.getLayers = function () { return this.layer_ ? [this.layer_] : [] }), (Ne.prototype.fireVRDisplayPresentChange_ = function () { var e = new CustomEvent('vrdisplaypresentchange', { detail: { display: this }, }) window.dispatchEvent(e) }), (Ne.prototype.fireVRDisplayConnect_ = function () { var e = new CustomEvent('vrdisplayconnect', { detail: { display: this }, }) window.dispatchEvent(e) }), (Ne.prototype.addFullscreenListeners_ = function (e, t, n) { this.removeFullscreenListeners_(), (this.fullscreenEventTarget_ = e), (this.fullscreenChangeHandler_ = t), (this.fullscreenErrorHandler_ = n), t && (document.fullscreenEnabled ? e.addEventListener('fullscreenchange', t, !1) : document.webkitFullscreenEnabled ? e.addEventListener('webkitfullscreenchange', t, !1) : document.mozFullScreenEnabled ? document.addEventListener('mozfullscreenchange', t, !1) : document.msFullscreenEnabled && e.addEventListener('msfullscreenchange', t, !1)), n && (document.fullscreenEnabled ? e.addEventListener('fullscreenerror', n, !1) : document.webkitFullscreenEnabled ? e.addEventListener('webkitfullscreenerror', n, !1) : document.mozFullScreenEnabled ? document.addEventListener('mozfullscreenerror', n, !1) : document.msFullscreenEnabled && e.addEventListener('msfullscreenerror', n, !1)) }), (Ne.prototype.removeFullscreenListeners_ = function () { if (this.fullscreenEventTarget_) { var e = this.fullscreenEventTarget_ if (this.fullscreenChangeHandler_) { var t = this.fullscreenChangeHandler_ e.removeEventListener('fullscreenchange', t, !1), e.removeEventListener('webkitfullscreenchange', t, !1), document.removeEventListener('mozfullscreenchange', t, !1), e.removeEventListener('msfullscreenchange', t, !1) } if (this.fullscreenErrorHandler_) { var n = this.fullscreenErrorHandler_ e.removeEventListener('fullscreenerror', n, !1), e.removeEventListener('webkitfullscreenerror', n, !1), document.removeEventListener('mozfullscreenerror', n, !1), e.removeEventListener('msfullscreenerror', n, !1) } ;(this.fullscreenEventTarget_ = null), (this.fullscreenChangeHandler_ = null), (this.fullscreenErrorHandler_ = null) } }), (Ne.prototype.enableWakeLock = function () { this.wakelock_ && this.wakelock_.enable() }), (Ne.prototype.disableWakeLock = function () { this.wakelock_ && this.wakelock_.disable() }), (Ne.prototype.beginPresent_ = function () {}), (Ne.prototype.endPresent_ = function () {}), (Ne.prototype.submitFrame = function (e) {}), (Ne.prototype.getEyeParameters = function (e) { return null }) var Ue = { ADDITIONAL_VIEWERS: [], DEFAULT_VIEWER: '', MOBILE_WAKE_LOCK: !0, DEBUG: !1, DPDB_URL: 'https://dpdb.webvr.rocks/dpdb.json', K_FILTER: 0.98, PREDICTION_TIME_S: 0.04, CARDBOARD_UI_DISABLED: !1, ROTATE_INSTRUCTIONS_DISABLED: !1, YAW_ONLY: !1, BUFFER_SCALE: 0.5, DIRTY_SUBMIT_FRAME_BINDINGS: !1, }, He = { LEFT: 'left', RIGHT: 'right' } function Ge(e) { var t = S({}, Ue) ;(e = S(t, e || {})), Ne.call(this, { wakelock: e.MOBILE_WAKE_LOCK }), (this.config = e), (this.displayName = 'Cardboard VRDisplay'), (this.capabilities = new ke({ hasPosition: !1, hasOrientation: !0, hasExternalDisplay: !1, canPresent: !0, maxLayers: 1, })), (this.stageParameters = null), (this.bufferScale_ = this.config.BUFFER_SCALE), (this.poseSensor_ = new we(this.config)), (this.distorter_ = null), (this.cardboardUI_ = null), (this.dpdb_ = new he( this.config.DPDB_URL, this.onDeviceParamsUpdated_.bind(this), )), (this.deviceInfo_ = new le( this.dpdb_.getDeviceParams(), e.ADDITIONAL_VIEWERS, )), (this.viewerSelector_ = new Se(e.DEFAULT_VIEWER)), this.viewerSelector_.onChange(this.onViewerChanged_.bind(this)), this.deviceInfo_.setViewer(this.viewerSelector_.getCurrentViewer()), this.config.ROTATE_INSTRUCTIONS_DISABLED || (this.rotateInstructions_ = new Ee()), l() && window.addEventListener('resize', this.onResize_.bind(this)) } return ( (Ge.prototype = Object.create(Ne.prototype)), (Ge.prototype._getPose = function () { return { position: null, orientation: this.poseSensor_.getOrientation(), linearVelocity: null, linearAcceleration: null, angularVelocity: null, angularAcceleration: null, } }), (Ge.prototype._resetPose = function () { this.poseSensor_.resetPose && this.poseSensor_.resetPose() }), (Ge.prototype._getFieldOfView = function (e) { var t if (e == He.LEFT) t = this.deviceInfo_.getFieldOfViewLeftEye() else { if (e != He.RIGHT) return console.error('Invalid eye provided: %s', e), null t = this.deviceInfo_.getFieldOfViewRightEye() } return t }), (Ge.prototype._getEyeOffset = function (e) { var t if (e == He.LEFT) t = [0.5 * -this.deviceInfo_.viewer.interLensDistance, 0, 0] else { if (e != He.RIGHT) return console.error('Invalid eye provided: %s', e), null t = [0.5 * this.deviceInfo_.viewer.interLensDistance, 0, 0] } return t }), (Ge.prototype.getEyeParameters = function (e) { var t = this._getEyeOffset(e), n = this._getFieldOfView(e), r = { offset: t, renderWidth: 0.5 * this.deviceInfo_.device.width * this.bufferScale_, renderHeight: this.deviceInfo_.device.height * this.bufferScale_, } return ( Object.defineProperty(r, 'fieldOfView', { enumerable: !0, get: function () { return ( I('VRFieldOfView', "VRFrameData's projection matrices"), n ) }, }), r ) }), (Ge.prototype.onDeviceParamsUpdated_ = function (e) { this.config.DEBUG && console.log('DPDB reported that device params were updated.'), this.deviceInfo_.updateDeviceParams(e), this.distorter_ && this.distorter_.updateDeviceInfo(this.deviceInfo_) }), (Ge.prototype.updateBounds_ = function () { this.layer_ && this.distorter_ && (this.layer_.leftBounds || this.layer_.rightBounds) && this.distorter_.setTextureBounds( this.layer_.leftBounds, this.layer_.rightBounds, ) }), (Ge.prototype.beginPresent_ = function () { var e = this.layer_.source.getContext('webgl') e || (e = this.layer_.source.getContext('experimental-webgl')), e || (e = this.layer_.source.getContext('webgl2')), e && (this.layer_.predistorted ? this.config.CARDBOARD_UI_DISABLED || ((e.canvas.width = y() * this.bufferScale_), (e.canvas.height = b() * this.bufferScale_), (this.cardboardUI_ = new J(e))) : (this.config.CARDBOARD_UI_DISABLED || (this.cardboardUI_ = new J(e)), (this.distorter_ = new U( e, this.cardboardUI_, this.config.BUFFER_SCALE, this.config.DIRTY_SUBMIT_FRAME_BINDINGS, )), this.distorter_.updateDeviceInfo(this.deviceInfo_)), this.cardboardUI_ && this.cardboardUI_.listen( function (e) { this.viewerSelector_.show( this.layer_.source.parentElement, ), e.stopPropagation(), e.preventDefault() }.bind(this), function (e) { this.exitPresent(), e.stopPropagation(), e.preventDefault() }.bind(this), ), this.rotateInstructions_ && (v() && T() ? this.rotateInstructions_.showTemporarily( 3e3, this.layer_.source.parentElement, ) : this.rotateInstructions_.update()), (this.orientationHandler = this.onOrientationChange_.bind(this)), window.addEventListener( 'orientationchange', this.orientationHandler, ), (this.vrdisplaypresentchangeHandler = this.updateBounds_.bind(this)), window.addEventListener( 'vrdisplaypresentchange', this.vrdisplaypresentchangeHandler, ), this.fireVRDisplayDeviceParamsChange_()) }), (Ge.prototype.endPresent_ = function () { this.distorter_ && (this.distorter_.destroy(), (this.distorter_ = null)), this.cardboardUI_ && (this.cardboardUI_.destroy(), (this.cardboardUI_ = null)), this.rotateInstructions_ && this.rotateInstructions_.hide(), this.viewerSelector_.hide(), window.removeEventListener( 'orientationchange', this.orientationHandler, ), window.removeEventListener( 'vrdisplaypresentchange', this.vrdisplaypresentchangeHandler, ) }), (Ge.prototype.updatePresent_ = function () { this.endPresent_(), this.beginPresent_() }), (Ge.prototype.submitFrame = function (e) { if (this.distorter_) this.updateBounds_(), this.distorter_.submitFrame() else if (this.cardboardUI_ && this.layer_) { var t = this.layer_.source.getContext('webgl') t || (t = this.layer_.source.getContext('experimental-webgl')), t || (t = this.layer_.source.getContext('webgl2')) var n = t.canvas ;(n.width == this.lastWidth && n.height == this.lastHeight) || this.cardboardUI_.onResize(), (this.lastWidth = n.width), (this.lastHeight = n.height), this.cardboardUI_.render() } }), (Ge.prototype.onOrientationChange_ = function (e) { this.viewerSelector_.hide(), this.rotateInstructions_ && this.rotateInstructions_.update(), this.onResize_() }), (Ge.prototype.onResize_ = function (e) { if (this.layer_) { var t = this.layer_.source.getContext('webgl') t || (t = this.layer_.source.getContext('experimental-webgl')), t || (t = this.layer_.source.getContext('webgl2')) var n = [ 'position: absolute', 'top: 0', 'left: 0', 'width: 100vw', 'height: 100vh', 'border: 0', 'margin: 0', 'padding: 0px', 'box-sizing: content-box', ] t.canvas.setAttribute('style', n.join('; ') + ';'), C(t.canvas) } }), (Ge.prototype.onViewerChanged_ = function (e) { this.deviceInfo_.setViewer(e), this.distorter_ && this.distorter_.updateDeviceInfo(this.deviceInfo_), this.fireVRDisplayDeviceParamsChange_() }), (Ge.prototype.fireVRDisplayDeviceParamsChange_ = function () { var e = new CustomEvent('vrdisplaydeviceparamschange', { detail: { vrdisplay: this, deviceInfo: this.deviceInfo_ }, }) window.dispatchEvent(e) }), (Ge.VRFrameData = Fe), (Ge.VRDisplay = Ne), Ge ) }), (e.exports = r()) }), ), l = '0.10.12', c = { ADDITIONAL_VIEWERS: [], DEFAULT_VIEWER: '', PROVIDE_MOBILE_VRDISPLAY: !0, MOBILE_WAKE_LOCK: !0, DEBUG: !1, DPDB_URL: 'https://dpdb.webvr.rocks/dpdb.json', K_FILTER: 0.98, PREDICTION_TIME_S: 0.04, CARDBOARD_UI_DISABLED: !1, ROTATE_INSTRUCTIONS_DISABLED: !1, YAW_ONLY: !1, BUFFER_SCALE: 0.5, DIRTY_SUBMIT_FRAME_BINDINGS: !1, } function u(e) { ;(this.config = a(a({}, c), e)), (this.polyfillDisplays = []), (this.enabled = !1), (this.hasNative = 'getVRDisplays' in navigator), (this.native = {}), (this.native.getVRDisplays = navigator.getVRDisplays), (this.native.VRFrameData = window.VRFrameData), (this.native.VRDisplay = window.VRDisplay), (!this.hasNative || (this.config.PROVIDE_MOBILE_VRDISPLAY && i())) && (this.enable(), this.getVRDisplays().then(function (e) { e && e[0] && e[0].fireVRDisplayConnect_ && e[0].fireVRDisplayConnect_() })) } ;(u.prototype.getPolyfillDisplays = function () { if (this._polyfillDisplaysPopulated) return this.polyfillDisplays if (i()) { var e = new s({ ADDITIONAL_VIEWERS: this.config.ADDITIONAL_VIEWERS, DEFAULT_VIEWER: this.config.DEFAULT_VIEWER, MOBILE_WAKE_LOCK: this.config.MOBILE_WAKE_LOCK, DEBUG: this.config.DEBUG, DPDB_URL: this.config.DPDB_URL, CARDBOARD_UI_DISABLED: this.config.CARDBOARD_UI_DISABLED, K_FILTER: this.config.K_FILTER, PREDICTION_TIME_S: this.config.PREDICTION_TIME_S, ROTATE_INSTRUCTIONS_DISABLED: this.config.ROTATE_INSTRUCTIONS_DISABLED, YAW_ONLY: this.config.YAW_ONLY, BUFFER_SCALE: this.config.BUFFER_SCALE, DIRTY_SUBMIT_FRAME_BINDINGS: this.config.DIRTY_SUBMIT_FRAME_BINDINGS, }) this.polyfillDisplays.push(e) } return (this._polyfillDisplaysPopulated = !0), this.polyfillDisplays }), (u.prototype.enable = function () { if (((this.enabled = !0), this.hasNative && this.native.VRFrameData)) { var e = this.native.VRFrameData, t = new this.native.VRFrameData(), n = this.native.VRDisplay.prototype.getFrameData window.VRDisplay.prototype.getFrameData = function (r) { r instanceof e ? n.call(this, r) : (n.call(this, t), (r.pose = t.pose), o(t.leftProjectionMatrix, r.leftProjectionMatrix), o(t.rightProjectionMatrix, r.rightProjectionMatrix), o(t.leftViewMatrix, r.leftViewMatrix), o(t.rightViewMatrix, r.rightViewMatrix)) } } ;(navigator.getVRDisplays = this.getVRDisplays.bind(this)), (window.VRDisplay = s.VRDisplay), (window.VRFrameData = s.VRFrameData) }), (u.prototype.getVRDisplays = function () { var e = this return ( this.config, this.hasNative ? this.native.getVRDisplays.call(navigator).then(function (t) { return t.length > 0 ? t : e.getPolyfillDisplays() }) : Promise.resolve(this.getPolyfillDisplays()) ) }), (u.version = l), (u.VRFrameData = s.VRFrameData), (u.VRDisplay = s.VRDisplay) var h = Object.freeze({ default: u }), d = (h && u) || h return ( 'undefined' !== typeof t && t.window && (t.document || (t.document = t.window.document), t.navigator || (t.navigator = t.window.navigator)), d ) }) }.call( this, 'undefined' !== typeof r.g ? r.g : 'undefined' !== typeof self ? self : 'undefined' !== typeof window ? window : {}, )) }, {}, ], 69: [ function (e, t, n) { var r = /\n/, i = '\n', o = /\s/ function a(e, t, n, r) { var i = e.indexOf(t, n) return -1 === i || i > r ? r : i } function s(e) { return o.test(e) } function l(e, t, n, i, o) { for (var a = [], s = n, l = n; l < i && l < t.length; l++) { var c = t.charAt(l), u = r.test(c) if (u || l === i - 1) { var h = e(t, s, u ? l : l + 1, o) a.push(h), (s = l + 1) } } return a } function c(e, t, n, r, o, l) { var c = [], u = o for ('nowrap' === l && (u = Number.MAX_VALUE); n < r && n < t.length; ) { for (var h = a(t, i, n, r); n < h && s(t.charAt(n)); ) n++ var d = e(t, n, h, u), p = n + (d.end - d.start), f = p + i.length if (p < h) { for (; p > n && !s(t.charAt(p)); ) p-- if (p === n) f > n + i.length && f--, (p = f) else for (f = p; p > n && s(t.charAt(p - i.length)); ) p-- } if (p >= n) { var m = e(t, n, p, u) c.push(m) } n = f } return c } function u(e, t, n, r) { return { start: t, end: t + Math.min(r, n - t) } } ;(t.exports = function (e, n) { return t.exports .lines(e, n) .map(function (t) { return e.substring(t.start, t.end) }) .join('\n') }), (t.exports.lines = function (e, t) { if (0 === (t = t || {}).width && 'nowrap' !== t.mode) return [] e = e || '' var n = 'number' === typeof t.width ? t.width : Number.MAX_VALUE, r = Math.max(0, t.start || 0), i = 'number' === typeof t.end ? t.end : e.length, o = t.mode, a = t.measure || u return 'pre' === o ? l(a, e, r, i, n) : c(a, e, r, i, n, o) }) }, {}, ], 70: [ function (t, n, r) { 'use strict' var i = t('global/window'), o = t('is-function'), a = t('parse-headers'), s = t('xtend') function l(e, t) { for (var n = 0; n < e.length; n++) t(e[n]) } function c(e) { for (var t in e) if (e.hasOwnProperty(t)) return !1 return !0 } function u(e, t, n) { var r = e return ( o(t) ? ((n = t), 'string' === typeof e && (r = { uri: e })) : (r = s(t, { uri: e })), (r.callback = n), r ) } function h(e, t, n) { return d((t = u(e, t, n))) } function d(t) { if ('undefined' === typeof t.callback) throw new Error('callback argument missing') var n = !1, r = function (e, r, i) { n || ((n = !0), t.callback(e, r, i)) } function i() { 4 === f.readyState && setTimeout(l, 0) } function o() { var t = void 0 if (((t = f.response ? f.response : f.responseText || p(f)), w)) try { t = JSON.parse(t) } catch (e) {} return t } function s(e) { return ( clearTimeout(m), e instanceof Error || (e = new Error('' + (e || 'Unknown XMLHttpRequest Error'))), (e.statusCode = 0), r(e, x) ) } function l() { if (!d) { var e clearTimeout(m), (e = t.useXDR && void 0 === f.status ? 200 : 1223 === f.status ? 204 : f.status) var n = x, i = null return ( 0 !== e ? ((n = { body: o(), statusCode: e, method: g, headers: {}, url: v, rawRequest: f, }), f.getAllResponseHeaders && (n.headers = a(f.getAllResponseHeaders()))) : (i = new Error('Internal XMLHttpRequest Error')), r(i, n, n.body) ) } } var u, d, f = t.xhr || null f || (f = t.cors || t.useXDR ? new h.XDomainRequest() : new h.XMLHttpRequest()) var m, v = (f.url = t.uri || t.url), g = (f.method = t.method || 'GET'), y = t.body || t.data, b = (f.headers = t.headers || {}), A = !!t.sync, w = !1, x = { body: void 0, headers: {}, statusCode: 0, method: g, url: v, rawRequest: f, } if ( ('json' in t && !1 !== t.json && ((w = !0), b.accept || b.Accept || (b.Accept = 'application/json'), 'GET' !== g && 'HEAD' !== g && (b['content-type'] || b['Content-Type'] || (b['Content-Type'] = 'application/json'), (y = JSON.stringify(!0 === t.json ? y : t.json)))), (f.onreadystatechange = i), (f.onload = l), (f.onerror = s), (f.onprogress = function () {}), (f.onabort = function () { d = !0 }), (f.ontimeout = s), f.open(g, v, !A, t.username, t.password), A || (f.withCredentials = !!t.withCredentials), !A && t.timeout > 0 && (m = setTimeout(function () { if (!d) { ;(d = !0), f.abort('timeout') var e = new Error('XMLHttpRequest timeout') ;(e.code = 'ETIMEDOUT'), s(e) } }, t.timeout)), f.setRequestHeader) ) for (u in b) b.hasOwnProperty(u) && f.setRequestHeader(u, b[u]) else if (t.headers && !c(t.headers)) throw new Error('Headers cannot be set on an XDomainRequest object') return ( 'responseType' in t && (f.responseType = t.responseType), 'beforeSend' in t && 'function' === typeof t.beforeSend && t.beforeSend(f), f.send(y || null), f ) } function p(t) { try { if ('document' === t.responseType) return t.responseXML var n = t.responseXML && 'parsererror' === t.responseXML.documentElement.nodeName if ('' === t.responseType && !n) return t.responseXML } catch (e) {} return null } function f() {} ;(n.exports = h), (n.exports.default = h), (h.XMLHttpRequest = i.XMLHttpRequest || f), (h.XDomainRequest = 'withCredentials' in new h.XMLHttpRequest() ? h.XMLHttpRequest : i.XDomainRequest), l(['get', 'put', 'post', 'patch', 'head', 'delete'], function (e) { h['delete' === e ? 'del' : e] = function (t, n, r) { return ((n = u(t, n, r)).method = e.toUpperCase()), d(n) } }) }, { 'global/window': 27, 'is-function': 33, 'parse-headers': 47, xtend: 72 }, ], 71: [ function (e, t, n) { t.exports = 'undefined' !== typeof self.DOMParser ? function (e) { return new self.DOMParser().parseFromString(e, 'application/xml') } : 'undefined' !== typeof self.ActiveXObject && new self.ActiveXObject('Microsoft.XMLDOM') ? function (e) { var t = new self.ActiveXObject('Microsoft.XMLDOM') return (t.async = 'false'), t.loadXML(e), t } : function (e) { var t = document.createElement('div') return (t.innerHTML = e), t } }, {}, ], 72: [ function (e, t, n) { t.exports = i var r = Object.prototype.hasOwnProperty function i() { for (var e = {}, t = 0; t < arguments.length; t++) { var n = arguments[t] for (var i in n) r.call(n, i) && (e[i] = n[i]) } return e } }, {}, ], 73: [ function (e, t, n) { t.exports = { name: 'aframe', version: '1.2.0', description: 'A web framework for building virtual reality experiences.', homepage: 'https://aframe.io/', main: 'dist/aframe-master.js', scripts: { browserify: "browserify src/index.js -s 'AFRAME' -p browserify-derequire", build: 'shx mkdir -p build/ && npm run browserify -- --debug -t [ envify --INSPECTOR_VERSION dev ] -o build/aframe.js', codecov: 'codecov', dev: 'npm run build && cross-env INSPECTOR_VERSION=dev node ./scripts/budo -t envify', dist: 'node scripts/updateVersionLog.js && npm run dist:min && npm run dist:max', 'dist:max': 'npm run browserify -s -- --debug | exorcist dist/aframe-master.js.map > dist/aframe-master.js', 'dist:min': 'npm run browserify -s -- --debug -p [ minifyify --map aframe-master.min.js.map --output dist/aframe-master.min.js.map ] -o dist/aframe-master.min.js', docs: 'markserv --dir docs --port 9001', preghpages: 'node ./scripts/preghpages.js', ghpages: 'ghpages -p gh-pages/', lint: 'semistandard -v | snazzy', 'lint:fix': 'semistandard --fix', precommit: 'npm run lint', prepush: 'node scripts/testOnlyCheck.js', prerelease: 'node scripts/release.js 1.0.4 1.1.0', start: 'npm run dev', 'start:https': 'cross-env SSL=true npm run dev', test: 'karma start ./tests/karma.conf.js', 'test:docs': 'node scripts/docsLint.js', 'test:firefox': 'npm test -- --browsers Firefox', 'test:chrome': 'npm test -- --browsers Chrome', 'test:nobrowser': 'NO_BROWSER=true npm test', 'test:node': 'mocha --ui tdd tests/node', }, repository: 'aframevr/aframe', license: 'MIT', files: ['dist/*', 'docs/**/*', 'src/**/*', 'vendor/**/*'], dependencies: { 'custom-event-polyfill': '^1.0.6', debug: 'ngokevin/debug#noTimestamp', 'deep-assign': '^2.0.0', 'document-register-element': 'dmarcos/document-register-element#8ccc532b7f3744be954574caf3072a5fd260ca90', 'load-bmfont': '^1.2.3', 'object-assign': '^4.0.1', present: '0.0.6', 'promise-polyfill': '^3.1.0', 'super-animejs': '^3.1.0', 'super-three': '^0.125.1', 'three-bmfont-text': 'dmarcos/three-bmfont-text#1babdf8507c731a18f8af3b807292e2b9740955e', 'webvr-polyfill': '^0.10.12', }, devDependencies: { browserify: '^13.1.0', 'browserify-css': '^0.8.4', 'browserify-derequire': '^0.9.4', 'browserify-istanbul': '^2.0.0', budo: '^9.2.0', chai: '^3.5.0', 'chai-shallow-deep-equal': '^1.4.0', chalk: '^1.1.3', codecov: '^1.0.1', 'cross-env': '^5.0.1', envify: '^3.4.1', exorcist: '^0.4.0', ghpages: '0.0.8', 'git-rev': '^0.2.1', glob: '^7.1.1', husky: '^0.11.7', istanbul: '^0.4.5', jsdom: '^9.11.0', karma: '1.4.1', 'karma-browserify': '^5.1.0', 'karma-chai-shallow-deep-equal': '0.0.4', 'karma-chrome-launcher': '^2.0.0', 'karma-coverage': '^1.1.1', 'karma-env-preprocessor': '^0.1.1', 'karma-firefox-launcher': '^1.2.0', 'karma-mocha': '^1.1.1', 'karma-mocha-reporter': '^2.1.0', 'karma-sinon-chai': '1.2.4', lolex: '^1.5.1', markserv: 'github:sukima/markserv#feature/fix-broken-websoketio-link', minifyify: '^7.3.3', mocha: '^3.0.2', 'mozilla-download': '^1.1.1', 'replace-in-file': '^2.5.3', semistandard: '^9.0.0', shelljs: '^0.7.7', shx: '^0.2.2', sinon: '^1.17.5', 'sinon-chai': '2.8.0', snazzy: '^5.0.0', 'too-wordy': 'ngokevin/too-wordy', uglifyjs: '^2.4.10', 'write-good': '^0.9.1', }, link: !0, browserify: { transform: ['browserify-css', 'envify'] }, semistandard: { ignore: ['build/**', 'dist/**', 'examples/**/shaders/*.js', '**/vendor/**'], }, keywords: [ '3d', 'aframe', 'cardboard', 'components', 'oculus', 'three', 'three.js', 'rift', 'vive', 'vr', 'web-components', 'webvr', ], 'browserify-css': { minify: !0 }, engines: { node: '>= 4.6.0', npm: '^2.15.9' }, } }, {}, ], 74: [ function (e, t, n) { var r = e('super-animejs'), i = e('../core/component').components, o = e('../core/component').registerComponent, a = e('../lib/three'), s = e('../utils'), l = new a.Color(), c = new a.Color(), u = s.entity.getComponentProperty, h = s.entity.setComponentProperty, d = {}, p = 'color', f = 'position', m = 'rotation', v = 'scale', g = 'components', y = 'object3D' function b(e, t) { var n, r, o, a return ( (r = (o = t.split('.'))[0]), (a = o[1]), (n = e.components[r] || i[r]) ? a && !n.schema[a] ? null : a ? n.schema[a].type : n.schema.type : null ) } function A(e) { ;(e.x = a.Math.degToRad(e.x)), (e.y = a.Math.degToRad(e.y)), (e.z = a.Math.degToRad(e.z)) } function w(e, t, n) { var r for (r = 0; r < t.length; r++) e.addEventListener(t[r], n) } function x(e, t, n) { var r for (r = 0; r < t.length; r++) e.removeEventListener(t[r], n) } function E(e, t) { var n, r, i for (r = _(t), i = e, n = 0; n < r.length; n++) i = i[r[n]] if (void 0 === i) throw ( (console.log(e), new Error('[animation] property (' + t + ') could not be found')) ) return i } function M(e, t, n, r) { var i, o, s, l for ( t.startsWith('object3D.rotation') && (n = a.Math.degToRad(n)), o = _(t), l = e, i = 0; i < o.length - 1; i++ ) l = l[o[i]] ;(s = o[o.length - 1]), r !== p ? (l[s] = n) : 'r' in l[s] ? ((l[s].r = n.r), (l[s].g = n.g), (l[s].b = n.b)) : ((l[s].x = n.r), (l[s].y = n.g), (l[s].z = n.b)) } function _(e) { return e in d || (d[e] = e.split('.')), d[e] } function T(e) { return e.isRawProperty || e.property.startsWith(g) || e.property.startsWith(y) } t.exports.Component = o('animation', { schema: { autoplay: { default: !0 }, delay: { default: 0 }, dir: { default: '' }, dur: { default: 1e3 }, easing: { default: 'easeInQuad' }, elasticity: { default: 400 }, enabled: { default: !0 }, from: { default: '' }, loop: { default: 0, parse: function (e) { return ( !0 === e || 'true' === e || (!1 !== e && 'false' !== e && parseInt(e, 10)) ) }, }, property: { default: '' }, startEvents: { type: 'array' }, pauseEvents: { type: 'array' }, resumeEvents: { type: 'array' }, round: { default: !1 }, to: { default: '' }, type: { default: '' }, isRawProperty: { default: !1 }, }, multiple: !0, init: function () { var e = this ;(this.eventDetail = { name: this.attrName }), (this.time = 0), (this.animation = null), (this.animationIsPlaying = !1), (this.onStartEvent = this.onStartEvent.bind(this)), (this.beginAnimation = this.beginAnimation.bind(this)), (this.pauseAnimation = this.pauseAnimation.bind(this)), (this.resumeAnimation = this.resumeAnimation.bind(this)), (this.fromColor = {}), (this.toColor = {}), (this.targets = {}), (this.targetsArray = []), (this.updateConfigForDefault = this.updateConfigForDefault.bind(this)), (this.updateConfigForRawColor = this.updateConfigForRawColor.bind(this)), (this.config = { complete: function () { ;(e.animationIsPlaying = !1), e.el.emit('animationcomplete', e.eventDetail, !1), e.id && e.el.emit('animationcomplete__' + e.id, e.eventDetail, !1) }, }) }, update: function (e) { var t = this.config, n = this.data ;(this.animationIsPlaying = !1), this.data.enabled && n.property && ((t.autoplay = !1), (t.direction = n.dir), (t.duration = n.dur), (t.easing = n.easing), (t.elasticity = n.elasticity), (t.loop = n.loop), (t.round = n.round), this.createAndStartAnimation()) }, tick: function (e, t) { this.animationIsPlaying && ((this.time += t), this.animation.tick(this.time)) }, remove: function () { this.pauseAnimation(), this.removeEventListeners() }, pause: function () { ;(this.paused = !0), (this.pausedWasPlaying = this.animationIsPlaying), this.pauseAnimation(), this.removeEventListeners() }, play: function () { this.paused && ((this.paused = !1), this.addEventListeners(), this.pausedWasPlaying && (this.resumeAnimation(), (this.pausedWasPlaying = !1))) }, createAndStartAnimation: function () { var e = this.data this.updateConfig(), (this.animationIsPlaying = !1), (this.animation = r(this.config)), (this.animation.began = !0), this.removeEventListeners(), this.addEventListeners(), !e.autoplay || (e.startEvents && e.startEvents.length) || (e.delay ? setTimeout(this.beginAnimation, e.delay) : this.beginAnimation()) }, beginAnimation: function () { this.updateConfig(), (this.animation.began = !0), (this.time = 0), (this.animationIsPlaying = !0), this.stopRelatedAnimations(), this.el.emit('animationbegin', this.eventDetail, !1) }, pauseAnimation: function () { this.animationIsPlaying = !1 }, resumeAnimation: function () { this.animationIsPlaying = !0 }, onStartEvent: function () { this.data.enabled && (this.updateConfig(), this.animation && this.animation.pause(), (this.animation = r(this.config)), this.data.delay ? setTimeout(this.beginAnimation, this.data.delay) : this.beginAnimation()) }, updateConfigForRawColor: function () { var e, t, n, r = this.config, i = this.data, o = this.el if (!this.waitComponentInitRawProperty(this.updateConfigForRawColor)) { for (t in ((e = '' === i.from ? E(o, i.property) : i.from), (n = i.to), this.setColorConfig(e, n), (e = this.fromColor), (n = this.toColor), (this.targetsArray.length = 0), this.targetsArray.push(e), (r.targets = this.targetsArray), n)) r[t] = n[t] r.update = (function () { var e = {} return function (t) { var n ;((n = t.animatables[0].target).r === e.r && n.g === e.g && n.b === e.b) || M(o, i.property, n, i.type) } })() } }, updateConfigForDefault: function () { var e, t, n, r = this.config, i = this.data, o = this.el this.waitComponentInitRawProperty(this.updateConfigForDefault) || ((e = '' === i.from ? (T(i) ? E(o, i.property) : u(o, i.property)) : i.from), (n = i.to), isNaN(e || n) ? ((e = e ? e.toString() : e), (n = n ? n.toString() : n)) : ((e = parseFloat(e)), (n = parseFloat(n))), (t = 'true' === i.to || 'false' === i.to || !0 === i.to || !1 === i.to) && ((e = 'true' === i.from || !0 === i.from ? 1 : 0), (n = 'true' === i.to || !0 === i.to ? 1 : 0)), (this.targets.aframeProperty = e), (r.targets = this.targets), (r.aframeProperty = n), (r.update = (function () { var e return function (n) { var r ;(r = n.animatables[0].target.aframeProperty) !== e && ((e = r), t && (r = r >= 1), T(i) ? M(o, i.property, r, i.type) : h(o, i.property, r)) } })())) }, updateConfigForVector: function () { var e, t, n, r = this.config, i = this.data, o = this.el for (e in ((t = '' !== i.from ? s.coordinates.parse(i.from) : u(o, i.property)), (n = s.coordinates.parse(i.to)), i.property === m && (A(t), A(n)), (this.targetsArray.length = 0), this.targetsArray.push(t), (r.targets = this.targetsArray), n)) r[e] = n[e] i.property !== f && i.property !== m && i.property !== v ? (r.update = (function () { var e = {} return function (t) { var n = t.animatables[0].target ;(n.x === e.x && n.y === e.y && n.z === e.z) || ((e.x = n.x), (e.y = n.y), (e.z = n.z), h(o, i.property, n)) } })()) : (r.update = (function () { var e = {} return function (t) { var n = t.animatables[0].target i.property === v && ((n.x = Math.max(1e-4, n.x)), (n.y = Math.max(1e-4, n.y)), (n.z = Math.max(1e-4, n.z))), (n.x === e.x && n.y === e.y && n.z === e.z) || ((e.x = n.x), (e.y = n.y), (e.z = n.z), o.object3D[i.property].set(n.x, n.y, n.z)) } })()) }, updateConfig: function () { var e ;(e = b(this.el, this.data.property)), T(this.data) && this.data.type === p ? this.updateConfigForRawColor() : 'vec2' === e || 'vec3' === e || 'vec4' === e ? this.updateConfigForVector() : this.updateConfigForDefault() }, waitComponentInitRawProperty: function (e) { var t, n = this.data, i = this.el, o = this return ( '' === n.from && !!n.property.startsWith(g) && ((t = _(n.property)[1]), !i.components[t] && (i.addEventListener('componentinitialized', function n(a) { a.detail.name === t && (e(), (o.animation = r(o.config)), i.removeEventListener('componentinitialized', n)) }), !0)) ) }, stopRelatedAnimations: function () { var e, t for (t in this.el.components) (e = this.el.components[t]), t !== this.attrName && 'animation' === e.name && e.animationIsPlaying && e.data.property === this.data.property && (e.animationIsPlaying = !1) }, addEventListeners: function () { var e = this.data, t = this.el w(t, e.startEvents, this.onStartEvent), w(t, e.pauseEvents, this.pauseAnimation), w(t, e.resumeEvents, this.resumeAnimation) }, removeEventListeners: function () { var e = this.data, t = this.el x(t, e.startEvents, this.onStartEvent), x(t, e.pauseEvents, this.pauseAnimation), x(t, e.resumeEvents, this.resumeAnimation) }, setColorConfig: function (e, t) { l.set(e), c.set(t), (e = this.fromColor), (t = this.toColor), (e.r = l.r), (e.g = l.g), (e.b = l.b), (t.r = c.r), (t.g = c.g), (t.b = c.b) }, }) }, { '../core/component': 131, '../lib/three': 179, '../utils': 205, 'super-animejs': 56, }, ], 75: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../lib/three') t.exports.Component = r('camera', { schema: { active: { default: !0 }, far: { default: 1e4 }, fov: { default: 80, min: 0 }, near: { default: 0.005, min: 0 }, spectator: { default: !1 }, zoom: { default: 1, min: 0 }, }, init: function () { var e, t = this.el ;(e = this.camera = new i.PerspectiveCamera()), t.setObject3D('camera', e) }, update: function (e) { var t = this.data, n = this.camera ;(n.aspect = t.aspect || window.innerWidth / window.innerHeight), (n.far = t.far), (n.fov = t.fov), (n.near = t.near), (n.zoom = t.zoom), n.updateProjectionMatrix(), this.updateActiveCamera(e), this.updateSpectatorCamera(e) }, updateActiveCamera: function (e) { var t = this.data, n = this.el, r = this.system ;(e && e.active === t.active) || t.spectator || (t.active && r.activeCameraEl !== n ? r.setActiveCamera(n) : t.active || r.activeCameraEl !== n || r.disableActiveCamera()) }, updateSpectatorCamera: function (e) { var t = this.data, n = this.el, r = this.system ;(e && e.spectator === t.spectator) || (t.spectator && r.spectatorCameraEl !== n ? r.setSpectatorCamera(n) : t.spectator || r.spectatorCameraEl !== n || r.disableSpectatorCamera()) }, remove: function () { this.el.removeObject3D('camera') }, }) }, { '../core/component': 131, '../lib/three': 179 }, ], 76: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/'), o = i.bind, a = { CLICK: 'click', FUSING: 'fusing', MOUSEENTER: 'mouseenter', MOUSEDOWN: 'mousedown', MOUSELEAVE: 'mouseleave', MOUSEUP: 'mouseup', }, s = { FUSING: 'cursor-fusing', HOVERING: 'cursor-hovering', HOVERED: 'cursor-hovered', }, l = { DOWN: ['mousedown', 'touchstart'], UP: ['mouseup', 'touchend'] }, c = { DOWN: ['selectstart'], UP: ['selectend'] }, u = 'a-mouse-cursor-hover' t.exports.Component = r('cursor', { dependencies: ['raycaster'], schema: { downEvents: { default: [] }, fuse: { default: i.device.isMobile() }, fuseTimeout: { default: 1500, min: 0 }, mouseCursorStylesEnabled: { default: !0 }, upEvents: { default: [] }, rayOrigin: { default: 'entity', oneOf: ['mouse', 'entity'] }, }, init: function () { var e = this ;(this.fuseTimeout = void 0), (this.cursorDownEl = null), (this.intersectedEl = null), (this.canvasBounds = document.body.getBoundingClientRect()), (this.isCursorDown = !1), (this.updateCanvasBounds = i.debounce(function () { e.canvasBounds = e.el.sceneEl.canvas.getBoundingClientRect() }, 500)), (this.eventDetail = {}), (this.intersectedEventDetail = { cursorEl: this.el }), (this.onCursorDown = o(this.onCursorDown, this)), (this.onCursorUp = o(this.onCursorUp, this)), (this.onIntersection = o(this.onIntersection, this)), (this.onIntersectionCleared = o(this.onIntersectionCleared, this)), (this.onMouseMove = o(this.onMouseMove, this)), (this.onEnterVR = o(this.onEnterVR, this)) }, update: function (e) { this.data.rayOrigin !== e.rayOrigin && this.updateMouseEventListeners() }, play: function () { this.addEventListeners() }, pause: function () { this.removeEventListeners() }, remove: function () { var e = this.el e.removeState(s.HOVERING), e.removeState(s.FUSING), clearTimeout(this.fuseTimeout), this.intersectedEl && this.intersectedEl.removeState(s.HOVERED), this.removeEventListeners() }, addEventListeners: function () { var e, t = this.data, n = this.el, r = this function i() { ;(e = n.sceneEl.canvas), t.downEvents.length || t.upEvents.length || (l.DOWN.forEach(function (t) { e.addEventListener(t, r.onCursorDown) }), l.UP.forEach(function (t) { e.addEventListener(t, r.onCursorUp) })) } ;(e = n.sceneEl.canvas) ? i() : n.sceneEl.addEventListener('render-target-loaded', i), t.downEvents.forEach(function (e) { n.addEventListener(e, r.onCursorDown) }), t.upEvents.forEach(function (e) { n.addEventListener(e, r.onCursorUp) }), n.addEventListener('raycaster-intersection', this.onIntersection), n.addEventListener( 'raycaster-intersection-cleared', this.onIntersectionCleared, ), n.sceneEl.addEventListener('rendererresize', this.updateCanvasBounds), n.sceneEl.addEventListener('enter-vr', this.onEnterVR), window.addEventListener('resize', this.updateCanvasBounds), window.addEventListener('scroll', this.updateCanvasBounds), this.updateMouseEventListeners() }, removeEventListeners: function () { var e, t = this.data, n = this.el, r = this !(e = n.sceneEl.canvas) || t.downEvents.length || t.upEvents.length || (l.DOWN.forEach(function (t) { e.removeEventListener(t, r.onCursorDown) }), l.UP.forEach(function (t) { e.removeEventListener(t, r.onCursorUp) })), t.downEvents.forEach(function (e) { n.removeEventListener(e, r.onCursorDown) }), t.upEvents.forEach(function (e) { n.removeEventListener(e, r.onCursorUp) }), n.removeEventListener('raycaster-intersection', this.onIntersection), n.removeEventListener( 'raycaster-intersection-cleared', this.onIntersectionCleared, ), e.removeEventListener('mousemove', this.onMouseMove), e.removeEventListener('touchstart', this.onMouseMove), e.removeEventListener('touchmove', this.onMouseMove), n.sceneEl.removeEventListener('rendererresize', this.updateCanvasBounds), n.sceneEl.removeEventListener('enter-vr', this.onEnterVR), window.removeEventListener('resize', this.updateCanvasBounds), window.removeEventListener('scroll', this.updateCanvasBounds) }, updateMouseEventListeners: function () { var e, t = this.el ;(e = t.sceneEl.canvas).removeEventListener('mousemove', this.onMouseMove), e.removeEventListener('touchmove', this.onMouseMove), t.setAttribute('raycaster', 'useWorldCoordinates', !1), 'mouse' === this.data.rayOrigin && (e.addEventListener('mousemove', this.onMouseMove, !1), e.addEventListener('touchmove', this.onMouseMove, !1), t.setAttribute('raycaster', 'useWorldCoordinates', !0), this.updateCanvasBounds()) }, onMouseMove: (function () { var e = new THREE.Vector3(), t = new THREE.Vector2(), n = new THREE.Vector3(), r = { origin: n, direction: e } return function (i) { var o, a, s, l = this.canvasBounds, c = this.el.sceneEl.camera c.parent.updateMatrixWorld(), (o = (a = 'touchmove' === i.type || 'touchstart' === i.type ? i.touches.item(0) : i).clientX - l.left), (s = a.clientY - l.top), (t.x = (o / l.width) * 2 - 1), (t.y = (-s / l.height) * 2 + 1), n.setFromMatrixPosition(c.matrixWorld), e.set(t.x, t.y, 0.5).unproject(c).sub(n).normalize(), this.el.setAttribute('raycaster', r), 'touchmove' === i.type && i.preventDefault() } })(), onCursorDown: function (e) { ;(this.isCursorDown = !0), 'mouse' === this.data.rayOrigin && 'touchstart' === e.type && (this.onMouseMove(e), this.el.components.raycaster.checkIntersections(), e.preventDefault()), this.twoWayEmit(a.MOUSEDOWN), (this.cursorDownEl = this.intersectedEl) }, onCursorUp: function (e) { if (this.isCursorDown) { this.isCursorDown = !1 var t = this.data this.twoWayEmit(a.MOUSEUP), this.cursorDownEl && this.cursorDownEl !== this.intersectedEl && ((this.intersectedEventDetail.intersection = null), this.cursorDownEl.emit(a.MOUSEUP, this.intersectedEventDetail)), (t.fuse && 'mouse' !== t.rayOrigin) || !this.intersectedEl || this.cursorDownEl !== this.intersectedEl || this.twoWayEmit(a.CLICK), (this.cursorDownEl = null), 'touchend' === e.type && e.preventDefault() } }, onIntersection: function (e) { var t, n, r, i, o = this.el ;(n = e.detail.els[0] === o ? 1 : 0), (i = e.detail.intersections[n]), (r = e.detail.els[n]) && this.intersectedEl !== r && ((this.intersectedEl && (t = this.el.components.raycaster.getIntersection(this.intersectedEl)) && t.distance <= i.distance) || (this.clearCurrentIntersection(!0), this.setIntersection(r, i))) }, onIntersectionCleared: function (e) { ;-1 !== e.detail.clearedEls.indexOf(this.intersectedEl) && this.clearCurrentIntersection() }, onEnterVR: function () { this.clearCurrentIntersection(!0) var e = this.el.sceneEl.xrSession, t = this e && 'mouse' !== this.data.rayOrigin && (c.DOWN.forEach(function (n) { e.addEventListener(n, t.onCursorDown) }), c.UP.forEach(function (n) { e.addEventListener(n, t.onCursorUp) })) }, setIntersection: function (e, t) { var n = this.el, r = this.data, i = this this.intersectedEl !== e && ((this.intersectedEl = e), n.addState(s.HOVERING), e.addState(s.HOVERED), this.twoWayEmit(a.MOUSEENTER), this.data.mouseCursorStylesEnabled && 'mouse' === this.data.rayOrigin && this.el.sceneEl.canvas.classList.add(u), 0 !== r.fuseTimeout && r.fuse && (n.addState(s.FUSING), this.twoWayEmit(a.FUSING), (this.fuseTimeout = setTimeout(function () { n.removeState(s.FUSING), i.twoWayEmit(a.CLICK) }, r.fuseTimeout)))) }, clearCurrentIntersection: function (e) { var t, n, r = this.el this.intersectedEl && (this.intersectedEl.removeState(s.HOVERED), r.removeState(s.HOVERING), r.removeState(s.FUSING), this.twoWayEmit(a.MOUSELEAVE), this.data.mouseCursorStylesEnabled && 'mouse' === this.data.rayOrigin && this.el.sceneEl.canvas.classList.remove(u), (this.intersectedEl = null), clearTimeout(this.fuseTimeout), !0 !== e && 0 !== (n = this.el.components.raycaster.intersections).length && (t = n[n[0].object.el === r ? 1 : 0]) && this.setIntersection(t.object.el, t)) }, twoWayEmit: function (e) { var t, n = this.el, r = this.intersectedEl ;(t = this.el.components.raycaster.getIntersection(r)), (this.eventDetail.intersectedEl = r), (this.eventDetail.intersection = t), n.emit(e, this.eventDetail), r && ((this.intersectedEventDetail.intersection = t), r.emit(e, this.intersectedEventDetail)) }, }) }, { '../core/component': 131, '../utils/': 205 }, ], 77: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/bind'), o = e('../utils/tracked-controls'), a = o.checkControllerPresentAndSetup, s = o.emitIfAxesChanged, l = o.onButtonEvent, c = 'https://cdn.aframe.io/controllers/google/', u = c + 'vr_controller_daydream.obj', h = c + 'vr_controller_daydream.mtl', d = e('../utils/').device.isWebXRAvailable, p = d ? 'google-daydream' : 'Daydream Controller', f = d ? { axes: { touchpad: [0, 1] }, buttons: ['none', 'none', 'touchpad', 'menu', 'system'], } : { axes: { trackpad: [0, 1] }, buttons: ['trackpad', 'menu', 'system'] } t.exports.Component = r('daydream-controls', { schema: { hand: { default: '' }, buttonColor: { type: 'color', default: '#000000' }, buttonTouchedColor: { type: 'color', default: '#777777' }, buttonHighlightColor: { type: 'color', default: '#FFFFFF' }, model: { default: !0 }, orientationOffset: { type: 'vec3' }, armModel: { default: !0 }, }, mapping: f, bindMethods: function () { ;(this.onModelLoaded = i(this.onModelLoaded, this)), (this.onControllersUpdate = i(this.onControllersUpdate, this)), (this.checkIfControllerPresent = i(this.checkIfControllerPresent, this)), (this.removeControllersUpdateListener = i( this.removeControllersUpdateListener, this, )), (this.onAxisMoved = i(this.onAxisMoved, this)) }, init: function () { var e = this ;(this.onButtonChanged = i(this.onButtonChanged, this)), (this.onButtonDown = function (t) { l(t.detail.id, 'down', e) }), (this.onButtonUp = function (t) { l(t.detail.id, 'up', e) }), (this.onButtonTouchStart = function (t) { l(t.detail.id, 'touchstart', e) }), (this.onButtonTouchEnd = function (t) { l(t.detail.id, 'touchend', e) }), (this.controllerPresent = !1), (this.lastControllerCheck = 0), this.bindMethods() }, addEventListeners: function () { var e = this.el e.addEventListener('buttonchanged', this.onButtonChanged), e.addEventListener('buttondown', this.onButtonDown), e.addEventListener('buttonup', this.onButtonUp), e.addEventListener('touchstart', this.onButtonTouchStart), e.addEventListener('touchend', this.onButtonTouchEnd), e.addEventListener('model-loaded', this.onModelLoaded), e.addEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !0) }, removeEventListeners: function () { var e = this.el e.removeEventListener('buttonchanged', this.onButtonChanged), e.removeEventListener('buttondown', this.onButtonDown), e.removeEventListener('buttonup', this.onButtonUp), e.removeEventListener('touchstart', this.onButtonTouchStart), e.removeEventListener('touchend', this.onButtonTouchEnd), e.removeEventListener('model-loaded', this.onModelLoaded), e.removeEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !1) }, checkIfControllerPresent: function () { a(this, p, this.data.hand ? { hand: this.data.hand } : {}) }, play: function () { this.checkIfControllerPresent(), this.addControllersUpdateListener() }, pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, injectTrackedControls: function () { var e = this.el, t = this.data e.setAttribute('tracked-controls', { armModel: t.armModel, hand: t.hand, idPrefix: p, id: p, orientationOffset: t.orientationOffset, }), this.data.model && this.el.setAttribute('obj-model', { obj: u, mtl: h }) }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { this.checkIfControllerPresent() }, onModelLoaded: function (e) { var t, n = e.detail.model this.data.model && (((t = this.buttonMeshes = {}).menu = n.getObjectByName( 'AppButton_AppButton_Cylinder.004', )), (t.system = n.getObjectByName('HomeButton_HomeButton_Cylinder.005')), (t.trackpad = n.getObjectByName('TouchPad_TouchPad_Cylinder.003')), (t.touchpad = n.getObjectByName('TouchPad_TouchPad_Cylinder.003')), n.position.set(0, 0, -0.04)) }, onAxisMoved: function (e) { s(this, this.mapping.axes, e) }, onButtonChanged: function (e) { var t = this.mapping.buttons[e.detail.id] t && this.el.emit(t + 'changed', e.detail.state) }, updateModel: function (e, t) { this.data.model && this.updateButtonModel(e, t) }, updateButtonModel: function (e, t) { var n = this.buttonMeshes if (n && n[e]) { var r switch (t) { case 'down': r = this.data.buttonHighlightColor break case 'touchstart': r = this.data.buttonTouchedColor break default: r = this.data.buttonColor } n[e].material.color.set(r) } }, }) }, { '../core/component': 131, '../utils/': 205, '../utils/bind': 199, '../utils/tracked-controls': 214, }, ], 78: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/bind'), o = e('../utils/tracked-controls'), a = o.checkControllerPresentAndSetup, s = o.emitIfAxesChanged, l = o.onButtonEvent, c = e('../utils/').device.isWebXRAvailable, u = 'https://cdn.aframe.io/controllers/samsung/', h = u + 'gear_vr_controller.obj', d = u + 'gear_vr_controller.mtl', p = c ? 'samsung-gearvr' : 'Gear VR', f = c ? { axes: { touchpad: [0, 1] }, buttons: ['trigger', 'none', 'touchpad', 'none', 'menu'], } : { axes: { trackpad: [0, 1] }, buttons: ['trackpad', 'trigger'] } t.exports.Component = r('gearvr-controls', { schema: { hand: { default: '' }, buttonColor: { type: 'color', default: '#000000' }, buttonTouchedColor: { type: 'color', default: '#777777' }, buttonHighlightColor: { type: 'color', default: '#FFFFFF' }, model: { default: !0 }, orientationOffset: { type: 'vec3' }, armModel: { default: !0 }, }, mapping: f, bindMethods: function () { ;(this.onModelLoaded = i(this.onModelLoaded, this)), (this.onControllersUpdate = i(this.onControllersUpdate, this)), (this.checkIfControllerPresent = i(this.checkIfControllerPresent, this)), (this.removeControllersUpdateListener = i( this.removeControllersUpdateListener, this, )), (this.onAxisMoved = i(this.onAxisMoved, this)) }, init: function () { var e = this ;(this.onButtonChanged = i(this.onButtonChanged, this)), (this.onButtonDown = function (t) { l(t.detail.id, 'down', e) }), (this.onButtonUp = function (t) { l(t.detail.id, 'up', e) }), (this.onButtonTouchStart = function (t) { l(t.detail.id, 'touchstart', e) }), (this.onButtonTouchEnd = function (t) { l(t.detail.id, 'touchend', e) }), (this.controllerPresent = !1), (this.lastControllerCheck = 0), this.bindMethods() }, addEventListeners: function () { var e = this.el e.addEventListener('buttonchanged', this.onButtonChanged), e.addEventListener('buttondown', this.onButtonDown), e.addEventListener('buttonup', this.onButtonUp), e.addEventListener('touchstart', this.onButtonTouchStart), e.addEventListener('touchend', this.onButtonTouchEnd), e.addEventListener('model-loaded', this.onModelLoaded), e.addEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !0) }, removeEventListeners: function () { var e = this.el e.removeEventListener('buttonchanged', this.onButtonChanged), e.removeEventListener('buttondown', this.onButtonDown), e.removeEventListener('buttonup', this.onButtonUp), e.removeEventListener('touchstart', this.onButtonTouchStart), e.removeEventListener('touchend', this.onButtonTouchEnd), e.removeEventListener('model-loaded', this.onModelLoaded), e.removeEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !1) }, checkIfControllerPresent: function () { a(this, p, this.data.hand ? { hand: this.data.hand } : {}) }, play: function () { this.checkIfControllerPresent(), this.addControllersUpdateListener() }, pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, injectTrackedControls: function () { var e = this.el, t = this.data e.setAttribute('tracked-controls', { armModel: t.armModel, hand: t.hand, idPrefix: p, id: p, orientationOffset: t.orientationOffset, }), this.data.model && this.el.setAttribute('obj-model', { obj: h, mtl: d }) }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { this.checkIfControllerPresent() }, onModelLoaded: function (e) { var t, n = e.detail.model this.data.model && (((t = this.buttonMeshes = {}).trigger = n.children[2]), (t.trackpad = n.children[1]), (t.touchpad = n.children[1])) }, onButtonChanged: function (e) { var t = this.mapping.buttons[e.detail.id] t && this.el.emit(t + 'changed', e.detail.state) }, onAxisMoved: function (e) { s(this, this.mapping.axes, e) }, updateModel: function (e, t) { this.data.model && this.updateButtonModel(e, t) }, updateButtonModel: function (e, t) { var n = this.buttonMeshes if (n && n[e]) { var r switch (t) { case 'down': r = this.data.buttonHighlightColor break case 'touchstart': r = this.data.buttonTouchedColor break default: r = this.data.buttonColor } n[e].material.color.set(r) } }, }) }, { '../core/component': 131, '../utils/': 205, '../utils/bind': 199, '../utils/tracked-controls': 214, }, ], 79: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/bind'), o = e('../utils/tracked-controls'), a = o.checkControllerPresentAndSetup, s = o.emitIfAxesChanged, l = o.onButtonEvent, c = 'generic', u = { axes: { touchpad: [0, 1], thumbstick: [2, 3] }, buttons: ['trigger', 'squeeze', 'touchpad', 'thumbstick'], } t.exports.Component = r('generic-tracked-controller-controls', { schema: { hand: { default: '' }, defaultModel: { default: !0 }, defaultModelColor: { default: 'gray' }, orientationOffset: { type: 'vec3' }, disabled: { default: !1 }, }, mapping: u, bindMethods: function () { ;(this.onControllersUpdate = i(this.onControllersUpdate, this)), (this.checkIfControllerPresent = i(this.checkIfControllerPresent, this)), (this.removeControllersUpdateListener = i( this.removeControllersUpdateListener, this, )), (this.onAxisMoved = i(this.onAxisMoved, this)) }, init: function () { var e = this ;(this.onButtonChanged = i(this.onButtonChanged, this)), (this.onButtonDown = function (t) { l(t.detail.id, 'down', e) }), (this.onButtonUp = function (t) { l(t.detail.id, 'up', e) }), (this.onButtonTouchStart = function (t) { l(t.detail.id, 'touchstart', e) }), (this.onButtonTouchEnd = function (t) { l(t.detail.id, 'touchend', e) }), (this.controllerPresent = !1), (this.wasControllerConnected = !1), (this.lastControllerCheck = 0), (this.rendererSystem = this.el.sceneEl.systems.renderer), this.bindMethods(), this.el.addEventListener('controllerconnected', function (t) { t.detail.name !== e.name && ((e.wasControllerConnected = !0), e.removeEventListeners(), e.removeControllersUpdateListener()) }) }, addEventListeners: function () { var e = this.el e.addEventListener('buttonchanged', this.onButtonChanged), e.addEventListener('buttondown', this.onButtonDown), e.addEventListener('buttonup', this.onButtonUp), e.addEventListener('touchstart', this.onButtonTouchStart), e.addEventListener('touchend', this.onButtonTouchEnd), e.addEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !0) }, removeEventListeners: function () { var e = this.el e.removeEventListener('buttonchanged', this.onButtonChanged), e.removeEventListener('buttondown', this.onButtonDown), e.removeEventListener('buttonup', this.onButtonUp), e.removeEventListener('touchstart', this.onButtonTouchStart), e.removeEventListener('touchend', this.onButtonTouchEnd), e.removeEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !1) }, checkIfControllerPresent: function () { var e = this.data, t = e.hand ? e.hand : void 0 a(this, c, { hand: t, iterateControllerProfiles: !0 }) }, play: function () { this.wasControllerConnected || (this.checkIfControllerPresent(), this.addControllersUpdateListener()) }, pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, injectTrackedControls: function () { var e = this.el, t = this.data this.el.components['tracked-controls'] ? this.removeEventListeners() : (e.setAttribute('tracked-controls', { hand: t.hand, idPrefix: c, orientationOffset: t.orientationOffset, iterateControllerProfiles: !0, }), this.data.defaultModel && this.initDefaultModel()) }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { this.checkIfControllerPresent() }, onButtonChanged: function (e) { var t = this.mapping.buttons[e.detail.id] t && this.el.emit(t + 'changed', e.detail.state) }, onAxisMoved: function (e) { s(this, this.mapping.axes, e) }, initDefaultModel: function () { var e = (this.modelEl = document.createElement('a-entity')) e.setAttribute('geometry', { primitive: 'sphere', radius: 0.03 }), e.setAttribute('material', { color: this.data.color }), this.el.appendChild(e) }, }) }, { '../core/component': 131, '../utils/bind': 199, '../utils/tracked-controls': 214 }, ], 80: [ function (e, t, n) { var r = e('../core/geometry').geometries, i = e('../core/geometry').geometryNames, o = e('../core/component').registerComponent, a = e('../lib/three'), s = new a.BufferGeometry() t.exports.Component = o('geometry', { schema: { buffer: { default: !0 }, primitive: { default: 'box', oneOf: i, schemaChange: !0 }, skipCache: { default: !1 }, }, init: function () { this.geometry = null }, update: function (e) { var t, n = this.data, r = this.el, i = this.system this.geometry && (i.unuseGeometry(e), (this.geometry = null)), (this.geometry = i.getOrCreateGeometry(n)), (t = r.getObject3D('mesh')) ? (t.geometry = this.geometry) : (((t = new a.Mesh()).geometry = this.geometry), this.el.getAttribute('material') || (t.material = new a.MeshStandardMaterial({ color: 16777215 * Math.random(), metalness: 0, roughness: 0.5, })), r.setObject3D('mesh', t)) }, remove: function () { this.system.unuseGeometry(this.data), (this.el.getObject3D('mesh').geometry = s), (this.geometry = null) }, updateSchema: function (e) { var t = this.oldData && this.oldData.primitive, n = e.primitive, i = r[n] && r[n].schema if (!i) throw new Error('Unknown geometry schema `' + n + '`') ;(t && t === n) || this.extendSchema(i) }, }) }, { '../core/component': 131, '../core/geometry': 132, '../lib/three': 179 }, ], 81: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../lib/three'), o = e('../utils/').debug('components:gltf-model:warn') t.exports.Component = r('gltf-model', { schema: { type: 'model' }, init: function () { var e = this.system.getDRACOLoader() ;(this.model = null), (this.loader = new i.GLTFLoader()), e && this.loader.setDRACOLoader(e) }, update: function () { var e = this, t = this.el, n = this.data n && (this.remove(), this.loader.load( n, function (n) { ;(e.model = n.scene || n.scenes[0]), (e.model.animations = n.animations), t.setObject3D('mesh', e.model), t.emit('model-loaded', { format: 'gltf', model: e.model }) }, void 0, function (e) { var r = e && e.message ? e.message : 'Failed to load glTF model' o(r), t.emit('model-error', { format: 'gltf', src: n }) }, )) }, remove: function () { this.model && this.el.removeObject3D('mesh') }, }) }, { '../core/component': 131, '../lib/three': 179, '../utils/': 205 }, ], 82: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = { toonLeft: 'https://cdn.aframe.io/controllers/hands/leftHand.glb', toonRight: 'https://cdn.aframe.io/controllers/hands/rightHand.glb', lowPolyLeft: 'https://cdn.aframe.io/controllers/hands/leftHandLow.glb', lowPolyRight: 'https://cdn.aframe.io/controllers/hands/rightHandLow.glb', highPolyLeft: 'https://cdn.aframe.io/controllers/hands/leftHandHigh.glb', highPolyRight: 'https://cdn.aframe.io/controllers/hands/rightHandHigh.glb', }, o = { open: 'Open', point: 'Point', pointThumb: 'Point + Thumb', fist: 'Fist', hold: 'Hold', thumbUp: 'Thumb Up', }, a = {} function s(e, t) { var n if (e) return 'grip' === (n = a[e]) ? n + (t ? 'close' : 'open') : 'point' === n ? n + (t ? 'up' : 'down') : 'pointing' === n || 'pistol' === n ? n + (t ? 'start' : 'end') : void 0 } function l(e) { var t = e && e.controller return ( t && ((t.id && 0 === t.id.indexOf('OpenVR ')) || (t.profiles && t.profiles[0] && 'htc-vive-controller-mv' === t.profiles[0])) ) } ;(a[o.fist] = 'grip'), (a[o.thumbUp] = 'pistol'), (a[o.point] = 'pointing'), (t.exports.Component = r('hand-controls', { schema: { color: { default: 'white', type: 'color' }, hand: { default: 'left' }, handModelStyle: { default: 'lowPoly', oneOf: ['lowPoly', 'highPoly', 'toon'], }, }, init: function () { var e = this, t = this.el ;(this.gesture = o.open), (this.pressedButtons = {}), (this.touchedButtons = {}), (this.loader = new THREE.GLTFLoader()), this.loader.setCrossOrigin('anonymous'), (this.onGripDown = function () { e.handleButton('grip', 'down') }), (this.onGripUp = function () { e.handleButton('grip', 'up') }), (this.onTrackpadDown = function () { e.handleButton('trackpad', 'down') }), (this.onTrackpadUp = function () { e.handleButton('trackpad', 'up') }), (this.onTrackpadTouchStart = function () { e.handleButton('trackpad', 'touchstart') }), (this.onTrackpadTouchEnd = function () { e.handleButton('trackpad', 'touchend') }), (this.onTriggerDown = function () { e.handleButton('trigger', 'down') }), (this.onTriggerUp = function () { e.handleButton('trigger', 'up') }), (this.onTriggerTouchStart = function () { e.handleButton('trigger', 'touchstart') }), (this.onTriggerTouchEnd = function () { e.handleButton('trigger', 'touchend') }), (this.onGripTouchStart = function () { e.handleButton('grip', 'touchstart') }), (this.onGripTouchEnd = function () { e.handleButton('grip', 'touchend') }), (this.onThumbstickDown = function () { e.handleButton('thumbstick', 'down') }), (this.onThumbstickUp = function () { e.handleButton('thumbstick', 'up') }), (this.onAorXTouchStart = function () { e.handleButton('AorX', 'touchstart') }), (this.onAorXTouchEnd = function () { e.handleButton('AorX', 'touchend') }), (this.onBorYTouchStart = function () { e.handleButton('BorY', 'touchstart') }), (this.onBorYTouchEnd = function () { e.handleButton('BorY', 'touchend') }), (this.onSurfaceTouchStart = function () { e.handleButton('surface', 'touchstart') }), (this.onSurfaceTouchEnd = function () { e.handleButton('surface', 'touchend') }), (this.onControllerConnected = this.onControllerConnected.bind(this)), (this.onControllerDisconnected = this.onControllerDisconnected.bind(this)), t.addEventListener('controllerconnected', this.onControllerConnected), t.addEventListener('controllerdisconnected', this.onControllerDisconnected), (t.object3D.visible = !1) }, play: function () { this.addEventListeners() }, pause: function () { this.removeEventListeners() }, tick: function (e, t) { var n = this.el.getObject3D('mesh') n && n.mixer && n.mixer.update(t / 1e3) }, onControllerConnected: function () { this.el.object3D.visible = !0 }, onControllerDisconnected: function () { this.el.object3D.visible = !1 }, addEventListeners: function () { var e = this.el e.addEventListener('gripdown', this.onGripDown), e.addEventListener('gripup', this.onGripUp), e.addEventListener('trackpaddown', this.onTrackpadDown), e.addEventListener('trackpadup', this.onTrackpadUp), e.addEventListener('trackpadtouchstart', this.onTrackpadTouchStart), e.addEventListener('trackpadtouchend', this.onTrackpadTouchEnd), e.addEventListener('triggerdown', this.onTriggerDown), e.addEventListener('triggerup', this.onTriggerUp), e.addEventListener('triggertouchstart', this.onTriggerTouchStart), e.addEventListener('triggertouchend', this.onTriggerTouchEnd), e.addEventListener('griptouchstart', this.onGripTouchStart), e.addEventListener('griptouchend', this.onGripTouchEnd), e.addEventListener('thumbstickdown', this.onThumbstickDown), e.addEventListener('thumbstickup', this.onThumbstickUp), e.addEventListener('abuttontouchstart', this.onAorXTouchStart), e.addEventListener('abuttontouchend', this.onAorXTouchEnd), e.addEventListener('bbuttontouchstart', this.onBorYTouchStart), e.addEventListener('bbuttontouchend', this.onBorYTouchEnd), e.addEventListener('xbuttontouchstart', this.onAorXTouchStart), e.addEventListener('xbuttontouchend', this.onAorXTouchEnd), e.addEventListener('ybuttontouchstart', this.onBorYTouchStart), e.addEventListener('ybuttontouchend', this.onBorYTouchEnd), e.addEventListener('surfacetouchstart', this.onSurfaceTouchStart), e.addEventListener('surfacetouchend', this.onSurfaceTouchEnd) }, removeEventListeners: function () { var e = this.el e.removeEventListener('gripdown', this.onGripDown), e.removeEventListener('gripup', this.onGripUp), e.removeEventListener('trackpaddown', this.onTrackpadDown), e.removeEventListener('trackpadup', this.onTrackpadUp), e.removeEventListener('trackpadtouchstart', this.onTrackpadTouchStart), e.removeEventListener('trackpadtouchend', this.onTrackpadTouchEnd), e.removeEventListener('triggerdown', this.onTriggerDown), e.removeEventListener('triggerup', this.onTriggerUp), e.removeEventListener('triggertouchstart', this.onTriggerTouchStart), e.removeEventListener('triggertouchend', this.onTriggerTouchEnd), e.removeEventListener('griptouchstart', this.onGripTouchStart), e.removeEventListener('griptouchend', this.onGripTouchEnd), e.removeEventListener('thumbstickdown', this.onThumbstickDown), e.removeEventListener('thumbstickup', this.onThumbstickUp), e.removeEventListener('abuttontouchstart', this.onAorXTouchStart), e.removeEventListener('abuttontouchend', this.onAorXTouchEnd), e.removeEventListener('bbuttontouchstart', this.onBorYTouchStart), e.removeEventListener('bbuttontouchend', this.onBorYTouchEnd), e.removeEventListener('xbuttontouchstart', this.onAorXTouchStart), e.removeEventListener('xbuttontouchend', this.onAorXTouchEnd), e.removeEventListener('ybuttontouchstart', this.onBorYTouchStart), e.removeEventListener('ybuttontouchend', this.onBorYTouchEnd), e.removeEventListener('surfacetouchstart', this.onSurfaceTouchStart), e.removeEventListener('surfacetouchend', this.onSurfaceTouchEnd) }, update: function (e) { var t, n = this.el, r = this.data.hand, o = this.data.handModelStyle, a = this.data.color, s = this if (((t = { hand: r, model: !1 }), r !== e)) { var l = i[o + r.charAt(0).toUpperCase() + r.slice(1)] this.loader.load(l, function (e) { var i = e.scene.children[0], o = 'left' === r ? Math.PI / 2 : -Math.PI / 2 ;(i.mixer = new THREE.AnimationMixer(i)), (s.clips = e.animations), n.setObject3D('mesh', i), (i.children[1].material.color = new THREE.Color(a)), i.position.set(0, 0, 0), i.rotation.set(0, 0, o), n.setAttribute('magicleap-controls', t), n.setAttribute('vive-controls', t), n.setAttribute('oculus-touch-controls', t), n.setAttribute('windows-motion-controls', t) }) } }, remove: function () { this.el.removeObject3D('mesh') }, handleButton: function (e, t) { var n, r = 'down' === t, i = 'touchstart' === t if (0 === t.indexOf('touch')) { if (i === this.touchedButtons[e]) return this.touchedButtons[e] = i } else { if (r === this.pressedButtons[e]) return this.pressedButtons[e] = r } ;(n = this.gesture), (this.gesture = this.determineGesture()), this.gesture !== n && (this.animateGesture(this.gesture, n), this.emitGestureEvents(this.gesture, n)) }, determineGesture: function () { var e, t = this.pressedButtons.grip, n = this.pressedButtons.surface || this.touchedButtons.surface, r = this.pressedButtons.trackpad || this.touchedButtons.trackpad, i = this.pressedButtons.trigger || this.touchedButtons.trigger, a = this.touchedButtons.AorX || this.touchedButtons.BorY return ( l(this.el.components['tracked-controls']) ? t || i ? (e = o.fist) : r && (e = o.point) : t ? (e = n || a || r ? (i ? o.fist : o.point) : i ? o.thumbUp : o.pointThumb) : i && (e = o.hold), e ) }, getClip: function (e) { var t, n for (n = 0; n < this.clips.length; n++) if ((t = this.clips[n]).name === e) return t }, animateGesture: function (e, t) { e ? this.playAnimation(e || o.open, t, !1) : this.playAnimation(t, t, !0) }, emitGestureEvents: function (e, t) { var n, r = this.el t !== e && ((n = s(t, !1)) && r.emit(n), (n = s(e, !0)) && r.emit(n)) }, playAnimation: function (e, t, n) { var r, i, o, a = this.el.getObject3D('mesh') if (a) { if ( (a.mixer.stopAllAction(), (r = this.getClip(e)), ((o = a.mixer.clipAction(r)).clampWhenFinished = !0), (o.loop = THREE.LoopRepeat), (o.repetitions = 0), (o.timeScale = n ? -1 : 1), (o.time = n ? r.duration : 0), (o.weight = 1), !t || e === t) ) return a.mixer.stopAllAction(), void o.play() ;(r = this.getClip(t)), ((i = a.mixer.clipAction(r)).weight = 0.15), i.play(), o.play(), i.crossFadeTo(o, 0.15, !0) } }, })) }, { '../core/component': 131 }, ], 83: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/bind'), o = e('../utils/tracked-controls').checkControllerPresentAndSetup, a = 'https://cdn.aframe.io/controllers/oculus-hands/unity/left.glb', s = 'https://cdn.aframe.io/controllers/oculus-hands/unity/right.glb', l = { left: 'b_l_', right: 'b_r_' }, c = [ 'wrist', 'thumb-metacarpal', 'thumb-phalanx-proximal', 'thumb-phalanx-distal', 'thumb-tip', 'index-finger-metacarpal', 'index-finger-phalanx-proximal', 'index-finger-phalanx-intermediate', 'index-finger-phalanx-distal', 'index-finger-tip', 'middle-finger-metacarpal', 'middle-finger-phalanx-proximal', 'middle-finger-phalanx-intermediate', 'middle-finger-phalanx-distal', 'middle-finger-tip', 'ring-finger-metacarpal', 'ring-finger-phalanx-proximal', 'ring-finger-phalanx-intermediate', 'ring-finger-phalanx-distal', 'ring-finger-tip', 'pinky-finger-metacarpal', 'pinky-finger-phalanx-proximal', 'pinky-finger-phalanx-intermediate', 'pinky-finger-phalanx-distal', 'pinky-finger-tip', ], u = { wrist: 'wrist', 'thumb-metacarpal': 'thumb1', 'thumb-phalanx-proximal': 'thumb2', 'thumb-phalanx-distal': 'thumb3', 'thumb-tip': 'thumb_null', 'index-finger-phalanx-proximal': 'index1', 'index-finger-phalanx-intermediate': 'index2', 'index-finger-phalanx-distal': 'index3', 'index-finger-tip': 'index_null', 'middle-finger-phalanx-proximal': 'middle1', 'middle-finger-phalanx-intermediate': 'middle2', 'middle-finger-phalanx-distal': 'middle3', 'middle-finger-tip': 'middle_null', 'ring-finger-phalanx-proximal': 'ring1', 'ring-finger-phalanx-intermediate': 'ring2', 'ring-finger-phalanx-distal': 'ring3', 'ring-finger-tip': 'ring_null', 'pinky-finger-metacarpal': 'pinky0', 'pinky-finger-phalanx-proximal': 'pinky1', 'pinky-finger-phalanx-intermediate': 'pinky2', 'pinky-finger-phalanx-distal': 'pinky3', 'pinky-finger-tip': 'pinky_null', }, h = 0.015, d = 0.03, p = 0.5 t.exports.Component = r('hand-tracking-controls', { schema: { hand: { default: 'right', oneOf: ['left', 'right'] }, modelStyle: { default: 'mesh', oneOf: ['dots', 'mesh'] }, modelColor: { default: 'white' }, }, bindMethods: function () { ;(this.onControllersUpdate = i(this.onControllersUpdate, this)), (this.checkIfControllerPresent = i(this.checkIfControllerPresent, this)), (this.removeControllersUpdateListener = i( this.removeControllersUpdateListener, this, )) }, addEventListeners: function () { this.el.addEventListener('model-loaded', this.onModelLoaded) for (var e = 0; e < this.jointEls.length; ++e) this.jointEls[e].object3D.visible = !0 }, removeEventListeners: function () { this.el.removeEventListener('model-loaded', this.onModelLoaded) for (var e = 0; e < this.jointEls.length; ++e) this.jointEls[e].object3D.visible = !1 }, init: function () { var e = this.el.sceneEl, t = e.getAttribute('webxr').optionalFeatures t.push('hand-tracking'), e.setAttribute('webxr', { optionalFeatures: t }), (this.onModelLoaded = this.onModelLoaded.bind(this)), (this.jointEls = []), (this.controllerPresent = !1), (this.isPinched = !1), (this.pinchEventDetail = { position: new THREE.Vector3() }), (this.indexTipPosition = new THREE.Vector3()), this.bindMethods(), (this.updateReferenceSpace = this.updateReferenceSpace.bind(this)), this.el.sceneEl.addEventListener('enter-vr', this.updateReferenceSpace), this.el.sceneEl.addEventListener('exit-vr', this.updateReferenceSpace) }, updateReferenceSpace: function () { var e = this, t = this.el.sceneEl.xrSession if (((this.referenceSpace = void 0), t)) { var n = e.el.sceneEl.systems.webxr.sessionReferenceSpaceType t.requestReferenceSpace(n) .then(function (t) { e.referenceSpace = t.getOffsetReferenceSpace( new XRRigidTransform({ x: 0, y: 1.5, z: 0 }), ) }) .catch(function (t) { throw ( (e.el.sceneEl.systems.webxr.warnIfFeatureNotRequested( n, 'tracked-controls-webxr uses reference space ' + n, ), t) ) }) } }, checkIfControllerPresent: function () { var e = this.data, t = e.hand ? e.hand : void 0 o(this, '', { hand: t, iterateControllerProfiles: !0, handTracking: !0 }) }, play: function () { this.checkIfControllerPresent(), this.addControllersUpdateListener() }, tick: function () { var e = this.el.sceneEl, t = this.el.components['tracked-controls'] && this.el.components['tracked-controls'].controller, n = e.frame, r = this.el.components['tracked-controls-webxr'] t && n && r && t.hand && (this.el.object3D.position.set(0, 0, 0), this.el.object3D.rotation.set(0, 0, 0), n.getJointPose && this.updateHandModel(), this.detectGesture()) }, updateHandModel: function () { 'dots' === this.data.modelStyle && this.updateHandDotsModel(), 'mesh' === this.data.modelStyle && this.updateHandMeshModel() }, getBone: function (e) { for (var t = this.bones, n = 0; n < t.length; n++) if (t[n].name === e) return t[n] return null }, updateHandMeshModel: function () { var e = this.el.sceneEl.frame, t = this.el.components['tracked-controls'] && this.el.components['tracked-controls'].controller, n = this.referenceSpace if (t && this.mesh && n) for (var r of ((this.mesh.visible = !1), t.hand.values())) { var i, o, a ;(o = e.getJointPose(r, n)), u[r.jointName] && null != (i = this.getBone(l[this.data.hand] + u[r.jointName])) && o && ((a = o.transform), (this.mesh.visible = !0), i.position.copy(a.position).multiplyScalar(100), i.quaternion.set( a.orientation.x, a.orientation.y, a.orientation.z, a.orientation.w, )) } }, updateHandDotsModel: function () { var e, t, n, r = this.el.sceneEl.frame, i = this.el.components['tracked-controls'] && this.el.components['tracked-controls'].controller, o = this.el.components['tracked-controls-webxr'].system.referenceSpace, a = 0 for (var s of i.hand.values()) (t = (e = this.jointEls[a++]).object3D), (n = r.getJointPose(s, o)), (e.object3D.visible = !!n), n && ((t.matrix.elements = n.transform.matrix), t.matrix.decompose(t.position, t.rotation, t.scale), e.setAttribute('scale', { x: n.radius, y: n.radius, z: n.radius })) }, detectGesture: function () { this.detectPinch() }, detectPinch: (function () { var e = new THREE.Vector3() return function () { var t = this.el.sceneEl.frame, n = this.indexTipPosition, r = this.el.components['tracked-controls'] && this.el.components['tracked-controls'].controller, i = this.el.components['tracked-controls-webxr'], o = this.referenceSpace || i.system.referenceSpace, a = r.hand.get('index-finger-tip'), s = r.hand.get('thumb-tip') if (a && s) { var l = t.getJointPose(a, o), c = t.getJointPose(s, o) if (l && c) { e.copy(c.transform.position), n.copy(l.transform.position) var u = n.distanceTo(e) u < h && !1 === this.isPinched && ((this.isPinched = !0), this.pinchEventDetail.position.copy(n).lerp(e, p), (this.pinchEventDetail.position.y += 1.5), this.el.emit('pinchstarted', this.pinchEventDetail)), u > d && !0 === this.isPinched && ((this.isPinched = !1), this.pinchEventDetail.position.copy(n).lerp(e, p), (this.pinchEventDetail.position.y += 1.5), this.el.emit('pinchended', this.pinchEventDetail)), this.isPinched && (this.pinchEventDetail.position.copy(n).lerp(e, p), (this.pinchEventDetail.position.y += 1.5), this.el.emit('pinchmoved', this.pinchEventDetail)), (n.y += 1.5) } } } })(), pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, injectTrackedControls: function () { var e = this.el, t = this.data e.setAttribute('tracked-controls', { hand: t.hand, iterateControllerProfiles: !0, handTrackingEnabled: !0, }), this.initDefaultModel() }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { var e this.checkIfControllerPresent(), (e = this.el.components['tracked-controls'] && this.el.components['tracked-controls'].controller), this.el.getObject3D('mesh') && ((e && e.hand && e.hand[0]) || (this.el.getObject3D('mesh').visible = !1)) }, initDefaultModel: function () { this.el.getObject3D('mesh') || ('dots' === this.data.modelStyle && this.initDotsModel(), 'mesh' === this.data.modelStyle && this.initMeshHandModel()) }, initDotsModel: function () { if (0 === this.jointEls.length) for (var e = 0; e < c.length; ++e) { var t = (this.jointEl = document.createElement('a-entity')) t.setAttribute('geometry', { primitive: 'sphere', radius: 1 }), t.setAttribute('material', { color: this.data.modelColor }), (t.object3D.visible = !1), this.el.appendChild(t), this.jointEls.push(t) } }, initMeshHandModel: function () { var e = 'left' === this.data.hand ? a : s this.el.setAttribute('gltf-model', e) }, onModelLoaded: function () { var e = (this.mesh = this.el.getObject3D('mesh').children[0]), t = (this.skinnedMesh = e.children[24]) this.skinnedMesh && ((this.bones = t.skeleton.bones), this.el.removeObject3D('mesh'), e.position.set(0, 1.5, 0), e.rotation.set(0, 0, 0), (t.frustumCulled = !1), (t.material = new THREE.MeshStandardMaterial({ skinning: !0, color: this.data.modelColor, })), this.el.setObject3D('mesh', e)) }, }) }, { '../core/component': 131, '../utils/bind': 199, '../utils/tracked-controls': 214 }, ], 84: [ function (e, t, n) { e('./animation'), e('./camera'), e('./cursor'), e('./daydream-controls'), e('./gearvr-controls'), e('./geometry'), e('./generic-tracked-controller-controls'), e('./gltf-model'), e('./hand-tracking-controls'), e('./hand-controls'), e('./layer'), e('./laser-controls'), e('./light'), e('./line'), e('./link'), e('./look-controls'), e('./magicleap-controls'), e('./material'), e('./obj-model'), e('./oculus-go-controls'), e('./oculus-touch-controls'), e('./position'), e('./raycaster'), e('./rotation'), e('./scale'), e('./shadow'), e('./sound'), e('./text'), e('./tracked-controls'), e('./tracked-controls-webvr'), e('./tracked-controls-webxr'), e('./visible'), e('./valve-index-controls'), e('./vive-controls'), e('./vive-focus-controls'), e('./wasd-controls'), e('./windows-motion-controls'), e('./scene/background'), e('./scene/debug'), e('./scene/device-orientation-permission-ui'), e('./scene/embedded'), e('./scene/inspector'), e('./scene/fog'), e('./scene/keyboard-shortcuts'), e('./scene/pool'), e('./scene/screenshot'), e('./scene/stats'), e('./scene/vr-mode-ui') }, { './animation': 74, './camera': 75, './cursor': 76, './daydream-controls': 77, './gearvr-controls': 78, './generic-tracked-controller-controls': 79, './geometry': 80, './gltf-model': 81, './hand-controls': 82, './hand-tracking-controls': 83, './laser-controls': 85, './layer': 86, './light': 87, './line': 88, './link': 89, './look-controls': 90, './magicleap-controls': 91, './material': 92, './obj-model': 93, './oculus-go-controls': 94, './oculus-touch-controls': 95, './position': 96, './raycaster': 97, './rotation': 98, './scale': 99, './scene/background': 100, './scene/debug': 101, './scene/device-orientation-permission-ui': 102, './scene/embedded': 103, './scene/fog': 104, './scene/inspector': 105, './scene/keyboard-shortcuts': 106, './scene/pool': 107, './scene/screenshot': 108, './scene/stats': 109, './scene/vr-mode-ui': 110, './shadow': 111, './sound': 112, './text': 113, './tracked-controls': 116, './tracked-controls-webvr': 114, './tracked-controls-webxr': 115, './valve-index-controls': 117, './visible': 118, './vive-controls': 119, './vive-focus-controls': 120, './wasd-controls': 121, './windows-motion-controls': 122, }, ], 85: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/') r('laser-controls', { schema: { hand: { default: 'right' }, model: { default: !0 }, defaultModelColor: { type: 'color', default: 'grey' }, }, init: function () { var e = this.config, t = this.data, n = this.el, r = this, o = { hand: t.hand, model: t.model } function a(t) { var o = e[t.detail.name] if (o) { var a = i.extend({ showLine: !0 }, o.raycaster || {}) t.detail.rayOrigin && ((a.origin = t.detail.rayOrigin.origin), (a.direction = t.detail.rayOrigin.direction), (a.showLine = !0)), t.detail.rayOrigin || !r.modelReady ? n.setAttribute('raycaster', a) : n.setAttribute('raycaster', 'showLine', !0), n.setAttribute('cursor', i.extend({ fuse: !1 }, o.cursor)) } } function s() { n.setAttribute('raycaster', 'showLine', !1) } n.setAttribute('daydream-controls', o), n.setAttribute('gearvr-controls', o), n.setAttribute('magicleap-controls', o), n.setAttribute('oculus-go-controls', o), n.setAttribute('oculus-touch-controls', o), n.setAttribute('valve-index-controls', o), n.setAttribute('vive-controls', o), n.setAttribute('vive-focus-controls', o), n.setAttribute('windows-motion-controls', o), n.setAttribute('generic-tracked-controller-controls', o), n.addEventListener('controllerconnected', a), n.addEventListener('controllerdisconnected', s), n.addEventListener('controllermodelready', function (e) { a(e), (r.modelReady = !0) }) }, config: { 'daydream-controls': { cursor: { downEvents: ['trackpaddown', 'triggerdown'], upEvents: ['trackpadup', 'triggerup'], }, }, 'gearvr-controls': { cursor: { downEvents: ['triggerdown'], upEvents: ['triggerup'] }, raycaster: { origin: { x: 0, y: 0.001, z: 0 } }, }, 'generic-tracked-controller-controls': { cursor: { downEvents: ['triggerdown'], upEvents: ['triggerup'] }, }, 'magicleap-controls': { cursor: { downEvents: ['trackpaddown', 'triggerdown'], upEvents: ['trackpadup', 'triggerup'], }, }, 'oculus-go-controls': { cursor: { downEvents: ['triggerdown'], upEvents: ['triggerup'] }, raycaster: { origin: { x: 0, y: 5e-4, z: 0 } }, }, 'oculus-touch-controls': { cursor: { downEvents: ['triggerdown'], upEvents: ['triggerup'] }, raycaster: { origin: { x: 0, y: 0, z: 0 } }, }, 'valve-index-controls': { cursor: { downEvents: ['triggerdown'], upEvents: ['triggerup'] }, }, 'vive-controls': { cursor: { downEvents: ['triggerdown'], upEvents: ['triggerup'] }, }, 'vive-focus-controls': { cursor: { downEvents: ['trackpaddown', 'triggerdown'], upEvents: ['trackpadup', 'triggerup'], }, }, 'windows-motion-controls': { cursor: { downEvents: ['triggerdown'], upEvents: ['triggerup'] }, raycaster: { showLine: !1 }, }, }, }) }, { '../core/component': 131, '../utils/': 205 }, ], 86: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/').debug('components:layer:warn') function o(e, t, n, r) { var i = e.createFramebuffer() let o = n.viewport.x, a = n.viewport.y, s = n.viewport.x + n.viewport.width, l = n.viewport.y + n.viewport.height 'VIDEO' === r.tagName && (e.bindTexture(e.TEXTURE_2D, t), e.texSubImage2D( e.TEXTURE_2D, 0, 0, 0, r.width, r.height, e.RGB, e.UNSIGNED_BYTE, r, )), e.bindFramebuffer(e.READ_FRAMEBUFFER, i), e.framebufferTexture2D( e.READ_FRAMEBUFFER, e.COLOR_ATTACHMENT0, e.TEXTURE_2D, t, 0, ), e.readBuffer(e.COLOR_ATTACHMENT0), e.blitFramebuffer( 0, 0, r.width, r.height, o, a, s, l, e.COLOR_BUFFER_BIT, e.NEAREST, ), e.bindFramebuffer(e.READ_FRAMEBUFFER, null), e.deleteFramebuffer(i) } t.exports.Component = r('layer', { schema: { type: { default: 'quad', oneOf: ['quad', 'monocubemap', 'stereocubemap'] }, src: { type: 'map' }, rotateCubemap: { default: !1 }, width: { default: 0 }, height: { default: 0 }, }, init: function () { var e = this.el.sceneEl.renderer.getContext() ;(this.quaternion = new THREE.Quaternion()), (this.position = new THREE.Vector3()), this.bindMethods(), (this.needsRedraw = !1), (this.frameBuffer = e.createFramebuffer()) var t = this.el.sceneEl.getAttribute('webxr').requiredFeatures t.push('layers'), this.el.sceneEl.getAttribute('webxr', 'requiredFeatures', t), this.el.sceneEl.addEventListener('enter-vr', this.onEnterVR), this.el.sceneEl.addEventListener('exit-vr', this.onExitVR) }, bindMethods: function () { ;(this.onRequestedReferenceSpace = this.onRequestedReferenceSpace.bind(this)), (this.onEnterVR = this.onEnterVR.bind(this)), (this.onExitVR = this.onExitVR.bind(this)) }, update: function (e) { this.data.src !== e.src && this.updateSrc() }, updateSrc: function () { var e = this.data.type ;(this.texture = void 0), 'quad' !== e ? ('monocubemap' !== e && 'stereocubemap' !== e) || this.loadCubeMapImages() : this.loadQuadImage() }, loadCubeMapImages: function () { var e, t = this.data.type, n = this.xrGLFactory, r = this.el.sceneEl.frame, i = this.data.src ;(this.visibilityChanged = !1), this.layer && (i.complete ? (this.pendingCubeMapUpdate = !1) : (this.pendingCubeMapUpdate = !0), this.loadingScreen ? (this.loadingScreen = !1) : (this.loadingScreen = !0), 'monocubemap' === t ? ((e = n.getSubImage(this.layer, r)), this.loadCubeMapImage(e.colorTexture, i, 0)) : ((e = n.getSubImage(this.layer, r, 'left')), this.loadCubeMapImage(e.colorTexture, i, 0), (e = n.getSubImage(this.layer, r, 'right')), this.loadCubeMapImage(e.colorTexture, i, 6))) }, loadQuadImage: function () { var e = this.data.src, t = this this.el.sceneEl.systems.material.loadTexture(e, { src: e }, function (n) { t.el.sceneEl.renderer.initTexture(n), (t.texture = n), 'VIDEO' === e.tagName && setTimeout(function () { t.textureIsVideo = !0 }, 1e3), t.layer && ((t.layer.height = t.data.height / 2 || t.texture.image.height / 1e3), (t.layer.width = t.data.width / 2 || t.texture.image.width / 1e3), (t.needsRedraw = !0)), t.updateQuadPanel() }) }, preGenerateCubeMapTextures: function (e, t) { 'monocubemap' === this.data.type ? this.generateCubeMapTextures(e, 0, t) : (this.generateCubeMapTextures(e, 0, t), this.generateCubeMapTextures(e, 6, t)) }, generateCubeMapTextures: function (e, t, n) { for ( var r, i, o = this.data, a = this.cubeFaceSize, s = Math.min(e.width, e.height), l = [], c = 0; c < 6; c++ ) { var u = document.createElement('CANVAS') u.width = u.height = a var h = u.getContext('2d') o.rotateCubemap && ((2 !== c && 3 !== c) || (h.save(), h.translate(a, a), h.rotate(Math.PI))), h.drawImage(e, (c + t) * s, 0, s, s, 0, 0, a, a), h.restore(), n && n(), l.push(u) } return ( o.rotateCubemap && ((r = l[0]), (i = l[1]), (l[0] = i), (l[1] = r), (r = l[4]), (i = l[5]), (l[4] = i), (l[5] = r)), n && n(), l ) }, loadCubeMapImage: function (e, t, n) { var r, i = this.el.sceneEl.renderer.getContext() i.pixelStorei(i.UNPACK_FLIP_Y_WEBGL, !1), i.bindTexture(i.TEXTURE_CUBE_MAP, e), (r = !t.complete || this.loadingScreen ? this.loadingScreenImages : this.generateCubeMapTextures(t, n)) var o = 0 r.forEach(function (e, t) { i.texSubImage2D( i.TEXTURE_CUBE_MAP_POSITIVE_X + t, 0, 0, 0, i.RGBA, i.UNSIGNED_BYTE, e, ), (o = i.getError()) }), 0 !== o && console.log('renderingError, WebGL Error Code: ' + o), i.bindTexture(i.TEXTURE_CUBE_MAP, null) }, tick: function () { this.el.sceneEl.xrSession && (!this.layer && this.el.sceneEl.is('vr-mode') && this.initLayer(), this.updateTransform(), this.data.src.complete && (this.pendingCubeMapUpdate || this.loadingScreen || this.visibilityChanged) && this.loadCubeMapImages(), (this.needsRedraw || this.layer.needsRedraw || this.textureIsVideo) && ('quad' === this.data.type && this.draw(), (this.needsRedraw = !1))) }, initLayer: function () { var e = this, t = this.data.type ;(this.el.sceneEl.xrSession.onvisibilitychange = function (t) { e.visibilityChanged = 'hidden' !== t.session.visibilityState }), 'quad' !== t ? ('monocubemap' !== t && 'stereocubemap' !== t) || this.initCubeMapLayer() : this.initQuadLayer() }, initQuadLayer: function () { var e = this.el.sceneEl, t = e.renderer.getContext(), n = (this.xrGLFactory = new XRWebGLBinding(e.xrSession, t)) this.texture && ((this.layer = n.createQuadLayer({ space: this.referenceSpace, viewPixelHeight: 2048, viewPixelWidth: 2048, height: this.data.height / 2 || this.texture.image.height / 1e3, width: this.data.width / 2 || this.texture.image.width / 1e3, })), e.renderer.xr.addLayer(this.layer)) }, initCubeMapLayer: function () { var e = this.data.src, t = this.el.sceneEl, n = t.renderer.getContext(), r = n.getParameter(n.MAX_CUBE_MAP_TEXTURE_SIZE), i = (this.cubeFaceSize = Math.min(r, Math.min(e.width, e.height))), o = (this.xrGLFactory = new XRWebGLBinding(t.xrSession, n)) ;(this.layer = o.createCubeLayer({ space: this.referenceSpace, viewPixelWidth: i, viewPixelHeight: i, layout: 'monocubemap' === this.data.type ? 'mono' : 'stereo', isStatic: !1, })), this.initLoadingScreenImages(), this.loadCubeMapImages(), t.renderer.xr.addLayer(this.layer) }, initLoadingScreenImages: function () { for ( var e = this.cubeFaceSize, t = (this.loadingScreenImages = []), n = 0; n < 6; n++ ) { var r = document.createElement('CANVAS') r.width = r.height = e var i = r.getContext('2d') ;(r.width = r.height = e), (i.fillStyle = 'black'), i.fillRect(0, 0, e, e), 2 !== n && 3 !== n && (i.translate(e, 0), i.scale(-1, 1), (i.fillStyle = 'white'), (i.font = '30px Arial'), i.fillText('Loading', e / 2, e / 2)), t.push(r) } }, destroyLayer: function () { this.layer && (this.el.sceneEl.renderer.xr.removeLayer(this.layer), this.layer.destroy(), (this.layer = void 0)) }, toggleCompositorLayer: function () { this.enableCompositorLayer(!this.layerEnabled) }, enableCompositorLayer: function (e) { ;(this.layerEnabled = e), (this.quadPanelEl.object3D.visible = !this.layerEnabled) }, updateQuadPanel: function () { var e = this.quadPanelEl this.quadPanelEl || ((e = this.quadPanelEl = document.createElement('a-entity')), this.el.appendChild(e)), e.setAttribute('material', { shader: 'flat', src: this.data.src, transparent: !0, }), e.setAttribute('geometry', { primitive: 'plane', height: this.data.height || this.texture.image.height / 1e3, width: this.data.width || this.texture.image.height / 1e3, }) }, draw: function () { var e = this.el.sceneEl, t = this.el.sceneEl.renderer.getContext(), n = this.xrGLFactory.getSubImage(this.layer, e.frame), r = e.renderer.properties.get(this.texture).__webglTexture, i = t.getParameter(t.FRAMEBUFFER_BINDING) t.viewport(n.viewport.x, n.viewport.y, n.viewport.width, n.viewport.height), t.bindFramebuffer(t.FRAMEBUFFER, this.frameBuffer), t.framebufferTexture2D( t.FRAMEBUFFER, t.COLOR_ATTACHMENT0, t.TEXTURE_2D, n.colorTexture, 0, ), o(t, r, n, this.data.src), t.bindFramebuffer(t.FRAMEBUFFER, i) }, updateTransform: function () { var e = this.el, t = this.position, n = this.quaternion e.object3D.updateMatrixWorld(), t.setFromMatrixPosition(e.object3D.matrixWorld), n.setFromRotationMatrix(e.object3D.matrixWorld), this.layerEnabled || t.set(0, 0, 1e8), (this.layer.transform = new XRRigidTransform(t, n)) }, onEnterVR: function () { var e = this.el.sceneEl, t = e.xrSession e.hasWebXR && XRWebGLBinding && t ? (t.requestReferenceSpace('local').then(this.onRequestedReferenceSpace), (this.needsRedraw = !0), (this.layerEnabled = !0), this.quadPanelEl && (this.quadPanelEl.object3D.visible = !1), this.data.src.play && this.data.src.play()) : i('The layer component requires WebXR and the layers API enabled') }, onExitVR: function () { this.quadPanelEl && (this.quadPanelEl.object3D.visible = !0), this.destroyLayer() }, onRequestedReferenceSpace: function (e) { this.referenceSpace = e }, }) }, { '../core/component': 131, '../utils/': 205 }, ], 87: [ function (e, t, n) { var r = e('../utils/bind'), i = e('../utils').diff, o = e('../utils/debug'), a = e('../core/component').registerComponent, s = e('../lib/three'), l = s.Math.degToRad, c = o('components:light:warn') t.exports.Component = a('light', { schema: { angle: { default: 60, if: { type: ['spot'] } }, color: { type: 'color' }, groundColor: { type: 'color', if: { type: ['hemisphere'] } }, decay: { default: 1, if: { type: ['point', 'spot'] } }, distance: { default: 0, min: 0, if: { type: ['point', 'spot'] } }, intensity: { default: 1, min: 0, if: { type: ['ambient', 'directional', 'hemisphere', 'point', 'spot'] }, }, penumbra: { default: 0, min: 0, max: 1, if: { type: ['spot'] } }, type: { default: 'directional', oneOf: ['ambient', 'directional', 'hemisphere', 'point', 'spot'], schemaChange: !0, }, target: { type: 'selector', if: { type: ['spot', 'directional'] } }, castShadow: { default: !1, if: { type: ['point', 'spot', 'directional'] } }, shadowBias: { default: 0, if: { castShadow: !0 } }, shadowCameraFar: { default: 500, if: { castShadow: !0 } }, shadowCameraFov: { default: 90, if: { castShadow: !0 } }, shadowCameraNear: { default: 0.5, if: { castShadow: !0 } }, shadowCameraTop: { default: 5, if: { castShadow: !0 } }, shadowCameraRight: { default: 5, if: { castShadow: !0 } }, shadowCameraBottom: { default: -5, if: { castShadow: !0 } }, shadowCameraLeft: { default: -5, if: { castShadow: !0 } }, shadowCameraVisible: { default: !1, if: { castShadow: !0 } }, shadowMapHeight: { default: 512, if: { castShadow: !0 } }, shadowMapWidth: { default: 512, if: { castShadow: !0 } }, shadowRadius: { default: 1, if: { castShadow: !0 } }, }, init: function () { var e = this.el ;(this.light = null), (this.defaultTarget = null), (this.rendererSystem = this.el.sceneEl.systems.renderer), this.system.registerLight(e) }, update: function (e) { var t = this.data, n = i(t, e), o = this.light, a = this.rendererSystem, s = this if (!o || 'type' in n) this.setLight(this.data), this.updateShadow() else { var c = !1 Object.keys(n).forEach(function (e) { var n = t[e] switch (e) { case 'color': o.color.set(n), a.applyColorCorrection(o.color) break case 'groundColor': o.groundColor.set(n), a.applyColorCorrection(o.groundColor) break case 'angle': o.angle = l(n) break case 'target': null === n ? ('spot' !== t.type && 'directional' !== t.type) || (o.target = s.defaultTarget) : n.hasLoaded ? s.onSetTarget(n, o) : n.addEventListener('loaded', r(s.onSetTarget, s, n, o)) break case 'castShadow': case 'shadowBias': case 'shadowCameraFar': case 'shadowCameraFov': case 'shadowCameraNear': case 'shadowCameraTop': case 'shadowCameraRight': case 'shadowCameraBottom': case 'shadowCameraLeft': case 'shadowCameraVisible': case 'shadowMapHeight': case 'shadowMapWidth': case 'shadowRadius': c || (s.updateShadow(), (c = !0)) break default: o[e] = n } }) } }, setLight: function (e) { var t = this.el, n = this.getLight(e) n && (this.light && t.removeObject3D('light'), (this.light = n), (this.light.el = t), t.setObject3D('light', this.light), ('spot' !== e.type && 'directional' !== e.type && 'hemisphere' !== e.type) || t.getObject3D('light').translateY(-1), 'spot' === e.type && (t.setObject3D('light-target', this.defaultTarget), t.getObject3D('light-target').position.set(0, 0, -1))) }, updateShadow: function () { var e = this.el, t = this.data, n = this.light n.castShadow = t.castShadow var r = e.getObject3D('cameraHelper') if ( (t.shadowCameraVisible && !r ? e.setObject3D('cameraHelper', new s.CameraHelper(n.shadow.camera)) : !t.shadowCameraVisible && r && e.removeObject3D('cameraHelper'), !t.castShadow) ) return n ;(n.shadow.bias = t.shadowBias), (n.shadow.radius = t.shadowRadius), (n.shadow.mapSize.height = t.shadowMapHeight), (n.shadow.mapSize.width = t.shadowMapWidth), (n.shadow.camera.near = t.shadowCameraNear), (n.shadow.camera.far = t.shadowCameraFar), n.shadow.camera instanceof s.OrthographicCamera ? ((n.shadow.camera.top = t.shadowCameraTop), (n.shadow.camera.right = t.shadowCameraRight), (n.shadow.camera.bottom = t.shadowCameraBottom), (n.shadow.camera.left = t.shadowCameraLeft)) : (n.shadow.camera.fov = t.shadowCameraFov), n.shadow.camera.updateProjectionMatrix(), r && r.update() }, getLight: function (e) { var t = e.angle, n = new s.Color(e.color) this.rendererSystem.applyColorCorrection(n), (n = n.getHex()) var i = e.decay, o = e.distance, a = new s.Color(e.groundColor) this.rendererSystem.applyColorCorrection(a), (a = a.getHex()) var u = e.intensity, h = e.type, d = e.target, p = null switch (h.toLowerCase()) { case 'ambient': return new s.AmbientLight(n, u) case 'directional': return ( (p = new s.DirectionalLight(n, u)), (this.defaultTarget = p.target), d && (d.hasLoaded ? this.onSetTarget(d, p) : d.addEventListener('loaded', r(this.onSetTarget, this, d, p))), p ) case 'hemisphere': return new s.HemisphereLight(n, a, u) case 'point': return new s.PointLight(n, u, o, i) case 'spot': return ( (p = new s.SpotLight(n, u, o, l(t), e.penumbra, i)), (this.defaultTarget = p.target), d && (d.hasLoaded ? this.onSetTarget(d, p) : d.addEventListener('loaded', r(this.onSetTarget, this, d, p))), p ) default: c( '%s is not a valid light type. Choose from ambient, directional, hemisphere, point, spot.', h, ) } }, onSetTarget: function (e, t) { t.target = e.object3D }, remove: function () { var e = this.el e.removeObject3D('light'), e.getObject3D('cameraHelper') && e.removeObject3D('cameraHelper') }, }) }, { '../core/component': 131, '../lib/three': 179, '../utils': 205, '../utils/bind': 199, '../utils/debug': 201, }, ], 88: [ function (e, t, n) { var r = e('../core/component').registerComponent function i(e, t) { return !(!e || !t) && e.x === t.x && e.y === t.y && e.z === t.z } t.exports.Component = r('line', { schema: { start: { type: 'vec3', default: { x: 0, y: 0, z: 0 } }, end: { type: 'vec3', default: { x: 0, y: 0, z: 0 } }, color: { type: 'color', default: '#74BEC1' }, opacity: { type: 'number', default: 1 }, visible: { default: !0 }, }, multiple: !0, init: function () { var e, t, n = this.data ;(this.rendererSystem = this.el.sceneEl.systems.renderer), (t = this.material = new THREE.LineBasicMaterial({ color: n.color, opacity: n.opacity, transparent: n.opacity < 1, visible: n.visible, })), (e = this.geometry = new THREE.BufferGeometry()).setAttribute( 'position', new THREE.BufferAttribute(new Float32Array(6), 3), ), this.rendererSystem.applyColorCorrection(t.color), (this.line = new THREE.Line(e, t)), this.el.setObject3D(this.attrName, this.line) }, update: function (e) { var t = this.data, n = this.geometry, r = !1, o = this.material, a = n.attributes.position.array i(t.start, e.start) || ((a[0] = t.start.x), (a[1] = t.start.y), (a[2] = t.start.z), (r = !0)), i(t.end, e.end) || ((a[3] = t.end.x), (a[4] = t.end.y), (a[5] = t.end.z), (r = !0)), r && ((n.attributes.position.needsUpdate = !0), n.computeBoundingSphere()), o.color.setStyle(t.color), this.rendererSystem.applyColorCorrection(o.color), (o.opacity = t.opacity), (o.transparent = t.opacity < 1), (o.visible = t.visible) }, remove: function () { this.el.removeObject3D('line', this.line) }, }) }, { '../core/component': 131 }, ], 89: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../core/shader').registerShader, o = e('../lib/three') ;(t.exports.Component = r('link', { schema: { backgroundColor: { default: 'red', type: 'color' }, borderColor: { default: 'white', type: 'color' }, highlighted: { default: !1 }, highlightedColor: { default: '#24CAFF', type: 'color' }, href: { default: '' }, image: { type: 'asset' }, on: { default: 'click' }, peekMode: { default: !1 }, title: { default: '' }, titleColor: { default: 'white', type: 'color' }, visualAspectEnabled: { default: !1 }, }, init: function () { ;(this.navigate = this.navigate.bind(this)), (this.previousQuaternion = void 0), (this.quaternionClone = new o.Quaternion()), (this.hiddenEls = []) }, update: function (e) { var t, n, r = this.data, i = this.el r.visualAspectEnabled && (this.initVisualAspect(), (t = r.highlighted ? r.highlightedColor : r.backgroundColor), (n = r.highlighted ? r.highlightedColor : r.borderColor), i.setAttribute('material', 'backgroundColor', t), i.setAttribute('material', 'strokeColor', n), r.on !== e.on && this.updateEventListener(), void 0 !== e.peekMode && r.peekMode !== e.peekMode && this.updatePeekMode(), r.image && e.image !== r.image && i.setAttribute( 'material', 'pano', 'string' === typeof r.image ? r.image : r.image.src, )) }, updatePeekMode: function () { var e = this.el, t = this.sphereEl this.data.peekMode ? (this.hideAll(), (e.getObject3D('mesh').visible = !1), t.setAttribute('visible', !0)) : (this.showAll(), (e.getObject3D('mesh').visible = !0), t.setAttribute('visible', !1)) }, play: function () { this.updateEventListener() }, pause: function () { this.removeEventListener() }, updateEventListener: function () { var e = this.el e.isPlaying && (this.removeEventListener(), e.addEventListener(this.data.on, this.navigate)) }, removeEventListener: function () { var e = this.data.on e && this.el.removeEventListener(e, this.navigate) }, initVisualAspect: function () { var e, t, n, r = this.el this.data.visualAspectEnabled && !this.visualAspectInitialized && ((n = this.textEl = this.textEl || document.createElement('a-entity')), (t = this.sphereEl = this.sphereEl || document.createElement('a-entity')), (e = this.semiSphereEl = this.semiSphereEl || document.createElement('a-entity')), r.setAttribute('geometry', { primitive: 'circle', radius: 1, segments: 64 }), r.setAttribute('material', { shader: 'portal', pano: this.data.image, side: 'double', }), n.setAttribute('text', { color: this.data.titleColor, align: 'center', font: 'kelsonsans', value: this.data.title || this.data.href, width: 4, }), n.setAttribute('position', '0 1.5 0'), r.appendChild(n), e.setAttribute('geometry', { primitive: 'sphere', radius: 1, phiStart: 0, segmentsWidth: 64, segmentsHeight: 64, phiLength: 180, thetaStart: 0, thetaLength: 360, }), e.setAttribute('material', { shader: 'portal', borderEnabled: 0, pano: this.data.image, side: 'back', }), e.setAttribute('rotation', '0 180 0'), e.setAttribute('position', '0 0 0'), e.setAttribute('visible', !1), r.appendChild(e), t.setAttribute('geometry', { primitive: 'sphere', radius: 10, segmentsWidth: 64, segmentsHeight: 64, }), t.setAttribute('material', { shader: 'portal', borderEnabled: 0, pano: this.data.image, side: 'back', }), t.setAttribute('visible', !1), r.appendChild(t), (this.visualAspectInitialized = !0)) }, navigate: function () { window.location = this.data.href }, tick: (function () { var e = new o.Vector3(), t = new o.Vector3(), n = new o.Quaternion(), r = new o.Vector3() return function () { var i, o, a = this.el, s = a.object3D, l = a.sceneEl.camera, c = this.textEl if (this.data.visualAspectEnabled) if ( (s.updateMatrixWorld(), l.parent.updateMatrixWorld(), l.updateMatrixWorld(), s.matrix.decompose(t, n, r), t.setFromMatrixPosition(s.matrixWorld), e.setFromMatrixPosition(l.matrixWorld), (o = t.distanceTo(e)) > 20) ) this.previousQuaternion || (this.quaternionClone.copy(n), (this.previousQuaternion = this.quaternionClone)), s.lookAt(e) else { if (((i = this.calculateCameraPortalOrientation()), o < 0.5)) { if (!0 === this.semiSphereEl.getAttribute('visible')) return c.setAttribute('text', 'width', 1.5), i <= 0 ? (c.setAttribute('position', '0 0 0.75'), c.setAttribute('rotation', '0 180 0'), this.semiSphereEl.setAttribute('rotation', '0 0 0')) : (c.setAttribute('position', '0 0 -0.75'), c.setAttribute('rotation', '0 0 0'), this.semiSphereEl.setAttribute('rotation', '0 180 0')), (a.getObject3D('mesh').visible = !1), this.semiSphereEl.setAttribute('visible', !0), (this.peekCameraPortalOrientation = i) } else i <= 0 ? c.setAttribute('rotation', '0 180 0') : c.setAttribute('rotation', '0 0 0'), c.setAttribute('text', 'width', 5), c.setAttribute('position', '0 1.5 0'), (a.getObject3D('mesh').visible = !0), this.semiSphereEl.setAttribute('visible', !1), (this.peekCameraPortalOrientation = void 0) this.previousQuaternion && (s.quaternion.copy(this.previousQuaternion), (this.previousQuaternion = void 0)) } } })(), hideAll: function () { var e = this.el, t = this.hiddenEls, n = this t.length > 0 || e.sceneEl.object3D.traverse(function (r) { ;(r && r.el && r.el.hasAttribute('link-controls')) || (r.el && r !== e.sceneEl.object3D && r.el !== e && r.el !== n.sphereEl && r.el !== e.sceneEl.cameraEl && !1 !== r.el.getAttribute('visible') && r.el !== n.textEl && r.el !== n.semiSphereEl && (r.el.setAttribute('visible', !1), t.push(r.el))) }) }, showAll: function () { this.hiddenEls.forEach(function (e) { e.setAttribute('visible', !0) }), (this.hiddenEls = []) }, calculateCameraPortalOrientation: (function () { var e = new o.Matrix4(), t = new o.Vector3(), n = new o.Vector3(0, 0, 1), r = new o.Vector3(0, 0, 0) return function () { var i = this.el, o = i.sceneEl.camera return ( t.set(0, 0, 0), n.set(0, 0, 1), r.set(0, 0, 0), i.object3D.matrixWorld.extractRotation(e), n.applyMatrix4(e), i.object3D.updateMatrixWorld(), i.object3D.localToWorld(r), o.parent.parent.updateMatrixWorld(), o.parent.updateMatrixWorld(), o.updateMatrixWorld(), o.localToWorld(t), t.sub(r).normalize(), n.normalize(), Math.sign(n.dot(t)) ) } })(), remove: function () { this.removeEventListener() }, })), i('portal', { schema: { borderEnabled: { default: 1, type: 'int', is: 'uniform' }, backgroundColor: { default: 'red', type: 'color', is: 'uniform' }, pano: { type: 'map', is: 'uniform' }, strokeColor: { default: 'white', type: 'color', is: 'uniform' }, }, vertexShader: [ 'vec3 portalPosition;', 'varying vec3 vWorldPosition;', 'varying float vDistanceToCenter;', 'varying float vDistance;', 'void main() {', 'vDistanceToCenter = clamp(length(position - vec3(0.0, 0.0, 0.0)), 0.0, 1.0);', 'portalPosition = (modelMatrix * vec4(0.0, 0.0, 0.0, 1.0)).xyz;', 'vDistance = length(portalPosition - cameraPosition);', 'vWorldPosition = (modelMatrix * vec4(position, 1.0)).xyz;', 'gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);', '}', ].join('\n'), fragmentShader: [ '#define RECIPROCAL_PI2 0.15915494', 'uniform sampler2D pano;', 'uniform vec3 strokeColor;', 'uniform vec3 backgroundColor;', 'uniform float borderEnabled;', 'varying float vDistanceToCenter;', 'varying float vDistance;', 'varying vec3 vWorldPosition;', 'void main() {', 'vec3 direction = normalize(vWorldPosition - cameraPosition);', 'vec2 sampleUV;', 'float borderThickness = clamp(exp(-vDistance / 50.0), 0.6, 0.95);', 'sampleUV.y = clamp(direction.y * 0.5 + 0.5, 0.0, 1.0);', 'sampleUV.x = atan(direction.z, -direction.x) * -RECIPROCAL_PI2 + 0.5;', 'if (vDistanceToCenter > borderThickness && borderEnabled == 1.0) {', 'gl_FragColor = vec4(strokeColor, 1.0);', '} else {', 'gl_FragColor = mix(texture2D(pano, sampleUV), vec4(backgroundColor, 1.0), clamp(pow((vDistance / 15.0), 2.0), 0.0, 1.0));', '}', '}', ].join('\n'), }) }, { '../core/component': 131, '../core/shader': 141, '../lib/three': 179 }, ], 90: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../lib/three'), o = e('../utils/'), a = o.bind, s = Math.PI / 2 t.exports.Component = r('look-controls', { dependencies: ['position', 'rotation'], schema: { enabled: { default: !0 }, magicWindowTrackingEnabled: { default: !0 }, pointerLockEnabled: { default: !1 }, reverseMouseDrag: { default: !1 }, reverseTouchDrag: { default: !1 }, touchEnabled: { default: !0 }, mouseEnabled: { default: !0 }, }, init: function () { ;(this.deltaYaw = 0), (this.previousHMDPosition = new i.Vector3()), (this.hmdQuaternion = new i.Quaternion()), (this.magicWindowAbsoluteEuler = new i.Euler()), (this.magicWindowDeltaEuler = new i.Euler()), (this.position = new i.Vector3()), (this.magicWindowObject = new i.Object3D()), (this.rotation = {}), (this.deltaRotation = {}), (this.savedPose = null), (this.pointerLocked = !1), this.setupMouseControls(), this.bindMethods(), (this.previousMouseEvent = {}), this.setupMagicWindowControls(), (this.savedPose = { position: new i.Vector3(), rotation: new i.Euler() }), this.el.sceneEl.is('vr-mode') && this.onEnterVR() }, setupMagicWindowControls: function () { var e, t = this.data o.device.isMobile() && ((e = this.magicWindowControls = new i.DeviceOrientationControls(this.magicWindowObject)), 'undefined' !== typeof DeviceOrientationEvent && DeviceOrientationEvent.requestPermission && ((e.enabled = !1), this.el.sceneEl.components['device-orientation-permission-ui'] .permissionGranted ? (e.enabled = t.magicWindowTrackingEnabled) : this.el.sceneEl.addEventListener( 'deviceorientationpermissiongranted', function () { e.enabled = t.magicWindowTrackingEnabled }, ))) }, update: function (e) { var t = this.data t.enabled !== e.enabled && this.updateGrabCursor(t.enabled), e && !t.magicWindowTrackingEnabled && e.magicWindowTrackingEnabled && (this.magicWindowAbsoluteEuler.set(0, 0, 0), this.magicWindowDeltaEuler.set(0, 0, 0)), this.magicWindowControls && (this.magicWindowControls.enabled = t.magicWindowTrackingEnabled), e && !t.pointerLockEnabled !== e.pointerLockEnabled && (this.removeEventListeners(), this.addEventListeners(), this.pointerLocked && this.exitPointerLock()) }, tick: function (e) { this.data.enabled && this.updateOrientation() }, play: function () { this.addEventListeners() }, pause: function () { this.removeEventListeners(), this.pointerLocked && this.exitPointerLock() }, remove: function () { this.removeEventListeners(), this.pointerLocked && this.exitPointerLock() }, bindMethods: function () { ;(this.onMouseDown = a(this.onMouseDown, this)), (this.onMouseMove = a(this.onMouseMove, this)), (this.onMouseUp = a(this.onMouseUp, this)), (this.onTouchStart = a(this.onTouchStart, this)), (this.onTouchMove = a(this.onTouchMove, this)), (this.onTouchEnd = a(this.onTouchEnd, this)), (this.onEnterVR = a(this.onEnterVR, this)), (this.onExitVR = a(this.onExitVR, this)), (this.onPointerLockChange = a(this.onPointerLockChange, this)), (this.onPointerLockError = a(this.onPointerLockError, this)) }, setupMouseControls: function () { ;(this.mouseDown = !1), (this.pitchObject = new i.Object3D()), (this.yawObject = new i.Object3D()), (this.yawObject.position.y = 10), this.yawObject.add(this.pitchObject) }, addEventListeners: function () { var e = this.el.sceneEl, t = e.canvas t ? (t.addEventListener('mousedown', this.onMouseDown, !1), window.addEventListener('mousemove', this.onMouseMove, !1), window.addEventListener('mouseup', this.onMouseUp, !1), t.addEventListener('touchstart', this.onTouchStart), window.addEventListener('touchmove', this.onTouchMove), window.addEventListener('touchend', this.onTouchEnd), e.addEventListener('enter-vr', this.onEnterVR), e.addEventListener('exit-vr', this.onExitVR), this.data.pointerLockEnabled && (document.addEventListener( 'pointerlockchange', this.onPointerLockChange, !1, ), document.addEventListener( 'mozpointerlockchange', this.onPointerLockChange, !1, ), document.addEventListener( 'pointerlockerror', this.onPointerLockError, !1, ))) : e.addEventListener('render-target-loaded', a(this.addEventListeners, this)) }, removeEventListeners: function () { var e = this.el.sceneEl, t = e && e.canvas t && (t.removeEventListener('mousedown', this.onMouseDown), window.removeEventListener('mousemove', this.onMouseMove), window.removeEventListener('mouseup', this.onMouseUp), t.removeEventListener('touchstart', this.onTouchStart), window.removeEventListener('touchmove', this.onTouchMove), window.removeEventListener('touchend', this.onTouchEnd), e.removeEventListener('enter-vr', this.onEnterVR), e.removeEventListener('exit-vr', this.onExitVR), document.removeEventListener( 'pointerlockchange', this.onPointerLockChange, !1, ), document.removeEventListener( 'mozpointerlockchange', this.onPointerLockChange, !1, ), document.removeEventListener('pointerlockerror', this.onPointerLockError, !1)) }, updateOrientation: (function () { var e = new i.Matrix4() return function () { var t, n = this.el.object3D, r = this.pitchObject, i = this.yawObject, o = this.el.sceneEl o.is('vr-mode') && o.checkHeadsetConnected() ? o.hasWebXR && (t = o.renderer.xr.getCameraPose()) && ((e.elements = t.transform.matrix), e.decompose(n.position, n.rotation, n.scale)) : (this.updateMagicWindowOrientation(), (n.rotation.x = this.magicWindowDeltaEuler.x + r.rotation.x), (n.rotation.y = this.magicWindowDeltaEuler.y + i.rotation.y), (n.rotation.z = this.magicWindowDeltaEuler.z)) } })(), updateMagicWindowOrientation: function () { var e = this.magicWindowAbsoluteEuler, t = this.magicWindowDeltaEuler this.magicWindowControls && this.magicWindowControls.enabled && (this.magicWindowControls.update(), e.setFromQuaternion(this.magicWindowObject.quaternion, 'YXZ'), this.previousMagicWindowYaw || 0 === e.y || (this.previousMagicWindowYaw = e.y), this.previousMagicWindowYaw && ((t.x = e.x), (t.y += e.y - this.previousMagicWindowYaw), (t.z = e.z), (this.previousMagicWindowYaw = e.y))) }, onMouseMove: function (e) { var t, n, r, i = this.pitchObject, o = this.previousMouseEvent, a = this.yawObject this.data.enabled && (this.mouseDown || this.pointerLocked) && (this.pointerLocked ? ((n = e.movementX || e.mozMovementX || 0), (r = e.movementY || e.mozMovementY || 0)) : ((n = e.screenX - o.screenX), (r = e.screenY - o.screenY)), (this.previousMouseEvent.screenX = e.screenX), (this.previousMouseEvent.screenY = e.screenY), (t = this.data.reverseMouseDrag ? 1 : -1), (a.rotation.y += 0.002 * n * t), (i.rotation.x += 0.002 * r * t), (i.rotation.x = Math.max(-s, Math.min(s, i.rotation.x)))) }, onMouseDown: function (e) { var t = this.el.sceneEl if ( this.data.enabled && this.data.mouseEnabled && (!t.is('vr-mode') || !t.checkHeadsetConnected()) && 0 === e.button ) { var n = t && t.canvas ;(this.mouseDown = !0), (this.previousMouseEvent.screenX = e.screenX), (this.previousMouseEvent.screenY = e.screenY), this.showGrabbingCursor(), this.data.pointerLockEnabled && !this.pointerLocked && (n.requestPointerLock ? n.requestPointerLock() : n.mozRequestPointerLock && n.mozRequestPointerLock()) } }, showGrabbingCursor: function () { this.el.sceneEl.canvas.style.cursor = 'grabbing' }, hideGrabbingCursor: function () { this.el.sceneEl.canvas.style.cursor = '' }, onMouseUp: function () { ;(this.mouseDown = !1), this.hideGrabbingCursor() }, onTouchStart: function (e) { 1 === e.touches.length && this.data.touchEnabled && !this.el.sceneEl.is('vr-mode') && ((this.touchStart = { x: e.touches[0].pageX, y: e.touches[0].pageY }), (this.touchStarted = !0)) }, onTouchMove: function (e) { var t, n, r = this.el.sceneEl.canvas, i = this.yawObject this.touchStarted && this.data.touchEnabled && ((n = (2 * Math.PI * (e.touches[0].pageX - this.touchStart.x)) / r.clientWidth), (t = this.data.reverseTouchDrag ? 1 : -1), (i.rotation.y -= 0.5 * n * t), (this.touchStart = { x: e.touches[0].pageX, y: e.touches[0].pageY })) }, onTouchEnd: function () { this.touchStarted = !1 }, onEnterVR: function () { var e = this.el.sceneEl e.checkHeadsetConnected() && (this.saveCameraPose(), this.el.object3D.position.set(0, 0, 0), this.el.object3D.rotation.set(0, 0, 0), e.hasWebXR && ((this.el.object3D.matrixAutoUpdate = !1), this.el.object3D.updateMatrix())) }, onExitVR: function () { this.el.sceneEl.checkHeadsetConnected() && (this.restoreCameraPose(), this.previousHMDPosition.set(0, 0, 0), (this.el.object3D.matrixAutoUpdate = !0)) }, onPointerLockChange: function () { this.pointerLocked = !( !document.pointerLockElement && !document.mozPointerLockElement ) }, onPointerLockError: function () { this.pointerLocked = !1 }, exitPointerLock: function () { document.exitPointerLock(), (this.pointerLocked = !1) }, updateGrabCursor: function (e) { var t = this.el.sceneEl function n() { t.canvas.classList.add('a-grab-cursor') } function r() { t.canvas.classList.remove('a-grab-cursor') } t.canvas ? e ? n() : r() : e ? t.addEventListener('render-target-loaded', n) : t.addEventListener('render-target-loaded', r) }, saveCameraPose: function () { var e = this.el this.savedPose.position.copy(e.object3D.position), this.savedPose.rotation.copy(e.object3D.rotation), (this.hasSavedPose = !0) }, restoreCameraPose: function () { var e = this.el, t = this.savedPose this.hasSavedPose && (e.object3D.position.copy(t.position), e.object3D.rotation.copy(t.rotation), (this.hasSavedPose = !1)) }, }) }, { '../core/component': 131, '../lib/three': 179, '../utils/': 205 }, ], 91: [ function (e, t, n) { var r = e('../utils/bind'), i = e('../core/component').registerComponent, o = e('../utils/tracked-controls'), a = o.checkControllerPresentAndSetup, s = o.emitIfAxesChanged, l = o.onButtonEvent, c = 'magicleap-one', u = 'https://cdn.aframe.io/controllers/magicleap/magicleap-one-controller.glb', h = { axes: { touchpad: [0, 1] }, buttons: ['trigger', 'grip', 'touchpad', 'menu'], } t.exports.Component = i('magicleap-controls', { schema: { hand: { default: 'none' }, model: { default: !0 }, orientationOffset: { type: 'vec3' }, }, mapping: h, init: function () { var e = this ;(this.controllerPresent = !1), (this.lastControllerCheck = 0), (this.onButtonChanged = r(this.onButtonChanged, this)), (this.onButtonDown = function (t) { l(t.detail.id, 'down', e) }), (this.onButtonUp = function (t) { l(t.detail.id, 'up', e) }), (this.onButtonTouchEnd = function (t) { l(t.detail.id, 'touchend', e) }), (this.onButtonTouchStart = function (t) { l(t.detail.id, 'touchstart', e) }), (this.previousButtonValues = {}), (this.rendererSystem = this.el.sceneEl.systems.renderer), this.bindMethods() }, update: function () { var e = this.data this.controllerIndex = 'right' === e.hand ? 0 : 'left' === e.hand ? 1 : 2 }, play: function () { this.checkIfControllerPresent(), this.addControllersUpdateListener() }, pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, bindMethods: function () { ;(this.onModelLoaded = r(this.onModelLoaded, this)), (this.onControllersUpdate = r(this.onControllersUpdate, this)), (this.checkIfControllerPresent = r(this.checkIfControllerPresent, this)), (this.removeControllersUpdateListener = r( this.removeControllersUpdateListener, this, )), (this.onAxisMoved = r(this.onAxisMoved, this)) }, addEventListeners: function () { var e = this.el e.addEventListener('buttonchanged', this.onButtonChanged), e.addEventListener('buttondown', this.onButtonDown), e.addEventListener('buttonup', this.onButtonUp), e.addEventListener('touchstart', this.onButtonTouchStart), e.addEventListener('touchend', this.onButtonTouchEnd), e.addEventListener('axismove', this.onAxisMoved), e.addEventListener('model-loaded', this.onModelLoaded), (this.controllerEventsActive = !0) }, removeEventListeners: function () { var e = this.el e.removeEventListener('buttonchanged', this.onButtonChanged), e.removeEventListener('buttondown', this.onButtonDown), e.removeEventListener('buttonup', this.onButtonUp), e.removeEventListener('touchstart', this.onButtonTouchStart), e.removeEventListener('touchend', this.onButtonTouchEnd), e.removeEventListener('axismove', this.onAxisMoved), e.removeEventListener('model-loaded', this.onModelLoaded), (this.controllerEventsActive = !1) }, checkIfControllerPresent: function () { var e = this.data a(this, c, { index: this.controllerIndex, hand: e.hand }) }, injectTrackedControls: function () { var e = this.el, t = this.data e.setAttribute('tracked-controls', { idPrefix: c, hand: t.hand, controller: this.controllerIndex, orientationOffset: t.orientationOffset, }), this.data.model && this.el.setAttribute('gltf-model', u) }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { this.checkIfControllerPresent() }, onButtonChanged: function (e) { var t, n = this.mapping.buttons[e.detail.id] n && ('trigger' === n && ((t = e.detail.state.value), console.log('analog value of trigger press: ' + t)), this.el.emit(n + 'changed', e.detail.state)) }, onModelLoaded: function (e) { e.detail.model.scale.set(0.01, 0.01, 0.01) }, onAxisMoved: function (e) { s(this, this.mapping.axes, e) }, updateModel: function (e, t) {}, setButtonColor: function (e, t) {}, }) }, { '../core/component': 131, '../utils/bind': 199, '../utils/tracked-controls': 214 }, ], 92: [ function (e, t, n) { var r = e('../utils/'), i = e('../core/component'), o = e('../lib/three'), a = e('../core/shader'), s = r.debug('components:material:error'), l = i.registerComponent, c = a.shaders, u = a.shaderNames function h(e) { switch (e) { case 'back': return o.BackSide case 'double': return o.DoubleSide default: return o.FrontSide } } function d(e) { switch (e) { case 'face': return o.FaceColors case 'vertex': return o.VertexColors default: return o.NoColors } } function p(e) { switch (e) { case 'none': return o.NoBlending case 'additive': return o.AdditiveBlending case 'subtractive': return o.SubtractiveBlending case 'multiply': return o.MultiplyBlending default: return o.NormalBlending } } function f(e, t) { e.dispose(), t.unregisterMaterial(e) } t.exports.Component = l('material', { schema: { alphaTest: { default: 0, min: 0, max: 1 }, depthTest: { default: !0 }, depthWrite: { default: !0 }, flatShading: { default: !1 }, npot: { default: !1 }, offset: { type: 'vec2', default: { x: 0, y: 0 } }, opacity: { default: 1, min: 0, max: 1 }, repeat: { type: 'vec2', default: { x: 1, y: 1 } }, shader: { default: 'standard', oneOf: u, schemaChange: !0 }, side: { default: 'front', oneOf: ['front', 'back', 'double'] }, transparent: { default: !1 }, vertexColors: { type: 'string', default: 'none', oneOf: ['face', 'vertex'] }, visible: { default: !0 }, blending: { default: 'normal', oneOf: ['none', 'normal', 'additive', 'subtractive', 'multiply'], }, dithering: { default: !0 }, }, init: function () { this.material = null }, update: function (e) { var t = this.data ;(this.shader && t.shader === e.shader) || this.updateShader(t.shader), this.shader.update(this.data), this.updateMaterial(e) }, updateSchema: function (e) { var t, n, r, i ;(n = e && e.shader), (t = this.oldData && this.oldData.shader), (r = c[(i = n || t)] && c[i].schema) || s('Unknown shader schema ' + i), (t && n === t) || (this.extendSchema(r), this.updateBehavior()) }, updateBehavior: function () { var e, t, n = this.el.sceneEl, r = this.schema, i = this function o(e, n) { var r for (r in t) t[r] = e i.shader.update(t) } for (e in ((this.tick = void 0), (t = {}), r)) 'time' === r[e].type && ((this.tick = o), (t[e] = !0)) n && (this.tick ? n.addBehavior(this) : n.removeBehavior(this)) }, updateShader: function (e) { var t, n = this.data, r = c[e] && c[e].Shader if (!r) throw new Error('Unknown shader ' + e) ;((t = this.shader = new r()).el = this.el), t.init(n), this.setMaterial(t.material), this.updateSchema(n) }, updateMaterial: function (e) { var t, n = this.data, r = this.material for (t in ((r.alphaTest = n.alphaTest), (r.depthTest = !1 !== n.depthTest), (r.depthWrite = !1 !== n.depthWrite), (r.opacity = n.opacity), (r.flatShading = n.flatShading), (r.side = h(n.side)), (r.transparent = !1 !== n.transparent || n.opacity < 1), (r.vertexColors = d(n.vertexColors)), (r.visible = n.visible), (r.blending = p(n.blending)), (r.dithering = n.dithering), e)) break !t || (e.alphaTest === n.alphaTest && e.side === n.side && e.vertexColors === n.vertexColors) || (r.needsUpdate = !0) }, remove: function () { var e = new o.MeshBasicMaterial(), t = this.material, n = this.el.getObject3D('mesh') n && (n.material = e), f(t, this.system) }, setMaterial: function (e) { var t, n = this.el, r = this.system this.material && f(this.material, r), (this.material = e), r.registerMaterial(e), (t = n.getObject3D('mesh')) ? (t.material = e) : n.addEventListener('object3dset', function t(r) { 'mesh' === r.detail.type && r.target === n && ((n.getObject3D('mesh').material = e), n.removeEventListener('object3dset', t)) }) }, }) }, { '../core/component': 131, '../core/shader': 141, '../lib/three': 179, '../utils/': 205, }, ], 93: [ function (e, t, n) { var r = e('../utils/debug'), i = e('../core/component').registerComponent, o = e('../lib/three'), a = r('components:obj-model:warn') t.exports.Component = i('obj-model', { schema: { mtl: { type: 'model' }, obj: { type: 'model' } }, init: function () { var e = this ;(this.model = null), (this.objLoader = new o.OBJLoader()), (this.mtlLoader = new o.MTLLoader(this.objLoader.manager)), (this.mtlLoader.crossOrigin = ''), this.el.addEventListener('componentinitialized', function (t) { e.model && 'material' === t.detail.name && e.applyMaterial() }) }, update: function () { var e = this.data e.obj && (this.resetMesh(), this.loadObj(e.obj, e.mtl)) }, remove: function () { this.model && this.resetMesh() }, resetMesh: function () { this.el.removeObject3D('mesh') }, loadObj: function (e, t) { var n = this, r = this.el, i = this.mtlLoader, o = this.objLoader, s = this.el.sceneEl.systems.renderer, l = t.substr(0, t.lastIndexOf('/') + 1) if (t) return ( r.hasAttribute('material') && a('Material component properties are ignored when a .MTL is provided'), i.setResourcePath(l), void i.load(t, function (t) { t.preload(), o.setMaterials(t), o.load(e, function (e) { ;(n.model = e), n.model.traverse(function (e) { if (e.isMesh) { var t = e.material t.color && s.applyColorCorrection(t.color), t.map && s.applyColorCorrection(t.map), t.emissive && s.applyColorCorrection(t.emissive), t.emissiveMap && s.applyColorCorrection(t.emissiveMap) } }), r.setObject3D('mesh', e), r.emit('model-loaded', { format: 'obj', model: e }) }) }) ) o.load(e, function (e) { ;(n.model = e), n.applyMaterial(), r.setObject3D('mesh', e), r.emit('model-loaded', { format: 'obj', model: e }) }) }, applyMaterial: function () { var e = this.el.components.material e && this.model.traverse(function (t) { t instanceof o.Mesh && (t.material = e.material) }) }, }) }, { '../core/component': 131, '../lib/three': 179, '../utils/debug': 201 }, ], 94: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/bind'), o = e('../utils/tracked-controls'), a = o.checkControllerPresentAndSetup, s = o.emitIfAxesChanged, l = o.onButtonEvent, c = e('../utils/').device.isWebXRAvailable, u = 'https://cdn.aframe.io/controllers/oculus/go/oculus-go-controller.gltf', h = c ? 'oculus-go' : 'Oculus Go', d = c ? { axes: { touchpad: [0, 1] }, buttons: ['trigger', 'none', 'touchpad'] } : { axes: { trackpad: [0, 1] }, buttons: ['trackpad', 'trigger'] } t.exports.Component = r('oculus-go-controls', { schema: { hand: { default: '' }, buttonColor: { type: 'color', default: '#FFFFFF' }, buttonTouchedColor: { type: 'color', default: '#BBBBBB' }, buttonHighlightColor: { type: 'color', default: '#7A7A7A' }, model: { default: !0 }, orientationOffset: { type: 'vec3' }, armModel: { default: !0 }, }, mapping: d, bindMethods: function () { ;(this.onModelLoaded = i(this.onModelLoaded, this)), (this.onControllersUpdate = i(this.onControllersUpdate, this)), (this.checkIfControllerPresent = i(this.checkIfControllerPresent, this)), (this.removeControllersUpdateListener = i( this.removeControllersUpdateListener, this, )), (this.onAxisMoved = i(this.onAxisMoved, this)) }, init: function () { var e = this ;(this.onButtonChanged = i(this.onButtonChanged, this)), (this.onButtonDown = function (t) { l(t.detail.id, 'down', e) }), (this.onButtonUp = function (t) { l(t.detail.id, 'up', e) }), (this.onButtonTouchStart = function (t) { l(t.detail.id, 'touchstart', e) }), (this.onButtonTouchEnd = function (t) { l(t.detail.id, 'touchend', e) }), (this.controllerPresent = !1), (this.lastControllerCheck = 0), (this.rendererSystem = this.el.sceneEl.systems.renderer), this.bindMethods() }, addEventListeners: function () { var e = this.el e.addEventListener('buttonchanged', this.onButtonChanged), e.addEventListener('buttondown', this.onButtonDown), e.addEventListener('buttonup', this.onButtonUp), e.addEventListener('touchstart', this.onButtonTouchStart), e.addEventListener('touchend', this.onButtonTouchEnd), e.addEventListener('model-loaded', this.onModelLoaded), e.addEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !0) }, removeEventListeners: function () { var e = this.el e.removeEventListener('buttonchanged', this.onButtonChanged), e.removeEventListener('buttondown', this.onButtonDown), e.removeEventListener('buttonup', this.onButtonUp), e.removeEventListener('touchstart', this.onButtonTouchStart), e.removeEventListener('touchend', this.onButtonTouchEnd), e.removeEventListener('model-loaded', this.onModelLoaded), e.removeEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !1) }, checkIfControllerPresent: function () { a(this, h, this.data.hand ? { hand: this.data.hand } : {}) }, play: function () { this.checkIfControllerPresent(), this.addControllersUpdateListener() }, pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, injectTrackedControls: function () { var e = this.el, t = this.data e.setAttribute('tracked-controls', { armModel: t.armModel, hand: t.hand, idPrefix: h, orientationOffset: t.orientationOffset, }), this.data.model && this.el.setAttribute('gltf-model', u) }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { this.checkIfControllerPresent() }, onModelLoaded: function (e) { var t, n = e.detail.model this.data.model && (((t = this.buttonMeshes = {}).trigger = n.getObjectByName( 'oculus_go_button_trigger', )), (t.trackpad = n.getObjectByName('oculus_go_touchpad')), (t.touchpad = n.getObjectByName('oculus_go_touchpad'))) }, onButtonChanged: function (e) { var t = this.mapping.buttons[e.detail.id] t && this.el.emit(t + 'changed', e.detail.state) }, onAxisMoved: function (e) { s(this, this.mapping.axes, e) }, updateModel: function (e, t) { this.data.model && this.updateButtonModel(e, t) }, updateButtonModel: function (e, t) { var n = this.buttonMeshes if (n && n[e]) { var r, i switch (t) { case 'down': r = this.data.buttonHighlightColor break case 'touchstart': r = this.data.buttonTouchedColor break default: r = this.data.buttonColor } ;(i = n[e]).material.color.set(r), this.rendererSystem.applyColorCorrection(i.material.color) } }, }) }, { '../core/component': 131, '../utils/': 205, '../utils/bind': 199, '../utils/tracked-controls': 214, }, ], 95: [ function (e, t, n) { var r = e('../utils/bind'), i = e('../core/component').registerComponent, o = e('../lib/three'), a = e('../utils/tracked-controls'), s = a.checkControllerPresentAndSetup, l = a.emitIfAxesChanged, c = a.onButtonEvent, u = e('../utils/').device.isWebXRAvailable, h = 'oculus-touch', d = u ? h : 'Oculus Touch', p = 'https://cdn.aframe.io/controllers/oculus/oculus-touch-controller-', f = { left: { modelUrl: p + 'left.gltf', rayOrigin: { origin: { x: 0.008, y: -0.01, z: 0 }, direction: { x: 0, y: -0.8, z: -1 }, }, modelPivotOffset: new o.Vector3(-0.005, 0.003, -0.055), modelPivotRotation: new o.Euler(0, 0, 0), }, right: { modelUrl: p + 'right.gltf', rayOrigin: { origin: { x: -0.008, y: -0.01, z: 0 }, direction: { x: 0, y: -0.8, z: -1 }, }, modelPivotOffset: new o.Vector3(0.005, 0.003, -0.055), modelPivotRotation: new o.Euler(0, 0, 0), }, }, m = { left: { modelUrl: p + 'left.gltf', rayOrigin: { origin: { x: 0.002, y: -0.005, z: -0.03 }, direction: { x: 0, y: -0.8, z: -1 }, }, modelPivotOffset: new o.Vector3(-0.005, 0.036, -0.037), modelPivotRotation: new o.Euler(Math.PI / 4.5, 0, 0), }, right: { modelUrl: p + 'right.gltf', rayOrigin: { origin: { x: -0.002, y: -0.005, z: -0.03 }, direction: { x: 0, y: -0.8, z: -1 }, }, modelPivotOffset: new o.Vector3(0.005, 0.036, -0.037), modelPivotRotation: new o.Euler(Math.PI / 4.5, 0, 0), }, }, v = 'oculus-touch', g = { 'oculus-touch': u ? m : f, 'oculus-touch-v2': { left: { modelUrl: p + 'gen2-left.gltf', rayOrigin: { origin: { x: -0.01, y: 0, z: -0.02 }, direction: { x: 0, y: -0.5, z: -1 }, }, modelPivotOffset: new o.Vector3(0, 0, 0), modelPivotRotation: new o.Euler(0, 0, 0), }, right: { modelUrl: p + 'gen2-right.gltf', rayOrigin: { origin: { x: 0.01, y: 0, z: -0.02 }, direction: { x: 0, y: -0.5, z: -1 }, }, modelPivotOffset: new o.Vector3(0, 0, 0), modelPivotRotation: new o.Euler(0, 0, 0), }, }, 'oculus-touch-v3': { left: { modelUrl: p + 'v3-left.glb', rayOrigin: { origin: { x: 0.015, y: 0.005, z: 0 }, direction: { x: 0, y: 0, z: -1 }, }, modelPivotOffset: new o.Vector3(0.01, -0.01, 0.05), modelPivotRotation: new o.Euler(Math.PI / 4, 0, 0), }, right: { modelUrl: p + 'v3-right.glb', rayOrigin: { origin: { x: -0.015, y: 0.005, z: 0 }, direction: { x: 0, y: 0, z: -1 }, }, modelPivotOffset: new o.Vector3(-0.01, -0.01, 0.05), modelPivotRotation: new o.Euler(Math.PI / 4, 0, 0), }, }, }, y = u ? { left: { axes: { thumbstick: [2, 3] }, buttons: [ 'trigger', 'grip', 'none', 'thumbstick', 'xbutton', 'ybutton', 'surface', ], }, right: { axes: { thumbstick: [2, 3] }, buttons: [ 'trigger', 'grip', 'none', 'thumbstick', 'abutton', 'bbutton', 'surface', ], }, } : { left: { axes: { thumbstick: [0, 1] }, buttons: [ 'thumbstick', 'trigger', 'grip', 'xbutton', 'ybutton', 'surface', ], }, right: { axes: { thumbstick: [0, 1] }, buttons: [ 'thumbstick', 'trigger', 'grip', 'abutton', 'bbutton', 'surface', ], }, } t.exports.Component = i('oculus-touch-controls', { schema: { hand: { default: 'left' }, buttonColor: { type: 'color', default: '#999' }, buttonTouchColor: { type: 'color', default: '#8AB' }, buttonHighlightColor: { type: 'color', default: '#2DF' }, model: { default: !0 }, controllerType: { default: 'auto', oneOf: ['auto', 'oculus-touch', 'oculus-touch-v2', 'oculus-touch-v3'], }, orientationOffset: { type: 'vec3', default: { x: 43, y: 0, z: 0 } }, }, mapping: y, bindMethods: function () { ;(this.onModelLoaded = r(this.onModelLoaded, this)), (this.onControllersUpdate = r(this.onControllersUpdate, this)), (this.checkIfControllerPresent = r(this.checkIfControllerPresent, this)), (this.onAxisMoved = r(this.onAxisMoved, this)) }, init: function () { var e = this ;(this.onButtonChanged = r(this.onButtonChanged, this)), (this.onButtonDown = function (t) { c(t.detail.id, 'down', e, e.data.hand) }), (this.onButtonUp = function (t) { c(t.detail.id, 'up', e, e.data.hand) }), (this.onButtonTouchStart = function (t) { c(t.detail.id, 'touchstart', e, e.data.hand) }), (this.onButtonTouchEnd = function (t) { c(t.detail.id, 'touchend', e, e.data.hand) }), (this.controllerPresent = !1), (this.lastControllerCheck = 0), (this.previousButtonValues = {}), (this.rendererSystem = this.el.sceneEl.systems.renderer), this.bindMethods() }, addEventListeners: function () { var e = this.el e.addEventListener('buttonchanged', this.onButtonChanged), e.addEventListener('buttondown', this.onButtonDown), e.addEventListener('buttonup', this.onButtonUp), e.addEventListener('touchstart', this.onButtonTouchStart), e.addEventListener('touchend', this.onButtonTouchEnd), e.addEventListener('axismove', this.onAxisMoved), e.addEventListener('model-loaded', this.onModelLoaded), (this.controllerEventsActive = !0) }, removeEventListeners: function () { var e = this.el e.removeEventListener('buttonchanged', this.onButtonChanged), e.removeEventListener('buttondown', this.onButtonDown), e.removeEventListener('buttonup', this.onButtonUp), e.removeEventListener('touchstart', this.onButtonTouchStart), e.removeEventListener('touchend', this.onButtonTouchEnd), e.removeEventListener('axismove', this.onAxisMoved), e.removeEventListener('model-loaded', this.onModelLoaded), (this.controllerEventsActive = !1) }, checkIfControllerPresent: function () { s(this, d, { hand: this.data.hand }) }, play: function () { this.checkIfControllerPresent(), this.addControllersUpdateListener() }, pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, loadModel: function (e) { var t, n = this.data if (n.model) { if ( ((this.displayModel = g[n.controllerType] || g[v]), 'auto' === n.controllerType) ) { var r = this.el.sceneEl.systems['tracked-controls-webvr'] if (r && r.vrDisplay) { var i = r.vrDisplay.displayName ;/^Oculus Quest$/.test(i) && (this.displayModel = g['oculus-touch-v2']) } else (t = v), (t = -1 !== e.profiles.indexOf('oculus-touch-v2') ? 'oculus-touch-v2' : t), (t = -1 !== e.profiles.indexOf('oculus-touch-v3') ? 'oculus-touch-v3' : t), (this.displayModel = g[t]) } var o = this.displayModel[n.hand].modelUrl this.el.setAttribute('gltf-model', o) } }, injectTrackedControls: function (e) { var t = this.data, n = h, r = 'right' === t.hand ? 'Oculus Touch (Right)' : 'Oculus Touch (Left)', i = u ? n : r this.el.setAttribute('tracked-controls', { id: i, hand: t.hand, orientationOffset: t.orientationOffset, handTrackingEnabled: !1, }), this.loadModel(e) }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { this.checkIfControllerPresent() }, onButtonChanged: function (e) { var t, n = this.mapping[this.data.hand].buttons[e.detail.id], r = this.buttonMeshes n && (('trigger' !== n && 'grip' !== n) || (t = e.detail.state.value), r && ('trigger' === n && r.trigger && (r.trigger.rotation.x = this.originalXRotationTrigger - t * (Math.PI / 26)), 'grip' === n && r.grip && (r.grip.position.x = this.originalXPositionGrip + ('left' === this.data.hand ? -1 : 1) * t * 0.004)), this.el.emit(n + 'changed', e.detail.state)) }, onModelLoaded: function (e) { var t, n = (this.controllerObject3D = e.detail.model) this.data.model && (((t = this.buttonMeshes = {}).grip = n.getObjectByName('buttonHand')), (this.originalXPositionGrip = t.grip && t.grip.position.x), (t.thumbstick = n.getObjectByName('stick')), (t.trigger = n.getObjectByName('buttonTrigger')), (this.originalXRotationTrigger = t.trigger && t.trigger.rotation.x), (t.xbutton = n.getObjectByName('buttonX')), (t.abutton = n.getObjectByName('buttonA')), (t.ybutton = n.getObjectByName('buttonY')), (t.bbutton = n.getObjectByName('buttonB')), n.position.copy(this.displayModel[this.data.hand].modelPivotOffset), n.rotation.copy(this.displayModel[this.data.hand].modelPivotRotation), this.el.emit('controllermodelready', { name: 'oculus-touch-controls', model: this.data.model, rayOrigin: this.displayModel[this.data.hand].rayOrigin, })) }, onAxisMoved: function (e) { l(this, this.mapping[this.data.hand].axes, e) }, updateModel: function (e, t) { this.data.model && this.updateButtonModel(e, t) }, updateButtonModel: function (e, t) { var n, r = 'up' === t || 'touchend' === t ? this.data.buttonColor : 'touchstart' === t ? this.data.buttonTouchColor : this.data.buttonHighlightColor, i = this.buttonMeshes this.data.model && i && i[e] && ((n = i[e]).material.color.set(r), this.rendererSystem.applyColorCorrection(n.material.color)) }, }) }, { '../core/component': 131, '../lib/three': 179, '../utils/': 205, '../utils/bind': 199, '../utils/tracked-controls': 214, }, ], 96: [ function (e, t, n) { var r = e('../core/component').registerComponent t.exports.Component = r('position', { schema: { type: 'vec3' }, update: function () { var e = this.el.object3D, t = this.data e.position.set(t.x, t.y, t.z) }, remove: function () { this.el.object3D.position.set(0, 0, 0) }, }) }, { '../core/component': 131 }, ], 97: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../lib/three'), o = e('../utils/').debug('components:raycaster:warn'), a = /^[\w\s-.,[\]#]*$/, s = { childList: !0, attributes: !0, subtree: !0 }, l = { INTERSECT: 'raycaster-intersected', INTERSECTION: 'raycaster-intersection', INTERSECT_CLEAR: 'raycaster-intersected-cleared', INTERSECTION_CLEAR: 'raycaster-intersection-cleared', } function c(e, t) { var n for (e.length = t.length, n = 0; n < t.length; n++) e[n] = t[n] } t.exports.Component = r('raycaster', { schema: { autoRefresh: { default: !0 }, direction: { type: 'vec3', default: { x: 0, y: 0, z: -1 } }, enabled: { default: !0 }, far: { default: 1e3 }, interval: { default: 0 }, near: { default: 0 }, objects: { default: '' }, origin: { type: 'vec3' }, showLine: { default: !1 }, lineColor: { default: 'white' }, lineOpacity: { default: 1 }, useWorldCoordinates: { default: !1 }, }, multiple: !0, init: function () { ;(this.clearedIntersectedEls = []), (this.unitLineEndVec3 = new i.Vector3()), (this.intersectedEls = []), (this.intersections = []), (this.newIntersectedEls = []), (this.newIntersections = []), (this.objects = []), (this.prevCheckTime = void 0), (this.prevIntersectedEls = []), (this.rawIntersections = []), (this.raycaster = new i.Raycaster()), this.updateOriginDirection(), (this.setDirty = this.setDirty.bind(this)), (this.updateLine = this.updateLine.bind(this)), (this.observer = new MutationObserver(this.setDirty)), (this.dirty = !0), (this.lineEndVec3 = new i.Vector3()), (this.otherLineEndVec3 = new i.Vector3()), (this.lineData = { end: this.lineEndVec3 }), (this.getIntersection = this.getIntersection.bind(this)), (this.intersectedDetail = { el: this.el, getIntersection: this.getIntersection, }), (this.intersectedClearedDetail = { el: this.el }), (this.intersectionClearedDetail = { clearedEls: this.clearedIntersectedEls }), (this.intersectionDetail = {}) }, update: function (e) { var t = this.data, n = this.el, r = this.raycaster ;(r.far = t.far), (r.near = t.near), !t.showLine || (t.far === e.far && t.origin === e.origin && t.direction === e.direction && e.showLine) || (this.unitLineEndVec3.copy(t.origin).add(t.direction).normalize(), this.drawLine()), !t.showLine && e.showLine && n.removeAttribute('line'), t.objects === e.objects || a.test(t.objects) || o( '[raycaster] Selector "' + t.objects + '" may not update automatically with DOM changes.', ), t.objects || o( '[raycaster] For performance, please define raycaster.objects when using raycaster or cursor components to whitelist which entities to intersect with. e.g., raycaster="objects: [data-raycastable]".', ), t.autoRefresh !== e.autoRefresh && n.isPlaying && (t.autoRefresh ? this.addEventListeners() : this.removeEventListeners()), e.enabled && !t.enabled && this.clearAllIntersections(), this.setDirty() }, play: function () { this.addEventListeners() }, pause: function () { this.removeEventListeners() }, remove: function () { this.data.showLine && this.el.removeAttribute('line'), this.clearAllIntersections() }, addEventListeners: function () { this.data.autoRefresh && (this.observer.observe(this.el.sceneEl, s), this.el.sceneEl.addEventListener('object3dset', this.setDirty), this.el.sceneEl.addEventListener('object3dremove', this.setDirty)) }, removeEventListeners: function () { this.observer.disconnect(), this.el.sceneEl.removeEventListener('object3dset', this.setDirty), this.el.sceneEl.removeEventListener('object3dremove', this.setDirty) }, setDirty: function () { this.dirty = !0 }, refreshObjects: function () { var e, t = this.data ;(e = t.objects ? this.el.sceneEl.querySelectorAll(t.objects) : this.el.sceneEl.querySelectorAll('*')), (this.objects = this.flattenObject3DMaps(e)), (this.dirty = !1) }, tock: function (e) { var t = this.data, n = this.prevCheckTime t.enabled && ((n && e - n < t.interval) || ((this.prevCheckTime = e), this.checkIntersections())) }, checkIntersections: function () { var e, t, n = this.clearedIntersectedEls, r = this.el, i = this.data, o = this.intersectedEls, a = this.intersections, s = this.newIntersectedEls, u = this.newIntersections, h = this.prevIntersectedEls, d = this.rawIntersections for ( this.dirty && this.refreshObjects(), c(this.prevIntersectedEls, this.intersectedEls), this.updateOriginDirection(), d.length = 0, this.raycaster.intersectObjects(this.objects, !0, d), a.length = 0, o.length = 0, e = 0; e < d.length; e++ ) (t = d[e]), (i.showLine && t.object === r.getObject3D('line')) || (t.object.el && (a.push(t), o.push(t.object.el))) for (u.length = 0, s.length = 0, e = 0; e < a.length; e++) -1 === h.indexOf(a[e].object.el) && (u.push(a[e]), s.push(a[e].object.el)) for (n.length = 0, e = 0; e < h.length; e++) -1 === o.indexOf(h[e]) && (h[e].emit(l.INTERSECT_CLEAR, this.intersectedClearedDetail), n.push(h[e])) for ( n.length && r.emit(l.INTERSECTION_CLEAR, this.intersectionClearedDetail), e = 0; e < s.length; e++ ) s[e].emit(l.INTERSECT, this.intersectedDetail) u.length && ((this.intersectionDetail.els = s), (this.intersectionDetail.intersections = u), r.emit(l.INTERSECTION, this.intersectionDetail)), i.showLine && setTimeout(this.updateLine) }, updateLine: function () { var e, t = this.el, n = this.intersections n.length && (e = n[0].object.el === t && n[1] ? n[1].distance : n[0].distance), this.drawLine(e) }, getIntersection: function (e) { var t, n for (t = 0; t < this.intersections.length; t++) if ((n = this.intersections[t]).object.el === e) return n return null }, updateOriginDirection: (function () { var e = new i.Vector3(), t = new i.Vector3() return function () { var n = this.el, r = this.data r.useWorldCoordinates ? this.raycaster.set(r.origin, r.direction) : (n.object3D.updateMatrixWorld(), t.setFromMatrixPosition(n.object3D.matrixWorld), (0 === r.origin.x && 0 === r.origin.y && 0 === r.origin.z) || (t = n.object3D.localToWorld(t.copy(r.origin))), e .copy(r.direction) .transformDirection(n.object3D.matrixWorld) .normalize(), this.raycaster.set(t, e)) } })(), drawLine: function (e) { var t, n = this.data, r = this.el ;(t = this.lineData.end === this.lineEndVec3 ? this.otherLineEndVec3 : this.lineEndVec3), void 0 === e && (e = n.far === 1 / 0 ? 1e3 : n.far), (this.lineData.start = n.origin), (this.lineData.end = t.copy(this.unitLineEndVec3).multiplyScalar(e)), (this.lineData.color = n.lineColor), (this.lineData.opacity = n.lineOpacity), r.setAttribute('line', this.lineData) }, flattenObject3DMaps: function (e) { var t, n, r = this.objects for (r.length = 0, n = 0; n < e.length; n++) if (e[n].isEntity && e[n].object3D) for (t in e[n].object3DMap) r.push(e[n].getObject3D(t)) return r }, clearAllIntersections: function () { var e for (e = 0; e < this.intersectedEls.length; e++) this.intersectedEls[e].emit(l.INTERSECT_CLEAR, this.intersectedClearedDetail) c(this.clearedIntersectedEls, this.intersectedEls), (this.intersectedEls.length = 0), (this.intersections.length = 0), this.el.emit(l.INTERSECTION_CLEAR, this.intersectionClearedDetail) }, }) }, { '../core/component': 131, '../lib/three': 179, '../utils/': 205 }, ], 98: [ function (e, t, n) { var r = e('../lib/three').Math.degToRad, i = e('../core/component').registerComponent t.exports.Component = i('rotation', { schema: { type: 'vec3' }, update: function () { var e = this.data, t = this.el.object3D t.rotation.set(r(e.x), r(e.y), r(e.z)), (t.rotation.order = 'YXZ') }, remove: function () { this.el.object3D.rotation.set(0, 0, 0) }, }) }, { '../core/component': 131, '../lib/three': 179 }, ], 99: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = 1e-5 t.exports.Component = r('scale', { schema: { type: 'vec3', default: { x: 1, y: 1, z: 1 } }, update: function () { var e = this.data, t = this.el.object3D, n = 0 === e.x ? i : e.x, r = 0 === e.y ? i : e.y, o = 0 === e.z ? i : e.z t.scale.set(n, r, o) }, remove: function () { this.el.object3D.scale.set(1, 1, 1) }, }) }, { '../core/component': 131 }, ], 100: [ function (e, t, n) { var r = e('../../core/component').registerComponent, i = e('../../core/component').components t.exports.Component = r('background', { schema: { color: { type: 'color', default: 'black' }, transparent: { default: !1 }, }, update: function () { var e = this.data, t = this.el.object3D e.transparent ? (t.background = null) : (t.background = new THREE.Color(e.color)) }, remove: function () { var e = this.data, t = this.el.object3D e.transparent ? (t.background = null) : (t.background = i[this.name].schema.color.default) }, }) }, { '../../core/component': 131 }, ], 101: [ function (e, t, n) { var r = e('../../core/component').registerComponent t.exports.Component = r('debug', { schema: { default: !0 } }) }, { '../../core/component': 131 }, ], 102: [ function (e, t, n) { var r = e('../../core/component').registerComponent, i = e('../../utils/'), o = i.bind, a = e('../../constants/'), s = 'a-modal', l = 'a-dialog', c = 'a-dialog-text', u = 'a-dialog-text-container', h = 'a-dialog-buttons-container', d = 'a-dialog-button', p = 'a-dialog-allow-button', f = 'a-dialog-deny-button', m = 'a-dialog-ok-button' function v(e, t, n, r, i) { var o, s, l return ( (o = document.createElement('div')).classList.add(h), (s = document.createElement('button')).classList.add(d, f), s.setAttribute(a.AFRAME_INJECTED, ''), (s.innerHTML = e), o.appendChild(s), (l = document.createElement('button')).classList.add(d, p), l.setAttribute(a.AFRAME_INJECTED, ''), (l.innerHTML = t), o.appendChild(l), l.addEventListener('click', function (e) { e.stopPropagation(), r() }), s.addEventListener('click', function (e) { e.stopPropagation(), i() }), y(n, o) ) } function g(e, t, n) { var r, i return ( (r = document.createElement('div')).classList.add(h), (i = document.createElement('button')).classList.add(d, m), i.setAttribute(a.AFRAME_INJECTED, ''), (i.innerHTML = e), r.appendChild(i), i.addEventListener('click', function (e) { e.stopPropagation(), n() }), y(t, r) ) } function y(e, t) { var n, r, i, o return ( (n = document.createElement('div')).classList.add(s), n.setAttribute(a.AFRAME_INJECTED, ''), ((r = document.createElement('div')).className = l), r.setAttribute(a.AFRAME_INJECTED, ''), n.appendChild(r), (i = document.createElement('div')).classList.add(u), r.appendChild(i), (o = document.createElement('div')).classList.add(c), (o.innerHTML = e), i.appendChild(o), r.appendChild(t), n ) } t.exports.Component = r('device-orientation-permission-ui', { schema: { enabled: { default: !0 }, deviceMotionMessage: { default: 'This immersive website requires access to your device motion sensors.', }, mobileDesktopMessage: { default: 'Set your browser to request the mobile version of the site and reload the page to enjoy immersive mode.', }, httpsMessage: { default: 'Access this site over HTTPS to enter VR mode and grant access to the device sensors.', }, denyButtonText: { default: 'Deny' }, allowButtonText: { default: 'Allow' }, cancelButtonText: { default: 'Cancel' }, }, init: function () { var e = this this.data.enabled && ('localhost' !== location.hostname && '127.0.0.1' !== location.hostname && 'http:' === location.protocol && this.showHTTPAlert(), i.device.isMobileDeviceRequestingDesktopSite() ? this.showMobileDesktopModeAlert() : 'undefined' !== typeof DeviceOrientationEvent && DeviceOrientationEvent.requestPermission ? ((this.onDeviceMotionDialogAllowClicked = o( this.onDeviceMotionDialogAllowClicked, this, )), (this.onDeviceMotionDialogDenyClicked = o( this.onDeviceMotionDialogDenyClicked, this, )), DeviceOrientationEvent.requestPermission() .catch(function () { ;(e.devicePermissionDialogEl = v( e.data.denyButtonText, e.data.allowButtonText, e.data.deviceMotionMessage, e.onDeviceMotionDialogAllowClicked, e.onDeviceMotionDialogDenyClicked, )), e.el.appendChild(e.devicePermissionDialogEl) }) .then(function () { e.el.emit('deviceorientationpermissiongranted'), (e.permissionGranted = !0) })) : (this.permissionGranted = !0)) }, remove: function () { this.devicePermissionDialogEl && this.el.removeChild(this.devicePermissionDialogEl) }, onDeviceMotionDialogDenyClicked: function () { this.remove() }, showMobileDesktopModeAlert: function () { var e = this, t = g(e.data.cancelButtonText, e.data.mobileDesktopMessage, function () { e.el.removeChild(t) }) this.el.appendChild(t) }, showHTTPAlert: function () { var e = this, t = g(e.data.cancelButtonText, e.data.httpsMessage, function () { e.el.removeChild(t) }) this.el.appendChild(t) }, onDeviceMotionDialogAllowClicked: function () { var e = this this.el.emit('deviceorientationpermissionrequested'), DeviceOrientationEvent.requestPermission() .then(function (t) { 'granted' === t ? (e.el.emit('deviceorientationpermissiongranted'), (e.permissionGranted = !0)) : e.el.emit('deviceorientationpermissionrejected'), e.remove() }) .catch(console.error) }, }) }, { '../../constants/': 123, '../../core/component': 131, '../../utils/': 205 }, ], 103: [ function (e, t, n) { var r = e('../../core/component').registerComponent t.exports.Component = r('embedded', { dependencies: ['vr-mode-ui'], schema: { default: !0 }, update: function () { var e = this.el, t = e.querySelector('.a-enter-vr') !0 === this.data ? (t && t.classList.add('embedded'), e.removeFullScreenStyles()) : (t && t.classList.remove('embedded'), e.addFullScreenStyles()) }, }) }, { '../../core/component': 131 }, ], 104: [ function (e, t, n) { var r = e('../../core/component').registerComponent, i = e('../../lib/three'), o = e('../../utils/debug')('components:fog:warn') function a(e) { var t return ( ((t = 'exponential' === e.type ? new i.FogExp2(e.color, e.density) : new i.Fog(e.color, e.near, e.far)).name = e.type), t ) } t.exports.Component = r('fog', { schema: { color: { type: 'color', default: '#000' }, density: { default: 25e-5 }, far: { default: 1e3, min: 0 }, near: { default: 1, min: 0 }, type: { default: 'linear', oneOf: ['linear', 'exponential'] }, }, update: function () { var e = this.data, t = this.el, n = this.el.object3D.fog if (t.isScene) return n && e.type === n.name ? void Object.keys(this.schema).forEach(function (t) { var r = e[t] 'color' === t && (r = new i.Color(r)), (n[t] = r) }) : ((t.object3D.fog = a(e)), void t.systems.material.updateMaterials()) o('Fog component can only be applied to ') }, remove: function () { var e = this.el.object3D.fog e && ((e.far = 0), (e.near = 0.1)) }, }) }, { '../../core/component': 131, '../../lib/three': 179, '../../utils/debug': 201 }, ], 105: [ function (e, t, n) { ;(function (n) { var r = e('../../constants').AFRAME_INJECTED, i = e('../../../package'), o = e('../../core/component').registerComponent, a = e('../../utils/') function s(e) { var t = e.split('.') return (t[2] = 'x'), t.join('.') } var l = 'https://aframe.io/aframe-inspector/dist/aframe-inspector.js', c = 'https://unpkg.com/aframe-inspector@' + s(i.version) + '/dist/aframe-inspector.min.js', u = 'dev' === n.env.INSPECTOR_VERSION ? l : c, h = 'Loading Inspector', d = 'Error loading Inspector' t.exports.Component = o('inspector', { schema: { url: { default: u } }, init: function () { ;(this.firstPlay = !0), (this.onKeydown = this.onKeydown.bind(this)), (this.onMessage = this.onMessage.bind(this)), this.initOverlay(), window.addEventListener('keydown', this.onKeydown), window.addEventListener('message', this.onMessage) }, play: function () { var e this.firstPlay && 'false' !== (e = a.getUrlParameter('inspector')) && e && (this.openInspector(), (this.firstPlay = !1)) }, initOverlay: function () { var e = '...' ;(this.loadingMessageEl = document.createElement('div')), this.loadingMessageEl.classList.add('a-inspector-loader'), (this.loadingMessageEl.innerHTML = h + e) }, remove: function () { this.removeEventListeners() }, onKeydown: function (e) { 73 === e.keyCode && ((e.ctrlKey && e.altKey) || e.getModifierState('AltGraph')) && this.openInspector() }, showLoader: function () { document.body.appendChild(this.loadingMessageEl) }, hideLoader: function () { document.body.removeChild(this.loadingMessageEl) }, onMessage: function (e) { 'INJECT_AFRAME_INSPECTOR' === e.data && this.openInspector() }, openInspector: function (e) { var t, n = this AFRAME.INSPECTOR || AFRAME.inspectorInjected ? AFRAME.INSPECTOR.open(e) : (this.showLoader(), ((t = document.createElement('script')).src = this.data.url), t.setAttribute('data-name', 'aframe-inspector'), t.setAttribute(r, ''), (t.onload = function () { AFRAME.INSPECTOR.open(e), n.hideLoader(), n.removeEventListeners() }), (t.onerror = function () { n.loadingMessageEl.innerHTML = d }), document.head.appendChild(t), (AFRAME.inspectorInjected = !0)) }, removeEventListeners: function () { window.removeEventListener('keydown', this.onKeydown), window.removeEventListener('message', this.onMessage) }, }) }.call(this, e('_process'))) }, { '../../../package': 73, '../../constants': 123, '../../core/component': 131, '../../utils/': 205, _process: 49, }, ], 106: [ function (e, t, n) { var r = e('../../core/component').registerComponent, i = e('../../utils/').shouldCaptureKeyEvent t.exports.Component = r('keyboard-shortcuts', { schema: { enterVR: { default: !0 }, exitVR: { default: !0 } }, init: function () { this.onKeyup = this.onKeyup.bind(this) }, update: function (e) { var t = this.data this.enterVREnabled = t.enterVR }, play: function () { window.addEventListener('keyup', this.onKeyup, !1) }, pause: function () { window.removeEventListener('keyup', this.onKeyup) }, onKeyup: function (e) { var t = this.el i(e) && (this.enterVREnabled && 70 === e.keyCode && t.enterVR(), this.enterVREnabled && 27 === e.keyCode && t.exitVR()) }, }) }, { '../../core/component': 131, '../../utils/': 205 }, ], 107: [ function (e, t, n) { var r = e('../../utils/debug'), i = e('../../core/component').registerComponent, o = r('components:pool:warn') t.exports.Component = i('pool', { schema: { container: { default: '' }, mixin: { default: '' }, size: { default: 0 }, dynamic: { default: !1 }, }, multiple: !0, initPool: function () { var e for ( this.availableEls = [], this.usedEls = [], this.data.mixin || o('No mixin provided for pool component.'), this.data.container && ((this.container = document.querySelector(this.data.container)), this.container || o('Container ' + this.data.container + ' not found.')), this.container = this.container || this.el, e = 0; e < this.data.size; ++e ) this.createEntity() }, update: function (e) { var t = this.data ;(e.mixin === t.mixin && e.size === t.size) || this.initPool() }, createEntity: function () { var e ;((e = document.createElement('a-entity')).play = this.wrapPlay(e.play)), e.setAttribute('mixin', this.data.mixin), (e.object3D.visible = !1), e.pause(), this.container.appendChild(e), this.availableEls.push(e) }, wrapPlay: function (e) { var t = this.usedEls return function () { ;-1 !== t.indexOf(this) && e.call(this) } }, requestEntity: function () { var e if (0 === this.availableEls.length) { if (!1 === this.data.dynamic) return void o('Requested entity from empty pool: ' + this.attrName) o( 'Requested entity from empty pool. This pool is dynamic and will resize automatically. You might want to increase its initial size: ' + this.attrName, ), this.createEntity() } return ( (e = this.availableEls.shift()), this.usedEls.push(e), (e.object3D.visible = !0), e ) }, returnEntity: function (e) { var t = this.usedEls.indexOf(e) if (-1 !== t) return ( this.usedEls.splice(t, 1), this.availableEls.push(e), (e.object3D.visible = !1), e.pause(), e ) o('The returned entity was not previously pooled from ' + this.attrName) }, }) }, { '../../core/component': 131, '../../utils/debug': 201 }, ], 108: [ function (e, t, n) { var r = e('../../core/component').registerComponent, i = e('../../lib/three'), o = [ 'attribute vec3 position;', 'attribute vec2 uv;', 'uniform mat4 projectionMatrix;', 'uniform mat4 modelViewMatrix;', 'varying vec2 vUv;', 'void main() {', ' vUv = vec2( 1.- uv.x, uv.y );', ' gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );', '}', ].join('\n'), a = [ 'precision mediump float;', 'uniform samplerCube map;', 'varying vec2 vUv;', '#define M_PI 3.141592653589793238462643383279', 'void main() {', ' vec2 uv = vUv;', ' float longitude = uv.x * 2. * M_PI - M_PI + M_PI / 2.;', ' float latitude = uv.y * M_PI;', ' vec3 dir = vec3(', ' - sin( longitude ) * sin( latitude ),', ' cos( latitude ),', ' - cos( longitude ) * sin( latitude )', ' );', ' normalize( dir );', ' gl_FragColor = vec4( textureCube( map, dir ).rgb, 1.0 );', '}', ].join('\n') t.exports.Component = r('screenshot', { schema: { width: { default: 4096 }, height: { default: 2048 }, camera: { type: 'selector' }, }, init: function () { var e = this.el, t = this function n() { var n = e.renderer.getContext() n && ((t.cubeMapSize = n.getParameter(n.MAX_CUBE_MAP_TEXTURE_SIZE)), (t.material = new i.RawShaderMaterial({ uniforms: { map: { type: 't', value: null } }, vertexShader: o, fragmentShader: a, side: i.DoubleSide, })), (t.quad = new i.Mesh(new i.PlaneBufferGeometry(1, 1), t.material)), (t.quad.visible = !1), (t.camera = new i.OrthographicCamera(-0.5, 0.5, 0.5, -0.5, -1e4, 1e4)), (t.canvas = document.createElement('canvas')), (t.ctx = t.canvas.getContext('2d')), e.object3D.add(t.quad), (t.onKeyDown = t.onKeyDown.bind(t))) } e.renderer ? n() : e.addEventListener('render-target-loaded', n) }, getRenderTarget: function (e, t) { return new i.WebGLRenderTarget(e, t, { minFilter: i.LinearFilter, magFilter: i.LinearFilter, wrapS: i.ClampToEdgeWrapping, wrapT: i.ClampToEdgeWrapping, format: i.RGBAFormat, type: i.UnsignedByteType, }) }, resize: function (e, t) { this.quad.scale.set(e, t, 1), (this.camera.left = (-1 * e) / 2), (this.camera.right = e / 2), (this.camera.top = t / 2), (this.camera.bottom = (-1 * t) / 2), this.camera.updateProjectionMatrix(), (this.canvas.width = e), (this.canvas.height = t) }, play: function () { window.addEventListener('keydown', this.onKeyDown) }, onKeyDown: function (e) { var t = 83 === e.keyCode && e.ctrlKey && e.altKey if (this.data && t) { var n = e.shiftKey ? 'equirectangular' : 'perspective' this.capture(n) } }, setCapture: function (e) { var t, n, r, o, a = this.el return ( 'perspective' === e ? ((this.quad.visible = !1), (n = (this.data.camera && this.data.camera.components.camera.camera) || a.camera), (t = { width: this.data.width, height: this.data.height })) : ((n = this.camera), (o = new i.WebGLCubeRenderTarget(Math.min(this.cubeMapSize, 2048), { format: i.RGBFormat, generateMipmaps: !0, minFilter: i.LinearMipmapLinearFilter, encoding: i.sRGBEncoding, })), (r = new i.CubeCamera(a.camera.near, a.camera.far, o)), a.camera.getWorldPosition(r.position), a.camera.getWorldQuaternion(r.quaternion), r.update(a.renderer, a.object3D), (this.quad.material.uniforms.map.value = r.renderTarget.texture), (t = { width: this.data.width, height: this.data.height }), (this.quad.visible = !0)), { camera: n, size: t, projection: e } ) }, capture: function (e) { var t, n = this.el.renderer.xr.enabled, r = this.el.renderer ;(r.xr.enabled = !1), (t = this.setCapture(e)), this.renderCapture(t.camera, t.size, t.projection), this.saveCapture(), (r.xr.enabled = n) }, getCanvas: function (e) { var t = this.el.renderer.xr.enabled, n = this.el.renderer, r = this.setCapture(e) return ( (n.xr.enabled = !1), this.renderCapture(r.camera, r.size, r.projection), (n.xr.enabled = t), this.canvas ) }, renderCapture: function (e, t, n) { var r, i, o, a = this.el.renderer.autoClear, s = this.el, l = s.renderer ;(i = this.getRenderTarget(t.width, t.height)), (o = new Uint8Array(4 * t.width * t.height)), this.resize(t.width, t.height), (l.autoClear = !0), l.clear(), l.setRenderTarget(i), l.render(s.object3D, e), (l.autoClear = a), l.readRenderTargetPixels(i, 0, 0, t.width, t.height, o), l.setRenderTarget(null), 'perspective' === n && (o = this.flipPixelsVertically(o, t.width, t.height)), (r = new ImageData(new Uint8ClampedArray(o), t.width, t.height)), (this.quad.visible = !1), this.ctx.putImageData(r, 0, 0) }, flipPixelsVertically: function (e, t, n) { for (var r = e.slice(0), i = 0; i < t; ++i) for (var o = 0; o < n; ++o) (r[4 * i + o * t * 4] = e[4 * i + (n - o) * t * 4]), (r[4 * i + 1 + o * t * 4] = e[4 * i + 1 + (n - o) * t * 4]), (r[4 * i + 2 + o * t * 4] = e[4 * i + 2 + (n - o) * t * 4]), (r[4 * i + 3 + o * t * 4] = e[4 * i + 3 + (n - o) * t * 4]) return r }, saveCapture: function () { this.canvas.toBlob(function (e) { var t = 'screenshot-' + document.title.toLowerCase() + '-' + Date.now() + '.png', n = document.createElement('a'), r = URL.createObjectURL(e) ;(n.href = r), n.setAttribute('download', t), (n.innerHTML = 'downloading...'), (n.style.display = 'none'), document.body.appendChild(n), setTimeout(function () { n.click(), document.body.removeChild(n) }, 1) }, 'image/png') }, }) }, { '../../core/component': 131, '../../lib/three': 179 }, ], 109: [ function (e, t, n) { var r = e('../../core/component').registerComponent, i = e('../../../vendor/rStats'), o = e('../../utils') e('../../../vendor/rStats.extras'), e('../../lib/rStatsAframe') var a = window.aframeStats, s = o.bind, l = 'a-hidden', c = window.threeStats function u(e) { var t = new c(e.renderer), n = new a(e), r = e.isMobile ? [] : [t, n] return new i({ css: [], values: { fps: { caption: 'fps', below: 30 } }, groups: [{ caption: 'Framerate', values: ['fps', 'raf'] }], plugins: r, }) } t.exports.Component = r('stats', { schema: { default: !0 }, init: function () { var e = this.el 'false' !== o.getUrlParameter('stats') && ((this.stats = u(e)), (this.statsEl = document.querySelector('.rs-base')), (this.hideBound = s(this.hide, this)), (this.showBound = s(this.show, this)), e.addEventListener('enter-vr', this.hideBound), e.addEventListener('exit-vr', this.showBound)) }, update: function () { if (this.stats) return this.data ? this.show() : this.hide() }, remove: function () { this.el.removeEventListener('enter-vr', this.hideBound), this.el.removeEventListener('exit-vr', this.showBound), this.statsEl && this.statsEl.parentNode.removeChild(this.statsEl) }, tick: function () { var e = this.stats e && (e('rAF').tick(), e('FPS').frame(), e().update()) }, hide: function () { this.statsEl.classList.add(l) }, show: function () { this.statsEl.classList.remove(l) }, }) }, { '../../../vendor/rStats': 217, '../../../vendor/rStats.extras': 216, '../../core/component': 131, '../../lib/rStatsAframe': 178, '../../utils': 205, }, ], 110: [ function (e, t, n) { var r = e('../../core/component').registerComponent, i = e('../../constants/'), o = e('../../utils/'), a = o.bind, s = 'a-enter-vr', l = 'a-enter-ar', c = 'a-enter-vr-button', u = 'a-enter-ar-button', h = 'a-hidden', d = 'a-orientation-modal' function p(e) { var t, n return ( (n = document.createElement('div')).classList.add(s), n.setAttribute(i.AFRAME_INJECTED, ''), ((t = document.createElement('button')).className = c), t.setAttribute( 'title', 'Enter VR mode with a headset or fullscreen mode on a desktop. Visit https://webvr.rocks or https://webvr.info for more information.', ), t.setAttribute(i.AFRAME_INJECTED, ''), o.device.isMobile() && v(t), n.appendChild(t), t.addEventListener('click', function (t) { e(), t.stopPropagation() }), n ) } function f(e) { var t, n return ( (n = document.createElement('div')).classList.add(l), n.setAttribute(i.AFRAME_INJECTED, ''), ((t = document.createElement('button')).className = u), t.setAttribute( 'title', 'Enter AR mode with a headset or handheld device. Visit https://webvr.rocks or https://webvr.info for more information.', ), t.setAttribute(i.AFRAME_INJECTED, ''), o.device.isMobile() && v(t), n.appendChild(t), t.addEventListener('click', function (t) { e(), t.stopPropagation() }), n ) } function m(e) { var t = document.createElement('div') ;(t.className = d), t.classList.add(h), t.setAttribute(i.AFRAME_INJECTED, '') var n = document.createElement('button') return ( n.setAttribute(i.AFRAME_INJECTED, ''), (n.innerHTML = 'Exit VR'), n.addEventListener('click', e), t.appendChild(n), t ) } function v(e) { e.addEventListener('touchstart', function () { e.classList.remove('resethover') }), e.addEventListener('touchend', function () { e.classList.add('resethover') }) } t.exports.Component = r('vr-mode-ui', { dependencies: ['canvas'], schema: { enabled: { default: !0 }, enterVRButton: { default: '' }, enterARButton: { default: '' }, }, init: function () { var e = this, t = this.el 'false' !== o.getUrlParameter('ui') && ((this.insideLoader = !1), (this.enterVREl = null), (this.enterAREl = null), (this.orientationModalEl = null), this.bindMethods(), t.addEventListener('enter-vr', this.updateEnterInterfaces), t.addEventListener('exit-vr', this.updateEnterInterfaces), t.addEventListener('update-vr-devices', this.updateEnterInterfaces), window.addEventListener('message', function (t) { 'loaderReady' === t.data.type && ((e.insideLoader = !0), e.remove()) }), window.addEventListener( 'orientationchange', this.toggleOrientationModalIfNeeded, )) }, bindMethods: function () { ;(this.onEnterVRButtonClick = a(this.onEnterVRButtonClick, this)), (this.onEnterARButtonClick = a(this.onEnterARButtonClick, this)), (this.onModalClick = a(this.onModalClick, this)), (this.toggleOrientationModalIfNeeded = a( this.toggleOrientationModalIfNeeded, this, )), (this.updateEnterInterfaces = a(this.updateEnterInterfaces, this)) }, onModalClick: function () { this.el.exitVR() }, onEnterVRButtonClick: function () { this.el.enterVR() }, onEnterARButtonClick: function () { this.el.enterAR() }, update: function () { var e = this.data, t = this.el if (!e.enabled || this.insideLoader || 'false' === o.getUrlParameter('ui')) return this.remove() this.enterVREl || this.enterAREl || this.orientationModalEl || (e.enterVRButton ? ((this.enterVREl = document.querySelector(e.enterVRButton)), this.enterVREl.addEventListener('click', this.onEnterVRButtonClick)) : ((this.enterVREl = p(this.onEnterVRButtonClick)), t.appendChild(this.enterVREl)), e.enterARButton ? ((this.enterAREl = document.querySelector(e.enterARButton)), this.enterAREl.addEventListener('click', this.onEnterARButtonClick)) : ((this.enterAREl = f(this.onEnterARButtonClick)), t.appendChild(this.enterAREl)), (this.orientationModalEl = m(this.onModalClick)), t.appendChild(this.orientationModalEl), this.updateEnterInterfaces()) }, remove: function () { ;[this.enterVREl, this.enterAREl, this.orientationModalEl].forEach(function ( e, ) { e && e.parentNode && e.parentNode.removeChild(e) }), (this.enterVREl = void 0), (this.enterAREl = void 0), (this.orientationModalEl = void 0) }, updateEnterInterfaces: function () { this.toggleEnterVRButtonIfNeeded(), this.toggleEnterARButtonIfNeeded(), this.toggleOrientationModalIfNeeded() }, toggleEnterVRButtonIfNeeded: function () { var e = this.el this.enterVREl && (e.is('vr-mode') ? this.enterVREl.classList.add(h) : this.enterVREl.classList.remove(h)) }, toggleEnterARButtonIfNeeded: function () { var e = this.el this.enterAREl && (e.is('vr-mode') || !o.device.checkARSupport() ? this.enterAREl.classList.add(h) : this.enterAREl.classList.remove(h)) }, toggleOrientationModalIfNeeded: function () { var e = this.el, t = this.orientationModalEl t && e.isMobile && (!o.device.isLandscape() && e.is('vr-mode') ? t.classList.remove(h) : t.classList.add(h)) }, }) }, { '../../constants/': 123, '../../core/component': 131, '../../utils/': 205 }, ], 111: [ function (e, t, n) { var r = e('../core/component'), i = e('../lib/three'), o = e('../utils/bind'), a = r.registerComponent t.exports.Component = a('shadow', { schema: { cast: { default: !0 }, receive: { default: !0 } }, init: function () { ;(this.onMeshChanged = o(this.update, this)), this.el.addEventListener('object3dset', this.onMeshChanged), this.system.setShadowMapEnabled(!0) }, update: function () { var e = this.data this.updateDescendants(e.cast, e.receive) }, remove: function () { this.el.removeEventListener('object3dset', this.onMeshChanged), this.updateDescendants(!1, !1) }, updateDescendants: function (e, t) { var n = this.el.sceneEl this.el.object3D.traverse(function (r) { if ( r instanceof i.Mesh && ((r.castShadow = e), (r.receiveShadow = t), n.hasLoaded && r.material) ) for ( var o = Array.isArray(r.material) ? r.material : [r.material], a = 0; a < o.length; a++ ) o[a].needsUpdate = !0 }) }, }) }, { '../core/component': 131, '../lib/three': 179, '../utils/bind': 199 }, ], 112: [ function (t, n, r) { var i = t('../core/component').registerComponent, o = t('../utils/debug'), a = t('../lib/three'), s = o('components:sound:warn') n.exports.Component = i('sound', { schema: { autoplay: { default: !1 }, distanceModel: { default: 'inverse', oneOf: ['linear', 'inverse', 'exponential'], }, loop: { default: !1 }, maxDistance: { default: 1e4 }, on: { default: '' }, poolSize: { default: 1 }, positional: { default: !0 }, refDistance: { default: 1 }, rolloffFactor: { default: 1 }, src: { type: 'audio' }, volume: { default: 1 }, }, multiple: !0, init: function () { var e = this ;(this.listener = null), (this.audioLoader = new a.AudioLoader()), (this.pool = new a.Group()), (this.loaded = !1), (this.mustPlay = !1), (this.playSoundBound = function () { e.playSound() }) }, update: function (e) { var t, n, r = this.data, i = r.src !== e.src if (i) { if (!r.src) return this.setupSound() } for (t = 0; t < this.pool.children.length; t++) (n = this.pool.children[t]), r.positional && (n.setDistanceModel(r.distanceModel), n.setMaxDistance(r.maxDistance), n.setRefDistance(r.refDistance), n.setRolloffFactor(r.rolloffFactor)), n.setLoop(r.loop), n.setVolume(r.volume), (n.isPaused = !1) if ((r.on !== e.on && this.updateEventListener(e.on), i)) { var o = this ;(this.loaded = !1), this.audioLoader.load(r.src, function (e) { for (t = 0; t < o.pool.children.length; t++) (n = o.pool.children[t]).setBuffer(e) ;(o.loaded = !0), a.Cache.remove(r.src), (o.data.autoplay || o.mustPlay) && o.playSound(), o.el.emit('sound-loaded', o.evtDetail, !1) }) } }, pause: function () { this.stopSound(), this.removeEventListener() }, play: function () { this.data.autoplay && this.playSound(), this.updateEventListener() }, remove: function () { var t this.removeEventListener(), this.el.getObject3D(this.attrName) && this.el.removeObject3D(this.attrName) try { for (t = 0; t < this.pool.children.length; t++) this.pool.children[t].disconnect() } catch (e) { s('Audio source not properly disconnected') } }, updateEventListener: function (e) { var t = this.el e && t.removeEventListener(e, this.playSoundBound), t.addEventListener(this.data.on, this.playSoundBound) }, removeEventListener: function () { this.el.removeEventListener(this.data.on, this.playSoundBound) }, setupSound: function () { var e, t, n = this.el, r = n.sceneEl, i = this this.pool.children.length > 0 && (this.stopSound(), n.removeObject3D('sound')) var o = (this.listener = r.audioListener || new a.AudioListener()) for ( r.audioListener = o, r.camera && r.camera.add(o), r.addEventListener('camera-set-active', function (e) { e.detail.cameraEl.getObject3D('camera').add(o) }), this.pool = new a.Group(), e = 0; e < this.data.poolSize; e++ ) (t = this.data.positional ? new a.PositionalAudio(o) : new a.Audio(o)), this.pool.add(t) for ( n.setObject3D(this.attrName, this.pool), e = 0; e < this.pool.children.length; e++ ) (t = this.pool.children[e]).onEnded = function () { ;(this.isPlaying = !1), i.el.emit('sound-ended', i.evtDetail, !1) } }, pauseSound: function () { var e, t for (this.isPlaying = !1, e = 0; e < this.pool.children.length; e++) (t = this.pool.children[e]).source && t.source.buffer && t.isPlaying && !t.isPaused && ((t.isPaused = !0), t.pause()) }, playSound: function (e) { var t, n, r if (!this.loaded) return ( s('Sound not loaded yet. It will be played once it finished loading'), void (this.mustPlay = !0) ) for (t = !1, this.isPlaying = !0, n = 0; n < this.pool.children.length; n++) (r = this.pool.children[n]).isPlaying || !r.buffer || t || (e && e(r), r.play(), (r.isPaused = !1), (t = !0)) t ? (this.mustPlay = !1) : s( 'All the sounds are playing. If you need to play more sounds simultaneously consider increasing the size of pool with the `poolSize` attribute.', this.el, ) }, stopSound: function () { var e, t for (this.isPlaying = !1, e = 0; e < this.pool.children.length; e++) { if (!(t = this.pool.children[e]).source || !t.source.buffer) return t.stop() } }, }) }, { '../core/component': 131, '../lib/three': 179, '../utils/debug': 201 }, ], 113: [ function (e, t, n) { var r = e('three-bmfont-text'), i = e('load-bmfont'), o = e('../core/component').registerComponent, a = e('../core/shader'), s = e('../lib/three'), l = e('../utils/'), c = l.debug('components:text:error'), u = a.shaders, h = l.debug('components:text:warn'), d = 1, p = 16, f = 'https://cdn.aframe.io/fonts/', m = { aileronsemibold: f + 'Aileron-Semibold.fnt', dejavu: f + 'DejaVu-sdf.fnt', exo2bold: f + 'Exo2Bold.fnt', exo2semibold: f + 'Exo2SemiBold.fnt', kelsonsans: f + 'KelsonSans.fnt', monoid: f + 'Monoid.fnt', mozillavr: f + 'mozillavr.fnt', roboto: f + 'Roboto-msdf.json', sourcecodepro: f + 'SourceCodePro.fnt', }, v = ['roboto'], g = 'roboto' t.exports.FONTS = m var y = new C(), b = {}, A = {}, w = /^\w+:/ function x(e) { switch (e) { case 'back': return s.FrontSide case 'double': return s.DoubleSide default: return s.BackSide } } function E(e, t) { return new Promise(function (n, r) { i(e, function (i, o) { if (i) return c('Error loading font', e), void r(i) e.indexOf('/Roboto-msdf.json') >= 0 && (t = 30), t && o.chars.map(function (e) { e.yoffset += t }), n(o) }) }) } function M(e) { return new Promise(function (t, n) { new s.ImageLoader().load( e, function (e) { t(e) }, void 0, function () { c('Error loading font image', e), n(null) }, ) }) } function _(e, t, n) { var r, i return ( ((i = new u[t].Shader()).el = e), i.init(n), i.update(n), ((r = i.material).transparent = n.transparent), { material: r, shader: i } ) } function T(e, t, n) { return e || (0.5 + t) * n } function S(e) { var t = 0, n = 0, r = 0 return ( e.chars.map(function (e) { ;(t += e.xadvance), e.id >= 48 && e.id <= 57 && (r++, (n += e.xadvance)) }), r ? n / r : t / e.chars.length ) } function C() { var e = (this.cache = {}) this.get = function (t, n) { return t in e || (e[t] = n()), e[t] } } t.exports.Component = o('text', { multiple: !0, schema: { align: { type: 'string', default: 'left', oneOf: ['left', 'right', 'center'] }, alphaTest: { default: 0.5 }, anchor: { default: 'center', oneOf: ['left', 'right', 'center', 'align'] }, baseline: { default: 'center', oneOf: ['top', 'center', 'bottom'] }, color: { type: 'color', default: '#FFF' }, font: { type: 'string', default: g }, fontImage: { type: 'string' }, height: { type: 'number' }, letterSpacing: { type: 'number', default: 0 }, lineHeight: { type: 'number' }, negate: { type: 'boolean', default: !0 }, opacity: { type: 'number', default: 1 }, shader: { default: 'sdf', oneOf: u }, side: { default: 'front', oneOf: ['front', 'back', 'double'] }, tabSize: { default: 4 }, transparent: { default: !0 }, value: { type: 'string' }, whiteSpace: { default: 'normal', oneOf: ['normal', 'pre', 'nowrap'] }, width: { type: 'number' }, wrapCount: { type: 'number', default: 40 }, wrapPixels: { type: 'number' }, xOffset: { type: 'number', default: 0 }, yOffset: { type: 'number', default: 0 }, zOffset: { type: 'number', default: 0.001 }, }, init: function () { ;(this.shaderData = {}), (this.geometry = r()), this.createOrUpdateMaterial() }, update: function (e) { var t = this.data, n = this.currentFont A[t.font] ? (this.texture = A[t.font]) : ((this.texture = A[t.font] = new s.Texture()), (this.texture.anisotropy = p)), this.createOrUpdateMaterial(), e.font === t.font ? n && (this.updateGeometry(this.geometry, n), this.updateLayout()) : this.updateFont() }, remove: function () { this.geometry.dispose(), (this.geometry = null), this.el.removeObject3D(this.attrName), this.material.dispose(), (this.material = null), this.texture.dispose(), (this.texture = null), this.shaderObject && delete this.shaderObject }, createOrUpdateMaterial: function () { var e, t, n, r = this.data, i = this.material, o = this.shaderData if ( ((n = r.shader), -1 !== v.indexOf(r.font) || r.font.indexOf('-msdf.') >= 0 ? (n = 'msdf') : r.font in m && -1 === v.indexOf(r.font) && (n = 'sdf'), (e = (this.shaderObject && this.shaderObject.name) !== n), (o.alphaTest = r.alphaTest), (o.color = r.color), (o.map = this.texture), (o.opacity = r.opacity), (o.side = x(r.side)), (o.transparent = r.transparent), (o.negate = r.negate), !e) ) return ( this.shaderObject.update(o), (i.transparent = o.transparent), void (i.side = o.side) ) ;(t = _(this.el, n, o)), (this.material = t.material), (this.shaderObject = t.shader), (this.material.side = o.side), this.mesh && (this.mesh.material = this.material) }, updateFont: function () { var e, t = this.data, n = this.el, r = this.geometry, i = this t.font || h('No font specified. Using the default font.'), this.mesh && (this.mesh.visible = !1), (e = this.lookupFont(t.font || g) || t.font), y .get(e, function () { return E(e, t.yOffset) }) .then(function (o) { var a if (1 !== o.pages.length) throw new Error( 'Currently only single-page bitmap fonts are supported.', ) b[e] || (o.widthFactor = b[o] = S(o)), (i.currentFont = o), (a = i.getFontImageSrc()), y .get(a, function () { return M(a) }) .then(function (e) { var a = i.texture ;(a.image = e), (a.needsUpdate = !0), (A[t.font] = a), (i.texture = a), i.initMesh(), (i.currentFont = o), i.updateGeometry(r, o), i.updateLayout(), (i.mesh.visible = !0), n.emit('textfontset', { font: t.font, fontObj: o }) }) .catch(function (e) { c(e.message), c(e.stack) }) }) .catch(function (e) { c(e.message), c(e.stack) }) }, initMesh: function () { this.mesh || ((this.mesh = new s.Mesh(this.geometry, this.material)), this.el.setObject3D(this.attrName, this.mesh)) }, getFontImageSrc: function () { if (this.data.fontImage) return this.data.fontImage var e = this.lookupFont(this.data.font || g) || this.data.font, t = this.currentFont.pages[0] return t.match(w) && 0 !== t.indexOf('http') ? e.replace(/(\.fnt)|(\.json)/, '.png') : s.LoaderUtils.extractUrlBase(e) + t }, updateLayout: function () { var e, t, n, r, i, o, a, s, l, c = this.el, u = this.data, h = this.geometry, p = this.mesh if (p && h.layout) { if ( ((n = c.getAttribute('geometry')), (r = (o = (a = u.width || (n && n.width) || d) / T(u.wrapPixels, u.wrapCount, this.currentFont.widthFactor)) * ((i = h.layout).height + i.descender)), n && 'plane' === n.primitive && (n.width || c.setAttribute('geometry', 'width', a), n.height || c.setAttribute('geometry', 'height', r)), 'left' === (e = 'align' === u.anchor ? u.align : u.anchor)) ) s = 0 else if ('right' === e) s = -1 * i.width else { if ('center' !== e) throw new TypeError('Invalid text.anchor property value', e) s = (-1 * i.width) / 2 } if ('bottom' === (t = u.baseline)) l = 0 else if ('top' === t) l = -1 * i.height + i.ascender else { if ('center' !== t) throw new TypeError('Invalid text.baseline property value', t) l = (-1 * i.height) / 2 } ;(p.position.x = s * o + u.xOffset), (p.position.y = l * o), (p.position.z = u.zOffset), p.scale.set(o, -1 * o, o) } }, lookupFont: function (e) { return m[e] }, updateGeometry: (function () { var e = {}, t = {}, n = /\\n/g, r = /\\t/g return function (i, o) { var a = this.data ;(t.font = o), (t.lineHeight = a.lineHeight && isFinite(a.lineHeight) ? a.lineHeight : o.common.lineHeight), (t.text = a.value.toString().replace(n, '\n').replace(r, '\t')), (t.width = T(a.wrapPixels, a.wrapCount, o.widthFactor)), i.update(l.extend(e, a, t)) } })(), }) }, { '../core/component': 131, '../core/shader': 141, '../lib/three': 179, '../utils/': 205, 'load-bmfont': 37, 'three-bmfont-text': 63, }, ], 114: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/tracked-controls'), o = e('../constants').DEFAULT_CAMERA_HEIGHT, a = e('../lib/three'), s = e('../constants').DEFAULT_HANDEDNESS, l = { x: 0.175, y: -0.3, z: -0.03 }, c = { x: 0, y: 0, z: -0.175 }, u = { touches: [] }, h = { AXISMOVE: 'axismove', BUTTONCHANGED: 'buttonchanged', BUTTONDOWN: 'buttondown', BUTTONUP: 'buttonup', TOUCHSTART: 'touchstart', TOUCHEND: 'touchend', } t.exports.Component = r('tracked-controls-webvr', { schema: { autoHide: { default: !0 }, controller: { default: 0 }, id: { type: 'string', default: '' }, hand: { type: 'string', default: '' }, idPrefix: { type: 'string', default: '' }, orientationOffset: { type: 'vec3' }, armModel: { default: !1 }, headElement: { type: 'selector' }, }, init: function () { ;(this.axis = this.el.components['tracked-controls'].axis = [0, 0, 0]), (this.buttonStates = this.el.components['tracked-controls'].buttonStates = {}), (this.changedAxes = []), (this.targetControllerNumber = this.data.controller), (this.axisMoveEventDetail = { axis: this.axis, changed: this.changedAxes }), (this.deltaControllerPosition = new a.Vector3()), (this.controllerQuaternion = new a.Quaternion()), (this.controllerEuler = new a.Euler()), this.updateGamepad(), (this.buttonEventDetails = {}) }, tick: function (e, t) { var n = this.el.getObject3D('mesh') n && n.update && n.update(t / 1e3), this.updateGamepad(), this.updatePose(), this.updateButtons() }, defaultUserHeight: function () { return o }, getHeadElement: function () { return this.data.headElement || this.el.sceneEl.camera.el }, updateGamepad: function () { var e = this.data, t = i.findMatchingControllerWebVR( this.system.controllers, e.id, e.idPrefix, e.hand, e.controller, ) ;(this.controller = t), (this.el.components['tracked-controls'].controller = t), this.data.autoHide && (this.el.object3D.visible = !!this.controller) }, applyArmModel: function (e) { var t, n, r, i, o = this.controller, a = this.controllerEuler, u = this.controllerQuaternion, h = this.deltaControllerPosition ;(n = this.getHeadElement().object3D), (i = this.defaultUserHeight()), (r = o.pose), (t = (o ? o.hand : void 0) || s), e.copy(n.position), h.set(l.x * ('left' === t ? -1 : 'right' === t ? 1 : 0), l.y, l.z), h.multiplyScalar(i), h.applyAxisAngle(n.up, n.rotation.y), e.add(h), h.set(c.x, c.y, c.z), h.multiplyScalar(i), r.orientation ? u.fromArray(r.orientation) : u.copy(n.quaternion), a.setFromQuaternion(u), a.set(a.x, a.y, 0), h.applyEuler(a), e.add(h) }, updatePose: function () { var e, t, n = this.controller, r = this.data, i = this.el.object3D, o = this.system.vrDisplay n && ((e = n.pose).position ? i.position.fromArray(e.position) : r.armModel && this.applyArmModel(i.position), e.orientation && i.quaternion.fromArray(e.orientation), o && e.position && ((t = this.el.sceneEl.renderer.xr.getStandingMatrix()), i.matrix.compose(i.position, i.quaternion, i.scale), i.matrix.multiplyMatrices(t, i.matrix), i.matrix.decompose(i.position, i.quaternion, i.scale)), i.rotateX(this.data.orientationOffset.x * a.Math.DEG2RAD), i.rotateY(this.data.orientationOffset.y * a.Math.DEG2RAD), i.rotateZ(this.data.orientationOffset.z * a.Math.DEG2RAD)) }, updateButtons: function () { var e, t, n = this.controller if (n) { for (t = 0; t < n.buttons.length; ++t) this.buttonStates[t] || (this.buttonStates[t] = { pressed: !1, touched: !1, value: 0 }), this.buttonEventDetails[t] || (this.buttonEventDetails[t] = { id: t, state: this.buttonStates[t] }), (e = n.buttons[t]), this.handleButton(t, e) this.handleAxes() } }, handleButton: function (e, t) { return ( !!( this.handlePress(e, t) | this.handleTouch(e, t) | this.handleValue(e, t) ) && (this.el.emit(h.BUTTONCHANGED, this.buttonEventDetails[e], !1), !0) ) }, handleAxes: function () { var e, t = !1, n = this.controller.axes, r = this.axis, i = this.changedAxes for ( this.changedAxes.splice(0, this.changedAxes.length), e = 0; e < n.length; ++e ) i.push(r[e] !== n[e]), i[e] && (t = !0) if (!t) return !1 for (this.axis.splice(0, this.axis.length), e = 0; e < n.length; e++) this.axis.push(n[e]) return this.el.emit(h.AXISMOVE, this.axisMoveEventDetail, !1), !0 }, handlePress: function (e, t) { var n, r = this.buttonStates[e] return ( t.pressed !== r.pressed && ((n = t.pressed ? h.BUTTONDOWN : h.BUTTONUP), this.el.emit(n, this.buttonEventDetails[e], !1), (r.pressed = t.pressed), !0) ) }, handleTouch: function (e, t) { var n, r = this.buttonStates[e] return ( t.touched !== r.touched && ((n = t.touched ? h.TOUCHSTART : h.TOUCHEND), this.el.emit(n, this.buttonEventDetails[e], !1, u), (r.touched = t.touched), !0) ) }, handleValue: function (e, t) { var n = this.buttonStates[e] return t.value !== n.value && ((n.value = t.value), !0) }, }) }, { '../constants': 123, '../core/component': 131, '../lib/three': 179, '../utils/tracked-controls': 214, }, ], 115: [ function (e, t, n) { var r = e('../utils/tracked-controls'), i = e('../core/component').registerComponent, o = { AXISMOVE: 'axismove', BUTTONCHANGED: 'buttonchanged', BUTTONDOWN: 'buttondown', BUTTONUP: 'buttonup', TOUCHSTART: 'touchstart', TOUCHEND: 'touchend', } t.exports.Component = i('tracked-controls-webxr', { schema: { id: { type: 'string', default: '' }, hand: { type: 'string', default: '' }, handTrackingEnabled: { default: !1 }, index: { type: 'int', default: -1 }, iterateControllerProfiles: { default: !1 }, }, init: function () { ;(this.updateController = this.updateController.bind(this)), (this.buttonEventDetails = {}), (this.buttonStates = this.el.components['tracked-controls'].buttonStates = {}), (this.axis = this.el.components['tracked-controls'].axis = [0, 0, 0]), (this.changedAxes = []), (this.axisMoveEventDetail = { axis: this.axis, changed: this.changedAxes }) }, update: function () { this.updateController() }, play: function () { var e = this.el.sceneEl this.updateController(), e.addEventListener('controllersupdated', this.updateController) }, pause: function () { this.el.sceneEl.removeEventListener('controllersupdated', this.updateController) }, isControllerPresent: function (e) { return ( !(!this.controller || this.controller.gamepad) && ('none' === e.inputSource.handedness || e.inputSource.handedness === this.data.hand) ) }, updateController: function () { ;(this.controller = r.findMatchingControllerWebXR( this.system.controllers, this.data.id, this.data.hand, this.data.index, this.data.iterateControllerProfiles, this.data.handTrackingEnabled, )), (this.el.components['tracked-controls'].controller = this.controller), this.data.autoHide && (this.el.object3D.visible = !!this.controller) }, tick: function () { var e = this.el.sceneEl, t = this.controller, n = e.frame t && e.frame && this.system.referenceSpace && (t.hand || ((this.pose = n.getPose(t.targetRaySpace, this.system.referenceSpace)), this.updatePose(), this.updateButtons())) }, updatePose: function () { var e = this.el.object3D, t = this.pose t && ((e.matrix.elements = t.transform.matrix), e.matrix.decompose(e.position, e.rotation, e.scale)) }, updateButtons: function () { var e, t, n, r = this.controller if (r && r.gamepad) { for (n = r.gamepad, t = 0; t < n.buttons.length; ++t) this.buttonStates[t] || (this.buttonStates[t] = { pressed: !1, touched: !1, value: 0 }), this.buttonEventDetails[t] || (this.buttonEventDetails[t] = { id: t, state: this.buttonStates[t] }), (e = n.buttons[t]), this.handleButton(t, e) this.handleAxes() } }, handleButton: function (e, t) { return ( !!( this.handlePress(e, t) | this.handleTouch(e, t) | this.handleValue(e, t) ) && (this.el.emit(o.BUTTONCHANGED, this.buttonEventDetails[e], !1), !0) ) }, handleAxes: function () { var e, t = !1, n = this.controller.gamepad.axes, r = this.axis, i = this.changedAxes for ( this.changedAxes.splice(0, this.changedAxes.length), e = 0; e < n.length; ++e ) i.push(r[e] !== n[e]), i[e] && (t = !0) if (!t) return !1 for (this.axis.splice(0, this.axis.length), e = 0; e < n.length; e++) this.axis.push(n[e]) return this.el.emit(o.AXISMOVE, this.axisMoveEventDetail, !1), !0 }, handlePress: function (e, t) { var n, r = this.buttonStates[e] return ( t.pressed !== r.pressed && ((n = t.pressed ? o.BUTTONDOWN : o.BUTTONUP), this.el.emit(n, this.buttonEventDetails[e], !1), (r.pressed = t.pressed), !0) ) }, handleTouch: function (e, t) { var n, r = this.buttonStates[e] return ( t.touched !== r.touched && ((n = t.touched ? o.TOUCHSTART : o.TOUCHEND), this.el.emit(n, this.buttonEventDetails[e], !1), (r.touched = t.touched), !0) ) }, handleValue: function (e, t) { var n = this.buttonStates[e] return t.value !== n.value && ((n.value = t.value), !0) }, }) }, { '../core/component': 131, '../utils/tracked-controls': 214 }, ], 116: [ function (e, t, n) { var r = e('../core/component').registerComponent t.exports.Component = r('tracked-controls', { schema: { autoHide: { default: !0 }, controller: { default: -1 }, id: { type: 'string', default: '' }, hand: { type: 'string', default: '' }, idPrefix: { type: 'string', default: '' }, handTrackingEnabled: { default: !1 }, orientationOffset: { type: 'vec3' }, armModel: { default: !1 }, headElement: { type: 'selector' }, iterateControllerProfiles: { default: !1 }, }, update: function () { var e = this.data, t = this.el t.sceneEl.hasWebXR ? t.setAttribute('tracked-controls-webxr', { id: e.id, hand: e.hand, index: e.controller, iterateControllerProfiles: e.iterateControllerProfiles, handTrackingEnabled: e.handTrackingEnabled, }) : t.setAttribute('tracked-controls-webvr', e) }, }) }, { '../core/component': 131 }, ], 117: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/bind'), o = e('../lib/three'), a = e('../utils/tracked-controls'), s = a.checkControllerPresentAndSetup, l = a.emitIfAxesChanged, c = a.onButtonEvent, u = 'https://cdn.aframe.io/controllers/valve/index/valve-index-', h = { left: u + 'left.glb', right: u + 'right.glb' }, d = 'valve', p = e('../utils/').device.isWebXRAvailable, f = { left: { x: -0.00023692678902063457, y: 0.04724540367838371, z: -0.061959880395271096, }, right: { x: 0.002471558599671131, y: 0.055765208987076195, z: -0.061068168708348844, }, }, m = { left: { x: 0, y: -0.05, z: 0.06 }, right: { x: 0, y: -0.05, z: 0.06 } }, v = { left: { _x: 0.692295102620542, _y: -0.0627618864318427, _z: -0.06265893149611756, _order: 'XYZ', }, right: { _x: 0.6484021229942998, _y: -0.032563619881892894, _z: -0.1327973171917482, _order: 'XYZ', }, }, g = { left: { _x: Math.PI / 3, _y: 0, _z: 0, _order: 'XYZ' }, right: { _x: Math.PI / 3, _y: 0, _z: 0, _order: 'XYZ' }, }, y = p ? g : v, b = p ? m : f t.exports.Component = r('valve-index-controls', { schema: { hand: { default: 'left' }, buttonColor: { type: 'color', default: '#FAFAFA' }, buttonHighlightColor: { type: 'color', default: '#22D1EE' }, model: { default: !0 }, orientationOffset: { type: 'vec3' }, }, mapping: { axes: { trackpad: [0, 1], thumbstick: [2, 3] }, buttons: ['trigger', 'grip', 'trackpad', 'thumbstick', 'abutton'], }, init: function () { var e = this ;(this.controllerPresent = !1), (this.lastControllerCheck = 0), (this.onButtonChanged = i(this.onButtonChanged, this)), (this.onButtonDown = function (t) { c(t.detail.id, 'down', e) }), (this.onButtonUp = function (t) { c(t.detail.id, 'up', e) }), (this.onButtonTouchEnd = function (t) { c(t.detail.id, 'touchend', e) }), (this.onButtonTouchStart = function (t) { c(t.detail.id, 'touchstart', e) }), (this.previousButtonValues = {}), (this.rendererSystem = this.el.sceneEl.systems.renderer), this.bindMethods() }, play: function () { this.checkIfControllerPresent(), this.addControllersUpdateListener() }, pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, bindMethods: function () { ;(this.onModelLoaded = i(this.onModelLoaded, this)), (this.onControllersUpdate = i(this.onControllersUpdate, this)), (this.checkIfControllerPresent = i(this.checkIfControllerPresent, this)), (this.removeControllersUpdateListener = i( this.removeControllersUpdateListener, this, )), (this.onAxisMoved = i(this.onAxisMoved, this)) }, addEventListeners: function () { var e = this.el e.addEventListener('buttonchanged', this.onButtonChanged), e.addEventListener('buttondown', this.onButtonDown), e.addEventListener('buttonup', this.onButtonUp), e.addEventListener('touchend', this.onButtonTouchEnd), e.addEventListener('touchstart', this.onButtonTouchStart), e.addEventListener('model-loaded', this.onModelLoaded), e.addEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !0) }, removeEventListeners: function () { var e = this.el e.removeEventListener('buttonchanged', this.onButtonChanged), e.removeEventListener('buttondown', this.onButtonDown), e.removeEventListener('buttonup', this.onButtonUp), e.removeEventListener('touchend', this.onButtonTouchEnd), e.removeEventListener('touchstart', this.onButtonTouchStart), e.removeEventListener('model-loaded', this.onModelLoaded), e.removeEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !1) }, checkIfControllerPresent: function () { var e = this.data, t = 'right' === e.hand ? 0 : 'left' === e.hand ? 1 : 2 s(this, d, { index: t, iterateControllerProfiles: !0, hand: e.hand }) }, injectTrackedControls: function () { var e = this.el, t = this.data e.setAttribute('tracked-controls', { idPrefix: d, controller: 'right' === t.hand ? 1 : 'left' === t.hand ? 0 : 2, hand: t.hand, orientationOffset: t.orientationOffset, }), this.loadModel() }, loadModel: function () { var e = this.data e.model && this.el.setAttribute('gltf-model', '' + h[e.hand]) }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { this.checkIfControllerPresent() }, onButtonChanged: function (e) { var t, n = this.mapping.buttons[e.detail.id], r = this.buttonMeshes n && ('trigger' === n && ((t = e.detail.state.value), r && r.trigger && (r.trigger.rotation.x = this.triggerOriginalRotationX - t * (Math.PI / 40))), this.el.emit(n + 'changed', e.detail.state)) }, onModelLoaded: function (e) { var t, n = e.detail.model, r = this this.data.model && (((t = this.buttonMeshes = {}).grip = { left: n.getObjectByName('leftgrip'), right: n.getObjectByName('rightgrip'), }), (t.menu = n.getObjectByName('menubutton')), (t.system = n.getObjectByName('systembutton')), (t.trackpad = n.getObjectByName('touchpad')), (t.trigger = n.getObjectByName('trigger')), (this.triggerOriginalRotationX = t.trigger.rotation.x), Object.keys(t).forEach(function (e) { r.setButtonColor(e, r.data.buttonColor) }), n.position.copy(b[this.data.hand]), n.rotation.copy(y[this.data.hand]), this.el.emit('controllermodelready', { name: 'valve-index-controlls', model: this.data.model, rayOrigin: new o.Vector3(0, 0, 0), })) }, onAxisMoved: function (e) { l(this, this.mapping.axes, e) }, updateModel: function (e, t) { var n this.data.model && (-1 !== t.indexOf('touch') || ((n = 'up' === t ? this.data.buttonColor : this.data.buttonHighlightColor), this.setButtonColor(e, n))) }, setButtonColor: function (e, t) {}, }) }, { '../core/component': 131, '../lib/three': 179, '../utils/': 205, '../utils/bind': 199, '../utils/tracked-controls': 214, }, ], 118: [ function (e, t, n) { var r = e('../core/component').registerComponent t.exports.Component = r('visible', { schema: { default: !0 }, update: function () { this.el.object3D.visible = this.data }, }) }, { '../core/component': 131 }, ], 119: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/bind'), o = e('../utils/tracked-controls'), a = o.checkControllerPresentAndSetup, s = o.emitIfAxesChanged, l = o.onButtonEvent, c = 'https://cdn.aframe.io/controllers/vive/vr_controller_vive.obj', u = 'https://cdn.aframe.io/controllers/vive/vr_controller_vive.mtl', h = e('../utils/').device.isWebXRAvailable, d = h ? 'htc-vive-controller-mv' : 'OpenVR ', p = h ? { axes: { thumbstick: [0, 1] }, buttons: ['trigger', 'grip', 'trackpad', 'none', 'menu'], } : { axes: { trackpad: [0, 1] }, buttons: ['trackpad', 'trigger', 'grip', 'menu', 'system'], } t.exports.Component = r('vive-controls', { schema: { hand: { default: 'left' }, buttonColor: { type: 'color', default: '#FAFAFA' }, buttonHighlightColor: { type: 'color', default: '#22D1EE' }, model: { default: !0 }, orientationOffset: { type: 'vec3' }, }, mapping: p, init: function () { var e = this ;(this.controllerPresent = !1), (this.lastControllerCheck = 0), (this.onButtonChanged = i(this.onButtonChanged, this)), (this.onButtonDown = function (t) { l(t.detail.id, 'down', e) }), (this.onButtonUp = function (t) { l(t.detail.id, 'up', e) }), (this.onButtonTouchEnd = function (t) { l(t.detail.id, 'touchend', e) }), (this.onButtonTouchStart = function (t) { l(t.detail.id, 'touchstart', e) }), (this.previousButtonValues = {}), (this.rendererSystem = this.el.sceneEl.systems.renderer), this.bindMethods() }, update: function () { var e = this.data this.controllerIndex = 'right' === e.hand ? 0 : 'left' === e.hand ? 1 : 2 }, play: function () { this.checkIfControllerPresent(), this.addControllersUpdateListener() }, pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, bindMethods: function () { ;(this.onModelLoaded = i(this.onModelLoaded, this)), (this.onControllersUpdate = i(this.onControllersUpdate, this)), (this.checkIfControllerPresent = i(this.checkIfControllerPresent, this)), (this.removeControllersUpdateListener = i( this.removeControllersUpdateListener, this, )), (this.onAxisMoved = i(this.onAxisMoved, this)) }, addEventListeners: function () { var e = this.el e.addEventListener('buttonchanged', this.onButtonChanged), e.addEventListener('buttondown', this.onButtonDown), e.addEventListener('buttonup', this.onButtonUp), e.addEventListener('touchend', this.onButtonTouchEnd), e.addEventListener('touchstart', this.onButtonTouchStart), e.addEventListener('model-loaded', this.onModelLoaded), e.addEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !0) }, removeEventListeners: function () { var e = this.el e.removeEventListener('buttonchanged', this.onButtonChanged), e.removeEventListener('buttondown', this.onButtonDown), e.removeEventListener('buttonup', this.onButtonUp), e.removeEventListener('touchend', this.onButtonTouchEnd), e.removeEventListener('touchstart', this.onButtonTouchStart), e.removeEventListener('model-loaded', this.onModelLoaded), e.removeEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !1) }, checkIfControllerPresent: function () { var e = this.data a(this, d, { index: this.controllerIndex, hand: e.hand }) }, injectTrackedControls: function () { var e = this.el, t = this.data e.setAttribute('tracked-controls', { idPrefix: d, hand: t.hand, controller: this.controllerIndex, orientationOffset: t.orientationOffset, }), this.data.model && this.el.setAttribute('obj-model', { obj: c, mtl: u }) }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { this.checkIfControllerPresent() }, onButtonChanged: function (e) { var t, n = this.mapping.buttons[e.detail.id], r = this.buttonMeshes n && ('trigger' === n && ((t = e.detail.state.value), r && r.trigger && (r.trigger.rotation.x = -t * (Math.PI / 12))), this.el.emit(n + 'changed', e.detail.state)) }, onModelLoaded: function (e) { var t, n = e.detail.model, r = this this.data.model && (((t = this.buttonMeshes = {}).grip = { left: n.getObjectByName('leftgrip'), right: n.getObjectByName('rightgrip'), }), (t.menu = n.getObjectByName('menubutton')), (t.system = n.getObjectByName('systembutton')), (t.trackpad = n.getObjectByName('touchpad')), (t.trigger = n.getObjectByName('trigger')), Object.keys(t).forEach(function (e) { r.setButtonColor(e, r.data.buttonColor) }), n.position.set(0, -0.015, 0.04)) }, onAxisMoved: function (e) { s(this, this.mapping.axes, e) }, updateModel: function (e, t) { var n this.data.model && (-1 !== t.indexOf('touch') || ((n = 'up' === t ? this.data.buttonColor : this.data.buttonHighlightColor), this.setButtonColor(e, n))) }, setButtonColor: function (e, t) { var n = this.buttonMeshes, r = this.rendererSystem if (n) { if ('grip' === e) return ( n.grip.left.material.color.set(t), n.grip.right.material.color.set(t), r.applyColorCorrection(n.grip.left.material.color), void r.applyColorCorrection(n.grip.right.material.color) ) n[e].material.color.set(t), r.applyColorCorrection(n[e].material.color) } }, }) }, { '../core/component': 131, '../utils/': 205, '../utils/bind': 199, '../utils/tracked-controls': 214, }, ], 120: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/bind'), o = e('../utils/tracked-controls'), a = o.checkControllerPresentAndSetup, s = o.emitIfAxesChanged, l = o.onButtonEvent, c = 'HTC Vive Focus', u = 'https://cdn.aframe.io/controllers/vive/focus-controller/focus-controller.gltf' t.exports.Component = r('vive-focus-controls', { schema: { hand: { default: '' }, buttonTouchedColor: { type: 'color', default: '#BBBBBB' }, buttonHighlightColor: { type: 'color', default: '#7A7A7A' }, model: { default: !0 }, orientationOffset: { type: 'vec3' }, armModel: { default: !0 }, }, mapping: { axes: { trackpad: [0, 1] }, buttons: ['trackpad', 'trigger'] }, bindMethods: function () { ;(this.onModelLoaded = i(this.onModelLoaded, this)), (this.onControllersUpdate = i(this.onControllersUpdate, this)), (this.checkIfControllerPresent = i(this.checkIfControllerPresent, this)), (this.removeControllersUpdateListener = i( this.removeControllersUpdateListener, this, )), (this.onAxisMoved = i(this.onAxisMoved, this)) }, init: function () { var e = this ;(this.onButtonChanged = i(this.onButtonChanged, this)), (this.onButtonDown = function (t) { l(t.detail.id, 'down', e) }), (this.onButtonUp = function (t) { l(t.detail.id, 'up', e) }), (this.onButtonTouchStart = function (t) { l(t.detail.id, 'touchstart', e) }), (this.onButtonTouchEnd = function (t) { l(t.detail.id, 'touchend', e) }), (this.controllerPresent = !1), (this.lastControllerCheck = 0), this.bindMethods() }, addEventListeners: function () { var e = this.el e.addEventListener('buttonchanged', this.onButtonChanged), e.addEventListener('buttondown', this.onButtonDown), e.addEventListener('buttonup', this.onButtonUp), e.addEventListener('touchstart', this.onButtonTouchStart), e.addEventListener('touchend', this.onButtonTouchEnd), e.addEventListener('model-loaded', this.onModelLoaded), e.addEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !0), this.addControllersUpdateListener() }, removeEventListeners: function () { var e = this.el e.removeEventListener('buttonchanged', this.onButtonChanged), e.removeEventListener('buttondown', this.onButtonDown), e.removeEventListener('buttonup', this.onButtonUp), e.removeEventListener('touchstart', this.onButtonTouchStart), e.removeEventListener('touchend', this.onButtonTouchEnd), e.removeEventListener('model-loaded', this.onModelLoaded), e.removeEventListener('axismove', this.onAxisMoved), (this.controllerEventsActive = !1), this.removeControllersUpdateListener() }, checkIfControllerPresent: function () { a(this, c, this.data.hand ? { hand: this.data.hand } : {}) }, play: function () { this.checkIfControllerPresent(), this.addControllersUpdateListener() }, pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, injectTrackedControls: function () { var e = this.el, t = this.data e.setAttribute('tracked-controls', { armModel: t.armModel, idPrefix: c, orientationOffset: t.orientationOffset, }), this.data.model && this.el.setAttribute('gltf-model', u) }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { this.checkIfControllerPresent() }, onModelLoaded: function (e) { var t, n = e.detail.model this.data.model && (((t = this.buttonMeshes = {}).trigger = n.getObjectByName('BumperKey')), (t.triggerPressed = n.getObjectByName('BumperKey_Press')), t.triggerPressed && (t.triggerPressed.visible = !1), (t.trackpad = n.getObjectByName('TouchPad')), (t.trackpadPressed = n.getObjectByName('TouchPad_Press')), t.trackpadPressed && (t.trackpadPressed.visible = !1)) }, onButtonChanged: function (e) { var t = this.mapping.buttons[e.detail.id] t && this.el.emit(t + 'changed', e.detail.state) }, onAxisMoved: function (e) { s(this, this.mapping.axes, e) }, updateModel: function (e, t) { this.data.model && this.updateButtonModel(e, t) }, updateButtonModel: function (e, t) { var n = this.buttonMeshes, r = e + 'Pressed' if (n && n[e] && n[r]) { var i switch (t) { case 'down': i = this.data.buttonHighlightColor break case 'touchstart': i = this.data.buttonTouchedColor } i && n[r].material.color.set(i), (n[r].visible = !!i), (n[e].visible = !i) } }, }) }, { '../core/component': 131, '../utils/bind': 199, '../utils/tracked-controls': 214 }, ], 121: [ function (e, t, n) { var r = e('../constants').keyboardevent.KEYCODE_TO_CODE, i = e('../core/component').registerComponent, o = e('../lib/three'), a = e('../utils/'), s = a.bind, l = a.shouldCaptureKeyEvent, c = 1e-5, u = 0.2, h = [ 'KeyW', 'KeyA', 'KeyS', 'KeyD', 'ArrowUp', 'ArrowLeft', 'ArrowRight', 'ArrowDown', ] function d(e) { var t for (t in e) return !1 return !0 } t.exports.Component = i('wasd-controls', { schema: { acceleration: { default: 65 }, adAxis: { default: 'x', oneOf: ['x', 'y', 'z'] }, adEnabled: { default: !0 }, adInverted: { default: !1 }, enabled: { default: !0 }, fly: { default: !1 }, wsAxis: { default: 'z', oneOf: ['x', 'y', 'z'] }, wsEnabled: { default: !0 }, wsInverted: { default: !1 }, }, init: function () { ;(this.keys = {}), (this.easing = 1.1), (this.velocity = new o.Vector3()), (this.onBlur = s(this.onBlur, this)), (this.onContextMenu = s(this.onContextMenu, this)), (this.onFocus = s(this.onFocus, this)), (this.onKeyDown = s(this.onKeyDown, this)), (this.onKeyUp = s(this.onKeyUp, this)), (this.onVisibilityChange = s(this.onVisibilityChange, this)), this.attachVisibilityEventListeners() }, tick: function (e, t) { var n = this.data, r = this.el, i = this.velocity ;(i[n.adAxis] || i[n.wsAxis] || !d(this.keys)) && ((t /= 1e3), this.updateVelocity(t), (i[n.adAxis] || i[n.wsAxis]) && r.object3D.position.add(this.getMovementVector(t))) }, remove: function () { this.removeKeyEventListeners(), this.removeVisibilityEventListeners() }, play: function () { this.attachKeyEventListeners() }, pause: function () { ;(this.keys = {}), this.removeKeyEventListeners() }, updateVelocity: function (e) { var t, n, r, i, o, a = this.data, s = this.keys, l = this.velocity if (((n = a.adAxis), (i = a.wsAxis), e > u)) return (l[n] = 0), void (l[i] = 0) var h = Math.pow(1 / this.easing, 60 * e) 0 !== l[n] && (l[n] = l[n] * h), 0 !== l[i] && (l[i] = l[i] * h), Math.abs(l[n]) < c && (l[n] = 0), Math.abs(l[i]) < c && (l[i] = 0), a.enabled && ((t = a.acceleration), a.adEnabled && ((r = a.adInverted ? -1 : 1), (s.KeyA || s.ArrowLeft) && (l[n] -= r * t * e), (s.KeyD || s.ArrowRight) && (l[n] += r * t * e)), a.wsEnabled && ((o = a.wsInverted ? -1 : 1), (s.KeyW || s.ArrowUp) && (l[i] -= o * t * e), (s.KeyS || s.ArrowDown) && (l[i] += o * t * e))) }, getMovementVector: (function () { var e = new o.Vector3(0, 0, 0), t = new o.Euler(0, 0, 0, 'YXZ') return function (n) { var r, i = this.el.getAttribute('rotation'), a = this.velocity return ( e.copy(a), e.multiplyScalar(n), i ? ((r = this.data.fly ? i.x : 0), t.set(o.Math.degToRad(r), o.Math.degToRad(i.y), 0), e.applyEuler(t), e) : e ) } })(), attachVisibilityEventListeners: function () { ;(window.oncontextmenu = this.onContextMenu), window.addEventListener('blur', this.onBlur), window.addEventListener('focus', this.onFocus), document.addEventListener('visibilitychange', this.onVisibilityChange) }, removeVisibilityEventListeners: function () { window.removeEventListener('blur', this.onBlur), window.removeEventListener('focus', this.onFocus), document.removeEventListener('visibilitychange', this.onVisibilityChange) }, attachKeyEventListeners: function () { window.addEventListener('keydown', this.onKeyDown), window.addEventListener('keyup', this.onKeyUp) }, removeKeyEventListeners: function () { window.removeEventListener('keydown', this.onKeyDown), window.removeEventListener('keyup', this.onKeyUp) }, onContextMenu: function () { for (var e = Object.keys(this.keys), t = 0; t < e.length; t++) delete this.keys[e[t]] }, onBlur: function () { this.pause() }, onFocus: function () { this.play() }, onVisibilityChange: function () { document.hidden ? this.onBlur() : this.onFocus() }, onKeyDown: function (e) { var t l(e) && ((t = e.code || r[e.keyCode]), -1 !== h.indexOf(t) && (this.keys[t] = !0)) }, onKeyUp: function (e) { var t ;(t = e.code || r[e.keyCode]), delete this.keys[t] }, }) }, { '../constants': 123, '../core/component': 131, '../lib/three': 179, '../utils/': 205, }, ], 122: [ function (e, t, n) { var r = e('../core/component').registerComponent, i = e('../utils/bind'), o = e('../utils/tracked-controls'), a = o.checkControllerPresentAndSetup, s = o.emitIfAxesChanged, l = o.onButtonEvent, c = e('../utils/'), u = c.debug('components:windows-motion-controls:debug'), h = c.debug('components:windows-motion-controls:warn'), d = e('../constants').DEFAULT_HANDEDNESS, p = 'https://cdn.aframe.io/controllers/microsoft/', f = { left: 'left.glb', right: 'right.glb', default: 'universal.glb' }, m = e('../utils/').device.isWebXRAvailable, v = /([0-9a-zA-Z]+-[0-9a-zA-Z]+)$/, g = m ? 'windows-mixed-reality' : 'Spatial Controller (Spatial Interaction Source) ', y = m ? { axes: { touchpad: [0, 1], thumbstick: [2, 3] }, buttons: ['trigger', 'squeeze', 'touchpad', 'thumbstick', 'menu'], axisMeshNames: [ 'TOUCHPAD_TOUCH_X', 'TOUCHPAD_TOUCH_X', 'THUMBSTICK_X', 'THUMBSTICK_Y', ], buttonMeshNames: { trigger: 'SELECT', menu: 'MENU', squeeze: 'GRASP', thumbstick: 'THUMBSTICK_PRESS', touchpad: 'TOUCHPAD_PRESS', }, pointingPoseMeshName: 'POINTING_POSE', } : { axes: { thumbstick: [0, 1], trackpad: [2, 3] }, buttons: ['thumbstick', 'trigger', 'grip', 'menu', 'trackpad'], axisMeshNames: [ 'THUMBSTICK_X', 'THUMBSTICK_Y', 'TOUCHPAD_TOUCH_X', 'TOUCHPAD_TOUCH_Y', ], buttonMeshNames: { trigger: 'SELECT', menu: 'MENU', grip: 'GRASP', thumbstick: 'THUMBSTICK_PRESS', trackpad: 'TOUCHPAD_PRESS', }, pointingPoseMeshName: 'POINTING_POSE', } t.exports.Component = r('windows-motion-controls', { schema: { hand: { default: d }, pair: { default: 0 }, model: { default: !0 }, hideDisconnected: { default: !0 }, }, mapping: y, bindMethods: function () { ;(this.onModelError = i(this.onModelError, this)), (this.onModelLoaded = i(this.onModelLoaded, this)), (this.onControllersUpdate = i(this.onControllersUpdate, this)), (this.checkIfControllerPresent = i(this.checkIfControllerPresent, this)), (this.onAxisMoved = i(this.onAxisMoved, this)) }, init: function () { var e = this, t = this.el ;(this.onButtonChanged = i(this.onButtonChanged, this)), (this.onButtonDown = function (t) { l(t.detail.id, 'down', e) }), (this.onButtonUp = function (t) { l(t.detail.id, 'up', e) }), (this.onButtonTouchStart = function (t) { l(t.detail.id, 'touchstart', e) }), (this.onButtonTouchEnd = function (t) { l(t.detail.id, 'touchend', e) }), (this.onControllerConnected = function () { e.setModelVisibility(!0) }), (this.onControllerDisconnected = function () { e.setModelVisibility(!1) }), (this.controllerPresent = !1), (this.lastControllerCheck = 0), (this.previousButtonValues = {}), this.bindMethods(), (this.loadedMeshInfo = { buttonMeshes: null, axisMeshes: null }), (this.rayOrigin = { origin: new THREE.Vector3(), direction: new THREE.Vector3(0, 0, -1), createdFromMesh: !1, }), t.addEventListener('controllerconnected', this.onControllerConnected), t.addEventListener('controllerdisconnected', this.onControllerDisconnected) }, addEventListeners: function () { var e = this.el e.addEventListener('buttonchanged', this.onButtonChanged), e.addEventListener('buttondown', this.onButtonDown), e.addEventListener('buttonup', this.onButtonUp), e.addEventListener('touchstart', this.onButtonTouchStart), e.addEventListener('touchend', this.onButtonTouchEnd), e.addEventListener('axismove', this.onAxisMoved), e.addEventListener('model-error', this.onModelError), e.addEventListener('model-loaded', this.onModelLoaded), (this.controllerEventsActive = !0) }, removeEventListeners: function () { var e = this.el e.removeEventListener('buttonchanged', this.onButtonChanged), e.removeEventListener('buttondown', this.onButtonDown), e.removeEventListener('buttonup', this.onButtonUp), e.removeEventListener('touchstart', this.onButtonTouchStart), e.removeEventListener('touchend', this.onButtonTouchEnd), e.removeEventListener('axismove', this.onAxisMoved), e.removeEventListener('model-error', this.onModelError), e.removeEventListener('model-loaded', this.onModelLoaded), (this.controllerEventsActive = !1) }, checkIfControllerPresent: function () { a(this, g, { hand: this.data.hand, index: this.data.pair, iterateControllerProfiles: !0, }) }, play: function () { this.checkIfControllerPresent(), this.addControllersUpdateListener() }, pause: function () { this.removeEventListeners(), this.removeControllersUpdateListener() }, updateControllerModel: function () { if (this.data.model && !this.rayOrigin.createdFromMesh) { var e = this.createControllerModelUrl() this.loadModel(e) } else this.modelReady() }, createControllerModelUrl: function (e) { var t, n = this.el.components['tracked-controls'], r = n ? n.controller : null, i = 'default', o = this.data.hand if (r && !window.hasNativeWebXRImplementation && ((o = r.hand), !e)) { var a = r.id.match(v) i = (a && a[0]) || i } return (t = f[o] || f.default), p + i + '/' + t }, injectTrackedControls: function () { var e = this.data this.el.setAttribute('tracked-controls', { idPrefix: g, controller: e.pair, hand: e.hand, armModel: !1, }), this.updateControllerModel() }, addControllersUpdateListener: function () { this.el.sceneEl.addEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, removeControllersUpdateListener: function () { this.el.sceneEl.removeEventListener( 'controllersupdated', this.onControllersUpdate, !1, ) }, onControllersUpdate: function () { this.checkIfControllerPresent() }, onModelError: function (e) { var t = this.createControllerModelUrl(!0) e.detail.src !== t ? (h( 'Failed to load controller model for device, attempting to load default.', ), this.loadModel(t)) : h('Failed to load default controller model.') }, loadModel: function (e) { this.el.setAttribute('gltf-model', 'url(' + e + ')') }, onModelLoaded: function (e) { var t, n, r, i, o = (this.controllerModel = e.detail.model), a = this.loadedMeshInfo if ((u('Processing model'), (a.buttonMeshes = {}), (a.axisMeshes = {}), o)) { for (t = 0; t < this.mapping.buttons.length; t++) (n = this.mapping.buttonMeshNames[this.mapping.buttons[t]]) ? (r = o.getObjectByName(n)) ? (i = { index: t, value: s(r, 'VALUE'), pressed: s(r, 'PRESSED'), unpressed: s(r, 'UNPRESSED'), }).value && i.pressed && i.unpressed ? (a.buttonMeshes[this.mapping.buttons[t]] = i) : h( 'Missing button submesh under mesh with name: ' + n + '(VALUE: ' + !!i.value + ', PRESSED: ' + !!i.pressed + ', UNPRESSED:' + !!i.unpressed + ')', ) : h('Missing button mesh with name: ' + n) : u( 'Skipping unknown button at index: ' + t + ' with mapped name: ' + this.mapping.buttons[t], ) for (t = 0; t < this.mapping.axisMeshNames.length; t++) (n = this.mapping.axisMeshNames[t]) ? (r = o.getObjectByName(n)) ? (i = { index: t, value: s(r, 'VALUE'), min: s(r, 'MIN'), max: s(r, 'MAX'), }).value && i.min && i.max ? (a.axisMeshes[t] = i) : h( 'Missing axis submesh under mesh with name: ' + n + '(VALUE: ' + !!i.value + ', MIN: ' + !!i.min + ', MAX:' + !!i.max + ')', ) : h('Missing axis mesh with name: ' + n) : u('Skipping unknown axis at index: ' + t) this.calculateRayOriginFromMesh(o), this.setModelVisibility() } function s(e, t) { for (var n = 0, r = e.children.length; n < r; n++) { var i = e.children[n] if (i && i.name === t) return i } } u('Model load complete.') }, calculateRayOriginFromMesh: (function () { var e = new THREE.Quaternion() return function (t) { var n if ( (this.rayOrigin.origin.set(0, 0, 0), this.rayOrigin.direction.set(0, 0, -1), (this.rayOrigin.createdFromMesh = !0), (n = t.getObjectByName(this.mapping.pointingPoseMeshName))) ) { var r = t.parent r && ((t.parent = null), t.updateMatrixWorld(!0), (t.parent = r)), n.getWorldPosition(this.rayOrigin.origin), n.getWorldQuaternion(e), this.rayOrigin.direction.applyQuaternion(e), r && t.updateMatrixWorld(!0) } else u('Mesh does not contain pointing origin data, defaulting to none.') this.modelReady() } })(), lerpAxisTransform: (function () { var e = new THREE.Quaternion() return function (t, n) { var r = this.loadedMeshInfo.axisMeshes[t] if (r) { var i = r.min, o = r.max, a = r.value, s = 0.5 * n + 0.5 a.setRotationFromQuaternion(e.copy(i.quaternion).slerp(o.quaternion, s)), a.position.lerpVectors(i.position, o.position, s) } } })(), lerpButtonTransform: (function () { var e = new THREE.Quaternion() return function (t, n) { var r = this.loadedMeshInfo.buttonMeshes[t] if (r) { var i = r.unpressed, o = r.pressed, a = r.value a.setRotationFromQuaternion(e.copy(i.quaternion).slerp(o.quaternion, n)), a.position.lerpVectors(i.position, o.position, n) } } })(), modelReady: function () { this.el.emit('controllermodelready', { name: 'windows-motion-controls', model: this.data.model, rayOrigin: this.rayOrigin, }) }, onButtonChanged: function (e) { var t = this.mapping.buttons[e.detail.id] t && (this.loadedMeshInfo && this.loadedMeshInfo.buttonMeshes && this.lerpButtonTransform(t, e.detail.state.value), this.el.emit(t + 'changed', e.detail.state)) }, onAxisMoved: function (e) { var t = this.mapping.axisMeshNames.length if (this.loadedMeshInfo && this.loadedMeshInfo.axisMeshes) for (var n = 0; n < t; n++) this.lerpAxisTransform(n, e.detail.axis[n] || 0) s(this, this.mapping.axes, e) }, setModelVisibility: function (e) { var t = this.el.getObject3D('mesh') ;(e = void 0 !== e ? e : this.modelVisible), (this.modelVisible = e), t && (t.visible = e) }, }) }, { '../constants': 123, '../core/component': 131, '../utils/': 205, '../utils/bind': 199, '../utils/tracked-controls': 214, }, ], 123: [ function (e, t, n) { t.exports = { AFRAME_INJECTED: 'aframe-injected', DEFAULT_CAMERA_HEIGHT: 1.6, DEFAULT_HANDEDNESS: 'right', keyboardevent: e('./keyboardevent'), } }, { './keyboardevent': 124 }, ], 124: [ function (e, t, n) { t.exports = { KEYCODE_TO_CODE: { 38: 'ArrowUp', 37: 'ArrowLeft', 40: 'ArrowDown', 39: 'ArrowRight', 87: 'KeyW', 65: 'KeyA', 83: 'KeyS', 68: 'KeyD', }, } }, {}, ], 125: [ function (e, t, n) { var r = e('./a-node'), i = e('../utils/bind'), o = e('../utils/debug'), a = e('./a-register-element').registerElement, s = e('../lib/three'), l = new s.FileLoader(), c = o('core:a-assets:warn') function u(e) { if (e.hasAttribute('autoplay') || 'auto' === e.getAttribute('preload')) return new Promise(function (t, n) { if (4 === e.readyState) return t() if (e.error) return n() function r() { for (var n = 0, r = 0; r < e.buffered.length; r++) n += e.buffered.end(r) - e.buffered.start(r) n >= e.duration && ('VIDEO' === e.tagName && (s.Cache.files[e.getAttribute('src')] = e), t()) } e.addEventListener('loadeddata', r, !1), e.addEventListener('progress', r, !1), e.addEventListener('error', n, !1) }) } function h(e) { var t = d(e) return ( t.tagName && 'video' === t.tagName.toLowerCase() && (t.setAttribute('playsinline', ''), t.setAttribute('webkit-playsinline', '')), t !== e && (e.parentNode.appendChild(t), e.parentNode.removeChild(e)), t ) } function d(e) { var t if (e.hasAttribute('crossorigin')) return e if (null !== (t = e.getAttribute('src'))) { if (-1 === t.indexOf('://')) return e if (p(t) === window.location.host) return e } return ( c( 'Cross-origin element (e.g., ) was requested without `crossorigin` set. A-Frame will re-request the asset with `crossorigin` attribute set. Please set `crossorigin` on the element (e.g., )', t, ), (e.crossOrigin = 'anonymous'), e.cloneNode(!0) ) } function p(e) { var t = e.indexOf('://') > -1 ? e.split('/')[2] : e.split('/')[0] return t.substring(0, t.indexOf(':')) } function f(e) { var t = m(e), n = t.lastIndexOf('.') return n >= 0 && '.glb' === t.slice(n, e.search(/\?|#|$/)) ? 'arraybuffer' : 'text' } function m(e) { var t = document.createElement('a') t.href = e var n = t.search.replace(/^\?/, ''), r = e.replace(n, '').replace('?', '') return r.substring(r.lastIndexOf('/') + 1) } ;(t.exports = a('a-assets', { prototype: Object.create(r.prototype, { createdCallback: { value: function () { ;(this.isAssets = !0), (this.fileLoader = l), (this.timeout = null) }, }, attachedCallback: { value: function () { var e, t, n, r, o, a, l = this, d = [] if (!this.parentNode.isScene) throw new Error(' must be a child of a .') for (o = this.querySelectorAll('img'), e = 0; e < o.length; e++) (r = h(o[e])), d.push( new Promise(function (t, n) { ;(s.Cache.files[o[e].getAttribute('src')] = r), (r.onload = t), (r.onerror = n) }), ) for (n = this.querySelectorAll('audio, video'), e = 0; e < n.length; e++) (t = h(n[e])).src || t.srcObject || c('Audio/video asset has neither `src` nor `srcObject` attributes.'), d.push(u(t)) Promise.all(d).then(i(this.load, this)), (a = parseInt(this.getAttribute('timeout'), 10) || 3e3), (this.timeout = setTimeout(function () { l.hasLoaded || (c('Asset loading timed out in ', a, 'ms'), l.emit('timeout'), l.load()) }, a)) }, }, detachedCallback: { value: function () { this.timeout && clearTimeout(this.timeout) }, }, load: { value: function () { r.prototype.load.call(this, null, function (e) { return e.isAssetItem && e.hasAttribute('src') }) }, }, }), })), a('a-asset-item', { prototype: Object.create(r.prototype, { createdCallback: { value: function () { ;(this.data = null), (this.isAssetItem = !0) }, }, attachedCallback: { value: function () { var e = this, t = this.getAttribute('src') l.setResponseType(this.getAttribute('response-type') || f(t)), l.load( t, function (t) { ;(e.data = t), setTimeout(function () { r.prototype.load.call(e) }) }, function (t) { e.emit('progress', { loadedBytes: t.loaded, totalBytes: t.total, xhr: t, }) }, function (t) { e.emit('error', { xhr: t }) }, ) }, }, }), }), (t.exports.inferResponseType = f), (t.exports.getFileNameFromURL = m) }, { '../lib/three': 179, '../utils/bind': 199, '../utils/debug': 201, './a-node': 129, './a-register-element': 130, }, ], 126: [ function (e, t, n) { var r = e('../utils/debug'), i = e('./a-register-element').registerElement, o = r('core:cubemap:warn') t.exports = i('a-cubemap', { prototype: Object.create(window.HTMLElement.prototype, { attachedCallback: { value: function () { this.srcs = this.validate() }, writable: window.debug, }, validate: { value: function () { var e, t = this.querySelectorAll('[src]'), n = [] if (6 === t.length) { for (e = 0; e < t.length; e++) n.push(t[e].getAttribute('src')) return n } o( ' did not contain exactly six elements each with a `src` attribute.', ) }, writable: window.debug, }, }), }) }, { '../utils/debug': 201, './a-register-element': 130 }, ], 127: [ function (e, t, n) { var r, i = e('./a-node'), o = e('./component').components, a = e('./a-register-element').registerElement, s = e('../lib/three'), l = e('../utils/'), c = l.debug('core:a-entity:debug'), u = l.debug('core:a-entity:warn'), h = '__', d = ['position', 'rotation', 'scale', 'visible'], p = { once: !0 }, f = Object.create(i.prototype, { createdCallback: { value: function () { ;(this.components = {}), (this.initializingComponents = {}), (this.componentsToUpdate = {}), (this.isEntity = !0), (this.isPlaying = !1), (this.object3D = new s.Group()), (this.object3D.el = this), (this.object3DMap = {}), (this.parentEl = null), (this.rotationObj = {}), (this.states = []) }, }, attributeChangedCallback: { value: function (e, t, n) { var r = this.components[e] r && r.justInitialized && '' === n ? delete r.justInitialized : (r || null !== n) && this.setEntityAttribute(e, t, n) }, }, attachedCallback: { value: function () { var e, t = this.sceneEl, n = this this.addToParent(), this.isScene || (t ? !(e = t.querySelector('a-assets')) || e.hasLoaded ? this.load() : e.addEventListener('loaded', function () { n.load() }) : this.load()) }, }, detachedCallback: { value: function () { var e if (this.parentEl) { for (e in this.components) this.removeComponent(e, !1) this.isScene || (this.removeFromParent(), i.prototype.detachedCallback.call(this), (this.object3D.el = null)) } }, }, getObject3D: { value: function (e) { return this.object3DMap[e] }, }, setObject3D: { value: function (e, t) { var n, r = this if (!(t instanceof s.Object3D)) throw new Error( '`Entity.setObject3D` was called with an object that was not an instance of THREE.Object3D.', ) ;(n = this.getObject3D(e)) && this.object3D.remove(n), (t.el = this), t.children.length && t.traverse(function (e) { e.el = r }), this.object3D.add(t), (this.object3DMap[e] = t), this.emit('object3dset', { object: t, type: e }) }, }, removeObject3D: { value: function (e) { var t = this.getObject3D(e) t ? (this.object3D.remove(t), delete this.object3DMap[e], this.emit('object3dremove', { type: e })) : u('Tried to remove `Object3D` of type:', e, 'which was not defined.') }, }, getOrCreateObject3D: { value: function (e, t) { var n = this.getObject3D(e) return ( !n && t && ((n = new t()), this.setObject3D(e, n)), u( '`getOrCreateObject3D` has been deprecated. Use `setObject3D()` and `object3dset` event instead.', ), n ) }, }, add: { value: function (e) { if (!e.object3D) throw new Error( "Trying to add an element that doesn't have an `object3D`", ) this.object3D.add(e.object3D), this.emit('child-attached', { el: e }) }, }, addToParent: { value: function () { var e = (this.parentEl = this.parentNode) e && e.add && !this.attachedToParent && (e.add(this), (this.attachedToParent = !0)) }, }, removeFromParent: { value: function () { var e = this.parentEl this.parentEl.remove(this), (this.attachedToParent = !1), (this.parentEl = null), e.emit('child-detached', { el: this }) }, }, load: { value: function () { var e = this !this.hasLoaded && this.parentEl && i.prototype.load.call(this, function () { e.parentEl && (e.updateComponents(), (e.isScene || e.parentEl.isPlaying) && e.play()) }) }, writable: window.debug, }, remove: { value: function (e) { e ? this.object3D.remove(e.object3D) : this.parentNode.removeChild(this) }, }, getChildEntities: { value: function () { for (var e = this.children, t = [], n = 0; n < e.length; n++) { var i = e[n] i instanceof r && t.push(i) } return t }, }, initComponent: { value: function (e, t, n) { var r, i, a, s if ( ((s = (a = l.split(e, h))[0]), (i = a.length > 2 ? a.slice(1).join('__') : a[1]), o[s] && (m(this, e) || void 0 !== t || n) && !(e in this.components)) ) { if ((this.initComponentDependencies(s), i && !o[s].multiple)) throw new Error( 'Trying to initialize multiple components of type `' + s + '`. There can only be one component of this type per entity.', ) ;(r = new o[s].Component(this, t, i)), this.isPlaying && r.play(), this.hasAttribute(e) || ((r.justInitialized = !0), window.HTMLElement.prototype.setAttribute.call(this, e, '')), c('Component initialized: %s', e) } }, writable: window.debug, }, initComponentDependencies: { value: function (e) { var t, n, r = this if (o[e] && (t = o[e].dependencies)) for (n = 0; n < t.length; n++) r.initComponent( t[n], window.HTMLElement.prototype.getAttribute.call(r, t[n]) || void 0, !0, ) }, }, removeComponent: { value: function (e, t) { var n ;(n = this.components[e]) && (n.initialized ? (n.pause(), n.remove(), t && (n.destroy(), delete this.components[e]), this.emit('componentremoved', n.evtDetail, !1)) : this.addEventListener('componentinitialized', function n(r) { r.detail.name === e && (this.removeComponent(e, t), this.removeEventListener('componentinitialized', n)) })) }, writable: window.debug, }, updateComponents: { value: function () { var e, t, n, r, i = this.componentsToUpdate if (this.hasLoaded) { for (n = 0; n < this.mixinEls.length; n++) for (r in this.mixinEls[n].componentCache) y(r) && (i[r] = !0) if (this.getExtraComponents) for (r in (t = this.getExtraComponents())) y(r) && (i[r] = !0) for (n = 0; n < this.attributes.length; ++n) (r = this.attributes[n].name), -1 === d.indexOf(r) && y(r) && (i[r] = !0) for (n = 0; n < d.length; n++) (r = d[n]), this.hasAttribute(r) && this.updateComponent(r, this.getDOMAttribute(r)) for (r in i) (e = g(this.getDOMAttribute(r), t && t[r])), this.updateComponent(r, e), delete i[r] } }, writable: window.debug, }, updateComponent: { value: function (e, t, n) { var r = this.components[e] if (r) return null !== t || m(this, e) ? void r.updateProperties(t, n) : void this.removeComponent(e, !0) this.initComponent(e, t, !1) }, }, removeAttribute: { value: function (e, t) { var n = this.components[e] n && void 0 === t && this.removeComponent(e, !0), n && void 0 !== t ? n.resetProperty(t) : ('mixin' === e && this.mixinUpdate(''), window.HTMLElement.prototype.removeAttribute.call(this, e)) }, }, play: { value: function () { var e, t, n if (!this.isPlaying && this.hasLoaded) { for (n in ((this.isPlaying = !0), this.components)) this.components[n].play() for (e = this.getChildEntities(), t = 0; t < e.length; t++) e[t].play() this.emit('play') } }, writable: !0, }, pause: { value: function () { var e, t, n if (this.isPlaying) { for (n in ((this.isPlaying = !1), this.components)) this.components[n].pause() for (e = this.getChildEntities(), t = 0; t < e.length; t++) e[t].pause() this.emit('pause') } }, writable: !0, }, setEntityAttribute: { value: function (e, t, n) { if (o[e] || this.components[e]) this.updateComponent(e, n) else if ('mixin' === e) { if (n === this.computedMixinStr) return this.mixinUpdate(n, t) } }, }, mixinUpdate: { value: (function () { var e = [] return function (t, n) { var r, i, o, a, s = this if (this.hasLoaded) { for ( n = n || this.getAttribute('mixin'), o = this.updateMixins(t, n), e.length = 0, a = 0; a < this.mixinEls.length; a++ ) for (r in this.mixinEls[a].componentCache) -1 === e.indexOf(r) && (this.components[r] ? this.components[r].handleMixinUpdate() : this.initComponent(r, null), e.push(r)) for (a = 0; a < o.oldMixinIds.length; a++) if ((i = document.getElementById(o.oldMixinIds[a]))) for (r in i.componentCache) -1 === e.indexOf(r) && this.components[r] && (this.getDOMAttribute(r) ? this.components[r].handleMixinUpdate() : this.removeComponent(r, !0)) } else this.addEventListener( 'loaded', function () { s.mixinUpdate(t, n) }, p, ) } })(), }, setAttribute: { value: (function () { var e = {} return function (t, n, r) { var a, s, c, u, d if (((c = (u = t.indexOf(h)) > 0 ? t.substring(0, u) : t), !o[c])) return ( 'mixin' === t && this.mixinUpdate(n), void i.prototype.setAttribute.call(this, t, n) ) if ( (!this.components[t] && this.hasAttribute(t) && this.updateComponent( t, window.HTMLElement.prototype.getAttribute.call(this, t), ), 'undefined' !== typeof r && 'string' === typeof n && n.length > 0 && 'string' === typeof l.styleParser.parse(n)) ) { for (d in e) delete e[d] ;((a = e)[n] = r), (s = !1) } else (a = n), (s = !0 === r) this.updateComponent(t, a, s), this.sceneEl && this.sceneEl.getAttribute('debug') && this.components[t].flushToDOM() } })(), writable: window.debug, }, flushToDOM: { value: function (e) { var t, n, r, i = this.components, o = this.children for (r in i) i[r].flushToDOM() if (e) for (n = 0; n < o.length; ++n) (t = o[n]).flushToDOM && t.flushToDOM(e) }, }, getAttribute: { value: function (e) { var t return 'position' === e ? this.object3D.position : 'rotation' === e ? b(this) : 'scale' === e ? this.object3D.scale : 'visible' === e ? this.object3D.visible : (t = this.components[e]) ? t.data : window.HTMLElement.prototype.getAttribute.call(this, e) }, writable: window.debug, }, getDOMAttribute: { value: function (e) { var t = this.components[e] return t ? t.attrValue : window.HTMLElement.prototype.getAttribute.call(this, e) }, writable: window.debug, }, addState: { value: function (e) { this.is(e) || (this.states.push(e), this.emit('stateadded', e)) }, }, removeState: { value: function (e) { var t = this.states.indexOf(e) ;-1 !== t && (this.states.splice(t, 1), this.emit('stateremoved', e)) }, }, is: { value: function (e) { return -1 !== this.states.indexOf(e) }, }, inspect: { value: function () { this.sceneEl.components.inspector.openInspector(this) }, }, destroy: { value: function () { var e if (this.parentNode) u('Entity can only be destroyed if detached from scenegraph.') else for (e in this.components) this.components[e].destroy() }, }, }) function m(e, t) { return !(!e.components[t] || !e.components[t].attrValue) || v(t, e.mixinEls) } function v(e, t) { var n, r = !1 for (n = 0; n < t.length && !(r = t[n].hasAttribute(e)); ++n); return r } function g(e, t) { return t ? t.constructor === Object ? l.extend(t, l.styleParser.parse(e || {})) : e || t : e } function y(e) { return -1 !== e.indexOf(h) && (e = l.split(e, h)[0]), !!o[e] } function b(e) { var t = s.Math.radToDeg, n = e.object3D.rotation, r = e.rotationObj return (r.x = t(n.x)), (r.y = t(n.y)), (r.z = t(n.z)), r } ;(r = a('a-entity', { prototype: f })), (t.exports = r) }, { '../lib/three': 179, '../utils/': 205, './a-node': 129, './a-register-element': 130, './component': 131, }, ], 128: [ function (e, t, n) { var r = e('./a-node'), i = e('./a-register-element').registerElement, o = e('./component').components, a = e('../utils'), s = '__' t.exports = i('a-mixin', { prototype: Object.create(r.prototype, { createdCallback: { value: function () { ;(this.componentCache = {}), (this.id = this.getAttribute('id')), (this.isMixin = !0) }, }, attributeChangedCallback: { value: function (e, t, n) { this.cacheAttribute(e, n), this.updateEntities() }, }, attachedCallback: { value: function () { ;(this.sceneEl = this.closestScene()), this.cacheAttributes(), this.updateEntities(), this.load() }, }, setAttribute: { value: function (e, t) { window.HTMLElement.prototype.setAttribute.call(this, e, t), this.cacheAttribute(e, t) }, }, cacheAttribute: { value: function (e, t) { var n, r ;(r = a.split(e, s)[0]), (n = o[r]) && (void 0 === t && (t = window.HTMLElement.prototype.getAttribute.call(this, e)), (this.componentCache[e] = n.parseAttrValueForCache(t))) }, }, getAttribute: { value: function (e) { return ( this.componentCache[e] || window.HTMLElement.prototype.getAttribute.call(this, e) ) }, }, cacheAttributes: { value: function () { var e, t, n = this.attributes for (t = 0; t < n.length; t++) (e = n[t].name), this.cacheAttribute(e) }, }, updateEntities: { value: function () { var e, t, n if (this.sceneEl) for ( t = this.sceneEl.querySelectorAll('[mixin~=' + this.id + ']'), n = 0; n < t.length; n++ ) (e = t[n]).hasLoaded && !e.isMixin && e.mixinUpdate(this.id) }, }, }), }) }, { '../utils': 205, './a-node': 129, './a-register-element': 130, './component': 131 }, ], 129: [ function (e, t, n) { var r = e('./a-register-element').registerElement, i = e('./a-register-element').isNode, o = e('../utils/'), a = o.debug('core:a-node:warn'), s = o.debug('core:a-node:error') t.exports = r('a-node', { prototype: Object.create(window.HTMLElement.prototype, { createdCallback: { value: function () { ;(this.computedMixinStr = ''), (this.hasLoaded = !1), (this.isNode = !0), (this.mixinEls = []) }, writable: window.debug, }, attachedCallback: { value: function () { var e ;(this.sceneEl = this.closestScene()), this.sceneEl || a( 'You are attempting to attach <' + this.tagName + '> outside of an A-Frame scene. Append this element to `` instead.', ), (this.hasLoaded = !1), this.emit('nodeready', void 0, !1), this.isMixin || ((e = this.getAttribute('mixin')) && this.updateMixins(e)) }, writable: window.debug, }, attributeChangedCallback: { value: function (e, t, n) { n !== this.computedMixinStr && ('mixin' !== e || this.isMixin || this.updateMixins(n, t)) }, }, closestScene: { value: function () { for (var e = this; e && !e.isScene; ) e = e.parentElement return e }, }, closest: { value: function (e) { for ( var t = this.matches || this.mozMatchesSelector || this.msMatchesSelector || this.oMatchesSelector || this.webkitMatchesSelector, n = this; n && !t.call(n, e); ) n = n.parentElement return n }, }, detachedCallback: { value: function () { this.hasLoaded = !1 }, }, load: { value: function (e, t) { var n, r = this this.hasLoaded || ((t = t || i), (n = this.getChildren() .filter(t) .map(function (e) { return new Promise(function (t) { if (e.hasLoaded) return t() e.addEventListener('loaded', t) }) })), Promise.all(n) .then(function () { ;(r.hasLoaded = !0), e && e(), r.emit('loaded', void 0, !1) }) .catch(function (e) { s('Failure loading node: ', e) })) }, writable: !0, }, getChildren: { value: function () { return Array.prototype.slice.call(this.children, 0) }, }, updateMixins: { value: (function () { var e = [], t = [], n = {} return function (r, i) { var a, s, l for ( e.length = 0, t.length = 0, s = r ? o.split(r.trim(), /\s+/) : e, l = i ? o.split(i.trim(), /\s+/) : t, n.newMixinIds = s, n.oldMixinIds = l, a = 0; a < l.length; a++ ) -1 === s.indexOf(l[a]) && this.unregisterMixin(l[a]) for ( this.computedMixinStr = '', this.mixinEls.length = 0, a = 0; a < s.length; a++ ) this.registerMixin(document.getElementById(s[a])) return ( this.computedMixinStr && ((this.computedMixinStr = this.computedMixinStr.trim()), window.HTMLElement.prototype.setAttribute.call( this, 'mixin', this.computedMixinStr, )), n ) } })(), }, registerMixin: { value: function (e) { var t, n, r if (e) { if ((r = e.getAttribute('mixin'))) for (t = o.split(r.trim(), /\s+/), n = 0; n < t.length; n++) this.registerMixin(document.getElementById(t[n])) ;(this.computedMixinStr = this.computedMixinStr + ' ' + e.id), this.mixinEls.push(e) } }, }, setAttribute: { value: function (e, t) { 'mixin' === e && this.updateMixins(t), window.HTMLElement.prototype.setAttribute.call(this, e, t) }, }, unregisterMixin: { value: function (e) { var t, n = this.mixinEls for (t = 0; t < n.length; ++t) if (e === n[t].id) { n.splice(t, 1) break } }, }, emit: { value: (function () { var e = {} return function (t, n, r, i) { void 0 === r && (r = !0), (e.bubbles = !!r), (e.detail = n), i && (e = o.extend({}, i, e)), this.dispatchEvent(new CustomEvent(t, e)) } })(), writable: window.debug, }, }), }) }, { '../utils/': 205, './a-register-element': 130 }, ], 130: [ function (e, t, n) { var r, i e('document-register-element') var o = (t.exports.knownTags = {}) function a(e) { o[e.toLowerCase()] = !0 } function s(e) { var t = {} return ( c( t, [ 'attachedCallback', 'attributeChangedCallback', 'createdCallback', 'detachedCallback', ], e, r.prototype, ), h(e, t), t ) } function l(e) { var t = {}, n = [ 'attachedCallback', 'attributeChangedCallback', 'createdCallback', 'detachedCallback', ] return ( c( t, [ 'attachedCallback', 'attributeChangedCallback', 'createdCallback', 'detachedCallback', ], e, r.prototype, ), c(t, n, e, i.prototype), h(e, t), t ) } function c(e, t, n, r) { t.forEach(function (t) { u(e, t, n, r) }) } function u(e, t, n, r) { var i = n[t], o = r[t] i && o && i !== o && (e[t] = { value: function () { return o.apply(this, arguments), i.apply(this, arguments) }, writable: window.debug, }) } function h(e, t) { Object.getOwnPropertyNames(e).forEach(function (n) { var r t[n] || ((r = Object.getOwnPropertyDescriptor(e, n)), (t[n] = { value: e[n], writable: r.writable })) }) } ;(t.exports.isNode = function (e) { return e.tagName.toLowerCase() in o || e.isNode }), (t.exports.registerElement = function (e, t) { var n = Object.getPrototypeOf(t.prototype), o = t, c = r && n === r.prototype, u = i && n === i.prototype return ( (c || u) && a(e), c && ((o = s(t.prototype)), (o = { prototype: Object.create(n, o) })), u && ((o = l(t.prototype)), (o = { prototype: Object.create(n, o) })), Object.getOwnPropertyNames(o.prototype).forEach(function (e) { var t = o.prototype[e] 'function' === typeof t && (t.displayName = e) }), document.registerElement(e, o) ) }), (t.exports.wrapMethods = c), (r = e('./a-node')), (i = e('./a-entity')) }, { './a-entity': 127, './a-node': 129, 'document-register-element': 12 }, ], 131: [ function (e, t, n) { var r = e('./schema'), i = e('./scene/scenes'), o = e('./system'), a = e('../utils/'), s = (t.exports.components = {}), l = r.parseProperties, c = r.parseProperty, u = r.process, h = r.isSingleProperty, d = r.stringifyProperties, p = r.stringifyProperty, f = a.styleParser, m = a.debug('core:component:warn'), v = document.currentScript, g = new RegExp('[A-Z]+'), y = {}, b = (t.exports.Component = function (e, t, n) { var r = this ;(this.el = e), (this.id = n), (this.attrName = this.name + (n ? '__' + n : '')), (this.evtDetail = { id: this.id, name: this.name }), (this.initialized = !1), (this.isSingleProperty = h(this.schema)), (this.isSinglePropertyObject = this.isSingleProperty && S(c(void 0, this.schema)) && !(this.schema.default instanceof window.HTMLElement)), (this.isObjectBased = !this.isSingleProperty || this.isSinglePropertyObject), (this.el.components[this.attrName] = this), (this.objectPool = y[this.name]) const i = this.events ;(this.events = {}), A(this, i), (this.attrValue = void 0), this.isObjectBased ? ((this.nextData = this.objectPool.use()), a.objectPool.removeUnusedKeys(this.nextData, this.schema), (this.oldData = this.objectPool.use()), a.objectPool.removeUnusedKeys(this.oldData, this.schema), (this.previousOldData = this.objectPool.use()), a.objectPool.removeUnusedKeys(this.previousOldData, this.schema), (this.parsingAttrValue = this.objectPool.use()), a.objectPool.removeUnusedKeys(this.parsingAttrValue, this.schema)) : ((this.nextData = void 0), (this.oldData = void 0), (this.previousOldData = void 0), (this.parsingAttrValue = void 0)), (this.throttledEmitComponentChanged = a.throttle(function () { e.emit('componentchanged', r.evtDetail, !1) }, 200)), this.updateProperties(t) }) function A(e, t) { var n for (n in t) e.events[n] = t[n].bind(e) } if ( ((b.prototype = { schema: {}, init: function () {}, events: {}, update: function (e) {}, updateSchema: void 0, tick: void 0, tock: void 0, play: function () {}, pause: function () {}, remove: function () {}, parse: function (e, t) { var n = this.schema return this.isSingleProperty ? c(e, n) : l(f.parse(e), n, !0, this.name, t) }, stringify: function (e) { var t = this.schema return 'string' === typeof e ? e : this.isSingleProperty ? p(e, t) : ((e = d(e, t)), f.stringify(e)) }, updateCachedAttrValue: function (e, t) { var n, r, i if (void 0 !== e) { if (null === e) return ( this.isObjectBased && this.attrValue && this.objectPool.recycle(this.attrValue), void (this.attrValue = void 0) ) if ( (e instanceof Object && !(e instanceof window.HTMLElement) ? ((r = this.objectPool.use()), (n = a.extend(r, e))) : (n = this.parseAttrValueForCache(e)), this.isObjectBased && !t && this.attrValue) ) for (i in this.attrValue) void 0 === n[i] && (n[i] = this.attrValue[i]) this.isObjectBased && !this.attrValue && (this.attrValue = this.objectPool.use()), a.objectPool.clearObject(this.attrValue), (this.attrValue = E(this.attrValue, n, this.isObjectBased)), a.objectPool.clearObject(r) } }, parseAttrValueForCache: function (e) { var t return 'string' !== typeof e ? e : (this.isSingleProperty ? 'string' === typeof (t = this.schema.parse(e)) && (t = e) : (a.objectPool.clearObject(this.parsingAttrValue), (t = f.parse(e, this.parsingAttrValue))), t) }, flushToDOM: function (e) { var t = e ? this.data : this.attrValue null !== t && void 0 !== t && window.HTMLElement.prototype.setAttribute.call( this.el, this.attrName, this.stringify(t), ) }, updateProperties: function (e, t) { this.el.hasLoaded ? (null !== e && (e = this.parseAttrValueForCache(e)), this.updateCachedAttrValue(e, t), this.initialized ? (this.updateComponent(e, t), this.callUpdateHandler()) : this.initComponent()) : this.updateCachedAttrValue(e) }, initComponent: function () { var e, t = this.el this.updateSchema && this.updateSchema(this.buildData(this.attrValue, !1, !0)), (this.data = this.buildData(this.attrValue)), t.initializingComponents[this.name] || ((t.initializingComponents[this.name] = !0), this.init(), (this.initialized = !0), delete t.initializingComponents[this.name], (this.oldData = E(this.oldData, this.data, this.isObjectBased)), (e = this.isObjectBased ? this.objectPool.use() : void 0), this.update(e), this.isObjectBased && this.objectPool.recycle(e), t.isPlaying && this.play(), t.emit('componentinitialized', this.evtDetail, !1)) }, updateComponent: function (e, t) { var n, r if (t) return ( this.updateSchema && this.updateSchema(this.buildData(this.attrValue, !0, !0)), void (this.data = this.buildData(this.attrValue, !0, !1)) ) if (this.isSingleProperty) return this.isObjectBased && c(e, this.schema), void (this.data = e) if ((l(e, this.schema, !0, this.name), this.schemaChangeKeys.length)) for (n in e) if (this.schema[n].schemaChange) { r = !0 break } if (r) return ( this.updateSchema && this.updateSchema(this.buildData(this.attrValue, !0, !0)), void (this.data = this.buildData(this.attrValue, !0, !1)) ) for (n in e) void 0 !== e[n] && (this.data[n] = e[n]) }, callUpdateHandler: function () { var e this.previousOldData instanceof Object && a.objectPool.clearObject(this.previousOldData), this.isObjectBased ? x(this.previousOldData, this.oldData) : (this.previousOldData = this.oldData), (e = !a.deepEqual(this.oldData, this.data)), (this.isPositionRotationScale || e) && (this.oldData instanceof Object && a.objectPool.clearObject(this.oldData), (this.oldData = E(this.oldData, this.data, this.isObjectBased)), this.update(this.previousOldData), this.throttledEmitComponentChanged()) }, handleMixinUpdate: function () { ;(this.data = this.buildData(this.attrValue)), this.callUpdateHandler() }, resetProperty: function (e) { if (this.isObjectBased) { if (!(e in this.attrValue)) return delete this.attrValue[e], (this.data[e] = this.schema[e].default) } else (this.attrValue = this.schema.default), (this.data = this.schema.default) this.updateProperties(this.attrValue) }, extendSchema: function (e) { var t ;(t = a.extend({}, s[this.name].schema)), a.extend(t, e), (this.schema = u(t)), this.el.emit('schemachanged', this.evtDetail) }, buildData: function (e, t, n) { var r, i, o, s, u, h, d, p = this.nextData, f = this.schema, m = this.el.mixinEls if ( ((r = e && e.constructor === Array ? e.length : void 0 !== e && null !== e), this.isObjectBased && a.objectPool.clearObject(p), this.isSingleProperty) ) i = this.isObjectBased ? x(p, f.default) : C(f.default) ? a.clone(f.default) : f.default else for (s in ((i = (d = !t && this.attrValue) instanceof Object ? x(p, d) : p), f)) (o = f[s].default), void 0 === i[s] && (i[s] = C(o) ? a.clone(o) : o) for (h = 0; h < m.length; h++) (u = m[h].getAttribute(this.attrName)) && (i = E(i, u, this.isObjectBased)) if (r) { if (this.isSingleProperty) return S(e) ? (x(this.parsingAttrValue, e), c(this.parsingAttrValue, f)) : c(e, f) i = E(i, e, this.isObjectBased) } else if (this.isSingleProperty) return c(i, f) return l(i, f, void 0, this.name, n) }, eventsAttach: function () { var e for (e in (this.eventsDetach(), this.events)) this.el.addEventListener(e, this.events[e]) }, eventsDetach: function () { var e for (e in this.events) this.el.removeEventListener(e, this.events[e]) }, destroy: function () { this.objectPool.recycle(this.attrValue), this.objectPool.recycle(this.oldData), this.objectPool.recycle(this.parsingAttrValue), (this.attrValue = this.oldData = this.parsingAttrValue = void 0) }, }), window.debug) ) var w = (t.exports.registrationOrderWarnings = {}) function x(e, t) { var n, r for (r in t) void 0 !== t[r] && ((n = t[r]), (e[r] = C(n) ? a.clone(n) : n)) return e } function E(e, t, n) { var r if (n && t.constructor === Object) { for (r in t) void 0 !== t[r] && (t[r] && t[r].constructor === Object ? (e[r] = a.clone(t[r])) : (e[r] = t[r])) return e } return t } function M(e) { return e.tick || e.tock } function _(e) { return function () { var t = this.el.sceneEl this.isPlaying && (e.call(this), (this.isPlaying = !1), this.eventsDetach(), M(this) && t.removeBehavior(this)) } } function T(e) { return function () { var t = this.el.sceneEl, n = this.el.isPlaying && !this.isPlaying this.initialized && n && (e.call(this), (this.isPlaying = !0), this.eventsAttach(), M(this) && t.addBehavior(this)) } } function S(e) { return e && e.constructor === Object && !(e instanceof window.HTMLElement) } function C(e) { return ( e && (e.constructor === Object || e.constructor === Array) && !(e instanceof window.HTMLElement) ) } t.exports.registerComponent = function (e, t) { var n, r, l, c, d = {} if ( (document.currentScript && document.currentScript !== v && i.forEach(function (t) { t.hasLoaded || (document.currentScript.compareDocumentPosition(t) !== Node.DOCUMENT_POSITION_FOLLOWING && (m( 'The component `' + e + '` was registered in a